[llvm] [llvm-objcopy] Always update indirectsymoff in MachO (PR #117726)

Richard Dzenis via llvm-commits llvm-commits at lists.llvm.org
Fri Nov 29 00:59:11 PST 2024


https://github.com/RIscRIpt updated https://github.com/llvm/llvm-project/pull/117726

>From a4a49ad623f358824c67767f4db5913c77f82949 Mon Sep 17 00:00:00 2001
From: Richard Dzenis <richard.dzenis at zimperium.com>
Date: Tue, 26 Nov 2024 17:23:24 +0200
Subject: [PATCH] [llvm-objcopy] Always update indirectsymoff in MachO

Let's say we've run llvm-strip over some MachO. The resulting MachO
became smaller and there are no indirect symbols anymore.

Then according to previous code we would not update indirectsymoff
field. This would lead to `MachOWriter::totalSize()` report size that is
larger than the new MachO. As a result we would get MachO that has zero
bytes past contents of the very last load command.

Codesign has a strict check that size of MachO file must be equal to

    lastLoadCommand.offset + lastLoadCommand.size

If this is not satisfied codesign reports the following error

    main executable failed strict validation

Fixes #117723
---
 llvm/lib/ObjCopy/MachO/MachOLayoutBuilder.cpp | 11 ++---
 .../MachO/dysymtab-zero-indirectsym.test      | 48 +++++++++++++++++++
 2 files changed, 52 insertions(+), 7 deletions(-)
 create mode 100644 llvm/test/tools/llvm-objcopy/MachO/dysymtab-zero-indirectsym.test

diff --git a/llvm/lib/ObjCopy/MachO/MachOLayoutBuilder.cpp b/llvm/lib/ObjCopy/MachO/MachOLayoutBuilder.cpp
index a3d4ba3a94f7ac..93bc6631e64c86 100644
--- a/llvm/lib/ObjCopy/MachO/MachOLayoutBuilder.cpp
+++ b/llvm/lib/ObjCopy/MachO/MachOLayoutBuilder.cpp
@@ -360,13 +360,10 @@ Error MachOLayoutBuilder::layoutTail(uint64_t Offset) {
           MLC.dysymtab_command_data.nextrel != 0)
         return createStringError(llvm::errc::not_supported,
                                  "shared library is not yet supported");
-
-      if (!O.IndirectSymTable.Symbols.empty()) {
-        MLC.dysymtab_command_data.indirectsymoff = StartOfIndirectSymbols;
-        MLC.dysymtab_command_data.nindirectsyms =
-            O.IndirectSymTable.Symbols.size();
-      }
-
+      MLC.dysymtab_command_data.indirectsymoff =
+          O.IndirectSymTable.Symbols.size() ? StartOfIndirectSymbols : 0;
+      MLC.dysymtab_command_data.nindirectsyms =
+          O.IndirectSymTable.Symbols.size();
       updateDySymTab(MLC);
       break;
     }
diff --git a/llvm/test/tools/llvm-objcopy/MachO/dysymtab-zero-indirectsym.test b/llvm/test/tools/llvm-objcopy/MachO/dysymtab-zero-indirectsym.test
new file mode 100644
index 00000000000000..bdfb8b809928d0
--- /dev/null
+++ b/llvm/test/tools/llvm-objcopy/MachO/dysymtab-zero-indirectsym.test
@@ -0,0 +1,48 @@
+## Show that llvm-strip correctly zeroes out indirectsymoff and indirectsyms
+## in LC_DYSYMTAB if there are no symbols
+#
+# RUN: yaml2obj %s -o %t
+# RUN: llvm-strip --strip-all %t -o %t.stripped
+# RUN: obj2yaml %t.stripped | FileCheck %s
+
+# CHECK: indirectsymoff: 0
+# CHECK-NEXT: nindirectsyms: 0
+
+--- !mach-o
+FileHeader:
+  magic:           0xFEEDFACF
+  cputype:         0x01000007
+  cpusubtype:      0x80000003
+  filetype:        0x00000002
+  ncmds:           2
+  sizeofcmds:      104
+  flags:           0x00200085
+  reserved:        0x00000000
+LoadCommands:
+  - cmd:             LC_SYMTAB
+    cmdsize:         24
+    symoff:          0
+    nsyms:           0
+    stroff:          0
+    strsize:         0
+  - cmd:             LC_DYSYMTAB
+    cmdsize:         80
+    ilocalsym:       0
+    nlocalsym:       0
+    iextdefsym:      0
+    nextdefsym:      0
+    iundefsym:       0
+    nundefsym:       0
+    tocoff:          0
+    ntoc:            0
+    modtaboff:       0
+    nmodtab:         0
+    extrefsymoff:    0
+    nextrefsyms:     0
+    indirectsymoff:  42
+    nindirectsyms:   0
+    extreloff:       0
+    nextrel:         0
+    locreloff:       0
+    nlocrel:         0
+...



More information about the llvm-commits mailing list