Index: test/wasm/relocatable.ll =================================================================== --- test/wasm/relocatable.ll +++ test/wasm/relocatable.ll @@ -7,14 +7,17 @@ define hidden i32 @my_func() local_unnamed_addr { entry: %call = tail call i32 @foo_import() + %call2 = tail call i32 @bar_import() ret i32 1 } declare i32 @foo_import() local_unnamed_addr +declare extern_weak i32 @bar_import() local_unnamed_addr @data_import = external global i64 @func_addr1 = hidden global i32()* @my_func, align 4 @func_addr2 = hidden global i32()* @foo_import, align 4 +@func_addr3 = hidden global i32()* @bar_import, align 4 @data_addr1 = hidden global i64* @data_import, align 8 $func_comdat = comdat any @@ -51,6 +54,10 @@ ; CHECK-NEXT: Kind: FUNCTION ; CHECK-NEXT: SigIndex: 2 ; CHECK-NEXT: - Module: env +; CHECK-NEXT: Field: bar_import +; CHECK-NEXT: Kind: FUNCTION +; CHECK-NEXT: SigIndex: 2 +; CHECK-NEXT: - Module: env ; CHECK-NEXT: Field: data_import ; CHECK-NEXT: Kind: GLOBAL ; CHECK-NEXT: GlobalType: I32 @@ -62,8 +69,8 @@ ; CHECK-NEXT: - ElemType: ANYFUNC ; CHECK-NEXT: Limits: ; CHECK-NEXT: Flags: [ HAS_MAX ] -; CHECK-NEXT: Initial: 0x00000002 -; CHECK-NEXT: Maximum: 0x00000002 +; CHECK-NEXT: Initial: 0x00000003 +; CHECK-NEXT: Maximum: 0x00000003 ; CHECK-NEXT: - Type: MEMORY ; CHECK-NEXT: Memories: ; CHECK-NEXT: - Initial: 0x00000001 @@ -80,7 +87,7 @@ ; CHECK-NEXT: Mutable: false ; CHECK-NEXT: InitExpr: ; CHECK-NEXT: Opcode: I32_CONST -; CHECK-NEXT: Value: 20 +; CHECK-NEXT: Value: 28 ; CHECK-NEXT: - Index: 3 ; CHECK-NEXT: Type: I32 ; CHECK-NEXT: Mutable: false @@ -99,17 +106,23 @@ ; CHECK-NEXT: InitExpr: ; CHECK-NEXT: Opcode: I32_CONST ; CHECK-NEXT: Value: 16 +; CHECK-NEXT: - Index: 6 +; CHECK-NEXT: Type: I32 +; CHECK-NEXT: Mutable: false +; CHECK-NEXT: InitExpr: +; CHECK-NEXT: Opcode: I32_CONST +; CHECK-NEXT: Value: 24 ; CHECK-NEXT: - Type: EXPORT ; CHECK-NEXT: Exports: ; CHECK-NEXT: - Name: hello ; CHECK-NEXT: Kind: FUNCTION -; CHECK-NEXT: Index: 2 +; CHECK-NEXT: Index: 3 ; CHECK-NEXT: - Name: my_func ; CHECK-NEXT: Kind: FUNCTION -; CHECK-NEXT: Index: 3 +; CHECK-NEXT: Index: 4 ; CHECK-NEXT: - Name: func_comdat ; CHECK-NEXT: Kind: FUNCTION -; CHECK-NEXT: Index: 4 +; CHECK-NEXT: Index: 5 ; CHECK-NEXT: - Name: hello_str ; CHECK-NEXT: Kind: GLOBAL ; CHECK-NEXT: Index: 1 @@ -122,15 +135,18 @@ ; CHECK-NEXT: - Name: func_addr2 ; CHECK-NEXT: Kind: GLOBAL ; CHECK-NEXT: Index: 4 -; CHECK-NEXT: - Name: data_addr1 +; CHECK-NEXT: - Name: func_addr3 ; CHECK-NEXT: Kind: GLOBAL ; CHECK-NEXT: Index: 5 +; CHECK-NEXT: - Name: data_addr1 +; CHECK-NEXT: Kind: GLOBAL +; CHECK-NEXT: Index: 6 ; CHECK-NEXT: - Type: ELEM ; CHECK-NEXT: Segments: ; CHECK-NEXT: - Offset: ; CHECK-NEXT: Opcode: I32_CONST ; CHECK-NEXT: Value: 0 -; CHECK-NEXT: Functions: [ 3, 1 ] +; CHECK-NEXT: Functions: [ 4, 1, 2 ] ; CHECK-NEXT: - Type: CODE ; CHECK-NEXT: Relocations: ; CHECK-NEXT: - Type: R_WEBASSEMBLY_MEMORY_ADDR_SLEB @@ -142,19 +158,22 @@ ; CHECK-NEXT: - Type: R_WEBASSEMBLY_FUNCTION_INDEX_LEB ; CHECK-NEXT: Index: 1 ; CHECK-NEXT: Offset: 0x00000013 +; CHECK-NEXT: - Type: R_WEBASSEMBLY_FUNCTION_INDEX_LEB +; CHECK-NEXT: Index: 2 +; CHECK-NEXT: Offset: 0x0000001A ; CHECK-NEXT: - Type: R_WEBASSEMBLY_MEMORY_ADDR_SLEB ; CHECK-NEXT: Index: 2 -; CHECK-NEXT: Offset: 0x0000001F +; CHECK-NEXT: Offset: 0x00000026 ; CHECK-NEXT: Functions: -; CHECK-NEXT: - Index: 2 +; CHECK-NEXT: - Index: 3 ; CHECK-NEXT: Locals: ; CHECK-NEXT: Body: 4180808080001080808080000B -; CHECK-NEXT: - Index: 3 +; CHECK-NEXT: - Index: 4 ; CHECK-NEXT: Locals: -; CHECK-NEXT: Body: 1081808080001A41010B -; CHECK-NEXT: - Index: 4 +; CHECK-NEXT: Body: 1081808080001A1082808080001A41010B +; CHECK-NEXT: - Index: 5 ; CHECK-NEXT: Locals: -; CHECK-NEXT: Body: 4194808080000B +; CHECK-NEXT: Body: 419C808080000B ; CHECK-NEXT: - Type: DATA ; CHECK-NEXT: Relocations: ; CHECK-NEXT: - Type: R_WEBASSEMBLY_TABLE_INDEX_I32 @@ -163,9 +182,12 @@ ; CHECK-NEXT: - Type: R_WEBASSEMBLY_TABLE_INDEX_I32 ; CHECK-NEXT: Index: 1 ; CHECK-NEXT: Offset: 0x0000001B +; CHECK-NEXT: - Type: R_WEBASSEMBLY_TABLE_INDEX_I32 +; CHECK-NEXT: Index: 2 +; CHECK-NEXT: Offset: 0x00000024 ; CHECK-NEXT: - Type: R_WEBASSEMBLY_MEMORY_ADDR_I32 ; CHECK-NEXT: Index: 0 -; CHECK-NEXT: Offset: 0x00000024 +; CHECK-NEXT: Offset: 0x0000002D ; CHECK-NEXT: Segments: ; CHECK-NEXT: - SectionOffset: 6 ; CHECK-NEXT: MemoryIndex: 0 @@ -190,16 +212,22 @@ ; CHECK-NEXT: Offset: ; CHECK-NEXT: Opcode: I32_CONST ; CHECK-NEXT: Value: 16 -; CHECK-NEXT: Content: '00000000' +; CHECK-NEXT: Content: '02000000' ; CHECK-NEXT: - SectionOffset: 45 ; CHECK-NEXT: MemoryIndex: 0 ; CHECK-NEXT: Offset: ; CHECK-NEXT: Opcode: I32_CONST -; CHECK-NEXT: Value: 20 +; CHECK-NEXT: Value: 24 +; CHECK-NEXT: Content: '00000000' +; CHECK-NEXT: - SectionOffset: 54 +; CHECK-NEXT: MemoryIndex: 0 +; CHECK-NEXT: Offset: +; CHECK-NEXT: Opcode: I32_CONST +; CHECK-NEXT: Value: 28 ; CHECK-NEXT: Content: '616263' ; CHECK-NEXT: - Type: CUSTOM ; CHECK-NEXT: Name: linking -; CHECK-NEXT: DataSize: 23 +; CHECK-NEXT: DataSize: 31 ; CHECK-NEXT: SymbolInfo: ; CHECK-NEXT: - Name: hello ; CHECK-NEXT: Flags: [ VISIBILITY_HIDDEN ] @@ -213,6 +241,8 @@ ; CHECK-NEXT: Flags: [ VISIBILITY_HIDDEN ] ; CHECK-NEXT: - Name: func_addr2 ; CHECK-NEXT: Flags: [ VISIBILITY_HIDDEN ] +; CHECK-NEXT: - Name: func_addr3 +; CHECK-NEXT: Flags: [ VISIBILITY_HIDDEN ] ; CHECK-NEXT: - Name: data_addr1 ; CHECK-NEXT: Flags: [ VISIBILITY_HIDDEN ] ; CHECK-NEXT: SegmentInfo: @@ -229,10 +259,14 @@ ; CHECK-NEXT: Alignment: 4 ; CHECK-NEXT: Flags: [ ] ; CHECK-NEXT: - Index: 3 +; CHECK-NEXT: Name: .data.func_addr3 +; CHECK-NEXT: Alignment: 4 +; CHECK-NEXT: Flags: [ ] +; CHECK-NEXT: - Index: 4 ; CHECK-NEXT: Name: .data.data_addr1 ; CHECK-NEXT: Alignment: 8 ; CHECK-NEXT: Flags: [ ] -; CHECK-NEXT: - Index: 4 +; CHECK-NEXT: - Index: 5 ; CHECK-NEXT: Name: .rodata.data_comdat ; CHECK-NEXT: Alignment: 1 ; CHECK-NEXT: Flags: [ ] @@ -240,9 +274,9 @@ ; CHECK-NEXT: - Name: func_comdat ; CHECK-NEXT: Entries: ; CHECK-NEXT: - Kind: FUNCTION -; CHECK-NEXT: Index: 4 +; CHECK-NEXT: Index: 5 ; CHECK-NEXT: - Kind: DATA -; CHECK-NEXT: Index: 4 +; CHECK-NEXT: Index: 5 ; CHECK-NEXT: - Type: CUSTOM ; CHECK-NEXT: Name: name ; CHECK-NEXT: FunctionNames: @@ -251,9 +285,11 @@ ; CHECK-NEXT: - Index: 1 ; CHECK-NEXT: Name: foo_import ; CHECK-NEXT: - Index: 2 -; CHECK-NEXT: Name: hello +; CHECK-NEXT: Name: bar_import ; CHECK-NEXT: - Index: 3 -; CHECK-NEXT: Name: my_func +; CHECK-NEXT: Name: hello ; CHECK-NEXT: - Index: 4 +; CHECK-NEXT: Name: my_func +; CHECK-NEXT: - Index: 5 ; CHECK-NEXT: Name: func_comdat ; CHECK-NEXT: ... Index: wasm/Writer.cpp =================================================================== --- wasm/Writer.cpp +++ wasm/Writer.cpp @@ -596,7 +596,7 @@ void Writer::calculateImports() { for (Symbol *Sym : Symtab->getSymbols()) { - if (!Sym->isUndefined() || Sym->isWeak()) + if (!Sym->isUndefined() || (Sym->isWeak() && !Config->EmitRelocs)) continue; if (Sym->isFunction()) {