a340ce50a6d9ed82237a23be6ac7db38e478bdf9
[oota-llvm.git] / include / llvm / IntrinsicsX86.td
1 //===- IntrinsicsX86.td - Defines X86 intrinsics -----------*- tablegen -*-===//
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 all of the X86-specific intrinsics.
11 //
12 //===----------------------------------------------------------------------===//
13
14
15 //===----------------------------------------------------------------------===//
16 // SSE1
17
18 // Arithmetic ops
19 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
20   def int_x86_sse_add_ss : GCCBuiltin<"__builtin_ia32_addss">,
21               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
22                          llvm_v4f32_ty], [IntrNoMem]>;
23   def int_x86_sse_add_ps : GCCBuiltin<"__builtin_ia32_addps">,
24               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
25                          llvm_v4f32_ty], [IntrNoMem, Commutative]>;
26   def int_x86_sse_sub_ss : GCCBuiltin<"__builtin_ia32_subss">,
27               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
28                          llvm_v4f32_ty], [IntrNoMem]>;
29   def int_x86_sse_sub_ps : GCCBuiltin<"__builtin_ia32_subps">,
30               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
31                          llvm_v4f32_ty], [IntrNoMem, Commutative]>;
32   def int_x86_sse_mul_ss : GCCBuiltin<"__builtin_ia32_mulss">,
33               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
34                          llvm_v4f32_ty], [IntrNoMem]>;
35   def int_x86_sse_mul_ps : GCCBuiltin<"__builtin_ia32_mulps">,
36               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
37                          llvm_v4f32_ty], [IntrNoMem, Commutative]>;
38   def int_x86_sse_div_ss : GCCBuiltin<"__builtin_ia32_divss">,
39               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
40                          llvm_v4f32_ty], [IntrNoMem]>;
41   def int_x86_sse_div_ps : GCCBuiltin<"__builtin_ia32_divps">,
42               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
43                          llvm_v4f32_ty], [IntrNoMem, Commutative]>;
44   def int_x86_sse_sqrt_ss : GCCBuiltin<"__builtin_ia32_sqrtss">,
45               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
46                         [IntrNoMem]>;
47   def int_x86_sse_sqrt_ps : GCCBuiltin<"__builtin_ia32_sqrtps">,
48               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
49                         [IntrNoMem]>;
50   def int_x86_sse_rcp_ss : GCCBuiltin<"__builtin_ia32_rcpss">,
51               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
52                         [IntrNoMem]>;
53   def int_x86_sse_rcp_ps : GCCBuiltin<"__builtin_ia32_rcpps">,
54               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
55                         [IntrNoMem]>;
56   def int_x86_sse_rsqrt_ss : GCCBuiltin<"__builtin_ia32_rsqrtss">,
57               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
58                         [IntrNoMem]>;
59   def int_x86_sse_rsqrt_ps : GCCBuiltin<"__builtin_ia32_rsqrtps">,
60               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty],
61                         [IntrNoMem]>;
62   def int_x86_sse_min_ss : GCCBuiltin<"__builtin_ia32_minss">,
63               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
64                          llvm_v4f32_ty], [IntrNoMem]>;
65   def int_x86_sse_min_ps : GCCBuiltin<"__builtin_ia32_minps">,
66               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
67                          llvm_v4f32_ty], [IntrNoMem]>;
68   def int_x86_sse_max_ss : GCCBuiltin<"__builtin_ia32_maxss">,
69               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
70                          llvm_v4f32_ty], [IntrNoMem]>;
71   def int_x86_sse_max_ps : GCCBuiltin<"__builtin_ia32_maxps">,
72               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
73                          llvm_v4f32_ty], [IntrNoMem]>;
74 }
75
76 // Comparison ops
77 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
78   def int_x86_sse_cmp_ss :
79               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
80                          llvm_v4f32_ty, llvm_i8_ty], [IntrNoMem]>;
81   def int_x86_sse_cmp_ps :
82               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
83                          llvm_v4f32_ty, llvm_i8_ty], [IntrNoMem]>;
84   def int_x86_sse_comieq_ss : GCCBuiltin<"__builtin_ia32_comieq">,
85               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
86                          llvm_v4f32_ty], [IntrNoMem]>;
87   def int_x86_sse_comilt_ss : GCCBuiltin<"__builtin_ia32_comilt">,
88               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
89                          llvm_v4f32_ty], [IntrNoMem]>;
90   def int_x86_sse_comile_ss : GCCBuiltin<"__builtin_ia32_comile">,
91               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
92                          llvm_v4f32_ty], [IntrNoMem]>;
93   def int_x86_sse_comigt_ss : GCCBuiltin<"__builtin_ia32_comigt">,
94               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
95                          llvm_v4f32_ty], [IntrNoMem]>;
96   def int_x86_sse_comige_ss : GCCBuiltin<"__builtin_ia32_comige">,
97               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
98                          llvm_v4f32_ty], [IntrNoMem]>;
99   def int_x86_sse_comineq_ss : GCCBuiltin<"__builtin_ia32_comineq">,
100               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
101                          llvm_v4f32_ty], [IntrNoMem]>;
102   def int_x86_sse_ucomieq_ss : GCCBuiltin<"__builtin_ia32_ucomieq">,
103               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
104                          llvm_v4f32_ty], [IntrNoMem]>;
105   def int_x86_sse_ucomilt_ss : GCCBuiltin<"__builtin_ia32_ucomilt">,
106               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
107                          llvm_v4f32_ty], [IntrNoMem]>;
108   def int_x86_sse_ucomile_ss : GCCBuiltin<"__builtin_ia32_ucomile">,
109               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
110                          llvm_v4f32_ty], [IntrNoMem]>;
111   def int_x86_sse_ucomigt_ss : GCCBuiltin<"__builtin_ia32_ucomigt">,
112               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
113                          llvm_v4f32_ty], [IntrNoMem]>;
114   def int_x86_sse_ucomige_ss : GCCBuiltin<"__builtin_ia32_ucomige">,
115               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
116                          llvm_v4f32_ty], [IntrNoMem]>;
117   def int_x86_sse_ucomineq_ss : GCCBuiltin<"__builtin_ia32_ucomineq">,
118               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty,
119                          llvm_v4f32_ty], [IntrNoMem]>;
120 }
121
122
123 // Conversion ops
124 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
125   def int_x86_sse_cvtss2si : GCCBuiltin<"__builtin_ia32_cvtss2si">,
126               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
127   def int_x86_sse_cvtss2si64 : GCCBuiltin<"__builtin_ia32_cvtss2si64">,
128               Intrinsic<[llvm_i64_ty], [llvm_v4f32_ty], [IntrNoMem]>;
129   def int_x86_sse_cvttss2si : GCCBuiltin<"__builtin_ia32_cvttss2si">,
130               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
131   def int_x86_sse_cvttss2si64 : GCCBuiltin<"__builtin_ia32_cvttss2si64">,
132               Intrinsic<[llvm_i64_ty], [llvm_v4f32_ty], [IntrNoMem]>;
133   def int_x86_sse_cvtsi2ss : GCCBuiltin<"__builtin_ia32_cvtsi2ss">,
134               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
135                          llvm_i32_ty], [IntrNoMem]>;
136   def int_x86_sse_cvtsi642ss : GCCBuiltin<"__builtin_ia32_cvtsi642ss">,
137               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
138                          llvm_i64_ty], [IntrNoMem]>;
139   def int_x86_sse_cvtps2pi : GCCBuiltin<"__builtin_ia32_cvtps2pi">,
140               Intrinsic<[llvm_v2i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
141   def int_x86_sse_cvttps2pi: GCCBuiltin<"__builtin_ia32_cvttps2pi">,
142               Intrinsic<[llvm_v2i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
143   def int_x86_sse_cvtpi2ps : GCCBuiltin<"__builtin_ia32_cvtpi2ps">,
144               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
145                          llvm_v2i32_ty], [IntrNoMem]>;
146 }
147
148 // SIMD load ops
149 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
150   def int_x86_sse_loadu_ps : GCCBuiltin<"__builtin_ia32_loadups">,
151               Intrinsic<[llvm_v4f32_ty], [llvm_ptr_ty], [IntrReadMem]>;
152 }
153
154 // SIMD store ops
155 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
156   def int_x86_sse_storeu_ps : GCCBuiltin<"__builtin_ia32_storeups">,
157               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
158                          llvm_v4f32_ty], [IntrWriteMem]>;
159 }
160
161 // Cacheability support ops
162 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
163   def int_x86_sse_movnt_ps : GCCBuiltin<"__builtin_ia32_movntps">,
164               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
165                          llvm_v4f32_ty], [IntrWriteMem]>;
166   def int_x86_sse_sfence : GCCBuiltin<"__builtin_ia32_sfence">,
167               Intrinsic<[llvm_void_ty], [], [IntrWriteMem]>;
168 }
169
170 // Control register.
171 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
172   def int_x86_sse_stmxcsr :
173               Intrinsic<[llvm_void_ty], [llvm_ptr_ty], [IntrWriteMem]>;
174   def int_x86_sse_ldmxcsr :
175               Intrinsic<[llvm_void_ty], [llvm_ptr_ty], [IntrWriteMem]>;
176 }
177
178 // Misc.
179 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
180   def int_x86_sse_movmsk_ps : GCCBuiltin<"__builtin_ia32_movmskps">,
181               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
182 }
183
184 //===----------------------------------------------------------------------===//
185 // SSE2
186
187 // FP arithmetic ops
188 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
189   def int_x86_sse2_add_sd : GCCBuiltin<"__builtin_ia32_addsd">,
190               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
191                          llvm_v2f64_ty], [IntrNoMem]>;
192   def int_x86_sse2_add_pd : GCCBuiltin<"__builtin_ia32_addpd">,
193               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
194                          llvm_v2f64_ty], [IntrNoMem, Commutative]>;
195   def int_x86_sse2_sub_sd : GCCBuiltin<"__builtin_ia32_subsd">,
196               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
197                          llvm_v2f64_ty], [IntrNoMem]>;
198   def int_x86_sse2_sub_pd : GCCBuiltin<"__builtin_ia32_subpd">,
199               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
200                          llvm_v2f64_ty], [IntrNoMem, Commutative]>;
201   def int_x86_sse2_mul_sd : GCCBuiltin<"__builtin_ia32_mulsd">,
202               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
203                          llvm_v2f64_ty], [IntrNoMem]>;
204   def int_x86_sse2_mul_pd : GCCBuiltin<"__builtin_ia32_mulpd">,
205               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
206                          llvm_v2f64_ty], [IntrNoMem, Commutative]>;
207   def int_x86_sse2_div_sd : GCCBuiltin<"__builtin_ia32_divsd">,
208               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
209                          llvm_v2f64_ty], [IntrNoMem]>;
210   def int_x86_sse2_div_pd : GCCBuiltin<"__builtin_ia32_divpd">,
211               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
212                          llvm_v2f64_ty], [IntrNoMem, Commutative]>;
213   def int_x86_sse2_sqrt_sd : GCCBuiltin<"__builtin_ia32_sqrtsd">,
214               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty],
215                         [IntrNoMem]>;
216   def int_x86_sse2_sqrt_pd : GCCBuiltin<"__builtin_ia32_sqrtpd">,
217               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty],
218                         [IntrNoMem]>;
219   def int_x86_sse2_min_sd : GCCBuiltin<"__builtin_ia32_minsd">,
220               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
221                          llvm_v2f64_ty], [IntrNoMem]>;
222   def int_x86_sse2_min_pd : GCCBuiltin<"__builtin_ia32_minpd">,
223               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
224                          llvm_v2f64_ty], [IntrNoMem]>;
225   def int_x86_sse2_max_sd : GCCBuiltin<"__builtin_ia32_maxsd">,
226               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
227                          llvm_v2f64_ty], [IntrNoMem]>;
228   def int_x86_sse2_max_pd : GCCBuiltin<"__builtin_ia32_maxpd">,
229               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
230                          llvm_v2f64_ty], [IntrNoMem]>;
231 }
232
233 // FP comparison ops
234 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
235   def int_x86_sse2_cmp_sd :
236               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
237                          llvm_v2f64_ty, llvm_i8_ty], [IntrNoMem]>;
238   def int_x86_sse2_cmp_pd :
239               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
240                          llvm_v2f64_ty, llvm_i8_ty], [IntrNoMem]>;
241   def int_x86_sse2_comieq_sd : GCCBuiltin<"__builtin_ia32_comisdeq">,
242               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
243                          llvm_v2f64_ty], [IntrNoMem]>;
244   def int_x86_sse2_comilt_sd : GCCBuiltin<"__builtin_ia32_comisdlt">,
245               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
246                          llvm_v2f64_ty], [IntrNoMem]>;
247   def int_x86_sse2_comile_sd : GCCBuiltin<"__builtin_ia32_comisdle">,
248               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
249                          llvm_v2f64_ty], [IntrNoMem]>;
250   def int_x86_sse2_comigt_sd : GCCBuiltin<"__builtin_ia32_comisdgt">,
251               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
252                          llvm_v2f64_ty], [IntrNoMem]>;
253   def int_x86_sse2_comige_sd : GCCBuiltin<"__builtin_ia32_comisdge">,
254               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
255                          llvm_v2f64_ty], [IntrNoMem]>;
256   def int_x86_sse2_comineq_sd : GCCBuiltin<"__builtin_ia32_comisdneq">,
257               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
258                          llvm_v2f64_ty], [IntrNoMem]>;
259   def int_x86_sse2_ucomieq_sd : GCCBuiltin<"__builtin_ia32_ucomisdeq">,
260               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
261                          llvm_v2f64_ty], [IntrNoMem]>;
262   def int_x86_sse2_ucomilt_sd : GCCBuiltin<"__builtin_ia32_ucomisdlt">,
263               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
264                          llvm_v2f64_ty], [IntrNoMem]>;
265   def int_x86_sse2_ucomile_sd : GCCBuiltin<"__builtin_ia32_ucomisdle">,
266               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
267                          llvm_v2f64_ty], [IntrNoMem]>;
268   def int_x86_sse2_ucomigt_sd : GCCBuiltin<"__builtin_ia32_ucomisdgt">,
269               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
270                          llvm_v2f64_ty], [IntrNoMem]>;
271   def int_x86_sse2_ucomige_sd : GCCBuiltin<"__builtin_ia32_ucomisdge">,
272               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
273                          llvm_v2f64_ty], [IntrNoMem]>;
274   def int_x86_sse2_ucomineq_sd : GCCBuiltin<"__builtin_ia32_ucomisdneq">,
275               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty,
276                          llvm_v2f64_ty], [IntrNoMem]>;
277 }
278
279 // Integer arithmetic ops.
280 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
281   def int_x86_sse2_padds_b : GCCBuiltin<"__builtin_ia32_paddsb128">,
282               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
283                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
284   def int_x86_sse2_padds_w : GCCBuiltin<"__builtin_ia32_paddsw128">,
285               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
286                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
287   def int_x86_sse2_paddus_b : GCCBuiltin<"__builtin_ia32_paddusb128">,
288               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
289                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
290   def int_x86_sse2_paddus_w : GCCBuiltin<"__builtin_ia32_paddusw128">,
291               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
292                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
293   def int_x86_sse2_psubs_b : GCCBuiltin<"__builtin_ia32_psubsb128">,
294               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
295                          llvm_v16i8_ty], [IntrNoMem]>;
296   def int_x86_sse2_psubs_w : GCCBuiltin<"__builtin_ia32_psubsw128">,
297               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
298                          llvm_v8i16_ty], [IntrNoMem]>;
299   def int_x86_sse2_psubus_b : GCCBuiltin<"__builtin_ia32_psubusb128">,
300               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
301                          llvm_v16i8_ty], [IntrNoMem]>;
302   def int_x86_sse2_psubus_w : GCCBuiltin<"__builtin_ia32_psubusw128">,
303               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
304                          llvm_v8i16_ty], [IntrNoMem]>;
305   def int_x86_sse2_pmulhu_w : GCCBuiltin<"__builtin_ia32_pmulhuw128">,
306               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
307                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
308   def int_x86_sse2_pmulh_w : GCCBuiltin<"__builtin_ia32_pmulhw128">,
309               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
310                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
311   def int_x86_sse2_pmulu_dq : GCCBuiltin<"__builtin_ia32_pmuludq128">,
312               Intrinsic<[llvm_v2i64_ty], [llvm_v4i32_ty,
313                          llvm_v4i32_ty], [IntrNoMem, Commutative]>;
314   def int_x86_sse2_pmadd_wd : GCCBuiltin<"__builtin_ia32_pmaddwd128">,
315               Intrinsic<[llvm_v4i32_ty], [llvm_v8i16_ty,
316                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
317   def int_x86_sse2_pavg_b : GCCBuiltin<"__builtin_ia32_pavgb128">,
318               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
319                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
320   def int_x86_sse2_pavg_w : GCCBuiltin<"__builtin_ia32_pavgw128">,
321               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
322                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
323   def int_x86_sse2_pmaxu_b : GCCBuiltin<"__builtin_ia32_pmaxub128">,
324               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
325                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
326   def int_x86_sse2_pmaxs_w : GCCBuiltin<"__builtin_ia32_pmaxsw128">,
327               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
328                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
329   def int_x86_sse2_pminu_b : GCCBuiltin<"__builtin_ia32_pminub128">,
330               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
331                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
332   def int_x86_sse2_pmins_w : GCCBuiltin<"__builtin_ia32_pminsw128">,
333               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
334                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
335   def int_x86_sse2_psad_bw : GCCBuiltin<"__builtin_ia32_psadbw128">,
336               Intrinsic<[llvm_v2i64_ty], [llvm_v16i8_ty,
337                          llvm_v16i8_ty], [IntrNoMem, Commutative]>;
338 }
339
340 // Integer shift ops.
341 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
342   def int_x86_sse2_psll_w : GCCBuiltin<"__builtin_ia32_psllw128">,
343               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
344                          llvm_v8i16_ty], [IntrNoMem]>;
345   def int_x86_sse2_psll_d : GCCBuiltin<"__builtin_ia32_pslld128">,
346               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
347                          llvm_v4i32_ty], [IntrNoMem]>;
348   def int_x86_sse2_psll_q : GCCBuiltin<"__builtin_ia32_psllq128">,
349               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
350                          llvm_v2i64_ty], [IntrNoMem]>;
351   def int_x86_sse2_psrl_w : GCCBuiltin<"__builtin_ia32_psrlw128">,
352               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
353                          llvm_v8i16_ty], [IntrNoMem]>;
354   def int_x86_sse2_psrl_d : GCCBuiltin<"__builtin_ia32_psrld128">,
355               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
356                          llvm_v4i32_ty], [IntrNoMem]>;
357   def int_x86_sse2_psrl_q : GCCBuiltin<"__builtin_ia32_psrlq128">,
358               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
359                          llvm_v2i64_ty], [IntrNoMem]>;
360   def int_x86_sse2_psra_w : GCCBuiltin<"__builtin_ia32_psraw128">,
361               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
362                          llvm_v8i16_ty], [IntrNoMem]>;
363   def int_x86_sse2_psra_d : GCCBuiltin<"__builtin_ia32_psrad128">,
364               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
365                          llvm_v4i32_ty], [IntrNoMem]>;
366
367   def int_x86_sse2_pslli_w : GCCBuiltin<"__builtin_ia32_psllwi128">,
368               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
369                          llvm_i32_ty], [IntrNoMem]>;
370   def int_x86_sse2_pslli_d : GCCBuiltin<"__builtin_ia32_pslldi128">,
371               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
372                          llvm_i32_ty], [IntrNoMem]>;
373   def int_x86_sse2_pslli_q : GCCBuiltin<"__builtin_ia32_psllqi128">,
374               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
375                          llvm_i32_ty], [IntrNoMem]>;
376   def int_x86_sse2_psrli_w : GCCBuiltin<"__builtin_ia32_psrlwi128">,
377               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
378                          llvm_i32_ty], [IntrNoMem]>;
379   def int_x86_sse2_psrli_d : GCCBuiltin<"__builtin_ia32_psrldi128">,
380               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
381                          llvm_i32_ty], [IntrNoMem]>;
382   def int_x86_sse2_psrli_q : GCCBuiltin<"__builtin_ia32_psrlqi128">,
383               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
384                          llvm_i32_ty], [IntrNoMem]>;
385   def int_x86_sse2_psrai_w : GCCBuiltin<"__builtin_ia32_psrawi128">,
386               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
387                          llvm_i32_ty], [IntrNoMem]>;
388   def int_x86_sse2_psrai_d : GCCBuiltin<"__builtin_ia32_psradi128">,
389               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
390                          llvm_i32_ty], [IntrNoMem]>;
391
392   def int_x86_sse2_psll_dq : GCCBuiltin<"__builtin_ia32_pslldqi128">,
393               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
394                          llvm_i32_ty], [IntrNoMem]>;
395   def int_x86_sse2_psrl_dq : GCCBuiltin<"__builtin_ia32_psrldqi128">,
396               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
397                          llvm_i32_ty], [IntrNoMem]>;
398   def int_x86_sse2_psll_dq_bs : GCCBuiltin<"__builtin_ia32_pslldqi128_byteshift">,
399               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
400                          llvm_i32_ty], [IntrNoMem]>;
401   def int_x86_sse2_psrl_dq_bs : GCCBuiltin<"__builtin_ia32_psrldqi128_byteshift">,
402               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
403                          llvm_i32_ty], [IntrNoMem]>;
404 }
405
406 // Integer comparison ops
407 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
408   def int_x86_sse2_pcmpeq_b : GCCBuiltin<"__builtin_ia32_pcmpeqb128">,
409               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
410                          llvm_v16i8_ty], [IntrNoMem]>;
411   def int_x86_sse2_pcmpeq_w : GCCBuiltin<"__builtin_ia32_pcmpeqw128">,
412               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
413                          llvm_v8i16_ty], [IntrNoMem]>;
414   def int_x86_sse2_pcmpeq_d : GCCBuiltin<"__builtin_ia32_pcmpeqd128">,
415               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
416                          llvm_v4i32_ty], [IntrNoMem]>;
417   def int_x86_sse2_pcmpgt_b : GCCBuiltin<"__builtin_ia32_pcmpgtb128">,
418               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
419                          llvm_v16i8_ty], [IntrNoMem]>;
420   def int_x86_sse2_pcmpgt_w : GCCBuiltin<"__builtin_ia32_pcmpgtw128">,
421               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
422                          llvm_v8i16_ty], [IntrNoMem]>;
423   def int_x86_sse2_pcmpgt_d : GCCBuiltin<"__builtin_ia32_pcmpgtd128">,
424               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
425                          llvm_v4i32_ty], [IntrNoMem]>;
426 }
427
428 // Conversion ops
429 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
430   def int_x86_sse2_cvtdq2pd : GCCBuiltin<"__builtin_ia32_cvtdq2pd">,
431               Intrinsic<[llvm_v2f64_ty], [llvm_v4i32_ty], [IntrNoMem]>;
432   def int_x86_sse2_cvtdq2ps : GCCBuiltin<"__builtin_ia32_cvtdq2ps">,
433               Intrinsic<[llvm_v4f32_ty], [llvm_v4i32_ty], [IntrNoMem]>;
434   def int_x86_sse2_cvtpd2dq : GCCBuiltin<"__builtin_ia32_cvtpd2dq">,
435               Intrinsic<[llvm_v4i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
436   def int_x86_sse2_cvttpd2dq : GCCBuiltin<"__builtin_ia32_cvttpd2dq">,
437               Intrinsic<[llvm_v4i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
438   def int_x86_sse2_cvtpd2ps : GCCBuiltin<"__builtin_ia32_cvtpd2ps">,
439               Intrinsic<[llvm_v4f32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
440   def int_x86_sse2_cvtps2dq : GCCBuiltin<"__builtin_ia32_cvtps2dq">,
441               Intrinsic<[llvm_v4i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
442   def int_x86_sse2_cvttps2dq : GCCBuiltin<"__builtin_ia32_cvttps2dq">,
443               Intrinsic<[llvm_v4i32_ty], [llvm_v4f32_ty], [IntrNoMem]>;
444   def int_x86_sse2_cvtps2pd : GCCBuiltin<"__builtin_ia32_cvtps2pd">,
445               Intrinsic<[llvm_v2f64_ty], [llvm_v4f32_ty], [IntrNoMem]>;
446   def int_x86_sse2_cvtsd2si : GCCBuiltin<"__builtin_ia32_cvtsd2si">,
447               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
448   def int_x86_sse2_cvtsd2si64 : GCCBuiltin<"__builtin_ia32_cvtsd2si64">,
449               Intrinsic<[llvm_i64_ty], [llvm_v2f64_ty], [IntrNoMem]>;
450   def int_x86_sse2_cvttsd2si : GCCBuiltin<"__builtin_ia32_cvttsd2si">,
451               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
452   def int_x86_sse2_cvttsd2si64 : GCCBuiltin<"__builtin_ia32_cvttsd2si64">,
453               Intrinsic<[llvm_i64_ty], [llvm_v2f64_ty], [IntrNoMem]>;
454   def int_x86_sse2_cvtsi2sd : GCCBuiltin<"__builtin_ia32_cvtsi2sd">,
455               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
456                          llvm_i32_ty], [IntrNoMem]>;
457   def int_x86_sse2_cvtsi642sd : GCCBuiltin<"__builtin_ia32_cvtsi642sd">,
458               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
459                          llvm_i64_ty], [IntrNoMem]>;
460   def int_x86_sse2_cvtsd2ss : GCCBuiltin<"__builtin_ia32_cvtsd2ss">,
461               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
462                          llvm_v2f64_ty], [IntrNoMem]>;
463   def int_x86_sse2_cvtss2sd : GCCBuiltin<"__builtin_ia32_cvtss2sd">,
464               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
465                          llvm_v4f32_ty], [IntrNoMem]>;
466   def int_x86_sse_cvtpd2pi : GCCBuiltin<"__builtin_ia32_cvtpd2pi">,
467               Intrinsic<[llvm_v2i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
468   def int_x86_sse_cvttpd2pi: GCCBuiltin<"__builtin_ia32_cvttpd2pi">,
469               Intrinsic<[llvm_v2i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
470   def int_x86_sse_cvtpi2pd : GCCBuiltin<"__builtin_ia32_cvtpi2pd">,
471               Intrinsic<[llvm_v2f64_ty], [llvm_v2i32_ty], [IntrNoMem]>;
472 }
473
474 // SIMD load ops
475 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
476   def int_x86_sse2_loadu_pd : GCCBuiltin<"__builtin_ia32_loadupd">,
477               Intrinsic<[llvm_v2f64_ty], [llvm_ptr_ty], [IntrReadMem]>;
478   def int_x86_sse2_loadu_dq : GCCBuiltin<"__builtin_ia32_loaddqu">,
479               Intrinsic<[llvm_v16i8_ty], [llvm_ptr_ty], [IntrReadMem]>;
480 }
481
482 // SIMD store ops
483 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
484   def int_x86_sse2_storeu_pd : GCCBuiltin<"__builtin_ia32_storeupd">,
485               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
486                          llvm_v2f64_ty], [IntrWriteMem]>;
487   def int_x86_sse2_storeu_dq : GCCBuiltin<"__builtin_ia32_storedqu">,
488               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
489                          llvm_v16i8_ty], [IntrWriteMem]>;
490   def int_x86_sse2_storel_dq : GCCBuiltin<"__builtin_ia32_storelv4si">,
491               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
492                          llvm_v4i32_ty], [IntrWriteMem]>;
493 }
494
495 // Cacheability support ops
496 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
497   def int_x86_sse2_movnt_dq : GCCBuiltin<"__builtin_ia32_movntdq">,
498               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
499                          llvm_v2i64_ty], [IntrWriteMem]>;
500   def int_x86_sse2_movnt_pd : GCCBuiltin<"__builtin_ia32_movntpd">,
501               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
502                          llvm_v2f64_ty], [IntrWriteMem]>;
503   def int_x86_sse2_movnt_i : GCCBuiltin<"__builtin_ia32_movnti">,
504               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
505                          llvm_i32_ty], [IntrWriteMem]>;
506 }
507
508 // Misc.
509 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
510   def int_x86_sse2_packsswb_128 : GCCBuiltin<"__builtin_ia32_packsswb128">,
511               Intrinsic<[llvm_v16i8_ty], [llvm_v8i16_ty,
512                          llvm_v8i16_ty], [IntrNoMem]>;
513   def int_x86_sse2_packssdw_128 : GCCBuiltin<"__builtin_ia32_packssdw128">,
514               Intrinsic<[llvm_v8i16_ty], [llvm_v4i32_ty,
515                          llvm_v4i32_ty], [IntrNoMem]>;
516   def int_x86_sse2_packuswb_128 : GCCBuiltin<"__builtin_ia32_packuswb128">,
517               Intrinsic<[llvm_v16i8_ty], [llvm_v8i16_ty,
518                          llvm_v8i16_ty], [IntrNoMem]>;
519   def int_x86_sse2_movmsk_pd : GCCBuiltin<"__builtin_ia32_movmskpd">,
520               Intrinsic<[llvm_i32_ty], [llvm_v2f64_ty], [IntrNoMem]>;
521   def int_x86_sse2_pmovmskb_128 : GCCBuiltin<"__builtin_ia32_pmovmskb128">,
522               Intrinsic<[llvm_i32_ty], [llvm_v16i8_ty], [IntrNoMem]>;
523   def int_x86_sse2_maskmov_dqu : GCCBuiltin<"__builtin_ia32_maskmovdqu">,
524               Intrinsic<[llvm_void_ty], [llvm_v16i8_ty,
525                          llvm_v16i8_ty, llvm_ptr_ty], [IntrWriteMem]>;
526   def int_x86_sse2_clflush : GCCBuiltin<"__builtin_ia32_clflush">,
527               Intrinsic<[llvm_void_ty], [llvm_ptr_ty], [IntrWriteMem]>;
528   def int_x86_sse2_lfence : GCCBuiltin<"__builtin_ia32_lfence">,
529               Intrinsic<[llvm_void_ty], [], [IntrWriteMem]>;
530   def int_x86_sse2_mfence : GCCBuiltin<"__builtin_ia32_mfence">,
531               Intrinsic<[llvm_void_ty], [], [IntrWriteMem]>;
532 }
533
534 //===----------------------------------------------------------------------===//
535 // SSE3
536
537 // Addition / subtraction ops.
538 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
539   def int_x86_sse3_addsub_ps : GCCBuiltin<"__builtin_ia32_addsubps">,
540               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
541                          llvm_v4f32_ty], [IntrNoMem]>;
542   def int_x86_sse3_addsub_pd : GCCBuiltin<"__builtin_ia32_addsubpd">,
543               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
544                          llvm_v2f64_ty], [IntrNoMem]>;
545 }
546
547 // Horizontal ops.
548 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
549   def int_x86_sse3_hadd_ps : GCCBuiltin<"__builtin_ia32_haddps">,
550               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
551                          llvm_v4f32_ty], [IntrNoMem]>;
552   def int_x86_sse3_hadd_pd : GCCBuiltin<"__builtin_ia32_haddpd">,
553               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
554                          llvm_v2f64_ty], [IntrNoMem]>;
555   def int_x86_sse3_hsub_ps : GCCBuiltin<"__builtin_ia32_hsubps">,
556               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
557                          llvm_v4f32_ty], [IntrNoMem]>;
558   def int_x86_sse3_hsub_pd : GCCBuiltin<"__builtin_ia32_hsubpd">,
559               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
560                          llvm_v2f64_ty], [IntrNoMem]>;
561 }
562
563 // Specialized unaligned load.
564 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
565   def int_x86_sse3_ldu_dq : GCCBuiltin<"__builtin_ia32_lddqu">,
566               Intrinsic<[llvm_v16i8_ty], [llvm_ptr_ty], [IntrReadMem]>;
567 }
568
569 // Thread synchronization ops.
570 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
571   def int_x86_sse3_monitor : GCCBuiltin<"__builtin_ia32_monitor">,
572               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
573                          llvm_i32_ty, llvm_i32_ty], [IntrWriteMem]>;
574   def int_x86_sse3_mwait : GCCBuiltin<"__builtin_ia32_mwait">,
575               Intrinsic<[llvm_void_ty], [llvm_i32_ty,
576                          llvm_i32_ty], [IntrWriteMem]>;
577 }
578
579 //===----------------------------------------------------------------------===//
580 // SSSE3
581
582 // Horizontal arithmetic ops
583 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
584   def int_x86_ssse3_phadd_w         : GCCBuiltin<"__builtin_ia32_phaddw">,
585               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
586                          llvm_v4i16_ty], [IntrNoMem]>;
587   def int_x86_ssse3_phadd_w_128     : GCCBuiltin<"__builtin_ia32_phaddw128">,
588               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
589                          llvm_v8i16_ty], [IntrNoMem]>;
590
591   def int_x86_ssse3_phadd_d         : GCCBuiltin<"__builtin_ia32_phaddd">,
592               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
593                          llvm_v2i32_ty], [IntrNoMem]>;
594   def int_x86_ssse3_phadd_d_128     : GCCBuiltin<"__builtin_ia32_phaddd128">,
595               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
596                          llvm_v4i32_ty], [IntrNoMem]>;
597
598   def int_x86_ssse3_phadd_sw        : GCCBuiltin<"__builtin_ia32_phaddsw">,
599               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
600                          llvm_v4i16_ty], [IntrNoMem]>;
601   def int_x86_ssse3_phadd_sw_128    : GCCBuiltin<"__builtin_ia32_phaddsw128">,
602               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
603                          llvm_v4i32_ty], [IntrNoMem]>;
604
605   def int_x86_ssse3_phsub_w         : GCCBuiltin<"__builtin_ia32_phsubw">,
606               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
607                          llvm_v4i16_ty], [IntrNoMem]>;
608   def int_x86_ssse3_phsub_w_128     : GCCBuiltin<"__builtin_ia32_phsubw128">,
609               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
610                          llvm_v8i16_ty], [IntrNoMem]>;
611
612   def int_x86_ssse3_phsub_d         : GCCBuiltin<"__builtin_ia32_phsubd">,
613               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
614                          llvm_v2i32_ty], [IntrNoMem]>;
615   def int_x86_ssse3_phsub_d_128     : GCCBuiltin<"__builtin_ia32_phsubd128">,
616               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
617                          llvm_v4i32_ty], [IntrNoMem]>;
618
619   def int_x86_ssse3_phsub_sw        : GCCBuiltin<"__builtin_ia32_phsubsw">,
620               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
621                          llvm_v4i16_ty], [IntrNoMem]>;
622   def int_x86_ssse3_phsub_sw_128    : GCCBuiltin<"__builtin_ia32_phsubsw128">,
623               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
624                          llvm_v8i16_ty], [IntrNoMem]>;
625
626   def int_x86_ssse3_pmadd_ub_sw     : GCCBuiltin<"__builtin_ia32_pmaddubsw">,
627               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
628                          llvm_v4i16_ty], [IntrNoMem]>;
629   def int_x86_ssse3_pmadd_ub_sw_128 : GCCBuiltin<"__builtin_ia32_pmaddubsw128">,
630               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
631                          llvm_v8i16_ty], [IntrNoMem]>;
632 }
633
634 // Packed multiply high with round and scale
635 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
636   def int_x86_ssse3_pmul_hr_sw      : GCCBuiltin<"__builtin_ia32_pmulhrsw">,
637               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
638                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
639   def int_x86_ssse3_pmul_hr_sw_128  : GCCBuiltin<"__builtin_ia32_pmulhrsw128">,
640               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
641                          llvm_v8i16_ty], [IntrNoMem, Commutative]>;
642 }
643
644 // Shuffle ops
645 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
646   def int_x86_ssse3_pshuf_b         : GCCBuiltin<"__builtin_ia32_pshufb">,
647               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
648                          llvm_v8i8_ty], [IntrNoMem]>;
649   def int_x86_ssse3_pshuf_b_128     : GCCBuiltin<"__builtin_ia32_pshufb128">,
650               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
651                          llvm_v16i8_ty], [IntrNoMem]>;
652 }
653
654 // Sign ops
655 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
656   def int_x86_ssse3_psign_b         : GCCBuiltin<"__builtin_ia32_psignb">,
657               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
658                          llvm_v8i8_ty], [IntrNoMem]>;
659   def int_x86_ssse3_psign_b_128     : GCCBuiltin<"__builtin_ia32_psignb128">,
660               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty,
661                          llvm_v16i8_ty], [IntrNoMem]>;
662
663   def int_x86_ssse3_psign_w         : GCCBuiltin<"__builtin_ia32_psignw">,
664               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
665                          llvm_v4i16_ty], [IntrNoMem]>;
666   def int_x86_ssse3_psign_w_128     : GCCBuiltin<"__builtin_ia32_psignw128">,
667               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty,
668                          llvm_v8i16_ty], [IntrNoMem]>;
669
670   def int_x86_ssse3_psign_d         : GCCBuiltin<"__builtin_ia32_psignd">,
671               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
672                          llvm_v2i32_ty], [IntrNoMem]>;
673   def int_x86_ssse3_psign_d_128     : GCCBuiltin<"__builtin_ia32_psignd128">,
674               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty,
675                          llvm_v4i32_ty], [IntrNoMem]>;
676 }
677
678 // Absolute value ops
679 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
680   def int_x86_ssse3_pabs_b     : GCCBuiltin<"__builtin_ia32_pabsb">,
681               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty], [IntrNoMem]>;
682   def int_x86_ssse3_pabs_b_128 : GCCBuiltin<"__builtin_ia32_pabsb128">,
683               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty], [IntrNoMem]>;
684
685   def int_x86_ssse3_pabs_w     : GCCBuiltin<"__builtin_ia32_pabsw">,
686               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty], [IntrNoMem]>;
687   def int_x86_ssse3_pabs_w_128 : GCCBuiltin<"__builtin_ia32_pabsw128">,
688               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty], [IntrNoMem]>;
689
690   def int_x86_ssse3_pabs_d     : GCCBuiltin<"__builtin_ia32_pabsd">,
691               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty], [IntrNoMem]>;
692   def int_x86_ssse3_pabs_d_128 : GCCBuiltin<"__builtin_ia32_pabsd128">,
693               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty], [IntrNoMem]>;
694 }
695
696 // Align ops
697 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
698   def int_x86_ssse3_palign_r        :
699               Intrinsic<[llvm_v1i64_ty], [llvm_v1i64_ty,
700                          llvm_v1i64_ty, llvm_i8_ty], [IntrNoMem]>;
701   def int_x86_ssse3_palign_r_128    :
702               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty,
703                          llvm_v2i64_ty, llvm_i8_ty], [IntrNoMem]>;
704 }
705
706 //===----------------------------------------------------------------------===//
707 // SSE4.1
708
709 // FP rounding ops
710 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
711   def int_x86_sse41_round_ss        : GCCBuiltin<"__builtin_ia32_roundss">,
712               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty, llvm_v4f32_ty,
713                          llvm_i32_ty], [IntrNoMem]>;
714   def int_x86_sse41_round_ps        : GCCBuiltin<"__builtin_ia32_roundps">,
715               Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty,
716                          llvm_i32_ty], [IntrNoMem]>;
717   def int_x86_sse41_round_sd        : GCCBuiltin<"__builtin_ia32_roundsd">,
718               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty, llvm_v2f64_ty,
719                          llvm_i32_ty], [IntrNoMem]>;
720   def int_x86_sse41_round_pd        : GCCBuiltin<"__builtin_ia32_roundpd">,
721               Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty,
722                          llvm_i32_ty], [IntrNoMem]>;
723 }
724
725 // Vector sign and zero extend
726 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
727   def int_x86_sse41_pmovsxbd        : GCCBuiltin<"__builtin_ia32_pmovsxbd128">,
728               Intrinsic<[llvm_v4i32_ty], [llvm_v16i8_ty],
729                         [IntrNoMem]>;
730   def int_x86_sse41_pmovsxbq        : GCCBuiltin<"__builtin_ia32_pmovsxbq128">,
731               Intrinsic<[llvm_v2i64_ty], [llvm_v16i8_ty],
732                         [IntrNoMem]>;
733   def int_x86_sse41_pmovsxbw        : GCCBuiltin<"__builtin_ia32_pmovsxbw128">,
734               Intrinsic<[llvm_v8i16_ty], [llvm_v16i8_ty],
735                         [IntrNoMem]>;
736   def int_x86_sse41_pmovsxdq        : GCCBuiltin<"__builtin_ia32_pmovsxdq128">,
737               Intrinsic<[llvm_v2i64_ty], [llvm_v4i32_ty],
738                         [IntrNoMem]>;
739   def int_x86_sse41_pmovsxwd        : GCCBuiltin<"__builtin_ia32_pmovsxwd128">,
740               Intrinsic<[llvm_v4i32_ty], [llvm_v8i16_ty],
741                         [IntrNoMem]>;
742   def int_x86_sse41_pmovsxwq        : GCCBuiltin<"__builtin_ia32_pmovsxwq128">,
743               Intrinsic<[llvm_v2i64_ty], [llvm_v8i16_ty],
744                         [IntrNoMem]>;
745   def int_x86_sse41_pmovzxbd        : GCCBuiltin<"__builtin_ia32_pmovzxbd128">,
746               Intrinsic<[llvm_v4i32_ty], [llvm_v16i8_ty],
747                         [IntrNoMem]>;
748   def int_x86_sse41_pmovzxbq        : GCCBuiltin<"__builtin_ia32_pmovzxbq128">,
749               Intrinsic<[llvm_v2i64_ty], [llvm_v16i8_ty],
750                         [IntrNoMem]>;
751   def int_x86_sse41_pmovzxbw        : GCCBuiltin<"__builtin_ia32_pmovzxbw128">,
752               Intrinsic<[llvm_v8i16_ty], [llvm_v16i8_ty],
753                         [IntrNoMem]>;
754   def int_x86_sse41_pmovzxdq        : GCCBuiltin<"__builtin_ia32_pmovzxdq128">,
755               Intrinsic<[llvm_v2i64_ty], [llvm_v4i32_ty],
756                         [IntrNoMem]>;
757   def int_x86_sse41_pmovzxwd        : GCCBuiltin<"__builtin_ia32_pmovzxwd128">,
758               Intrinsic<[llvm_v4i32_ty], [llvm_v8i16_ty],
759                         [IntrNoMem]>;
760   def int_x86_sse41_pmovzxwq        : GCCBuiltin<"__builtin_ia32_pmovzxwq128">,
761               Intrinsic<[llvm_v2i64_ty], [llvm_v8i16_ty],
762                         [IntrNoMem]>;
763 }
764
765 // Vector min element
766 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
767   def int_x86_sse41_phminposuw     : GCCBuiltin<"__builtin_ia32_phminposuw128">,
768               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty],
769                         [IntrNoMem]>;
770 }
771
772 // Vector compare, min, max
773 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
774   def int_x86_sse41_pcmpeqq         : GCCBuiltin<"__builtin_ia32_pcmpeqq">,
775               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty, llvm_v2i64_ty],
776                         [IntrNoMem, Commutative]>;
777   def int_x86_sse42_pcmpgtq         : GCCBuiltin<"__builtin_ia32_pcmpgtq">,
778               Intrinsic<[llvm_v2i64_ty], [llvm_v2i64_ty, llvm_v2i64_ty],
779                         [IntrNoMem]>;
780   def int_x86_sse41_pmaxsb          : GCCBuiltin<"__builtin_ia32_pmaxsb128">,
781               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty, llvm_v16i8_ty],
782                         [IntrNoMem, Commutative]>;
783   def int_x86_sse41_pmaxsd          : GCCBuiltin<"__builtin_ia32_pmaxsd128">,
784               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
785                         [IntrNoMem, Commutative]>;
786   def int_x86_sse41_pmaxud          : GCCBuiltin<"__builtin_ia32_pmaxud128">,
787               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
788                         [IntrNoMem, Commutative]>;
789   def int_x86_sse41_pmaxuw          : GCCBuiltin<"__builtin_ia32_pmaxuw128">,
790               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty, llvm_v8i16_ty],
791                         [IntrNoMem, Commutative]>;
792   def int_x86_sse41_pminsb          : GCCBuiltin<"__builtin_ia32_pminsb128">,
793               Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty, llvm_v16i8_ty],
794                         [IntrNoMem, Commutative]>;
795   def int_x86_sse41_pminsd          : GCCBuiltin<"__builtin_ia32_pminsd128">,
796               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
797                         [IntrNoMem, Commutative]>;
798   def int_x86_sse41_pminud          : GCCBuiltin<"__builtin_ia32_pminud128">,
799               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
800                         [IntrNoMem, Commutative]>;
801   def int_x86_sse41_pminuw          : GCCBuiltin<"__builtin_ia32_pminuw128">,
802               Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty, llvm_v8i16_ty],
803                         [IntrNoMem, Commutative]>;
804 }
805
806 // Vector pack
807 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
808   def int_x86_sse41_packusdw        : GCCBuiltin<"__builtin_ia32_packusdw128">,
809               Intrinsic<[llvm_v8i16_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
810                         [IntrNoMem]>;
811 }
812
813 // Vector multiply
814 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
815   def int_x86_sse41_pmuldq          : GCCBuiltin<"__builtin_ia32_pmuldq128">,
816               Intrinsic<[llvm_v2i64_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
817                         [IntrNoMem, Commutative]>;
818   def int_x86_sse41_pmulld          : GCCBuiltin<"__builtin_ia32_pmulld128">,
819               Intrinsic<[llvm_v4i32_ty], [llvm_v4i32_ty, llvm_v4i32_ty],
820                         [IntrNoMem, Commutative]>;
821 }
822
823 // Vector extract
824 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
825   def int_x86_sse41_pextrb         :
826               Intrinsic<[llvm_i32_ty], [llvm_v16i8_ty, llvm_i32_ty],
827                         [IntrNoMem]>;
828   def int_x86_sse41_pextrd         :
829               Intrinsic<[llvm_i32_ty], [llvm_v4i32_ty, llvm_i32_ty],
830                         [IntrNoMem]>;
831   def int_x86_sse41_pextrq         :
832               Intrinsic<[llvm_i64_ty], [llvm_v2i64_ty, llvm_i32_ty],
833                         [IntrNoMem]>;
834   def int_x86_sse41_extractps      : GCCBuiltin<"__builtin_ia32_extractps128">,
835               Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty, llvm_i32_ty],
836                         [IntrNoMem]>;
837 }
838
839 // Vector insert
840 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
841   def int_x86_sse41_insertps       : GCCBuiltin<"__builtin_ia32_insertps128">,
842           Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty, llvm_v4f32_ty,llvm_i32_ty],
843                     [IntrNoMem]>;
844 }
845
846 // Vector blend
847 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
848   def int_x86_sse41_pblendvb         : GCCBuiltin<"__builtin_ia32_pblendvb128">,
849         Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty, llvm_v16i8_ty,llvm_v16i8_ty],
850                   [IntrNoMem]>;
851   def int_x86_sse41_pblendw          : GCCBuiltin<"__builtin_ia32_pblendw128">,
852         Intrinsic<[llvm_v8i16_ty], [llvm_v8i16_ty, llvm_v8i16_ty, llvm_i32_ty],
853                   [IntrNoMem]>;
854   def int_x86_sse41_blendpd          : GCCBuiltin<"__builtin_ia32_blendpd">,
855         Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty, llvm_v2f64_ty, llvm_i32_ty],
856                   [IntrNoMem]>;
857   def int_x86_sse41_blendps          : GCCBuiltin<"__builtin_ia32_blendps">,
858         Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty, llvm_v4f32_ty, llvm_i32_ty],
859                   [IntrNoMem]>;
860   def int_x86_sse41_blendvpd         : GCCBuiltin<"__builtin_ia32_blendvpd">,
861         Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty, llvm_v2f64_ty,llvm_v2f64_ty],
862                   [IntrNoMem]>;
863   def int_x86_sse41_blendvps         : GCCBuiltin<"__builtin_ia32_blendvps">,
864         Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty, llvm_v4f32_ty,llvm_v4f32_ty],
865                   [IntrNoMem]>;
866 }
867
868 // Vector dot product
869 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
870   def int_x86_sse41_dppd            : GCCBuiltin<"__builtin_ia32_dppd">,
871           Intrinsic<[llvm_v2f64_ty], [llvm_v2f64_ty, llvm_v2f64_ty,llvm_i32_ty],
872                     [IntrNoMem, Commutative]>;
873   def int_x86_sse41_dpps            : GCCBuiltin<"__builtin_ia32_dpps">,
874           Intrinsic<[llvm_v4f32_ty], [llvm_v4f32_ty, llvm_v4f32_ty,llvm_i32_ty],
875                     [IntrNoMem, Commutative]>;
876 }
877
878 // Vector sum of absolute differences
879 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
880   def int_x86_sse41_mpsadbw         : GCCBuiltin<"__builtin_ia32_mpsadbw128">,
881           Intrinsic<[llvm_v16i8_ty], [llvm_v16i8_ty, llvm_v16i8_ty,llvm_i32_ty],
882                     [IntrNoMem, Commutative]>;
883 }
884
885 // Cacheability support ops
886 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
887   def int_x86_sse41_movntdqa        : GCCBuiltin<"__builtin_ia32_movntdqa">,
888           Intrinsic<[llvm_v2i64_ty], [llvm_ptr_ty], [IntrReadMem]>;
889 }
890
891 // Test instruction with bitwise comparison.
892 let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.".
893   def int_x86_sse41_ptestz          : GCCBuiltin<"__builtin_ia32_ptestz128">,
894           Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty, llvm_v4f32_ty],
895                     [IntrNoMem]>;
896   def int_x86_sse41_ptestc          : GCCBuiltin<"__builtin_ia32_ptestc128">,
897           Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty, llvm_v4f32_ty],
898                     [IntrNoMem]>;
899   def int_x86_sse41_ptestnzc        : GCCBuiltin<"__builtin_ia32_ptestnzc128">,
900           Intrinsic<[llvm_i32_ty], [llvm_v4f32_ty, llvm_v4f32_ty],
901                     [IntrNoMem]>;
902 }
903
904 //===----------------------------------------------------------------------===//
905 // SSE4.2
906
907 // Miscellaneous
908 // CRC Instruction
909 let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.".
910   def int_x86_sse42_crc32_8         : GCCBuiltin<"__builtin_ia32_crc32qi">,
911           Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i8_ty],
912                     [IntrNoMem]>;
913   def int_x86_sse42_crc32_16         : GCCBuiltin<"__builtin_ia32_crc32hi">,
914           Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i16_ty],
915                     [IntrNoMem]>;
916   def int_x86_sse42_crc32_32         : GCCBuiltin<"__builtin_ia32_crc32si">,
917           Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_i32_ty],
918                     [IntrNoMem]>;
919   def int_x86_sse42_crc32_64         : GCCBuiltin<"__builtin_ia32_crc32di">,
920           Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty],
921                     [IntrNoMem]>;
922 }
923
924 // String/text processing ops.
925 let TargetPrefix = "x86" in { // All intrinsics start with "llvm.x86.".
926   def int_x86_sse42_pcmpistrm128  : GCCBuiltin<"__builtin_ia32_pcmpistrm128">,
927           Intrinsic<[llvm_v16i8_ty],
928                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
929                     [IntrNoMem]>;
930   def int_x86_sse42_pcmpistri128  : GCCBuiltin<"__builtin_ia32_pcmpistri128">,
931           Intrinsic<[llvm_i32_ty],
932                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
933                     [IntrNoMem]>;
934   def int_x86_sse42_pcmpistria128 : GCCBuiltin<"__builtin_ia32_pcmpistria128">,
935           Intrinsic<[llvm_i32_ty],
936                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
937                     [IntrNoMem]>;
938   def int_x86_sse42_pcmpistric128 : GCCBuiltin<"__builtin_ia32_pcmpistric128">,
939           Intrinsic<[llvm_i32_ty],
940                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
941                     [IntrNoMem]>;
942   def int_x86_sse42_pcmpistrio128 : GCCBuiltin<"__builtin_ia32_pcmpistrio128">,
943           Intrinsic<[llvm_i32_ty],
944                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
945                     [IntrNoMem]>;
946   def int_x86_sse42_pcmpistris128 : GCCBuiltin<"__builtin_ia32_pcmpistris128">,
947           Intrinsic<[llvm_i32_ty],
948                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
949                     [IntrNoMem]>;
950   def int_x86_sse42_pcmpistriz128 : GCCBuiltin<"__builtin_ia32_pcmpistriz128">,
951           Intrinsic<[llvm_i32_ty],
952                     [llvm_v16i8_ty, llvm_v16i8_ty, llvm_i8_ty],
953                     [IntrNoMem]>;
954   def int_x86_sse42_pcmpestrm128  : GCCBuiltin<"__builtin_ia32_pcmpestrm128">,
955           Intrinsic<[llvm_v16i8_ty],
956                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
957                      llvm_i8_ty],
958                     [IntrNoMem]>;
959   def int_x86_sse42_pcmpestri128  : GCCBuiltin<"__builtin_ia32_pcmpestri128">,
960           Intrinsic<[llvm_i32_ty],
961                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
962                      llvm_i8_ty],
963                     [IntrNoMem]>;
964   def int_x86_sse42_pcmpestria128 : GCCBuiltin<"__builtin_ia32_pcmpestria128">,
965           Intrinsic<[llvm_i32_ty],
966                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
967                      llvm_i8_ty],
968                     [IntrNoMem]>;
969   def int_x86_sse42_pcmpestric128 : GCCBuiltin<"__builtin_ia32_pcmpestric128">,
970           Intrinsic<[llvm_i32_ty],
971                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
972                      llvm_i8_ty],
973                     [IntrNoMem]>;
974   def int_x86_sse42_pcmpestrio128 : GCCBuiltin<"__builtin_ia32_pcmpestrio128">,
975           Intrinsic<[llvm_i32_ty],
976                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
977                      llvm_i8_ty],
978                     [IntrNoMem]>;
979   def int_x86_sse42_pcmpestris128 : GCCBuiltin<"__builtin_ia32_pcmpestris128">,
980           Intrinsic<[llvm_i32_ty],
981                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
982                      llvm_i8_ty],
983                     [IntrNoMem]>;
984   def int_x86_sse42_pcmpestriz128 : GCCBuiltin<"__builtin_ia32_pcmpestriz128">,
985           Intrinsic<[llvm_i32_ty],
986                     [llvm_v16i8_ty, llvm_i32_ty, llvm_v16i8_ty, llvm_i32_ty,
987                      llvm_i8_ty],
988                     [IntrNoMem]>;
989 }
990
991 //===----------------------------------------------------------------------===//
992 // MMX
993
994 // Empty MMX state op.
995 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
996   def int_x86_mmx_emms  : GCCBuiltin<"__builtin_ia32_emms">,
997               Intrinsic<[llvm_void_ty], [], [IntrWriteMem]>;
998   def int_x86_mmx_femms : GCCBuiltin<"__builtin_ia32_femms">,
999               Intrinsic<[llvm_void_ty], [], [IntrWriteMem]>;
1000 }
1001
1002 // Integer arithmetic ops.
1003 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
1004   // Addition
1005   def int_x86_mmx_padds_b : GCCBuiltin<"__builtin_ia32_paddsb">,
1006               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1007                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1008   def int_x86_mmx_padds_w : GCCBuiltin<"__builtin_ia32_paddsw">,
1009               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1010                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1011
1012   def int_x86_mmx_paddus_b : GCCBuiltin<"__builtin_ia32_paddusb">,
1013               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1014                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1015   def int_x86_mmx_paddus_w : GCCBuiltin<"__builtin_ia32_paddusw">,
1016               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1017                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1018
1019   // Subtraction
1020   def int_x86_mmx_psubs_b : GCCBuiltin<"__builtin_ia32_psubsb">,
1021               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1022                          llvm_v8i8_ty], [IntrNoMem]>;
1023   def int_x86_mmx_psubs_w : GCCBuiltin<"__builtin_ia32_psubsw">,
1024               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1025                          llvm_v4i16_ty], [IntrNoMem]>;
1026
1027   def int_x86_mmx_psubus_b : GCCBuiltin<"__builtin_ia32_psubusb">,
1028               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1029                          llvm_v8i8_ty], [IntrNoMem]>;
1030   def int_x86_mmx_psubus_w : GCCBuiltin<"__builtin_ia32_psubusw">,
1031               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1032                          llvm_v4i16_ty], [IntrNoMem]>;
1033
1034   // Multiplication
1035   def int_x86_mmx_pmulh_w : GCCBuiltin<"__builtin_ia32_pmulhw">,
1036               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1037                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1038   def int_x86_mmx_pmulhu_w : GCCBuiltin<"__builtin_ia32_pmulhuw">,
1039               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1040                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1041   def int_x86_mmx_pmulu_dq : GCCBuiltin<"__builtin_ia32_pmuludq">,
1042               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1043                          llvm_v2i32_ty], [IntrNoMem, Commutative]>;
1044   def int_x86_mmx_pmadd_wd : GCCBuiltin<"__builtin_ia32_pmaddwd">,
1045               Intrinsic<[llvm_v2i32_ty], [llvm_v4i16_ty,
1046                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1047
1048   // Averages
1049   def int_x86_mmx_pavg_b : GCCBuiltin<"__builtin_ia32_pavgb">,
1050               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1051                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1052   def int_x86_mmx_pavg_w : GCCBuiltin<"__builtin_ia32_pavgw">,
1053               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1054                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1055
1056   // Maximum
1057   def int_x86_mmx_pmaxu_b : GCCBuiltin<"__builtin_ia32_pmaxub">,
1058               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1059                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1060   def int_x86_mmx_pmaxs_w : GCCBuiltin<"__builtin_ia32_pmaxsw">,
1061               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1062                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1063
1064   // Minimum
1065   def int_x86_mmx_pminu_b : GCCBuiltin<"__builtin_ia32_pminub">,
1066               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1067                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1068   def int_x86_mmx_pmins_w : GCCBuiltin<"__builtin_ia32_pminsw">,
1069               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1070                          llvm_v4i16_ty], [IntrNoMem, Commutative]>;
1071
1072   // Packed sum of absolute differences
1073   def int_x86_mmx_psad_bw : GCCBuiltin<"__builtin_ia32_psadbw">,
1074               Intrinsic<[llvm_v4i16_ty], [llvm_v8i8_ty,
1075                          llvm_v8i8_ty], [IntrNoMem, Commutative]>;
1076 }
1077
1078 // Integer shift ops.
1079 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
1080   // Shift left logical
1081   def int_x86_mmx_psll_w : GCCBuiltin<"__builtin_ia32_psllw">,
1082               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1083                          llvm_v1i64_ty], [IntrNoMem]>;
1084   def int_x86_mmx_psll_d : GCCBuiltin<"__builtin_ia32_pslld">,
1085               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1086                          llvm_v1i64_ty], [IntrNoMem]>;
1087   def int_x86_mmx_psll_q : GCCBuiltin<"__builtin_ia32_psllq">,
1088               Intrinsic<[llvm_v1i64_ty], [llvm_v1i64_ty,
1089                          llvm_v1i64_ty], [IntrNoMem]>;
1090
1091   def int_x86_mmx_psrl_w : GCCBuiltin<"__builtin_ia32_psrlw">,
1092               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1093                          llvm_v1i64_ty], [IntrNoMem]>;
1094   def int_x86_mmx_psrl_d : GCCBuiltin<"__builtin_ia32_psrld">,
1095               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1096                          llvm_v1i64_ty], [IntrNoMem]>;
1097   def int_x86_mmx_psrl_q : GCCBuiltin<"__builtin_ia32_psrlq">,
1098               Intrinsic<[llvm_v1i64_ty], [llvm_v1i64_ty,
1099                          llvm_v1i64_ty], [IntrNoMem]>;
1100
1101   def int_x86_mmx_psra_w : GCCBuiltin<"__builtin_ia32_psraw">,
1102               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1103                          llvm_v1i64_ty], [IntrNoMem]>;
1104   def int_x86_mmx_psra_d : GCCBuiltin<"__builtin_ia32_psrad">,
1105               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1106                          llvm_v1i64_ty], [IntrNoMem]>;
1107
1108   def int_x86_mmx_pslli_w : GCCBuiltin<"__builtin_ia32_psllwi">,
1109               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1110                          llvm_i32_ty], [IntrNoMem]>;
1111   def int_x86_mmx_pslli_d : GCCBuiltin<"__builtin_ia32_pslldi">,
1112               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1113                          llvm_i32_ty], [IntrNoMem]>;
1114   def int_x86_mmx_pslli_q : GCCBuiltin<"__builtin_ia32_psllqi">,
1115               Intrinsic<[llvm_v1i64_ty], [llvm_v1i64_ty,
1116                          llvm_i32_ty], [IntrNoMem]>;
1117
1118   def int_x86_mmx_psrli_w : GCCBuiltin<"__builtin_ia32_psrlwi">,
1119               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1120                          llvm_i32_ty], [IntrNoMem]>;
1121   def int_x86_mmx_psrli_d : GCCBuiltin<"__builtin_ia32_psrldi">,
1122               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1123                          llvm_i32_ty], [IntrNoMem]>;
1124   def int_x86_mmx_psrli_q : GCCBuiltin<"__builtin_ia32_psrlqi">,
1125               Intrinsic<[llvm_v1i64_ty], [llvm_v1i64_ty,
1126                          llvm_i32_ty], [IntrNoMem]>;
1127
1128   def int_x86_mmx_psrai_w : GCCBuiltin<"__builtin_ia32_psrawi">,
1129               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1130                          llvm_i32_ty], [IntrNoMem]>;
1131   def int_x86_mmx_psrai_d : GCCBuiltin<"__builtin_ia32_psradi">,
1132               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1133                          llvm_i32_ty], [IntrNoMem]>;
1134 }
1135
1136 // Pack ops.
1137 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
1138   def int_x86_mmx_packsswb : GCCBuiltin<"__builtin_ia32_packsswb">,
1139               Intrinsic<[llvm_v8i8_ty], [llvm_v4i16_ty,
1140                          llvm_v4i16_ty], [IntrNoMem]>;
1141   def int_x86_mmx_packssdw : GCCBuiltin<"__builtin_ia32_packssdw">,
1142               Intrinsic<[llvm_v4i16_ty], [llvm_v2i32_ty,
1143                          llvm_v2i32_ty], [IntrNoMem]>;
1144   def int_x86_mmx_packuswb : GCCBuiltin<"__builtin_ia32_packuswb">,
1145               Intrinsic<[llvm_v8i8_ty], [llvm_v4i16_ty,
1146                          llvm_v4i16_ty], [IntrNoMem]>;
1147 }
1148
1149 // Integer comparison ops
1150 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
1151   def int_x86_mmx_pcmpeq_b : GCCBuiltin<"__builtin_ia32_pcmpeqb">,
1152               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1153                          llvm_v8i8_ty], [IntrNoMem]>;
1154   def int_x86_mmx_pcmpeq_w : GCCBuiltin<"__builtin_ia32_pcmpeqw">,
1155               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1156                          llvm_v4i16_ty], [IntrNoMem]>;
1157   def int_x86_mmx_pcmpeq_d : GCCBuiltin<"__builtin_ia32_pcmpeqd">,
1158               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1159                          llvm_v2i32_ty], [IntrNoMem]>;
1160
1161   def int_x86_mmx_pcmpgt_b : GCCBuiltin<"__builtin_ia32_pcmpgtb">,
1162               Intrinsic<[llvm_v8i8_ty], [llvm_v8i8_ty,
1163                          llvm_v8i8_ty], [IntrNoMem]>;
1164   def int_x86_mmx_pcmpgt_w : GCCBuiltin<"__builtin_ia32_pcmpgtw">,
1165               Intrinsic<[llvm_v4i16_ty], [llvm_v4i16_ty,
1166                          llvm_v4i16_ty], [IntrNoMem]>;
1167   def int_x86_mmx_pcmpgt_d : GCCBuiltin<"__builtin_ia32_pcmpgtd">,
1168               Intrinsic<[llvm_v2i32_ty], [llvm_v2i32_ty,
1169                          llvm_v2i32_ty], [IntrNoMem]>;
1170 }
1171
1172 // Misc.
1173 let TargetPrefix = "x86" in {  // All intrinsics start with "llvm.x86.".
1174   def int_x86_mmx_maskmovq : GCCBuiltin<"__builtin_ia32_maskmovq">,
1175               Intrinsic<[llvm_void_ty],
1176                         [llvm_v8i8_ty, llvm_v8i8_ty, llvm_ptr_ty],
1177                         [IntrWriteMem]>;
1178
1179   def int_x86_mmx_pmovmskb : GCCBuiltin<"__builtin_ia32_pmovmskb">,
1180               Intrinsic<[llvm_i32_ty], [llvm_v8i8_ty], [IntrNoMem]>;
1181
1182   def int_x86_mmx_movnt_dq : GCCBuiltin<"__builtin_ia32_movntq">,
1183               Intrinsic<[llvm_void_ty], [llvm_ptr_ty,
1184                          llvm_v1i64_ty], [IntrWriteMem]>;
1185 }