diff options
| author | Jakub Konka <kubkon@jakubkonka.com> | 2024-08-06 22:28:38 +0200 |
|---|---|---|
| committer | Jakub Konka <kubkon@jakubkonka.com> | 2024-08-07 10:21:03 +0200 |
| commit | 89db24ec6d6195cc10f17bf21dd9bf23e6ff1bf1 (patch) | |
| tree | d07d4fdbc63acb4d68ffc02969f10dfaad98637d /src/link | |
| parent | e99818c602f7e2f75c62be7c4329688c8fa5afe1 (diff) | |
| download | zig-89db24ec6d6195cc10f17bf21dd9bf23e6ff1bf1.tar.gz zig-89db24ec6d6195cc10f17bf21dd9bf23e6ff1bf1.zip | |
elf: fix .eh_frame calc in relocatable mode
Diffstat (limited to 'src/link')
| -rw-r--r-- | src/link/Elf.zig | 4 | ||||
| -rw-r--r-- | src/link/Elf/eh_frame.zig | 6 |
2 files changed, 7 insertions, 3 deletions
diff --git a/src/link/Elf.zig b/src/link/Elf.zig index 1a3087e8f9..e5885cefc4 100644 --- a/src/link/Elf.zig +++ b/src/link/Elf.zig @@ -5860,6 +5860,10 @@ pub const Ref = struct { index: u32, file: u32, + pub fn eql(ref: Ref, other: Ref) bool { + return ref.index == other.index and ref.file == other.file; + } + pub fn format( ref: Ref, comptime unused_fmt_string: []const u8, diff --git a/src/link/Elf/eh_frame.zig b/src/link/Elf/eh_frame.zig index 30f35b16d8..f090cf0820 100644 --- a/src/link/Elf/eh_frame.zig +++ b/src/link/Elf/eh_frame.zig @@ -145,10 +145,10 @@ pub const Cie = struct { if (cie_rel.r_addend != other_rel.r_addend) return false; const cie_object = elf_file.file(cie.file_index).?.object; + const cie_ref = cie_object.resolveSymbol(cie_rel.r_sym(), elf_file); const other_object = elf_file.file(other.file_index).?.object; - const cie_sym = cie_object.symbols.items[cie_rel.r_sym()]; - const other_sym = other_object.symbols.items[other_rel.r_sym()]; - if (!std.mem.eql(u8, std.mem.asBytes(&cie_sym), std.mem.asBytes(&other_sym))) return false; + const other_ref = other_object.resolveSymbol(other_rel.r_sym(), elf_file); + if (!cie_ref.eql(other_ref)) return false; } return true; } |
