xref: /aosp_15_r20/external/llvm/test/ExecutionEngine/test-interp-vec-loadstore.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: %lli -force-interpreter=true %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; CHECK: int test passed
3*9880d681SAndroid Build Coastguard Worker; CHECK: double test passed
4*9880d681SAndroid Build Coastguard Worker; CHECK: float test passed
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker@msg_int = internal global [17 x i8] c"int test passed\0A\00"
7*9880d681SAndroid Build Coastguard Worker@msg_double = internal global [20 x i8] c"double test passed\0A\00"
8*9880d681SAndroid Build Coastguard Worker@msg_float = internal global [19 x i8] c"float test passed\0A\00"
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8*, ...)
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Workerdefine i32 @main() {
13*9880d681SAndroid Build Coastguard Worker  %a = alloca <4 x i32>, align 16
14*9880d681SAndroid Build Coastguard Worker  %b = alloca <4 x double>, align 16
15*9880d681SAndroid Build Coastguard Worker  %c = alloca <4 x float>, align 16
16*9880d681SAndroid Build Coastguard Worker  %pint_0 = alloca i32
17*9880d681SAndroid Build Coastguard Worker  %pint_1 = alloca i32
18*9880d681SAndroid Build Coastguard Worker  %pint_2 = alloca i32
19*9880d681SAndroid Build Coastguard Worker  %pint_3 = alloca i32
20*9880d681SAndroid Build Coastguard Worker  %pdouble_0 = alloca double
21*9880d681SAndroid Build Coastguard Worker  %pdouble_1 = alloca double
22*9880d681SAndroid Build Coastguard Worker  %pdouble_2 = alloca double
23*9880d681SAndroid Build Coastguard Worker  %pdouble_3 = alloca double
24*9880d681SAndroid Build Coastguard Worker  %pfloat_0 = alloca float
25*9880d681SAndroid Build Coastguard Worker  %pfloat_1 = alloca float
26*9880d681SAndroid Build Coastguard Worker  %pfloat_2 = alloca float
27*9880d681SAndroid Build Coastguard Worker  %pfloat_3 = alloca float
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker  ; store constants 1,2,3,4 as vector
30*9880d681SAndroid Build Coastguard Worker  store <4 x i32> <i32 1, i32 2, i32 3, i32 4>, <4 x i32>* %a, align 16
31*9880d681SAndroid Build Coastguard Worker  ; store constants 1,2,3,4 as scalars
32*9880d681SAndroid Build Coastguard Worker  store i32 1, i32* %pint_0
33*9880d681SAndroid Build Coastguard Worker  store i32 2, i32* %pint_1
34*9880d681SAndroid Build Coastguard Worker  store i32 3, i32* %pint_2
35*9880d681SAndroid Build Coastguard Worker  store i32 4, i32* %pint_3
36*9880d681SAndroid Build Coastguard Worker
37*9880d681SAndroid Build Coastguard Worker  ; load stored scalars
38*9880d681SAndroid Build Coastguard Worker  %val_int0 = load i32, i32* %pint_0
39*9880d681SAndroid Build Coastguard Worker  %val_int1 = load i32, i32* %pint_1
40*9880d681SAndroid Build Coastguard Worker  %val_int2 = load i32, i32* %pint_2
41*9880d681SAndroid Build Coastguard Worker  %val_int3 = load i32, i32* %pint_3
42*9880d681SAndroid Build Coastguard Worker
43*9880d681SAndroid Build Coastguard Worker  ; load stored vector
44*9880d681SAndroid Build Coastguard Worker  %val0 = load <4 x i32> , <4 x i32> *%a, align 16
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Worker  ; extract integers from the loaded vector
47*9880d681SAndroid Build Coastguard Worker  %res_i32_0 = extractelement <4 x i32> %val0, i32 0
48*9880d681SAndroid Build Coastguard Worker  %res_i32_1 = extractelement <4 x i32> %val0, i32 1
49*9880d681SAndroid Build Coastguard Worker  %res_i32_2 = extractelement <4 x i32> %val0, i32 2
50*9880d681SAndroid Build Coastguard Worker  %res_i32_3 = extractelement <4 x i32> %val0, i32 3
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Worker  ; compare extracted data with stored constants
53*9880d681SAndroid Build Coastguard Worker  %test_result_int_0 = icmp eq i32 %res_i32_0, %val_int0
54*9880d681SAndroid Build Coastguard Worker  %test_result_int_1 = icmp eq i32 %res_i32_1, %val_int1
55*9880d681SAndroid Build Coastguard Worker  %test_result_int_2 = icmp eq i32 %res_i32_2, %val_int2
56*9880d681SAndroid Build Coastguard Worker  %test_result_int_3 = icmp eq i32 %res_i32_3, %val_int3
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Worker  %test_result_int_4 = icmp eq i32 %res_i32_0, %val_int3
59*9880d681SAndroid Build Coastguard Worker  %test_result_int_5 = icmp eq i32 %res_i32_1, %val_int2
60*9880d681SAndroid Build Coastguard Worker  %test_result_int_6 = icmp eq i32 %res_i32_2, %val_int1
61*9880d681SAndroid Build Coastguard Worker  %test_result_int_7 = icmp eq i32 %res_i32_3, %val_int0
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Worker  ; it should be TRUE
64*9880d681SAndroid Build Coastguard Worker  %A_i = or i1 %test_result_int_0, %test_result_int_4
65*9880d681SAndroid Build Coastguard Worker  %B_i = or i1 %test_result_int_1, %test_result_int_5
66*9880d681SAndroid Build Coastguard Worker  %C_i = or i1 %test_result_int_2, %test_result_int_6
67*9880d681SAndroid Build Coastguard Worker  %D_i = or i1 %test_result_int_3, %test_result_int_7
68*9880d681SAndroid Build Coastguard Worker  %E_i = and i1 %A_i, %B_i
69*9880d681SAndroid Build Coastguard Worker  %F_i = and i1 %C_i, %D_i
70*9880d681SAndroid Build Coastguard Worker  %res_i = and i1 %E_i, %F_i
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Worker  ; if TRUE print message
73*9880d681SAndroid Build Coastguard Worker  br i1 %res_i, label %Print_int, label %Double
74*9880d681SAndroid Build Coastguard WorkerPrint_int:
75*9880d681SAndroid Build Coastguard Worker  %ptr0 = getelementptr [17 x i8], [17 x i8]* @msg_int, i32 0, i32 0
76*9880d681SAndroid Build Coastguard Worker  call i32 (i8*,...) @printf(i8* %ptr0)
77*9880d681SAndroid Build Coastguard Worker  br label %Double
78*9880d681SAndroid Build Coastguard WorkerDouble:
79*9880d681SAndroid Build Coastguard Worker  store <4 x double> <double 5.0, double 6.0, double 7.0, double 8.0>, <4 x double>* %b, align 16
80*9880d681SAndroid Build Coastguard Worker  ; store constants as scalars
81*9880d681SAndroid Build Coastguard Worker  store double 5.0, double* %pdouble_0
82*9880d681SAndroid Build Coastguard Worker  store double 6.0, double* %pdouble_1
83*9880d681SAndroid Build Coastguard Worker  store double 7.0, double* %pdouble_2
84*9880d681SAndroid Build Coastguard Worker  store double 8.0, double* %pdouble_3
85*9880d681SAndroid Build Coastguard Worker
86*9880d681SAndroid Build Coastguard Worker  ; load stored vector
87*9880d681SAndroid Build Coastguard Worker  %val1 = load <4 x double> , <4 x double> *%b, align 16
88*9880d681SAndroid Build Coastguard Worker  ; load stored scalars
89*9880d681SAndroid Build Coastguard Worker  %val_double0 = load double, double* %pdouble_0
90*9880d681SAndroid Build Coastguard Worker  %val_double1 = load double, double* %pdouble_1
91*9880d681SAndroid Build Coastguard Worker  %val_double2 = load double, double* %pdouble_2
92*9880d681SAndroid Build Coastguard Worker  %val_double3 = load double, double* %pdouble_3
93*9880d681SAndroid Build Coastguard Worker
94*9880d681SAndroid Build Coastguard Worker  %res_double_0 = extractelement <4 x double> %val1, i32 0
95*9880d681SAndroid Build Coastguard Worker  %res_double_1 = extractelement <4 x double> %val1, i32 1
96*9880d681SAndroid Build Coastguard Worker  %res_double_2 = extractelement <4 x double> %val1, i32 2
97*9880d681SAndroid Build Coastguard Worker  %res_double_3 = extractelement <4 x double> %val1, i32 3
98*9880d681SAndroid Build Coastguard Worker
99*9880d681SAndroid Build Coastguard Worker  %test_result_double_0 = fcmp oeq double %res_double_0, %val_double0
100*9880d681SAndroid Build Coastguard Worker  %test_result_double_1 = fcmp oeq double %res_double_1, %val_double1
101*9880d681SAndroid Build Coastguard Worker  %test_result_double_2 = fcmp oeq double %res_double_2, %val_double2
102*9880d681SAndroid Build Coastguard Worker  %test_result_double_3 = fcmp oeq double %res_double_3, %val_double3
103*9880d681SAndroid Build Coastguard Worker
104*9880d681SAndroid Build Coastguard Worker  %test_result_double_4 = fcmp oeq double %res_double_0, %val_double3
105*9880d681SAndroid Build Coastguard Worker  %test_result_double_5 = fcmp oeq double %res_double_1, %val_double2
106*9880d681SAndroid Build Coastguard Worker  %test_result_double_6 = fcmp oeq double %res_double_2, %val_double1
107*9880d681SAndroid Build Coastguard Worker  %test_result_double_7 = fcmp oeq double %res_double_3, %val_double0
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Worker  %A_double = or i1 %test_result_double_0, %test_result_double_4
110*9880d681SAndroid Build Coastguard Worker  %B_double = or i1 %test_result_double_1, %test_result_double_5
111*9880d681SAndroid Build Coastguard Worker  %C_double = or i1 %test_result_double_2, %test_result_double_6
112*9880d681SAndroid Build Coastguard Worker  %D_double = or i1 %test_result_double_3, %test_result_double_7
113*9880d681SAndroid Build Coastguard Worker  %E_double = and i1 %A_double, %B_double
114*9880d681SAndroid Build Coastguard Worker  %F_double = and i1 %C_double, %D_double
115*9880d681SAndroid Build Coastguard Worker  %res_double = and i1 %E_double, %F_double
116*9880d681SAndroid Build Coastguard Worker
117*9880d681SAndroid Build Coastguard Worker  br i1 %res_double, label %Print_double, label %Float
118*9880d681SAndroid Build Coastguard WorkerPrint_double:
119*9880d681SAndroid Build Coastguard Worker  %ptr1 = getelementptr [20 x i8], [20 x i8]* @msg_double, i32 0, i32 0
120*9880d681SAndroid Build Coastguard Worker  call i32 (i8*,...) @printf(i8* %ptr1)
121*9880d681SAndroid Build Coastguard Worker  br label %Float
122*9880d681SAndroid Build Coastguard WorkerFloat:
123*9880d681SAndroid Build Coastguard Worker  store <4 x float> <float 9.0, float 10.0, float 11.0, float 12.0>, <4 x float>* %c, align 16
124*9880d681SAndroid Build Coastguard Worker
125*9880d681SAndroid Build Coastguard Worker  store float 9.0, float* %pfloat_0
126*9880d681SAndroid Build Coastguard Worker  store float 10.0, float* %pfloat_1
127*9880d681SAndroid Build Coastguard Worker  store float 11.0, float* %pfloat_2
128*9880d681SAndroid Build Coastguard Worker  store float 12.0, float* %pfloat_3
129*9880d681SAndroid Build Coastguard Worker
130*9880d681SAndroid Build Coastguard Worker  ; load stored vector
131*9880d681SAndroid Build Coastguard Worker  %val2 = load <4 x float> , <4 x float> *%c, align 16
132*9880d681SAndroid Build Coastguard Worker  ; load stored scalars
133*9880d681SAndroid Build Coastguard Worker  %val_float0 = load float, float* %pfloat_0
134*9880d681SAndroid Build Coastguard Worker  %val_float1 = load float, float* %pfloat_1
135*9880d681SAndroid Build Coastguard Worker  %val_float2 = load float, float* %pfloat_2
136*9880d681SAndroid Build Coastguard Worker  %val_float3 = load float, float* %pfloat_3
137*9880d681SAndroid Build Coastguard Worker
138*9880d681SAndroid Build Coastguard Worker  %res_float_0 = extractelement <4 x float> %val2, i32 0
139*9880d681SAndroid Build Coastguard Worker  %res_float_1 = extractelement <4 x float> %val2, i32 1
140*9880d681SAndroid Build Coastguard Worker  %res_float_2 = extractelement <4 x float> %val2, i32 2
141*9880d681SAndroid Build Coastguard Worker  %res_float_3 = extractelement <4 x float> %val2, i32 3
142*9880d681SAndroid Build Coastguard Worker
143*9880d681SAndroid Build Coastguard Worker  %test_result_float_0 = fcmp oeq float %res_float_0, %val_float0
144*9880d681SAndroid Build Coastguard Worker  %test_result_float_1 = fcmp oeq float %res_float_1, %val_float1
145*9880d681SAndroid Build Coastguard Worker  %test_result_float_2 = fcmp oeq float %res_float_2, %val_float2
146*9880d681SAndroid Build Coastguard Worker  %test_result_float_3 = fcmp oeq float %res_float_3, %val_float3
147*9880d681SAndroid Build Coastguard Worker
148*9880d681SAndroid Build Coastguard Worker  %test_result_float_4 = fcmp oeq float %res_float_0, %val_float3
149*9880d681SAndroid Build Coastguard Worker  %test_result_float_5 = fcmp oeq float %res_float_1, %val_float2
150*9880d681SAndroid Build Coastguard Worker  %test_result_float_6 = fcmp oeq float %res_float_2, %val_float1
151*9880d681SAndroid Build Coastguard Worker  %test_result_float_7 = fcmp oeq float %res_float_3, %val_float0
152*9880d681SAndroid Build Coastguard Worker
153*9880d681SAndroid Build Coastguard Worker  %A_float = or i1 %test_result_float_0, %test_result_float_4
154*9880d681SAndroid Build Coastguard Worker  %B_float = or i1 %test_result_float_1, %test_result_float_5
155*9880d681SAndroid Build Coastguard Worker  %C_float = or i1 %test_result_float_2, %test_result_float_6
156*9880d681SAndroid Build Coastguard Worker  %D_float = or i1 %test_result_float_3, %test_result_float_7
157*9880d681SAndroid Build Coastguard Worker  %E_float = and i1 %A_float, %B_float
158*9880d681SAndroid Build Coastguard Worker  %F_float = and i1 %C_float, %D_float
159*9880d681SAndroid Build Coastguard Worker  %res_float = and i1 %E_float, %F_float
160*9880d681SAndroid Build Coastguard Worker
161*9880d681SAndroid Build Coastguard Worker  br i1 %res_float, label %Print_float, label %Exit
162*9880d681SAndroid Build Coastguard WorkerPrint_float:
163*9880d681SAndroid Build Coastguard Worker  %ptr2 = getelementptr [19 x i8], [19 x i8]* @msg_float, i32 0, i32 0
164*9880d681SAndroid Build Coastguard Worker  call i32 (i8*,...) @printf(i8* %ptr2)
165*9880d681SAndroid Build Coastguard Worker  br label %Exit
166*9880d681SAndroid Build Coastguard WorkerExit:
167*9880d681SAndroid Build Coastguard Worker
168*9880d681SAndroid Build Coastguard Worker  ret i32 0
169*9880d681SAndroid Build Coastguard Worker}
170