motiejus/zig

fork of https://codeberg.org/ziglang/zig
git clone https://git.jakstys.lt/motiejus/zig.git
Log | Tree | Refs | README | LICENSE

commit 129fe8668c8b4835c11c50360ee4ed36972ae773 (tree)
parent e5a66184eda96d8571ea5abaf7d5623d092bfac2
Author: Jakub Konka <kubkon@jakubkonka.com>
Date:   Sat, 13 Jul 2024 07:56:28 +0200

macho: write non-incremental atoms in ZigObject

Diffstat:
Msrc/link/MachO.zig | 3+++
Msrc/link/MachO/ZigObject.zig | 17++++++++++++++---
2 files changed, 17 insertions(+), 3 deletions(-)

diff --git a/src/link/MachO.zig b/src/link/MachO.zig @@ -2351,6 +2351,9 @@ fn writeSectionsAndUpdateLinkeditSizes(self: *MachO) !void { for (self.objects.items) |index| { try self.getFile(index).?.writeAtoms(self); } + if (self.getZigObject()) |zo| { + try zo.writeAtoms(self); + } if (self.getInternalObject()) |obj| { try obj.asFile().writeAtoms(self); } diff --git a/src/link/MachO/ZigObject.zig b/src/link/MachO/ZigObject.zig @@ -508,9 +508,20 @@ pub fn writeAtomsRelocatable(self: *ZigObject, macho_file: *MachO) !void { // For example, TLS data gets written out via traditional route. // Is there any better way of handling this? pub fn writeAtoms(self: *ZigObject, macho_file: *MachO) !void { - const gpa = macho_file.base.comp.gpa; - _ = gpa; - _ = self; + const tracy = trace(@src()); + defer tracy.end(); + + for (self.getAtoms()) |atom_index| { + const atom = self.getAtom(atom_index) orelse continue; + if (!atom.flags.alive) continue; + const sect = atom.getInputSection(macho_file); + if (sect.isZerofill()) continue; + if (macho_file.isZigSection(atom.out_n_sect)) continue; + const off = atom.value; + const buffer = macho_file.sections.items(.out)[atom.out_n_sect].items; + try self.getAtomData(macho_file, atom.*, buffer[off..][0..atom.size]); + try atom.resolveRelocs(macho_file, buffer[off..][0..atom.size]); + } } pub fn calcSymtabSize(self: *ZigObject, macho_file: *MachO) void {