1*67e74705SXin Li // Test frontend handling of nontemporal builtins.
2*67e74705SXin Li // RUN: %clang_cc1 -triple x86_64-apple-darwin -emit-llvm %s -o - | FileCheck %s
3*67e74705SXin Li
4*67e74705SXin Li signed char sc;
5*67e74705SXin Li unsigned char uc;
6*67e74705SXin Li signed short ss;
7*67e74705SXin Li unsigned short us;
8*67e74705SXin Li signed int si;
9*67e74705SXin Li unsigned int ui;
10*67e74705SXin Li signed long long sll;
11*67e74705SXin Li unsigned long long ull;
12*67e74705SXin Li float f1, f2;
13*67e74705SXin Li double d1, d2;
14*67e74705SXin Li float __attribute__((vector_size(16))) vf1, vf2;
15*67e74705SXin Li char __attribute__((vector_size(8))) vc1, vc2;
16*67e74705SXin Li bool b1, b2;
17*67e74705SXin Li
test_all_sizes(void)18*67e74705SXin Li void test_all_sizes(void) // CHECK-LABEL: test_all_sizes
19*67e74705SXin Li {
20*67e74705SXin Li __builtin_nontemporal_store(true, &b1); // CHECK: store i8 1, i8* @b1, align 1, !nontemporal
21*67e74705SXin Li __builtin_nontemporal_store(b1, &b2); // CHECK: store i8{{.*}}, align 1, !nontemporal
22*67e74705SXin Li __builtin_nontemporal_store(1, &uc); // CHECK: store i8{{.*}}align 1, !nontemporal
23*67e74705SXin Li __builtin_nontemporal_store(1, &sc); // CHECK: store i8{{.*}}align 1, !nontemporal
24*67e74705SXin Li __builtin_nontemporal_store(1, &us); // CHECK: store i16{{.*}}align 2, !nontemporal
25*67e74705SXin Li __builtin_nontemporal_store(1, &ss); // CHECK: store i16{{.*}}align 2, !nontemporal
26*67e74705SXin Li __builtin_nontemporal_store(1, &ui); // CHECK: store i32{{.*}}align 4, !nontemporal
27*67e74705SXin Li __builtin_nontemporal_store(1, &si); // CHECK: store i32{{.*}}align 4, !nontemporal
28*67e74705SXin Li __builtin_nontemporal_store(1, &ull); // CHECK: store i64{{.*}}align 8, !nontemporal
29*67e74705SXin Li __builtin_nontemporal_store(1, &sll); // CHECK: store i64{{.*}}align 8, !nontemporal
30*67e74705SXin Li __builtin_nontemporal_store(1.0, &f1); // CHECK: store float{{.*}}align 4, !nontemporal
31*67e74705SXin Li __builtin_nontemporal_store(1.0, &d1); // CHECK: store double{{.*}}align 8, !nontemporal
32*67e74705SXin Li __builtin_nontemporal_store(vf1, &vf2); // CHECK: store <4 x float>{{.*}}align 16, !nontemporal
33*67e74705SXin Li __builtin_nontemporal_store(vc1, &vc2); // CHECK: store <8 x i8>{{.*}}align 8, !nontemporal
34*67e74705SXin Li
35*67e74705SXin Li b1 = __builtin_nontemporal_load(&b2); // CHECK: load i8{{.*}}align 1, !nontemporal
36*67e74705SXin Li uc = __builtin_nontemporal_load(&sc); // CHECK: load i8{{.*}}align 1, !nontemporal
37*67e74705SXin Li sc = __builtin_nontemporal_load(&uc); // CHECK: load i8{{.*}}align 1, !nontemporal
38*67e74705SXin Li us = __builtin_nontemporal_load(&ss); // CHECK: load i16{{.*}}align 2, !nontemporal
39*67e74705SXin Li ss = __builtin_nontemporal_load(&us); // CHECK: load i16{{.*}}align 2, !nontemporal
40*67e74705SXin Li ui = __builtin_nontemporal_load(&si); // CHECK: load i32{{.*}}align 4, !nontemporal
41*67e74705SXin Li si = __builtin_nontemporal_load(&ui); // CHECK: load i32{{.*}}align 4, !nontemporal
42*67e74705SXin Li ull = __builtin_nontemporal_load(&sll); // CHECK: load i64{{.*}}align 8, !nontemporal
43*67e74705SXin Li sll = __builtin_nontemporal_load(&ull); // CHECK: load i64{{.*}}align 8, !nontemporal
44*67e74705SXin Li f1 = __builtin_nontemporal_load(&f2); // CHECK: load float{{.*}}align 4, !nontemporal
45*67e74705SXin Li d1 = __builtin_nontemporal_load(&d2); // CHECK: load double{{.*}}align 8, !nontemporal
46*67e74705SXin Li vf2 = __builtin_nontemporal_load(&vf1); // CHECK: load <4 x float>{{.*}}align 16, !nontemporal
47*67e74705SXin Li vc2 = __builtin_nontemporal_load(&vc1); // CHECK: load <8 x i8>{{.*}}align 8, !nontemporal
48*67e74705SXin Li }
49