aboutsummaryrefslogtreecommitdiff
path: root/lib/std
diff options
context:
space:
mode:
authorGiuseppe Cesarano <PecoraInPannaCotta@gmail.com>2025-08-08 20:32:17 +0200
committerAndrew Kelley <andrew@ziglang.org>2025-08-08 12:47:00 -0700
commit3ee4252183e92ee8ec51c9ba8631bd9524e26b1f (patch)
treec72e47defe12130819fcf0fbdcaff1651c7a0a98 /lib/std
parent1ba6838bc3919f2e1306b01a11fd3d5dd01fefe1 (diff)
downloadzig-3ee4252183e92ee8ec51c9ba8631bd9524e26b1f.tar.gz
zig-3ee4252183e92ee8ec51c9ba8631bd9524e26b1f.zip
Fix: std.elf offset computation
Diffstat (limited to 'lib/std')
-rw-r--r--lib/std/elf.zig12
1 files changed, 8 insertions, 4 deletions
diff --git a/lib/std/elf.zig b/lib/std/elf.zig
index 0be6e6d0a2..e6c4a10ea6 100644
--- 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);