[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / WebAssembly / function-pointer64.ll
blob7c7b9e00c3f59434d7e5262bfa06c9d0a9dd48f0
1 ; RUN: llc < %s -asm-verbose=false -O2 | FileCheck %s
2 ; RUN: llc < %s -asm-verbose=false -mattr=+reference-types -O2 | FileCheck --check-prefix=REF %s
3 ; RUN: llc < %s -asm-verbose=false -O2 --filetype=obj | obj2yaml | FileCheck --check-prefix=YAML %s
5 ; This tests pointer features that may codegen differently in wasm64.
7 target triple = "wasm64-unknown-unknown"
9 define void @bar(i32 %n) {
10 entry:
11   ret void
14 define void @foo(void (i32)* %fp) {
15 entry:
16   call void %fp(i32 1)
17   ret void
20 define void @test() {
21 entry:
22   call void @foo(void (i32)* @bar)
23   store void (i32)* @bar, void (i32)** @fptr
24   ret void
27 @fptr = global void (i32)* @bar
29 ; For simplicity (and compatibility with UB C/C++ code) we keep all types
30 ; of pointers the same size, so function pointers (which are 32-bit indices
31 ; in Wasm) are represented as 64-bit until called.
33 ; CHECK:      .functype foo (i64) -> ()
34 ; CHECK-NEXT: i32.const 1
35 ; CHECK-NEXT: local.get 0
36 ; CHECK-NEXT: i32.wrap_i64
37 ; CHECK-NEXT: call_indirect (i32) -> ()
38 ; REF:        call_indirect __indirect_function_table, (i32) -> ()
40 ; CHECK:      .functype test () -> ()
41 ; CHECK-NEXT: i64.const bar
42 ; CHECK-NEXT: call foo
45 ; Check we're emitting a 64-bit relocs for the call_indirect, the
46 ; `i64.const bar` reference in code, and the global.
48 ; YAML:      Memory:
49 ; YAML-NEXT:   Flags:   [ IS_64 ]
50 ; YAML-NEXT:   Minimum: 0x1
52 ; YAML:      - Type:   CODE
53 ; YAML:      - Type:   R_WASM_TABLE_INDEX_SLEB64
54 ; YAML-NEXT:   Index:  0
55 ; YAML-NEXT:   Offset: 0x16
56 ; YAML:      - Type:   R_WASM_TABLE_INDEX_SLEB64
57 ; YAML-NEXT:   Index:  0
58 ; YAML-NEXT:   Offset: 0x29
60 ; YAML:      - Type:   DATA
61 ; YAML:      - Type:   R_WASM_TABLE_INDEX_I64
62 ; YAML-NEXT:   Index:  0
63 ; YAML-NEXT:   Offset: 0x6