]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - include/clang/Basic/BuiltinsX86.def
Update clang to r103004.
[FreeBSD/FreeBSD.git] / include / clang / Basic / BuiltinsX86.def
1 //===--- BuiltinsX86.def - X86 Builtin function database --------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file defines the X86-specific builtin function database.  Users of
11 // this file must define the BUILTIN macro to make use of this information.
12 //
13 //===----------------------------------------------------------------------===//
14
15 // The format of this database matches clang/Basic/Builtins.def.
16
17 // FIXME: In GCC, these builtins are defined depending on whether support for
18 // MMX/SSE/etc is turned on. We should do this too.
19
20 // FIXME: Ideally we would be able to pull this information from what
21 // LLVM already knows about X86 builtins. We need to match the LLVM
22 // definition anyway, since code generation will lower to the
23 // intrinsic if one exists.
24
25 BUILTIN(__builtin_ia32_emms  , "v", "")
26
27 // FIXME: Are these nothrow/const?
28
29 // SSE intrinsics.
30 BUILTIN(__builtin_ia32_comieq, "iV4fV4f", "")
31 BUILTIN(__builtin_ia32_comilt, "iV4fV4f", "")
32 BUILTIN(__builtin_ia32_comile, "iV4fV4f", "")
33 BUILTIN(__builtin_ia32_comigt, "iV4fV4f", "")
34 BUILTIN(__builtin_ia32_comige, "iV4fV4f", "")
35 BUILTIN(__builtin_ia32_comineq, "iV4fV4f", "")
36 BUILTIN(__builtin_ia32_ucomieq, "iV4fV4f", "")
37 BUILTIN(__builtin_ia32_ucomilt, "iV4fV4f", "")
38 BUILTIN(__builtin_ia32_ucomile, "iV4fV4f", "")
39 BUILTIN(__builtin_ia32_ucomigt, "iV4fV4f", "")
40 BUILTIN(__builtin_ia32_ucomige, "iV4fV4f", "")
41 BUILTIN(__builtin_ia32_ucomineq, "iV4fV4f", "")
42 BUILTIN(__builtin_ia32_comisdeq, "iV2dV2d", "")
43 BUILTIN(__builtin_ia32_comisdlt, "iV2dV2d", "")
44 BUILTIN(__builtin_ia32_comisdle, "iV2dV2d", "")
45 BUILTIN(__builtin_ia32_comisdgt, "iV2dV2d", "")
46 BUILTIN(__builtin_ia32_comisdge, "iV2dV2d", "")
47 BUILTIN(__builtin_ia32_comisdneq, "iV2dV2d", "")
48 BUILTIN(__builtin_ia32_ucomisdeq, "iV2dV2d", "")
49 BUILTIN(__builtin_ia32_ucomisdlt, "iV2dV2d", "")
50 BUILTIN(__builtin_ia32_ucomisdle, "iV2dV2d", "")
51 BUILTIN(__builtin_ia32_ucomisdgt, "iV2dV2d", "")
52 BUILTIN(__builtin_ia32_ucomisdge, "iV2dV2d", "")
53 BUILTIN(__builtin_ia32_ucomisdneq, "iV2dV2d", "")
54 BUILTIN(__builtin_ia32_cmpps, "V4fV4fV4fc", "")
55 BUILTIN(__builtin_ia32_cmpss, "V4fV4fV4fc", "")
56 BUILTIN(__builtin_ia32_minps, "V4fV4fV4f", "")
57 BUILTIN(__builtin_ia32_maxps, "V4fV4fV4f", "")
58 BUILTIN(__builtin_ia32_minss, "V4fV4fV4f", "")
59 BUILTIN(__builtin_ia32_maxss, "V4fV4fV4f", "")
60 BUILTIN(__builtin_ia32_paddsb, "V8cV8cV8c", "")
61 BUILTIN(__builtin_ia32_paddsw, "V4sV4sV4s", "")
62 BUILTIN(__builtin_ia32_psubsb, "V8cV8cV8c", "")
63 BUILTIN(__builtin_ia32_psubsw, "V4sV4sV4s", "")
64 BUILTIN(__builtin_ia32_paddusb, "V8cV8cV8c", "")
65 BUILTIN(__builtin_ia32_paddusw, "V4sV4sV4s", "")
66 BUILTIN(__builtin_ia32_psubusb, "V8cV8cV8c", "")
67 BUILTIN(__builtin_ia32_psubusw, "V4sV4sV4s", "")
68 BUILTIN(__builtin_ia32_pmulhw, "V4sV4sV4s", "")
69 BUILTIN(__builtin_ia32_pmulhuw, "V4sV4sV4s", "")
70 BUILTIN(__builtin_ia32_pavgb, "V8cV8cV8c", "")
71 BUILTIN(__builtin_ia32_pavgw, "V4sV4sV4s", "")
72 BUILTIN(__builtin_ia32_pcmpeqb, "V8cV8cV8c", "")
73 BUILTIN(__builtin_ia32_pcmpeqw, "V4sV4sV4s", "")
74 BUILTIN(__builtin_ia32_pcmpeqd, "V2iV2iV2i", "")
75 BUILTIN(__builtin_ia32_pcmpgtb, "V8cV8cV8c", "")
76 BUILTIN(__builtin_ia32_pcmpgtw, "V4sV4sV4s", "")
77 BUILTIN(__builtin_ia32_pcmpgtd, "V2iV2iV2i", "")
78 BUILTIN(__builtin_ia32_pmaxub, "V8cV8cV8c", "")
79 BUILTIN(__builtin_ia32_pmaxsw, "V4sV4sV4s", "")
80 BUILTIN(__builtin_ia32_pminub, "V8cV8cV8c", "")
81 BUILTIN(__builtin_ia32_pminsw, "V4sV4sV4s", "")
82 BUILTIN(__builtin_ia32_punpcklwd, "V4sV4sV4s", "")
83 BUILTIN(__builtin_ia32_cmppd, "V2dV2dV2dc", "")
84 BUILTIN(__builtin_ia32_cmpsd, "V2dV2dV2dc", "")
85 BUILTIN(__builtin_ia32_minpd, "V2dV2dV2d", "")
86 BUILTIN(__builtin_ia32_maxpd, "V2dV2dV2d", "")
87 BUILTIN(__builtin_ia32_minsd, "V2dV2dV2d", "")
88 BUILTIN(__builtin_ia32_maxsd, "V2dV2dV2d", "")
89 BUILTIN(__builtin_ia32_paddsb128, "V16cV16cV16c", "")
90 BUILTIN(__builtin_ia32_paddsw128, "V8sV8sV8s", "")
91 BUILTIN(__builtin_ia32_psubsb128, "V16cV16cV16c", "")
92 BUILTIN(__builtin_ia32_psubsw128, "V8sV8sV8s", "")
93 BUILTIN(__builtin_ia32_paddusb128, "V16cV16cV16c", "")
94 BUILTIN(__builtin_ia32_paddusw128, "V8sV8sV8s", "")
95 BUILTIN(__builtin_ia32_psubusb128, "V16cV16cV16c", "")
96 BUILTIN(__builtin_ia32_psubusw128, "V8sV8sV8s", "")
97 BUILTIN(__builtin_ia32_pmulhw128, "V8sV8sV8s", "")
98 BUILTIN(__builtin_ia32_pavgb128, "V16cV16cV16c", "")
99 BUILTIN(__builtin_ia32_pavgw128, "V8sV8sV8s", "")
100 BUILTIN(__builtin_ia32_pcmpeqb128, "V16cV16cV16c", "")
101 BUILTIN(__builtin_ia32_pcmpeqw128, "V8sV8sV8s", "")
102 BUILTIN(__builtin_ia32_pcmpeqd128, "V4iV4iV4i", "")
103 BUILTIN(__builtin_ia32_pcmpgtb128, "V16cV16cV16c", "")
104 BUILTIN(__builtin_ia32_pcmpgtw128, "V8sV8sV8s", "")
105 BUILTIN(__builtin_ia32_pcmpgtd128, "V4iV4iV4i", "")
106 BUILTIN(__builtin_ia32_pmaxub128, "V16cV16cV16c", "")
107 BUILTIN(__builtin_ia32_pmaxsw128, "V8sV8sV8s", "")
108 BUILTIN(__builtin_ia32_pminub128, "V16cV16cV16c", "")
109 BUILTIN(__builtin_ia32_pminsw128, "V8sV8sV8s", "")
110 BUILTIN(__builtin_ia32_packsswb128, "V8sV8sV8s", "")
111 BUILTIN(__builtin_ia32_packssdw128, "V4iV4iV4i", "")
112 BUILTIN(__builtin_ia32_packuswb128, "V8sV8sV8s", "")
113 BUILTIN(__builtin_ia32_pmulhuw128, "V8sV8sV8s", "")
114 BUILTIN(__builtin_ia32_addsubps, "V4fV4fV4f", "")
115 BUILTIN(__builtin_ia32_addsubpd, "V2dV2dV2d", "")
116 BUILTIN(__builtin_ia32_haddps, "V4fV4fV4f", "")
117 BUILTIN(__builtin_ia32_haddpd, "V2dV2dV2d", "")
118 BUILTIN(__builtin_ia32_hsubps, "V4fV4fV4f", "")
119 BUILTIN(__builtin_ia32_hsubpd, "V2dV2dV2d", "")
120 BUILTIN(__builtin_ia32_phaddw128, "V8sV8sV8s", "")
121 BUILTIN(__builtin_ia32_phaddw, "V4sV4sV4s", "")
122 BUILTIN(__builtin_ia32_phaddd128, "V4iV4iV4i", "")
123 BUILTIN(__builtin_ia32_phaddd, "V2iV2iV2i", "")
124 BUILTIN(__builtin_ia32_phaddsw128, "V8sV8sV8s", "")
125 BUILTIN(__builtin_ia32_phaddsw, "V4sV4sV4s", "")
126 BUILTIN(__builtin_ia32_phsubw128, "V8sV8sV8s", "")
127 BUILTIN(__builtin_ia32_phsubw, "V4sV4sV4s", "")
128 BUILTIN(__builtin_ia32_phsubd128, "V4iV4iV4i", "")
129 BUILTIN(__builtin_ia32_phsubd, "V2iV2iV2i", "")
130 BUILTIN(__builtin_ia32_phsubsw128, "V8sV8sV8s", "")
131 BUILTIN(__builtin_ia32_phsubsw, "V4sV4sV4s", "")
132 BUILTIN(__builtin_ia32_pmaddubsw128, "V16cV16cV16c", "")
133 BUILTIN(__builtin_ia32_pmaddubsw, "V8cV8cV8c", "")
134 BUILTIN(__builtin_ia32_pmulhrsw128, "V8sV8sV8s", "")
135 BUILTIN(__builtin_ia32_pmulhrsw, "V4sV4sV4s", "")
136 BUILTIN(__builtin_ia32_pshufb128, "V16cV16cV16c", "")
137 BUILTIN(__builtin_ia32_pshufb, "V8cV8cV8c", "")
138 BUILTIN(__builtin_ia32_psignb128, "V16cV16cV16c", "")
139 BUILTIN(__builtin_ia32_psignb, "V8cV8cV8c", "")
140 BUILTIN(__builtin_ia32_psignw128, "V8sV8sV8s", "")
141 BUILTIN(__builtin_ia32_psignw, "V4sV4sV4s", "")
142 BUILTIN(__builtin_ia32_psignd128, "V4iV4iV4i", "")
143 BUILTIN(__builtin_ia32_psignd, "V2iV2iV2i", "")
144 BUILTIN(__builtin_ia32_pabsb128, "V16cV16c", "")
145 BUILTIN(__builtin_ia32_pabsb, "V8cV8c", "")
146 BUILTIN(__builtin_ia32_pabsw128, "V8sV8s", "")
147 BUILTIN(__builtin_ia32_pabsw, "V4sV4s", "")
148 BUILTIN(__builtin_ia32_pabsd128, "V4iV4i", "")
149 BUILTIN(__builtin_ia32_pabsd, "V2iV2i", "")
150 BUILTIN(__builtin_ia32_psllw, "V4sV4sV1LLi", "")
151 BUILTIN(__builtin_ia32_pslld, "V2iV2iV1LLi", "")
152 BUILTIN(__builtin_ia32_psllq, "V1LLiV1LLiV1LLi", "")
153 BUILTIN(__builtin_ia32_psrlw, "V4sV4sV1LLi", "")
154 BUILTIN(__builtin_ia32_psrld, "V2iV2iV1LLi", "")
155 BUILTIN(__builtin_ia32_psrlq, "V1LLiV1LLiV1LLi", "")
156 BUILTIN(__builtin_ia32_psraw, "V4sV4sV1LLi", "")
157 BUILTIN(__builtin_ia32_psrad, "V2iV2iV1LLi", "")
158 BUILTIN(__builtin_ia32_pmaddwd, "V2iV4sV4s", "")
159 BUILTIN(__builtin_ia32_packsswb, "V8cV4sV4s", "")
160 BUILTIN(__builtin_ia32_packssdw, "V4sV2iV2i", "")
161 BUILTIN(__builtin_ia32_packuswb, "V8cV4sV4s", "")
162 BUILTIN(__builtin_ia32_ldmxcsr, "vUi", "")
163 BUILTIN(__builtin_ia32_stmxcsr, "Ui", "")
164 BUILTIN(__builtin_ia32_cvtpi2ps, "V4fV4fV2i", "")
165 BUILTIN(__builtin_ia32_cvtps2pi, "V2iV4f", "")
166 BUILTIN(__builtin_ia32_cvtss2si, "iV4f", "")
167 BUILTIN(__builtin_ia32_cvtss2si64, "LLiV4f", "")
168 BUILTIN(__builtin_ia32_cvttps2pi, "V2iV4f", "")
169 BUILTIN(__builtin_ia32_maskmovq, "vV8cV8cc*", "")
170 BUILTIN(__builtin_ia32_loadups, "V4ffC*", "")
171 BUILTIN(__builtin_ia32_storeups, "vf*V4f", "")
172 BUILTIN(__builtin_ia32_storehps, "vV2i*V4f", "")
173 BUILTIN(__builtin_ia32_storelps, "vV2i*V4f", "")
174 BUILTIN(__builtin_ia32_movmskps, "iV4f", "")
175 BUILTIN(__builtin_ia32_pmovmskb, "iV8c", "")
176 BUILTIN(__builtin_ia32_movntps, "vf*V4f", "")
177 BUILTIN(__builtin_ia32_movntq, "vV1LLi*V1LLi", "")
178 BUILTIN(__builtin_ia32_sfence, "v", "")
179 BUILTIN(__builtin_ia32_psadbw, "V4sV8cV8c", "")
180 BUILTIN(__builtin_ia32_rcpps, "V4fV4f", "")
181 BUILTIN(__builtin_ia32_rcpss, "V4fV4f", "")
182 BUILTIN(__builtin_ia32_rsqrtps, "V4fV4f", "")
183 BUILTIN(__builtin_ia32_rsqrtss, "V4fV4f", "")
184 BUILTIN(__builtin_ia32_sqrtps, "V4fV4f", "")
185 BUILTIN(__builtin_ia32_sqrtss, "V4fV4f", "")
186 BUILTIN(__builtin_ia32_maskmovdqu, "vV16cV16cc*", "")
187 BUILTIN(__builtin_ia32_loadupd, "V2ddC*", "")
188 BUILTIN(__builtin_ia32_storeupd, "vd*V2d", "")
189 BUILTIN(__builtin_ia32_movmskpd, "iV2d", "")
190 BUILTIN(__builtin_ia32_pmovmskb128, "iV16c", "")
191 BUILTIN(__builtin_ia32_movnti, "vi*i", "")
192 BUILTIN(__builtin_ia32_movntpd, "vd*V2d", "")
193 BUILTIN(__builtin_ia32_movntdq, "vV2LLi*V2LLi", "")
194 BUILTIN(__builtin_ia32_psadbw128, "V2LLiV16cV16c", "")
195 BUILTIN(__builtin_ia32_sqrtpd, "V2dV2d", "")
196 BUILTIN(__builtin_ia32_sqrtsd, "V2dV2d", "")
197 BUILTIN(__builtin_ia32_cvtdq2pd, "V2dV4i", "")
198 BUILTIN(__builtin_ia32_cvtdq2ps, "V4fV4i", "")
199 BUILTIN(__builtin_ia32_cvtpd2dq, "V2LLiV2d", "")
200 BUILTIN(__builtin_ia32_cvtpd2pi, "V2iV2d", "")
201 BUILTIN(__builtin_ia32_cvtpd2ps, "V4fV2d", "")
202 BUILTIN(__builtin_ia32_cvttpd2dq, "V4iV2d", "")
203 BUILTIN(__builtin_ia32_cvttpd2pi, "V2iV2d", "")
204 BUILTIN(__builtin_ia32_cvtpi2pd, "V2dV2i", "")
205 BUILTIN(__builtin_ia32_cvtsd2si, "iV2d", "")
206 BUILTIN(__builtin_ia32_cvtsd2si64, "LLiV2d", "")
207 BUILTIN(__builtin_ia32_cvtps2dq, "V4iV4f", "")
208 BUILTIN(__builtin_ia32_cvtps2pd, "V2dV4f", "")
209 BUILTIN(__builtin_ia32_cvttps2dq, "V4iV4f", "")
210 BUILTIN(__builtin_ia32_clflush, "vvC*", "")
211 BUILTIN(__builtin_ia32_lfence, "v", "")
212 BUILTIN(__builtin_ia32_mfence, "v", "")
213 BUILTIN(__builtin_ia32_loaddqu, "V16ccC*", "")
214 BUILTIN(__builtin_ia32_storedqu, "vc*V16c", "")
215 BUILTIN(__builtin_ia32_psllwi, "V4sV4si", "")
216 BUILTIN(__builtin_ia32_pslldi, "V2iV2ii", "")
217 BUILTIN(__builtin_ia32_psllqi, "V1LLiV1LLii", "")
218 BUILTIN(__builtin_ia32_psrawi, "V4sV4si", "")
219 BUILTIN(__builtin_ia32_psradi, "V2iV2ii", "")
220 BUILTIN(__builtin_ia32_psrlwi, "V4sV4si", "")
221 BUILTIN(__builtin_ia32_psrldi, "V2iV2ii", "")
222 BUILTIN(__builtin_ia32_psrlqi, "V1LLiV1LLii", "")
223 BUILTIN(__builtin_ia32_pmuludq, "V1LLiV2iV2i", "")
224 BUILTIN(__builtin_ia32_pmuludq128, "V2LLiV4iV4i", "")
225 BUILTIN(__builtin_ia32_psraw128, "V8sV8sV8s", "")
226 BUILTIN(__builtin_ia32_psrad128, "V4iV4iV4i", "")
227 BUILTIN(__builtin_ia32_psrlw128, "V8sV8sV8s", "")
228 BUILTIN(__builtin_ia32_psrld128, "V4iV4iV4i", "")
229 BUILTIN(__builtin_ia32_pslldqi128, "V2LLiV2LLii", "")
230 BUILTIN(__builtin_ia32_psrldqi128, "V2LLiV2LLii", "")
231 BUILTIN(__builtin_ia32_psrlq128, "V2LLiV2LLiV2LLi", "")
232 BUILTIN(__builtin_ia32_psllw128, "V8sV8sV8s", "")
233 BUILTIN(__builtin_ia32_pslld128, "V4iV4iV4i", "")
234 BUILTIN(__builtin_ia32_psllq128, "V2LLiV2LLiV2LLi", "")
235 BUILTIN(__builtin_ia32_psllwi128, "V8sV8si", "")
236 BUILTIN(__builtin_ia32_pslldi128, "V4iV4ii", "")
237 BUILTIN(__builtin_ia32_psllqi128, "V2LLiV2LLii", "")
238 BUILTIN(__builtin_ia32_psrlwi128, "V8sV8si", "")
239 BUILTIN(__builtin_ia32_psrldi128, "V4iV4ii", "")
240 BUILTIN(__builtin_ia32_psrlqi128, "V2LLiV2LLii", "")
241 BUILTIN(__builtin_ia32_psrawi128, "V8sV8si", "")
242 BUILTIN(__builtin_ia32_psradi128, "V4iV4ii", "")
243 BUILTIN(__builtin_ia32_pmaddwd128, "V8sV8sV8s", "")
244 BUILTIN(__builtin_ia32_monitor, "vv*UiUi", "")
245 BUILTIN(__builtin_ia32_mwait, "vUiUi", "")
246 BUILTIN(__builtin_ia32_lddqu, "V16ccC*", "")
247 BUILTIN(__builtin_ia32_palignr128, "V16cV16cV16cc", "")
248 BUILTIN(__builtin_ia32_palignr, "V8cV8cV8cc", "")
249 BUILTIN(__builtin_ia32_insertps128, "V4fV4fV4fi", "")
250
251 BUILTIN(__builtin_ia32_storelv4si, "vV2i*V2LLi", "")
252
253 BUILTIN(__builtin_ia32_pblendvb128, "V16cV16cV16cV16c", "")
254 BUILTIN(__builtin_ia32_pblendw128, "V8sV8sV8si", "")
255 BUILTIN(__builtin_ia32_blendpd, "V2dV2dV2di", "")
256 BUILTIN(__builtin_ia32_blendps, "V4fV4fV4fi", "")
257 BUILTIN(__builtin_ia32_blendvpd, "V2dV2dV2dV2d", "")
258 BUILTIN(__builtin_ia32_blendvps, "V4fV4fV4fV4f", "")
259
260 BUILTIN(__builtin_ia32_packusdw128, "V8sV4iV4i", "")
261 BUILTIN(__builtin_ia32_pmaxsb128, "V16cV16cV16c", "")
262 BUILTIN(__builtin_ia32_pmaxsd128, "V4iV4iV4i", "")
263 BUILTIN(__builtin_ia32_pmaxud128, "V4iV4iV4i", "")
264 BUILTIN(__builtin_ia32_pmaxuw128, "V8sV8sV8s", "")
265 BUILTIN(__builtin_ia32_pminsb128, "V16cV16cV16c", "")
266 BUILTIN(__builtin_ia32_pminsd128, "V4iV4iV4i", "")
267 BUILTIN(__builtin_ia32_pminud128, "V4iV4iV4i", "")
268 BUILTIN(__builtin_ia32_pminuw128, "V8sV8sV8s", "")
269 BUILTIN(__builtin_ia32_pmovsxbd128, "V4iV16c", "")
270 BUILTIN(__builtin_ia32_pmovsxbq128, "V2LLiV16c", "")
271 BUILTIN(__builtin_ia32_pmovsxbw128, "V8sV16c", "")
272 BUILTIN(__builtin_ia32_pmovsxdq128, "V2LLiV4i", "")
273 BUILTIN(__builtin_ia32_pmovsxwd128, "V4iV8s", "")
274 BUILTIN(__builtin_ia32_pmovsxwq128, "V2LLiV8s", "")
275 BUILTIN(__builtin_ia32_pmovzxbd128, "V4iV16c", "")
276 BUILTIN(__builtin_ia32_pmovzxbq128, "V2LLiV16c", "")
277 BUILTIN(__builtin_ia32_pmovzxbw128, "V8sV16c", "")
278 BUILTIN(__builtin_ia32_pmovzxdq128, "V2LLiV4i", "")
279 BUILTIN(__builtin_ia32_pmovzxwd128, "V4iV8s", "")
280 BUILTIN(__builtin_ia32_pmovzxwq128, "V2LLiV8s", "")
281 BUILTIN(__builtin_ia32_pmuldq128, "V2LLiV4iV4i", "")
282 BUILTIN(__builtin_ia32_pmulld128, "V4iV4iV4i", "")
283 BUILTIN(__builtin_ia32_roundps, "V4fV4fi", "")
284 BUILTIN(__builtin_ia32_roundss, "V4fV4fV4fi", "")
285 BUILTIN(__builtin_ia32_roundsd, "V2dV2dV2di", "")
286 BUILTIN(__builtin_ia32_roundpd, "V2dV2di", "")
287 BUILTIN(__builtin_ia32_dpps, "V4fV4fV4fi", "")
288 BUILTIN(__builtin_ia32_dppd, "V2dV2dV2di", "")
289 BUILTIN(__builtin_ia32_movntdqa, "V2LLiV2LLi*", "")
290 BUILTIN(__builtin_ia32_ptestz128, "iV2LLiV2LLi", "")
291 BUILTIN(__builtin_ia32_ptestc128, "iV2LLiV2LLi", "")
292 BUILTIN(__builtin_ia32_ptestnzc128, "iV2LLiV2LLi", "")
293 BUILTIN(__builtin_ia32_pcmpeqq, "V2LLiV2LLiV2LLi", "")
294 BUILTIN(__builtin_ia32_mpsadbw128, "V16cV16cV16ci", "")
295
296 // SSE 4.2
297 BUILTIN(__builtin_ia32_pcmpistrm128, "V16cV16cV16cc", "")
298 BUILTIN(__builtin_ia32_pcmpistri128, "iV16cV16cc", "")
299 BUILTIN(__builtin_ia32_pcmpestrm128, "V16cV16ciV16cic", "")
300 BUILTIN(__builtin_ia32_pcmpestri128, "iV16ciV16cic","")
301
302 BUILTIN(__builtin_ia32_pcmpistria128, "iV16ciV16cic","")
303 BUILTIN(__builtin_ia32_pcmpistric128, "iV16ciV16cic","")
304 BUILTIN(__builtin_ia32_pcmpistrio128, "iV16ciV16cic","")
305 BUILTIN(__builtin_ia32_pcmpistris128, "iV16ciV16cic","")
306 BUILTIN(__builtin_ia32_pcmpistriz128, "iV16ciV16cic","")
307
308 BUILTIN(__builtin_ia32_pcmpestria128, "iV16ciV16cic","")
309 BUILTIN(__builtin_ia32_pcmpestric128, "iV16ciV16cic","")
310 BUILTIN(__builtin_ia32_pcmpestrio128, "iV16ciV16cic","")
311 BUILTIN(__builtin_ia32_pcmpestris128, "iV16ciV16cic","")
312 BUILTIN(__builtin_ia32_pcmpestriz128, "iV16ciV16cic","")
313
314 BUILTIN(__builtin_ia32_pcmpgtq, "V2LLiV2LLiV2LLi", "")
315
316 BUILTIN(__builtin_ia32_crc32qi, "iic", "")
317 BUILTIN(__builtin_ia32_crc32hi, "iis", "")
318 BUILTIN(__builtin_ia32_crc32si, "iii", "")
319 BUILTIN(__builtin_ia32_crc32di, "LLiLLiLLi", "")
320
321 // AES
322 BUILTIN(__builtin_ia32_aesenc128, "V2LLiV2LLiV2LLi", "")
323 BUILTIN(__builtin_ia32_aesenclast128, "V2LLiV2LLiV2LLi", "")
324 BUILTIN(__builtin_ia32_aesdec128, "V2LLiV2LLiV2LLi", "")
325 BUILTIN(__builtin_ia32_aesdeclast128, "V2LLiV2LLiV2LLi", "")
326 BUILTIN(__builtin_ia32_aesimc128, "V2LLiV2LLi", "")
327 BUILTIN(__builtin_ia32_aeskeygenassist128, "V2LLiV2LLii", "")
328 #undef BUILTIN