forked from OSchip/llvm-project
245 lines
8.2 KiB
ArmAsm
245 lines
8.2 KiB
ArmAsm
# RUN: llvm-mc -triple=wasm64-unknown-unknown -mattr=+atomics,+unimplemented-simd128,+nontrapping-fptoint,+exception-handling < %s | FileCheck %s
|
|
# RUN: llvm-mc -triple=wasm64-unknown-unknown -filetype=obj -mattr=+atomics,+unimplemented-simd128,+nontrapping-fptoint,+exception-handling -o - < %s | obj2yaml | FileCheck %s -check-prefix=BIN
|
|
|
|
# Most of our other tests are for wasm32, this one adds some wasm64 specific tests.
|
|
|
|
test:
|
|
.functype test (i64) -> ()
|
|
.local i64
|
|
|
|
### basic loads
|
|
|
|
i64.const 0 # get i64 from constant.
|
|
f32.load 0
|
|
drop
|
|
|
|
local.get 0 # get i64 from local.
|
|
f32.load 0
|
|
drop
|
|
|
|
i64.const .L.str # get i64 relocatable.
|
|
f32.load 0
|
|
drop
|
|
|
|
global.get myglob64 # get i64 from global
|
|
f32.load 0
|
|
drop
|
|
|
|
i64.const 0
|
|
f32.load .L.str # relocatable offset!
|
|
drop
|
|
|
|
### basic stores
|
|
|
|
f32.const 0.0
|
|
i64.const 0 # get i64 from constant.
|
|
f32.store 0
|
|
|
|
f32.const 0.0
|
|
local.get 0 # get i64 from local.
|
|
f32.store 0
|
|
|
|
f32.const 0.0
|
|
i64.const .L.str # get i64 relocatable.
|
|
f32.store 0
|
|
|
|
f32.const 0.0
|
|
global.get myglob64 # get i64 from global
|
|
f32.store 0
|
|
|
|
f32.const 0.0
|
|
i64.const 0
|
|
f32.store .L.str # relocatable offset!
|
|
|
|
### 64-bit SP
|
|
|
|
global.get __stack_pointer
|
|
drop
|
|
|
|
end_function
|
|
|
|
.section .rodata..L.str,"",@
|
|
.hidden .L.str
|
|
.type .L.str,@object
|
|
.L.str:
|
|
.asciz "Hello, World!!!"
|
|
.int64 .L.str # relocatable inside data.
|
|
.size .L.str, 24
|
|
|
|
.globaltype myglob64, i64
|
|
.globaltype __stack_pointer, i64
|
|
|
|
|
|
# CHECK: .functype test (i64) -> ()
|
|
# CHECK-NEXT: .local i64
|
|
|
|
|
|
# CHECK: i64.const 0
|
|
# CHECK-NEXT: f32.load 0
|
|
# CHECK-NEXT: drop
|
|
|
|
# CHECK: local.get 0
|
|
# CHECK-NEXT: f32.load 0
|
|
# CHECK-NEXT: drop
|
|
|
|
# CHECK: i64.const .L.str
|
|
# CHECK-NEXT: f32.load 0
|
|
# CHECK-NEXT: drop
|
|
|
|
# CHECK: global.get myglob64
|
|
# CHECK-NEXT: f32.load 0
|
|
# CHECK-NEXT: drop
|
|
|
|
# CHECK: i64.const 0
|
|
# CHECK-NEXT: f32.load .L.str
|
|
# CHECK-NEXT: drop
|
|
|
|
|
|
# CHECK: f32.const 0x0p0
|
|
# CHECK-NEXT: i64.const 0
|
|
# CHECK-NEXT: f32.store 0
|
|
|
|
# CHECK: f32.const 0x0p0
|
|
# CHECK-NEXT: local.get 0
|
|
# CHECK-NEXT: f32.store 0
|
|
|
|
# CHECK: f32.const 0x0p0
|
|
# CHECK-NEXT: i64.const .L.str
|
|
# CHECK-NEXT: f32.store 0
|
|
|
|
# CHECK: f32.const 0x0p0
|
|
# CHECK-NEXT: global.get myglob64
|
|
# CHECK-NEXT: f32.store 0
|
|
|
|
# CHECK: f32.const 0x0p0
|
|
# CHECK-NEXT: i64.const 0
|
|
# CHECK-NEXT: f32.store .L.str
|
|
|
|
|
|
# CHECK: end_function
|
|
# CHECK-NEXT: .Ltmp0:
|
|
# CHECK-NEXT: .size test, .Ltmp0-test
|
|
|
|
# CHECK: .section .rodata..L.str,"",@
|
|
# CHECK-NEXT: .hidden .L.str
|
|
# CHECK-NEXT: .L.str:
|
|
# CHECK-NEXT: .asciz "Hello, World!!!"
|
|
# CHECK-NEXT: .int64 .L.str
|
|
# CHECK-NEXT: .size .L.str, 24
|
|
|
|
# CHECK: .globaltype myglob64, i64
|
|
|
|
|
|
|
|
# BIN: --- !WASM
|
|
# BIN-NEXT: FileHeader:
|
|
# BIN-NEXT: Version: 0x00000001
|
|
# BIN-NEXT: Sections:
|
|
# BIN-NEXT: - Type: TYPE
|
|
# BIN-NEXT: Signatures:
|
|
# BIN-NEXT: - Index: 0
|
|
# BIN-NEXT: ParamTypes:
|
|
# BIN-NEXT: - I64
|
|
# BIN-NEXT: ReturnTypes: []
|
|
# BIN-NEXT: - Type: IMPORT
|
|
# BIN-NEXT: Imports:
|
|
# BIN-NEXT: - Module: env
|
|
# BIN-NEXT: Field: __linear_memory
|
|
# BIN-NEXT: Kind: MEMORY
|
|
# BIN-NEXT: Memory:
|
|
# BIN-NEXT: Flags: [ IS_64 ]
|
|
# BIN-NEXT: Initial: 0x00000001
|
|
# BIN-NEXT: - Module: env
|
|
# BIN-NEXT: Field: __indirect_function_table
|
|
# BIN-NEXT: Kind: TABLE
|
|
# BIN-NEXT: Table:
|
|
# BIN-NEXT: ElemType: FUNCREF
|
|
# BIN-NEXT: Limits:
|
|
# BIN-NEXT: Initial: 0x00000000
|
|
# BIN-NEXT: - Module: env
|
|
# BIN-NEXT: Field: myglob64
|
|
# BIN-NEXT: Kind: GLOBAL
|
|
# BIN-NEXT: GlobalType: I64
|
|
# BIN-NEXT: GlobalMutable: true
|
|
# BIN-NEXT: - Module: env
|
|
# BIN-NEXT: Field: __stack_pointer
|
|
# BIN-NEXT: Kind: GLOBAL
|
|
# BIN-NEXT: GlobalType: I64
|
|
# BIN-NEXT: GlobalMutable: true
|
|
# BIN-NEXT: - Type: FUNCTION
|
|
# BIN-NEXT: FunctionTypes: [ 0 ]
|
|
# BIN-NEXT: - Type: DATACOUNT
|
|
# BIN-NEXT: Count: 1
|
|
# BIN-NEXT: - Type: CODE
|
|
# BIN-NEXT: Relocations:
|
|
# BIN-NEXT: - Type: R_WASM_MEMORY_ADDR_SLEB64
|
|
# BIN-NEXT: Index: 1
|
|
# BIN-NEXT: Offset: 0x00000013
|
|
# BIN-NEXT: - Type: R_WASM_GLOBAL_INDEX_LEB
|
|
# BIN-NEXT: Index: 2
|
|
# BIN-NEXT: Offset: 0x00000022
|
|
# BIN-NEXT: - Type: R_WASM_MEMORY_ADDR_LEB64
|
|
# BIN-NEXT: Index: 1
|
|
# BIN-NEXT: Offset: 0x0000002F
|
|
# BIN-NEXT: - Type: R_WASM_MEMORY_ADDR_SLEB64
|
|
# BIN-NEXT: Index: 1
|
|
# BIN-NEXT: Offset: 0x00000054
|
|
# BIN-NEXT: - Type: R_WASM_GLOBAL_INDEX_LEB
|
|
# BIN-NEXT: Index: 2
|
|
# BIN-NEXT: Offset: 0x00000067
|
|
# BIN-NEXT: - Type: R_WASM_MEMORY_ADDR_LEB64
|
|
# BIN-NEXT: Index: 1
|
|
# BIN-NEXT: Offset: 0x00000078
|
|
# BIN-NEXT: - Type: R_WASM_GLOBAL_INDEX_LEB
|
|
# BIN-NEXT: Index: 3
|
|
# BIN-NEXT: Offset: 0x00000083
|
|
# BIN-NEXT: Functions:
|
|
# BIN-NEXT: - Index: 0
|
|
# BIN-NEXT: Locals:
|
|
# BIN-NEXT: - Type: I64
|
|
# BIN-NEXT: Count: 1
|
|
# BIN-NEXT: Body: 42002A02001A20002A02001A42808080808080808080002A02001A2380808080002A02001A42002A02808080808080808080001A4300000000420038020043000000002000380200430000000042808080808080808080003802004300000000238080808000380200430000000042003802808080808080808080002381808080001A0B
|
|
# BIN-NEXT: - Type: DATA
|
|
# BIN-NEXT: Relocations:
|
|
# BIN-NEXT: - Type: R_WASM_MEMORY_ADDR_I64
|
|
# BIN-NEXT: Index: 1
|
|
# BIN-NEXT: Offset: 0x00000016
|
|
# BIN-NEXT: Segments:
|
|
# BIN-NEXT: - SectionOffset: 6
|
|
# BIN-NEXT: InitFlags: 0
|
|
# BIN-NEXT: Offset:
|
|
# BIN-NEXT: Opcode: I32_CONST
|
|
# BIN-NEXT: Value: 0
|
|
# BIN-NEXT: Content: 48656C6C6F2C20576F726C64212121000000000000000000
|
|
# BIN-NEXT: - Type: CUSTOM
|
|
# BIN-NEXT: Name: linking
|
|
# BIN-NEXT: Version: 2
|
|
# BIN-NEXT: SymbolTable:
|
|
# BIN-NEXT: - Index: 0
|
|
# BIN-NEXT: Kind: FUNCTION
|
|
# BIN-NEXT: Name: test
|
|
# BIN-NEXT: Flags: [ BINDING_LOCAL ]
|
|
# BIN-NEXT: Function: 0
|
|
# BIN-NEXT: - Index: 1
|
|
# BIN-NEXT: Kind: DATA
|
|
# BIN-NEXT: Name: .L.str
|
|
# BIN-NEXT: Flags: [ BINDING_LOCAL, VISIBILITY_HIDDEN ]
|
|
# BIN-NEXT: Segment: 0
|
|
# BIN-NEXT: Size: 24
|
|
# BIN-NEXT: - Index: 2
|
|
# BIN-NEXT: Kind: GLOBAL
|
|
# BIN-NEXT: Name: myglob64
|
|
# BIN-NEXT: Flags: [ UNDEFINED ]
|
|
# BIN-NEXT: Global: 0
|
|
# BIN-NEXT: - Index: 3
|
|
# BIN-NEXT: Kind: GLOBAL
|
|
# BIN-NEXT: Name: __stack_pointer
|
|
# BIN-NEXT: Flags: [ UNDEFINED ]
|
|
# BIN-NEXT: Global: 1
|
|
# BIN-NEXT: SegmentInfo:
|
|
# BIN-NEXT: - Index: 0
|
|
# BIN-NEXT: Name: .rodata..L.str
|
|
# BIN-NEXT: Alignment: 0
|
|
# BIN-NEXT: Flags: [ ]
|
|
# BIN-NEXT: ...
|