annotate gcc/config/rs6000/htmxlintrin.h @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* XL compiler Hardware Transactional Memory (HTM) execution intrinsics.
kono
parents:
diff changeset
2 Copyright (C) 2013-2017 Free Software Foundation, Inc.
kono
parents:
diff changeset
3 Contributed by Peter Bergner <bergner@vnet.ibm.com>.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
6 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
7 Software Foundation; either version 3 of the License, or (at your option)
kono
parents:
diff changeset
8 any later version.
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 This file is distributed in the hope that it will be useful, but WITHOUT
kono
parents:
diff changeset
11 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
12 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
13 for more details.
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
16 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
17 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
20 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
21 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
22 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 #ifndef __HTM__
kono
parents:
diff changeset
25 # error "HTM instruction set not enabled"
kono
parents:
diff changeset
26 #endif /* __HTM__ */
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 #ifndef _HTMXLINTRIN_H
kono
parents:
diff changeset
29 #define _HTMXLINTRIN_H
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 #include <stdint.h>
kono
parents:
diff changeset
32 #include <htmintrin.h>
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 #ifdef __cplusplus
kono
parents:
diff changeset
35 extern "C" {
kono
parents:
diff changeset
36 #endif
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 #define _TEXASR_PTR(TM_BUF) \
kono
parents:
diff changeset
39 ((texasr_t *)((TM_BUF)+0))
kono
parents:
diff changeset
40 #define _TEXASRU_PTR(TM_BUF) \
kono
parents:
diff changeset
41 ((texasru_t *)((TM_BUF)+0))
kono
parents:
diff changeset
42 #define _TEXASRL_PTR(TM_BUF) \
kono
parents:
diff changeset
43 ((texasrl_t *)((TM_BUF)+4))
kono
parents:
diff changeset
44 #define _TFIAR_PTR(TM_BUF) \
kono
parents:
diff changeset
45 ((tfiar_t *)((TM_BUF)+8))
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 typedef char TM_buff_type[16];
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 /* Compatibility macro with s390. This macro can be used to determine
kono
parents:
diff changeset
50 whether a transaction was successfully started from the __TM_begin()
kono
parents:
diff changeset
51 and __TM_simple_begin() intrinsic functions below. */
kono
parents:
diff changeset
52 #define _HTM_TBEGIN_STARTED 1
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 extern __inline long
kono
parents:
diff changeset
55 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
56 __TM_simple_begin (void)
kono
parents:
diff changeset
57 {
kono
parents:
diff changeset
58 if (__builtin_expect (__builtin_tbegin (0), 1))
kono
parents:
diff changeset
59 return _HTM_TBEGIN_STARTED;
kono
parents:
diff changeset
60 return 0;
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 extern __inline long
kono
parents:
diff changeset
64 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
65 __TM_begin (void* const TM_buff)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 *_TEXASRL_PTR (TM_buff) = 0;
kono
parents:
diff changeset
68 if (__builtin_expect (__builtin_tbegin (0), 1))
kono
parents:
diff changeset
69 return _HTM_TBEGIN_STARTED;
kono
parents:
diff changeset
70 #ifdef __powerpc64__
kono
parents:
diff changeset
71 *_TEXASR_PTR (TM_buff) = __builtin_get_texasr ();
kono
parents:
diff changeset
72 #else
kono
parents:
diff changeset
73 *_TEXASRU_PTR (TM_buff) = __builtin_get_texasru ();
kono
parents:
diff changeset
74 *_TEXASRL_PTR (TM_buff) = __builtin_get_texasr ();
kono
parents:
diff changeset
75 #endif
kono
parents:
diff changeset
76 *_TFIAR_PTR (TM_buff) = __builtin_get_tfiar ();
kono
parents:
diff changeset
77 return 0;
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 extern __inline long
kono
parents:
diff changeset
81 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
82 __TM_end (void)
kono
parents:
diff changeset
83 {
kono
parents:
diff changeset
84 unsigned char status = _HTM_STATE (__builtin_tend (0));
kono
parents:
diff changeset
85 if (__builtin_expect (status, _HTM_TRANSACTIONAL))
kono
parents:
diff changeset
86 return 1;
kono
parents:
diff changeset
87 return 0;
kono
parents:
diff changeset
88 }
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 extern __inline void
kono
parents:
diff changeset
91 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
92 __TM_abort (void)
kono
parents:
diff changeset
93 {
kono
parents:
diff changeset
94 __builtin_tabort (0);
kono
parents:
diff changeset
95 }
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 extern __inline void
kono
parents:
diff changeset
98 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
99 __TM_named_abort (unsigned char const code)
kono
parents:
diff changeset
100 {
kono
parents:
diff changeset
101 __builtin_tabort (code);
kono
parents:
diff changeset
102 }
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 extern __inline void
kono
parents:
diff changeset
105 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
106 __TM_resume (void)
kono
parents:
diff changeset
107 {
kono
parents:
diff changeset
108 __builtin_tresume ();
kono
parents:
diff changeset
109 }
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 extern __inline void
kono
parents:
diff changeset
112 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
113 __TM_suspend (void)
kono
parents:
diff changeset
114 {
kono
parents:
diff changeset
115 __builtin_tsuspend ();
kono
parents:
diff changeset
116 }
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 extern __inline long
kono
parents:
diff changeset
119 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
120 __TM_is_user_abort (void* const TM_buff)
kono
parents:
diff changeset
121 {
kono
parents:
diff changeset
122 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
123 return _TEXASRU_ABORT (texasru);
kono
parents:
diff changeset
124 }
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 extern __inline long
kono
parents:
diff changeset
127 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
128 __TM_is_named_user_abort (void* const TM_buff, unsigned char *code)
kono
parents:
diff changeset
129 {
kono
parents:
diff changeset
130 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 *code = _TEXASRU_FAILURE_CODE (texasru);
kono
parents:
diff changeset
133 return _TEXASRU_ABORT (texasru);
kono
parents:
diff changeset
134 }
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 extern __inline long
kono
parents:
diff changeset
137 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
138 __TM_is_illegal (void* const TM_buff)
kono
parents:
diff changeset
139 {
kono
parents:
diff changeset
140 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
141 return _TEXASRU_DISALLOWED (texasru);
kono
parents:
diff changeset
142 }
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 extern __inline long
kono
parents:
diff changeset
145 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
146 __TM_is_footprint_exceeded (void* const TM_buff)
kono
parents:
diff changeset
147 {
kono
parents:
diff changeset
148 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
149 return _TEXASRU_FOOTPRINT_OVERFLOW (texasru);
kono
parents:
diff changeset
150 }
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 extern __inline long
kono
parents:
diff changeset
153 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
154 __TM_nesting_depth (void* const TM_buff)
kono
parents:
diff changeset
155 {
kono
parents:
diff changeset
156 texasrl_t texasrl;
kono
parents:
diff changeset
157
kono
parents:
diff changeset
158 if (_HTM_STATE (__builtin_ttest ()) == _HTM_NONTRANSACTIONAL)
kono
parents:
diff changeset
159 {
kono
parents:
diff changeset
160 texasrl = *_TEXASRL_PTR (TM_buff);
kono
parents:
diff changeset
161 if (!_TEXASR_FAILURE_SUMMARY (texasrl))
kono
parents:
diff changeset
162 texasrl = 0;
kono
parents:
diff changeset
163 }
kono
parents:
diff changeset
164 else
kono
parents:
diff changeset
165 texasrl = (texasrl_t) __builtin_get_texasr ();
kono
parents:
diff changeset
166
kono
parents:
diff changeset
167 return _TEXASR_TRANSACTION_LEVEL (texasrl);
kono
parents:
diff changeset
168 }
kono
parents:
diff changeset
169
kono
parents:
diff changeset
170 extern __inline long
kono
parents:
diff changeset
171 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
172 __TM_is_nested_too_deep(void* const TM_buff)
kono
parents:
diff changeset
173 {
kono
parents:
diff changeset
174 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
175 return _TEXASRU_NESTING_OVERFLOW (texasru);
kono
parents:
diff changeset
176 }
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 extern __inline long
kono
parents:
diff changeset
179 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
180 __TM_is_conflict(void* const TM_buff)
kono
parents:
diff changeset
181 {
kono
parents:
diff changeset
182 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
183 /* Return TEXASR bits 11 (Self-Induced Conflict) through
kono
parents:
diff changeset
184 14 (Translation Invalidation Conflict). */
kono
parents:
diff changeset
185 return (_TEXASRU_EXTRACT_BITS (texasru, 14, 4)) ? 1 : 0;
kono
parents:
diff changeset
186 }
kono
parents:
diff changeset
187
kono
parents:
diff changeset
188 extern __inline long
kono
parents:
diff changeset
189 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
190 __TM_is_failure_persistent(void* const TM_buff)
kono
parents:
diff changeset
191 {
kono
parents:
diff changeset
192 texasru_t texasru = *_TEXASRU_PTR (TM_buff);
kono
parents:
diff changeset
193 return _TEXASRU_FAILURE_PERSISTENT (texasru);
kono
parents:
diff changeset
194 }
kono
parents:
diff changeset
195
kono
parents:
diff changeset
196 extern __inline long
kono
parents:
diff changeset
197 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
198 __TM_failure_address(void* const TM_buff)
kono
parents:
diff changeset
199 {
kono
parents:
diff changeset
200 return *_TFIAR_PTR (TM_buff);
kono
parents:
diff changeset
201 }
kono
parents:
diff changeset
202
kono
parents:
diff changeset
203 extern __inline long long
kono
parents:
diff changeset
204 __attribute__ ((__gnu_inline__, __always_inline__, __artificial__))
kono
parents:
diff changeset
205 __TM_failure_code(void* const TM_buff)
kono
parents:
diff changeset
206 {
kono
parents:
diff changeset
207 return *_TEXASR_PTR (TM_buff);
kono
parents:
diff changeset
208 }
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 #ifdef __cplusplus
kono
parents:
diff changeset
211 }
kono
parents:
diff changeset
212 #endif
kono
parents:
diff changeset
213
kono
parents:
diff changeset
214 #endif /* _HTMXLINTRIN_H */