[PATCH] D158799: [llvm-nm][WebAssembly] Report the size of data symbols
Sam Clegg via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 25 16:48:36 PDT 2023
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rG79cf24e2118f: [llvm-nm][WebAssembly] Report the size of data symbols (authored by sbc100).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D158799/new/
https://reviews.llvm.org/D158799
Files:
llvm/lib/Object/WasmObjectFile.cpp
llvm/test/tools/llvm-nm/wasm/print-size.test
llvm/tools/llvm-nm/llvm-nm.cpp
Index: llvm/tools/llvm-nm/llvm-nm.cpp
===================================================================
--- llvm/tools/llvm-nm/llvm-nm.cpp
+++ llvm/tools/llvm-nm/llvm-nm.cpp
@@ -1818,6 +1818,12 @@
dyn_cast<const XCOFFObjectFile>(&Obj))
S.Size = XCOFFObj->getSymbolSize(Sym.getRawDataRefImpl());
+ if (const WasmObjectFile *WasmObj = dyn_cast<WasmObjectFile>(&Obj)) {
+ const WasmSymbol &WasmSym = WasmObj->getWasmSymbol(Sym);
+ if (WasmSym.isTypeData())
+ S.Size = WasmSym.Info.DataRef.Size;
+ }
+
if (PrintAddress && isa<ObjectFile>(Obj)) {
SymbolRef SymRef(Sym);
Expected<uint64_t> AddressOrErr = SymRef.getAddress();
Index: llvm/test/tools/llvm-nm/wasm/print-size.test
===================================================================
--- /dev/null
+++ llvm/test/tools/llvm-nm/wasm/print-size.test
@@ -0,0 +1,46 @@
+# RUN: yaml2obj %s -o %t.o
+# RUN: llvm-nm --print-size %t.o | FileCheck %s --strict-whitespace
+# RUN: llvm-nm -S %t.o | FileCheck %s --strict-whitespace
+
+--- !WASM
+FileHeader:
+ Version: 0x1
+Sections:
+ - Type: TYPE
+ Signatures:
+ - Index: 0
+ ParamTypes: []
+ ReturnTypes: []
+ - Type: FUNCTION
+ FunctionTypes: [ 0 ]
+ - Type: CODE
+ Functions:
+ - Index: 0
+ Locals:
+ Body: 200008808080800041000B
+ - Type: DATA
+ Segments:
+ - SectionOffset: 6
+ InitFlags: 0
+ Offset:
+ Opcode: I32_CONST
+ Value: 0
+ Content: '00000000'
+ - Type: CUSTOM
+ Name: linking
+ Version: 2
+ SymbolTable:
+ - Index: 0
+ Kind: FUNCTION
+ Name: a_func
+ Flags: [ ]
+ Function: 0
+ - Index: 1
+ Kind: DATA
+ Name: a_data_symbol
+ Flags: [ ]
+ Segment: 0
+ Size: 32
+
+# CHECK: 00000000 00000020 D a_data_symbol
+# CHECK: 00000001 00000000 T a_func
Index: llvm/lib/Object/WasmObjectFile.cpp
===================================================================
--- llvm/lib/Object/WasmObjectFile.cpp
+++ llvm/lib/Object/WasmObjectFile.cpp
@@ -724,7 +724,7 @@
if (IsDefined) {
auto Index = readVaruint32(Ctx);
if (Index >= DataSegments.size())
- return make_error<GenericBinaryError>("invalid data symbol index",
+ return make_error<GenericBinaryError>("invalid data segment index",
object_error::parse_failed);
auto Offset = readVaruint64(Ctx);
auto Size = readVaruint64(Ctx);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D158799.553671.patch
Type: text/x-patch
Size: 2833 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20230825/81cdf717/attachment.bin>
More information about the llvm-commits
mailing list