Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / VE / Scalar / pic_access_data.ll
blob184b1aa8a55329cdaa9832b2282ce9be6ea777e2
1 ; RUN: llc -relocation-model=pic < %s -mtriple=ve-unknown-unknown | FileCheck %s
3 @dst = external global i32, align 4
4 @ptr = external global i32*, align 8
5 @src = external global i32, align 4
7 define i32 @func() {
8 ; CHECK-LABEL: func:
9 ; CHECK:       # %bb.0:
10 ; CHECK-NEXT:    st %s15, 24(, %s11)
11 ; CHECK-NEXT:    st %s16, 32(, %s11)
12 ; CHECK-NEXT:    lea %s15, _GLOBAL_OFFSET_TABLE_@pc_lo(-24)
13 ; CHECK-NEXT:    and %s15, %s15, (32)0
14 ; CHECK-NEXT:    sic %s16
15 ; CHECK-NEXT:    lea.sl %s15, _GLOBAL_OFFSET_TABLE_@pc_hi(%s16, %s15)
16 ; CHECK-NEXT:    lea %s0, dst@got_lo
17 ; CHECK-NEXT:    and %s0, %s0, (32)0
18 ; CHECK-NEXT:    lea.sl %s0, dst@got_hi(, %s0)
19 ; CHECK-NEXT:    ld %s1, (%s0, %s15)
20 ; CHECK-NEXT:    lea %s0, ptr@got_lo
21 ; CHECK-NEXT:    and %s0, %s0, (32)0
22 ; CHECK-NEXT:    lea %s2, src@got_lo
23 ; CHECK-NEXT:    and %s2, %s2, (32)0
24 ; CHECK-NEXT:    lea.sl %s2, src@got_hi(, %s2)
25 ; CHECK-NEXT:    ld %s2, (%s2, %s15)
26 ; CHECK-NEXT:    lea.sl %s0, ptr@got_hi(, %s0)
27 ; CHECK-NEXT:    ld %s0, (%s0, %s15)
28 ; CHECK-NEXT:    ldl.sx %s2, (, %s2)
29 ; CHECK-NEXT:    st %s1, (, %s0)
30 ; CHECK-NEXT:    or %s0, 1, (0)1
31 ; CHECK-NEXT:    stl %s2, (, %s1)
32 ; CHECK-NEXT:    ld %s16, 32(, %s11)
33 ; CHECK-NEXT:    ld %s15, 24(, %s11)
34 ; CHECK-NEXT:    b.l.t (, %s10)
36   store i32* @dst, i32** @ptr, align 8
37   %1 = load i32, i32* @src, align 4
38   store i32 %1, i32* @dst, align 4
39   ret i32 1