[PATCH] D117058: [ifs] Added missing DT_STRSZ to the .dynamic section
Haowei Wu via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 11 14:56:13 PST 2022
haowei created this revision.
haowei added reviewers: phosek, mcgrathr, jhenderson.
Herald added a subscriber: hiraditya.
haowei requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
This patch adds DT_STRSZ into the dynamic section, which was absent previously. This was a bug and caused failures in other tools.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D117058
Files:
llvm/lib/InterfaceStub/ELFObjHandler.cpp
llvm/test/tools/llvm-ifs/write-stub.test
Index: llvm/test/tools/llvm-ifs/write-stub.test
===================================================================
--- llvm/test/tools/llvm-ifs/write-stub.test
+++ llvm/test/tools/llvm-ifs/write-stub.test
@@ -142,10 +142,11 @@
# CHECK-NEXT: EntrySize: 0
# CHECK-NEXT: }
-# CHECK: DynamicSection [ (4 entries)
+# CHECK: DynamicSection [ (5 entries)
# CHECK-NEXT: Tag Type Name/Value
# CHECK-NEXT: 0x[[DYNTABZ]]0000006 SYMTAB
# CHECK-NEXT: 0x[[DYNTABZ]]0000005 STRTAB
+# CHECK-NEXT: 0x[[DYNTABZ]]000000A STRSZ
# CHECK-NEXT: 0x[[DYNTABZ]]0000001 NEEDED Shared library: [libc.so.6]
# CHECK-NEXT: 0x[[DYNTABZ]]0000000 NULL
# CHECK-NEXT: ]
Index: llvm/lib/InterfaceStub/ELFObjHandler.cpp
===================================================================
--- llvm/lib/InterfaceStub/ELFObjHandler.cpp
+++ llvm/lib/InterfaceStub/ELFObjHandler.cpp
@@ -226,6 +226,7 @@
// Poplulate dynamic table.
size_t DynSymIndex = DynTab.Content.addAddr(DT_SYMTAB, 0);
size_t DynStrIndex = DynTab.Content.addAddr(DT_STRTAB, 0);
+ DynTab.Content.addValue(DT_STRSZ, DynSym.Size);
for (const std::string &Lib : Stub.NeededLibs)
DynTab.Content.addValue(DT_NEEDED, DynStr.Content.getOffset(Lib));
if (Stub.SoName)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D117058.399092.patch
Type: text/x-patch
Size: 1274 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220111/9e896d6c/attachment.bin>
More information about the llvm-commits
mailing list