From 7145064efde75aaf4711671d1f5461ea56040815 Mon Sep 17 00:00:00 2001 From: Jakub Konka Date: Tue, 8 Nov 2022 15:45:15 +0100 Subject: macho: fix parsing len of DW_FORM_string --- src/link/MachO/DwarfInfo.zig | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) (limited to 'src') diff --git a/src/link/MachO/DwarfInfo.zig b/src/link/MachO/DwarfInfo.zig index 48c5782571..dad248f60e 100644 --- a/src/link/MachO/DwarfInfo.zig +++ b/src/link/MachO/DwarfInfo.zig @@ -257,13 +257,21 @@ pub const Attribute = struct { } pub fn getString(self: Attribute, ctx: DwarfInfo, cuh: CompileUnit.Header) ?[]const u8 { - if (self.form != dwarf.FORM.strp) return null; const debug_info = self.getDebugInfo(ctx); - const off = if (cuh.is_64bit) - mem.readIntLittle(u64, debug_info[0..8]) - else - mem.readIntLittle(u32, debug_info[0..4]); - return ctx.getString(off); + + switch (self.form) { + dwarf.FORM.string => { + return mem.sliceTo(@ptrCast([*:0]const u8, debug_info.ptr), 0); + }, + dwarf.FORM.strp => { + const off = if (cuh.is_64bit) + mem.readIntLittle(u64, debug_info[0..8]) + else + mem.readIntLittle(u32, debug_info[0..4]); + return ctx.getString(off); + }, + else => return null, + } } pub fn getConstant(self: Attribute, ctx: DwarfInfo) !?i128 { @@ -440,8 +448,9 @@ fn findFormSize(self: DwarfInfo, form: u64, di_off: usize, cuh: CompileUnit.Head dwarf.FORM.string => { var count: usize = 0; - while (true) : (count += 1) { + while (true) { const byte = try reader.readByte(); + count += 1; if (byte == 0x0) break; } return count; -- cgit v1.2.3 From 9db63d4f1d394f54225b87b53665f76a2b99d312 Mon Sep 17 00:00:00 2001 From: Jakub Konka Date: Tue, 8 Nov 2022 17:39:46 +0100 Subject: macho: fix handling of DW_FORM_block* forms --- src/link/MachO/DwarfInfo.zig | 24 ++++++++++++++++++++---- 1 file changed, 20 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/link/MachO/DwarfInfo.zig b/src/link/MachO/DwarfInfo.zig index dad248f60e..3e822bb80c 100644 --- a/src/link/MachO/DwarfInfo.zig +++ b/src/link/MachO/DwarfInfo.zig @@ -402,6 +402,26 @@ fn findFormSize(self: DwarfInfo, form: u64, di_off: usize, cuh: CompileUnit.Head => return if (cuh.is_64bit) @sizeOf(u64) else @sizeOf(u32), dwarf.FORM.addr => return cuh.address_size, + + dwarf.FORM.block1, + dwarf.FORM.block2, + dwarf.FORM.block4, + dwarf.FORM.block, + => { + const len: u64 = switch (form) { + dwarf.FORM.block1 => try reader.readIntLittle(u8), + dwarf.FORM.block2 => try reader.readIntLittle(u16), + dwarf.FORM.block4 => try reader.readIntLittle(u32), + dwarf.FORM.block => try leb.readULEB128(u64, reader), + else => unreachable, + }; + var i: u64 = 0; + while (i < len) : (i += 1) { + _ = try reader.readByte(); + } + return creader.bytes_read; + }, + dwarf.FORM.exprloc => { const expr_len = try leb.readULEB128(u64, reader); var i: u64 = 0; @@ -414,18 +434,15 @@ fn findFormSize(self: DwarfInfo, form: u64, di_off: usize, cuh: CompileUnit.Head dwarf.FORM.data1, dwarf.FORM.ref1, - dwarf.FORM.block1, dwarf.FORM.flag, => return @sizeOf(u8), dwarf.FORM.data2, dwarf.FORM.ref2, - dwarf.FORM.block2, => return @sizeOf(u16), dwarf.FORM.data4, dwarf.FORM.ref4, - dwarf.FORM.block4, => return @sizeOf(u32), dwarf.FORM.data8, @@ -435,7 +452,6 @@ fn findFormSize(self: DwarfInfo, form: u64, di_off: usize, cuh: CompileUnit.Head dwarf.FORM.udata, dwarf.FORM.ref_udata, - dwarf.FORM.block, => { _ = try leb.readULEB128(u64, reader); return math.cast(usize, creader.bytes_read) orelse error.Overflow; -- cgit v1.2.3 From 188ad31cf3516c6b9b04b8f4a13bd539f9db8803 Mon Sep 17 00:00:00 2001 From: Jakub Konka Date: Tue, 8 Nov 2022 21:21:25 +0100 Subject: macho: fix 32bit build --- src/link/MachO/DwarfInfo.zig | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src') diff --git a/src/link/MachO/DwarfInfo.zig b/src/link/MachO/DwarfInfo.zig index 3e822bb80c..a8f44df5c3 100644 --- a/src/link/MachO/DwarfInfo.zig +++ b/src/link/MachO/DwarfInfo.zig @@ -419,7 +419,7 @@ fn findFormSize(self: DwarfInfo, form: u64, di_off: usize, cuh: CompileUnit.Head while (i < len) : (i += 1) { _ = try reader.readByte(); } - return creader.bytes_read; + return math.cast(usize, creader.bytes_read) orelse error.Overflow; }, dwarf.FORM.exprloc => { -- cgit v1.2.3