diff --git a/src/link/MachO.zig b/src/link/MachO.zig index cc5b9ecdc6..9e205417e3 100644 --- a/src/link/MachO.zig +++ b/src/link/MachO.zig @@ -613,6 +613,9 @@ pub fn flushModule(self: *MachO, comp: *Compilation, prog_node: *std.Progress.No if (self.dyld_stub_binder_index == null) { self.dyld_stub_binder_index = try self.addUndefined("dyld_stub_binder", .add_got); } + if (!self.base.options.single_threaded) { + _ = try self.addUndefined("_tlv_bootstrap", .none); + } try self.createMhExecuteHeaderSymbol(); diff --git a/src/link/MachO/Relocation.zig b/src/link/MachO/Relocation.zig index 1d1d91279c..cb62ff98f0 100644 --- a/src/link/MachO/Relocation.zig +++ b/src/link/MachO/Relocation.zig @@ -48,6 +48,7 @@ pub fn isResolvable(self: Relocation, macho_file: *MachO) bool { pub fn getTargetAtomIndex(self: Relocation, macho_file: *MachO) ?Atom.Index { switch (self.type) { .got, .got_page, .got_pageoff => return macho_file.getGotAtomIndexForSymbol(self.target), + .tlv, .tlv_page, .tlv_pageoff => return macho_file.getTlvpAtomIndexForSymbol(self.target), else => {}, } if (macho_file.getStubsAtomIndexForSymbol(self.target)) |stubs_atom| return stubs_atom;