summaryrefslogtreecommitdiff
path: root/test/CodeGen/SystemZ/05-MemRegLoads.ll
blob: f690a4889962e476d33ae1f50b342948167ea9a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
; RUN: llc < %s -march=systemz | not grep aghi
; RUN: llc < %s -march=systemz | grep llgf | count 1
; RUN: llc < %s -march=systemz | grep llgh | count 1
; RUN: llc < %s -march=systemz | grep llgc | count 1
; RUN: llc < %s -march=systemz | grep lgf  | count 2
; RUN: llc < %s -march=systemz | grep lgh  | count 2
; RUN: llc < %s -march=systemz | grep lgb  | count 1


target datalayout = "E-p:64:64:64-i1:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f128:128:128"
target triple = "s390x-unknown-linux-gnu"

define zeroext i64 @foo1(i64* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i64* %a, i64 %add.ptr.sum		; <i64*> [#uses=1]
	%tmp3 = load i64* %add.ptr2		; <i64> [#uses=1]
	ret i64 %tmp3
}

define zeroext i32 @foo2(i32* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i32* %a, i64 %add.ptr.sum		; <i32*> [#uses=1]
	%tmp3 = load i32* %add.ptr2		; <i32> [#uses=1]
	ret i32 %tmp3
}

define zeroext i16 @foo3(i16* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i16* %a, i64 %add.ptr.sum		; <i16*> [#uses=1]
	%tmp3 = load i16* %add.ptr2		; <i16> [#uses=1]
	ret i16 %tmp3
}

define zeroext i8 @foo4(i8* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i8* %a, i64 %add.ptr.sum		; <i8*> [#uses=1]
	%tmp3 = load i8* %add.ptr2		; <i8> [#uses=1]
	ret i8 %tmp3
}

define signext i64 @foo5(i64* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i64* %a, i64 %add.ptr.sum		; <i64*> [#uses=1]
	%tmp3 = load i64* %add.ptr2		; <i64> [#uses=1]
	ret i64 %tmp3
}

define signext i32 @foo6(i32* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i32* %a, i64 %add.ptr.sum		; <i32*> [#uses=1]
	%tmp3 = load i32* %add.ptr2		; <i32> [#uses=1]
	ret i32 %tmp3
}

define signext i16 @foo7(i16* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i16* %a, i64 %add.ptr.sum		; <i16*> [#uses=1]
	%tmp3 = load i16* %add.ptr2		; <i16> [#uses=1]
	ret i16 %tmp3
}

define signext i8 @foo8(i8* nocapture %a, i64 %idx) nounwind readonly {
entry:
	%add.ptr.sum = add i64 %idx, 1		; <i64> [#uses=1]
	%add.ptr2 = getelementptr i8* %a, i64 %add.ptr.sum		; <i8*> [#uses=1]
	%tmp3 = load i8* %add.ptr2		; <i8> [#uses=1]
	ret i8 %tmp3
}