Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / XCore / load.ll
blob7b6993de82cd16f7b11cc6ea30e90dc582d63b42
1 ; RUN: llc < %s -march=xcore | FileCheck %s
3 define i32 @load32(ptr %p, i32 %offset) nounwind {
4 entry:
5 ; CHECK-LABEL: load32:
6 ; CHECK: ldw r0, r0[r1]
7         %0 = getelementptr i32, ptr %p, i32 %offset
8         %1 = load i32, ptr %0, align 4
9         ret i32 %1
12 define i32 @load32_imm(ptr %p) nounwind {
13 entry:
14 ; CHECK-LABEL: load32_imm:
15 ; CHECK: ldw r0, r0[11]
16         %0 = getelementptr i32, ptr %p, i32 11
17         %1 = load i32, ptr %0, align 4
18         ret i32 %1
21 define i32 @load16(ptr %p, i32 %offset) nounwind {
22 entry:
23 ; CHECK-LABEL: load16:
24 ; CHECK: ld16s r0, r0[r1]
25 ; CHECK-NOT: sext
26         %0 = getelementptr i16, ptr %p, i32 %offset
27         %1 = load i16, ptr %0, align 2
28         %2 = sext i16 %1 to i32
29         ret i32 %2
32 define i32 @load8(ptr %p, i32 %offset) nounwind {
33 entry:
34 ; CHECK-LABEL: load8:
35 ; CHECK: ld8u r0, r0[r1]
36 ; CHECK-NOT: zext
37         %0 = getelementptr i8, ptr %p, i32 %offset
38         %1 = load i8, ptr %0, align 1
39         %2 = zext i8 %1 to i32
40         ret i32 %2
43 @GConst = internal constant i32 42
44 define i32 @load_cp() nounwind {
45 entry:
46 ; CHECK-LABEL: load_cp:
47 ; CHECK: ldw r0, cp[GConst]
48   %0 = load i32, ptr @GConst
49   ret i32 %0