xref: /aosp_15_r20/external/llvm/test/CodeGen/WebAssembly/global.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -asm-verbose=false -disable-wasm-fallthrough-return-opt | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Test that globals assemble as expected.
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-i64:64-n32:64-S128"
6*9880d681SAndroid Build Coastguard Workertarget triple = "wasm32-unknown-unknown"
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: llvm.used
9*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: llvm.metadata
10*9880d681SAndroid Build Coastguard Worker@llvm.used = appending global [1 x i32*] [i32* @g], section "llvm.metadata"
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker; CHECK: foo:
13*9880d681SAndroid Build Coastguard Worker; CHECK: i32.const $push0=, 0{{$}}
14*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: i32.load $push1=, answer($pop0){{$}}
15*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: return $pop1{{$}}
16*9880d681SAndroid Build Coastguard Workerdefine i32 @foo() {
17*9880d681SAndroid Build Coastguard Worker  %a = load i32, i32* @answer
18*9880d681SAndroid Build Coastguard Worker  ret i32 %a
19*9880d681SAndroid Build Coastguard Worker}
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: call_memcpy:
22*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .param          i32, i32, i32{{$}}
23*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .result         i32{{$}}
24*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: i32.call        $push0=, memcpy@FUNCTION, $0, $1, $2{{$}}
25*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: return          $pop0{{$}}
26*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture readonly, i32, i32, i1)
27*9880d681SAndroid Build Coastguard Workerdefine i8* @call_memcpy(i8* %p, i8* nocapture readonly %q, i32 %n) {
28*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.memcpy.p0i8.p0i8.i32(i8* %p, i8* %q, i32 %n, i32 1, i1 false)
29*9880d681SAndroid Build Coastguard Worker  ret i8* %p
30*9880d681SAndroid Build Coastguard Worker}
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Worker; CHECK: .type   .Lg,@object
33*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align  2{{$}}
34*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .Lg:
35*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 1337{{$}}
36*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size .Lg, 4{{$}}
37*9880d681SAndroid Build Coastguard Worker@g = private global i32 1337
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: ud:
40*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .skip 4{{$}}
41*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size ud, 4{{$}}
42*9880d681SAndroid Build Coastguard Worker@ud = internal global i32 undef
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Worker; CHECK: .type nil,@object
45*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .lcomm nil,4,2{{$}}
46*9880d681SAndroid Build Coastguard Worker@nil = internal global i32 zeroinitializer
47*9880d681SAndroid Build Coastguard Worker
48*9880d681SAndroid Build Coastguard Worker; CHECK: .type z,@object
49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .lcomm z,4,2{{$}}
50*9880d681SAndroid Build Coastguard Worker@z = internal global i32 0
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .type one,@object
53*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .p2align 2{{$}}
54*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: one:
55*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 1{{$}}
56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size one, 4{{$}}
57*9880d681SAndroid Build Coastguard Worker@one = internal global i32 1
58*9880d681SAndroid Build Coastguard Worker
59*9880d681SAndroid Build Coastguard Worker; CHECK: .type answer,@object
60*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 2{{$}}
61*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: answer:
62*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 42{{$}}
63*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size answer, 4{{$}}
64*9880d681SAndroid Build Coastguard Worker@answer = internal global i32 42
65*9880d681SAndroid Build Coastguard Worker
66*9880d681SAndroid Build Coastguard Worker; CHECK: .type u32max,@object
67*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 2{{$}}
68*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: u32max:
69*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 4294967295{{$}}
70*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size u32max, 4{{$}}
71*9880d681SAndroid Build Coastguard Worker@u32max = internal global i32 -1
72*9880d681SAndroid Build Coastguard Worker
73*9880d681SAndroid Build Coastguard Worker; CHECK: .type ud64,@object
74*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
75*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ud64:
76*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .skip 8{{$}}
77*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size ud64, 8{{$}}
78*9880d681SAndroid Build Coastguard Worker@ud64 = internal global i64 undef
79*9880d681SAndroid Build Coastguard Worker
80*9880d681SAndroid Build Coastguard Worker; CHECK: .type nil64,@object
81*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm nil64,8,3{{$}}
82*9880d681SAndroid Build Coastguard Worker@nil64 = internal global i64 zeroinitializer
83*9880d681SAndroid Build Coastguard Worker
84*9880d681SAndroid Build Coastguard Worker; CHECK: .type z64,@object
85*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm z64,8,3{{$}}
86*9880d681SAndroid Build Coastguard Worker@z64 = internal global i64 0
87*9880d681SAndroid Build Coastguard Worker
88*9880d681SAndroid Build Coastguard Worker; CHECK: .type twoP32,@object
89*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
90*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: twoP32:
91*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int64 4294967296{{$}}
92*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size twoP32, 8{{$}}
93*9880d681SAndroid Build Coastguard Worker@twoP32 = internal global i64 4294967296
94*9880d681SAndroid Build Coastguard Worker
95*9880d681SAndroid Build Coastguard Worker; CHECK: .type u64max,@object
96*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
97*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: u64max:
98*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int64 -1{{$}}
99*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size u64max, 8{{$}}
100*9880d681SAndroid Build Coastguard Worker@u64max = internal global i64 -1
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Worker; CHECK: .type f32ud,@object
103*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 2{{$}}
104*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: f32ud:
105*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .skip 4{{$}}
106*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size f32ud, 4{{$}}
107*9880d681SAndroid Build Coastguard Worker@f32ud = internal global float undef
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Worker; CHECK: .type f32nil,@object
110*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm f32nil,4,2{{$}}
111*9880d681SAndroid Build Coastguard Worker@f32nil = internal global float zeroinitializer
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Worker; CHECK: .type f32z,@object
114*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm f32z,4,2{{$}}
115*9880d681SAndroid Build Coastguard Worker@f32z = internal global float 0.0
116*9880d681SAndroid Build Coastguard Worker
117*9880d681SAndroid Build Coastguard Worker; CHECK: .type f32nz,@object
118*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 2{{$}}
119*9880d681SAndroid Build Coastguard Worker; CHECK: f32nz:
120*9880d681SAndroid Build Coastguard Worker; CHECK: .int32 2147483648{{$}}
121*9880d681SAndroid Build Coastguard Worker; CHECK: .size f32nz, 4{{$}}
122*9880d681SAndroid Build Coastguard Worker@f32nz = internal global float -0.0
123*9880d681SAndroid Build Coastguard Worker
124*9880d681SAndroid Build Coastguard Worker; CHECK: .type f32two,@object
125*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 2{{$}}
126*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: f32two:
127*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 1073741824{{$}}
128*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size f32two, 4{{$}}
129*9880d681SAndroid Build Coastguard Worker@f32two = internal global float 2.0
130*9880d681SAndroid Build Coastguard Worker
131*9880d681SAndroid Build Coastguard Worker; CHECK: .type f64ud,@object
132*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
133*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: f64ud:
134*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .skip 8{{$}}
135*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size f64ud, 8{{$}}
136*9880d681SAndroid Build Coastguard Worker@f64ud = internal global double undef
137*9880d681SAndroid Build Coastguard Worker
138*9880d681SAndroid Build Coastguard Worker; CHECK: .type f64nil,@object
139*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm f64nil,8,3{{$}}
140*9880d681SAndroid Build Coastguard Worker@f64nil = internal global double zeroinitializer
141*9880d681SAndroid Build Coastguard Worker
142*9880d681SAndroid Build Coastguard Worker; CHECK: .type f64z,@object
143*9880d681SAndroid Build Coastguard Worker; CHECK: .lcomm f64z,8,3{{$}}
144*9880d681SAndroid Build Coastguard Worker@f64z = internal global double 0.0
145*9880d681SAndroid Build Coastguard Worker
146*9880d681SAndroid Build Coastguard Worker; CHECK: .type f64nz,@object
147*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
148*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: f64nz:
149*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int64 -9223372036854775808{{$}}
150*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size f64nz, 8{{$}}
151*9880d681SAndroid Build Coastguard Worker@f64nz = internal global double -0.0
152*9880d681SAndroid Build Coastguard Worker
153*9880d681SAndroid Build Coastguard Worker; CHECK: .type f64two,@object
154*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align 3{{$}}
155*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: f64two:
156*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int64 4611686018427387904{{$}}
157*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size f64two, 8{{$}}
158*9880d681SAndroid Build Coastguard Worker@f64two = internal global double 2.0
159*9880d681SAndroid Build Coastguard Worker
160*9880d681SAndroid Build Coastguard Worker; Indexing into a global array produces a relocation.
161*9880d681SAndroid Build Coastguard Worker; CHECK:      .type arr,@object
162*9880d681SAndroid Build Coastguard Worker; CHECK:      .type ptr,@object
163*9880d681SAndroid Build Coastguard Worker; CHECK:      ptr:
164*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32 arr+80
165*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size ptr, 4
166*9880d681SAndroid Build Coastguard Worker@arr = global [128 x i32] zeroinitializer, align 16
167*9880d681SAndroid Build Coastguard Worker@ptr = global i32* getelementptr inbounds ([128 x i32], [128 x i32]* @arr, i32 0, i32 20), align 4
168*9880d681SAndroid Build Coastguard Worker
169*9880d681SAndroid Build Coastguard Worker; Constant global.
170*9880d681SAndroid Build Coastguard Worker; CHECK: .type    rom,@object{{$}}
171*9880d681SAndroid Build Coastguard Worker; CHECK: .section .rodata,"a",@progbits{{$}}
172*9880d681SAndroid Build Coastguard Worker; CHECK: .globl   rom{{$}}
173*9880d681SAndroid Build Coastguard Worker; CHECK: .p2align   4{{$}}
174*9880d681SAndroid Build Coastguard Worker; CHECK: rom:
175*9880d681SAndroid Build Coastguard Worker; CHECK: .skip    512{{$}}
176*9880d681SAndroid Build Coastguard Worker; CHECK: .size    rom, 512{{$}}
177*9880d681SAndroid Build Coastguard Worker@rom = constant [128 x i32] zeroinitializer, align 16
178*9880d681SAndroid Build Coastguard Worker
179*9880d681SAndroid Build Coastguard Worker; CHECK: .type       array,@object
180*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: array:
181*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .skip       8
182*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size       array, 8
183*9880d681SAndroid Build Coastguard Worker; CHECK: .type       pointer_to_array,@object
184*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .section    .data.rel.ro,"aw",@progbits
185*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .globl      pointer_to_array
186*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .p2align      2
187*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: pointer_to_array:
188*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .int32      array+4
189*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .size       pointer_to_array, 4
190*9880d681SAndroid Build Coastguard Worker@array = internal constant [8 x i8] zeroinitializer, align 1
191*9880d681SAndroid Build Coastguard Worker@pointer_to_array = constant i8* getelementptr inbounds ([8 x i8], [8 x i8]* @array, i32 0, i32 4), align 4
192