xref: /llvm-project/llvm/test/CodeGen/VE/Scalar/pic_access_data.ll (revision ff9af4c43ad71eeba2cabe99609cfaa0fd54c1d0)
1; RUN: llc -relocation-model=pic < %s -mtriple=ve-unknown-unknown | FileCheck %s
2
3@dst = external global i32, align 4
4@ptr = external global ptr, align 8
5@src = external global i32, align 4
6
7define 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)
35
36  store ptr @dst, ptr @ptr, align 8
37  %1 = load i32, ptr @src, align 4
38  store i32 %1, ptr @dst, align 4
39  ret i32 1
40}
41