Files
clang-p2996/llvm/test/CodeGen/WebAssembly/externref-tableget.ll
Paulo Matos c67c9cfe3f [WebAssembly] Refactor and fix emission of external IR global decls
Reland of 00bf4755.

This patches fixes the visibility and linkage information of symbols
referring to IR globals.

Emission of external declarations is now done in the first execution
of emitConstantPool rather than in emitLinkage (and a few other
places). This is the point where we have already gathered information
about used symbols (by running the MC Lower PrePass) and not yet
started emitting any functions so that any declarations that need to
be emitted are done so at the top of the file before any functions.

This changes the order of a few directives in the final asm file which
required an update to a few tests.

Reviewed By: sbc100

Differential Revision: https://reviews.llvm.org/D118995
2022-02-04 22:01:46 +01:00

78 lines
3.1 KiB
LLVM

; RUN: llc < %s --mtriple=wasm32-unknown-unknown -asm-verbose=false -mattr=+reference-types | FileCheck %s
%extern = type opaque
%externref = type %extern addrspace(10)* ;; addrspace 10 is nonintegral
@externref_table = local_unnamed_addr addrspace(1) global [0 x %externref] undef
define %externref @get_externref_from_table(i32 %i) {
; CHECK-LABEL: get_externref_from_table:
; CHECK-NEXT: .functype get_externref_from_table (i32) -> (externref)
; CHECK-NEXT: local.get 0
; CHECK-NEXT: table.get externref_table
; CHECK-NEXT: end_function
%p = getelementptr [0 x %externref], [0 x %externref] addrspace (1)* @externref_table, i32 0, i32 %i
%ref = load %externref, %externref addrspace(1)* %p
ret %externref %ref
}
define %externref @get_externref_from_table_const() {
; CHECK-LABEL: get_externref_from_table_const:
; CHECK-NEXT: .functype get_externref_from_table_const () -> (externref)
; CHECK-NEXT: i32.const 0
; CHECK-NEXT: table.get externref_table
; CHECK-NEXT: end_function
%p = getelementptr [0 x %externref], [0 x %externref] addrspace (1)* @externref_table, i32 0, i32 0
%ref = load %externref, %externref addrspace(1)* %p
ret %externref %ref
}
define %externref @get_externref_from_table_with_offset(i32 %i) {
; CHECK-LABEL: get_externref_from_table_with_offset:
; CHECK-NEXT: .functype get_externref_from_table_with_offset (i32) -> (externref)
; CHECK-NEXT: local.get 0
; CHECK-NEXT: i32.const 2
; CHECK-NEXT: i32.add
; CHECK-NEXT: table.get externref_table
; CHECK-NEXT: end_function
%off = add nsw i32 %i, 2
%p = getelementptr [0 x %externref], [0 x %externref] addrspace (1)* @externref_table, i32 0, i32 %off
%ref = load %externref, %externref addrspace(1)* %p
ret %externref %ref
}
define %externref @get_externref_from_table_with_var_offset(i32 %i, i32 %j) {
; CHECK-LABEL: get_externref_from_table_with_var_offset:
; CHECK-NEXT: .functype get_externref_from_table_with_var_offset (i32, i32) -> (externref)
; CHECK-NEXT: local.get 0
; CHECK-NEXT: local.get 1
; CHECK-NEXT: i32.add
; CHECK-NEXT: table.get externref_table
; CHECK-NEXT: end_function
%off = add nsw i32 %i, %j
%p = getelementptr [0 x %externref], [0 x %externref] addrspace (1)* @externref_table, i32 0, i32 %off
%ref = load %externref, %externref addrspace(1)* %p
ret %externref %ref
}
declare i32 @get_offset()
define %externref @get_externref_from_table_with_var_offset2(i32 %i) {
; CHECK-LABEL: get_externref_from_table_with_var_offset2:
; CHECK-NEXT: .functype get_externref_from_table_with_var_offset2 (i32) -> (externref)
; CHECK-NEXT: local.get 0
; CHECK-NEXT: call get_offset
; CHECK-NEXT: i32.add
; CHECK-NEXT: table.get externref_table
; CHECK-NEXT: end_function
%j = call i32 @get_offset()
%off = add nsw i32 %i, %j
%p = getelementptr [0 x %externref], [0 x %externref] addrspace (1)* @externref_table, i32 0, i32 %off
%ref = load %externref, %externref addrspace(1)* %p
ret %externref %ref
}
; CHECK: .tabletype externref_table, externref
; CHECK-LABEL: externref_table: