blob: e9156b1648118a74d158e3d65c90500a90ba8d96 [file] [log] [blame]
Tom Stellard49f8bfd2015-01-06 18:00:21 +00001; RUN: llc -march=amdgcn -mcpu=SI < %s
Matt Arsenault717c1d02014-06-15 21:08:58 +00002; RUN: llc -march=r600 -mcpu=redwood < %s
3
4define void @srem_i32(i32 addrspace(1)* %out, i32 addrspace(1)* %in) {
5 %den_ptr = getelementptr i32 addrspace(1)* %in, i32 1
6 %num = load i32 addrspace(1) * %in
7 %den = load i32 addrspace(1) * %den_ptr
8 %result = srem i32 %num, %den
9 store i32 %result, i32 addrspace(1)* %out
10 ret void
11}
12
13define void @srem_i32_4(i32 addrspace(1)* %out, i32 addrspace(1)* %in) {
14 %num = load i32 addrspace(1) * %in
15 %result = srem i32 %num, 4
16 store i32 %result, i32 addrspace(1)* %out
17 ret void
18}
19
20define void @srem_v2i32(<2 x i32> addrspace(1)* %out, <2 x i32> addrspace(1)* %in) {
21 %den_ptr = getelementptr <2 x i32> addrspace(1)* %in, i32 1
22 %num = load <2 x i32> addrspace(1) * %in
23 %den = load <2 x i32> addrspace(1) * %den_ptr
24 %result = srem <2 x i32> %num, %den
25 store <2 x i32> %result, <2 x i32> addrspace(1)* %out
26 ret void
27}
28
29define void @srem_v2i32_4(<2 x i32> addrspace(1)* %out, <2 x i32> addrspace(1)* %in) {
30 %num = load <2 x i32> addrspace(1) * %in
31 %result = srem <2 x i32> %num, <i32 4, i32 4>
32 store <2 x i32> %result, <2 x i32> addrspace(1)* %out
33 ret void
34}
35
36define void @srem_v4i32(<4 x i32> addrspace(1)* %out, <4 x i32> addrspace(1)* %in) {
37 %den_ptr = getelementptr <4 x i32> addrspace(1)* %in, i32 1
38 %num = load <4 x i32> addrspace(1) * %in
39 %den = load <4 x i32> addrspace(1) * %den_ptr
40 %result = srem <4 x i32> %num, %den
41 store <4 x i32> %result, <4 x i32> addrspace(1)* %out
42 ret void
43}
44
45define void @srem_v4i32_4(<4 x i32> addrspace(1)* %out, <4 x i32> addrspace(1)* %in) {
46 %num = load <4 x i32> addrspace(1) * %in
47 %result = srem <4 x i32> %num, <i32 4, i32 4, i32 4, i32 4>
48 store <4 x i32> %result, <4 x i32> addrspace(1)* %out
49 ret void
50}
Matt Arsenaultd9987c72015-01-21 22:43:19 +000051
52define void @srem_i64(i64 addrspace(1)* %out, i64 addrspace(1)* %in) {
53 %den_ptr = getelementptr i64 addrspace(1)* %in, i64 1
54 %num = load i64 addrspace(1) * %in
55 %den = load i64 addrspace(1) * %den_ptr
56 %result = srem i64 %num, %den
57 store i64 %result, i64 addrspace(1)* %out
58 ret void
59}
60
61define void @srem_i64_4(i64 addrspace(1)* %out, i64 addrspace(1)* %in) {
62 %num = load i64 addrspace(1) * %in
63 %result = srem i64 %num, 4
64 store i64 %result, i64 addrspace(1)* %out
65 ret void
66}
67
68define void @srem_v2i64(<2 x i64> addrspace(1)* %out, <2 x i64> addrspace(1)* %in) {
69 %den_ptr = getelementptr <2 x i64> addrspace(1)* %in, i64 1
70 %num = load <2 x i64> addrspace(1) * %in
71 %den = load <2 x i64> addrspace(1) * %den_ptr
72 %result = srem <2 x i64> %num, %den
73 store <2 x i64> %result, <2 x i64> addrspace(1)* %out
74 ret void
75}
76
77define void @srem_v2i64_4(<2 x i64> addrspace(1)* %out, <2 x i64> addrspace(1)* %in) {
78 %num = load <2 x i64> addrspace(1) * %in
79 %result = srem <2 x i64> %num, <i64 4, i64 4>
80 store <2 x i64> %result, <2 x i64> addrspace(1)* %out
81 ret void
82}
83
84define void @srem_v4i64(<4 x i64> addrspace(1)* %out, <4 x i64> addrspace(1)* %in) {
85 %den_ptr = getelementptr <4 x i64> addrspace(1)* %in, i64 1
86 %num = load <4 x i64> addrspace(1) * %in
87 %den = load <4 x i64> addrspace(1) * %den_ptr
88 %result = srem <4 x i64> %num, %den
89 store <4 x i64> %result, <4 x i64> addrspace(1)* %out
90 ret void
91}
92
93define void @srem_v4i64_4(<4 x i64> addrspace(1)* %out, <4 x i64> addrspace(1)* %in) {
94 %num = load <4 x i64> addrspace(1) * %in
95 %result = srem <4 x i64> %num, <i64 4, i64 4, i64 4, i64 4>
96 store <4 x i64> %result, <4 x i64> addrspace(1)* %out
97 ret void
98}