zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 3ee4252183e92ee8ec51c9ba8631bd9524e26b1f (tree)
parent 1ba6838bc3919f2e1306b01a11fd3d5dd01fefe1
Author: Giuseppe Cesarano <PecoraInPannaCotta@gmail.com>
Date:   Fri,  8 Aug 2025 20:32:17 +0200

Fix: std.elf offset computation

Diffstat:
Mlib/std/elf.zig | 12++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)

diff --git a/lib/std/elf.zig b/lib/std/elf.zig @@ -584,7 +584,8 @@ pub const ProgramHeaderIterator = struct { if (it.index >= it.elf_header.phnum) return null; defer it.index += 1; - const offset = it.elf_header.phoff + if (it.elf_header.is_64) @sizeOf(Elf64_Phdr) else @sizeOf(Elf32_Phdr) * it.index; + const size: u64 = if (it.elf_header.is_64) @sizeOf(Elf64_Phdr) else @sizeOf(Elf32_Phdr); + const offset = it.elf_header.phoff + size * it.index; try it.file_reader.seekTo(offset); return takePhdr(&it.file_reader.interface, it.elf_header); @@ -600,7 +601,8 @@ pub const ProgramHeaderBufferIterator = struct { if (it.index >= it.elf_header.phnum) return null; defer it.index += 1; - const offset = it.elf_header.phoff + if (it.elf_header.is_64) @sizeOf(Elf64_Phdr) else @sizeOf(Elf32_Phdr) * it.index; + const size: u64 = if (it.elf_header.is_64) @sizeOf(Elf64_Phdr) else @sizeOf(Elf32_Phdr); + const offset = it.elf_header.phoff + size * it.index; var reader = std.Io.Reader.fixed(it.buf[offset..]); return takePhdr(&reader, it.elf_header); @@ -635,7 +637,8 @@ pub const SectionHeaderIterator = struct { if (it.index >= it.elf_header.shnum) return null; defer it.index += 1; - const offset = it.elf_header.shoff + if (it.elf_header.is_64) @sizeOf(Elf64_Shdr) else @sizeOf(Elf32_Shdr) * it.index; + const size: u64 = if (it.elf_header.is_64) @sizeOf(Elf64_Shdr) else @sizeOf(Elf32_Shdr); + const offset = it.elf_header.shoff + size * it.index; try it.file_reader.seekTo(offset); return takeShdr(&it.file_reader.interface, it.elf_header); @@ -651,7 +654,8 @@ pub const SectionHeaderBufferIterator = struct { if (it.index >= it.elf_header.shnum) return null; defer it.index += 1; - const offset = it.elf_header.shoff + if (it.elf_header.is_64) @sizeOf(Elf64_Shdr) else @sizeOf(Elf32_Shdr) * it.index; + const size: u64 = if (it.elf_header.is_64) @sizeOf(Elf64_Shdr) else @sizeOf(Elf32_Shdr); + const offset = it.elf_header.shoff + size * it.index; var reader = std.Io.Reader.fixed(it.buf[offset..]); return takeShdr(&reader, it.elf_header);