A few more load instructions.
[oota-llvm.git] / test / CodeGen / Thumb2 / thumb2-ldrb.ll
1 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep {ldrb r0} | count 7
2 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep mov | grep 1
3 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | not grep mvn
4 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep ldrb | grep lsl
5 ; RUN: llvm-as < %s | llc -march=thumb -mattr=+thumb2 | grep lsr | not grep ldrb
6
7 define i8 @f1(i8* %v) {
8 entry:
9         %tmp = load i8* %v
10         ret i8 %tmp
11 }
12
13 define i8 @f2(i8* %v) {
14 entry:
15         %tmp2 = getelementptr i8* %v, i8 1023
16         %tmp = load i8* %tmp2
17         ret i8 %tmp
18 }
19
20 define i8 @f3(i32 %base) {
21 entry:
22         %tmp1 = add i32 %base, 4096
23         %tmp2 = inttoptr i32 %tmp1 to i8*
24         %tmp3 = load i8* %tmp2
25         ret i8 %tmp3
26 }
27
28 define i8 @f4(i32 %base) {
29 entry:
30         %tmp1 = sub i32 %base, 128
31         %tmp2 = inttoptr i32 %tmp1 to i8*
32         %tmp3 = load i8* %tmp2
33         ret i8 %tmp3
34 }
35
36 define i8 @f5(i32 %base, i32 %offset) {
37 entry:
38         %tmp1 = add i32 %base, %offset
39         %tmp2 = inttoptr i32 %tmp1 to i8*
40         %tmp3 = load i8* %tmp2
41         ret i8 %tmp3
42 }
43
44 define i8 @f6(i32 %base, i32 %offset) {
45 entry:
46         %tmp1 = shl i32 %offset, 2
47         %tmp2 = add i32 %base, %tmp1
48         %tmp3 = inttoptr i32 %tmp2 to i8*
49         %tmp4 = load i8* %tmp3
50         ret i8 %tmp4
51 }
52
53 define i8 @f7(i32 %base, i32 %offset) {
54 entry:
55         %tmp1 = lshr i32 %offset, 2
56         %tmp2 = add i32 %base, %tmp1
57         %tmp3 = inttoptr i32 %tmp2 to i8*
58         %tmp4 = load i8* %tmp3
59         ret i8 %tmp4
60 }