[test] Pre-commit llvm.experimental.memset.pattern tests prior to MemoryLocation...
[llvm-project.git] / llvm / test / CodeGen / ARM / Windows / mingw-refptr.ll
blob63f405f756231f138e1d689b74941059705c1ae6
1 ; RUN: llc < %s -mtriple=thumbv7-w64-mingw32 | FileCheck %s
3 @var = external local_unnamed_addr global i32, align 4
4 @dsolocalvar = external dso_local local_unnamed_addr global i32, align 4
5 @localvar = dso_local local_unnamed_addr global i32 0, align 4
6 @localcommon = common dso_local local_unnamed_addr global i32 0, align 4
7 @extvar = external dllimport local_unnamed_addr global i32, align 4
9 define dso_local i32 @getVar() {
10 ; CHECK-LABEL: getVar:
11 ; CHECK:    movw r0, :lower16:.refptr.var
12 ; CHECK:    movt r0, :upper16:.refptr.var
13 ; CHECK:    ldr  r0, [r0]
14 ; CHECK:    ldr  r0, [r0]
15 ; CHECK:    bx   lr
16 entry:
17   %0 = load i32, ptr @var, align 4
18   ret i32 %0
21 define dso_local i32 @getDsoLocalVar() {
22 ; CHECK-LABEL: getDsoLocalVar:
23 ; CHECK:    movw r0, :lower16:dsolocalvar
24 ; CHECK:    movt r0, :upper16:dsolocalvar
25 ; CHECK:    ldr  r0, [r0]
26 ; CHECK:    bx   lr
27 entry:
28   %0 = load i32, ptr @dsolocalvar, align 4
29   ret i32 %0
32 define dso_local i32 @getLocalVar() {
33 ; CHECK-LABEL: getLocalVar:
34 ; CHECK:    movw r0, :lower16:localvar
35 ; CHECK:    movt r0, :upper16:localvar
36 ; CHECK:    ldr  r0, [r0]
37 ; CHECK:    bx   lr
38 entry:
39   %0 = load i32, ptr @localvar, align 4
40   ret i32 %0
43 define dso_local i32 @getLocalCommon() {
44 ; CHECK-LABEL: getLocalCommon:
45 ; CHECK:    movw r0, :lower16:localcommon
46 ; CHECK:    movt r0, :upper16:localcommon
47 ; CHECK:    ldr  r0, [r0]
48 ; CHECK:    bx   lr
49 entry:
50   %0 = load i32, ptr @localcommon, align 4
51   ret i32 %0
54 define dso_local i32 @getExtVar() {
55 ; CHECK-LABEL: getExtVar:
56 ; CHECK:    movw r0, :lower16:__imp_extvar
57 ; CHECK:    movt r0, :upper16:__imp_extvar
58 ; CHECK:    ldr  r0, [r0]
59 ; CHECK:    ldr  r0, [r0]
60 ; CHECK:    bx   lr
61 entry:
62   %0 = load i32, ptr @extvar, align 4
63   ret i32 %0
66 define dso_local void @callFunc() {
67 ; CHECK-LABEL: callFunc:
68 ; CHECK:    b.w otherFunc
69 entry:
70   tail call void @otherFunc()
71   ret void
74 declare dso_local void @otherFunc()
76 ; CHECK:        .section        .rdata$.refptr.var,"dr",discard,.refptr.var
77 ; CHECK:        .globl  .refptr.var
78 ; CHECK: .refptr.var:
79 ; CHECK:        .long   var