commit 33f0d458cf1ff8450297274f2e69afd64abbe816 (tree)
parent 5c39ccdddaa0a601e233aad9a146561bb8ac6b82
Author: Rafael Batiati <rbatiati@gmail.com>
Date: Tue, 11 Feb 2025 18:12:44 -0300
std.elf: fix panic while parsing header
When parsing an invalid (e.g., corrupted) ELF header, `@enumFromInt` can panic casting the exhaustive enum `ET`.
Diffstat:
1 file changed, 6 insertions(+), 0 deletions(-)
diff --git a/lib/std/elf.zig b/lib/std/elf.zig
@@ -462,6 +462,8 @@ pub const ET = enum(u16) {
/// Core file
CORE = 4,
+ _,
+
/// Beginning of OS-specific codes
pub const LOOS = 0xfe00;
@@ -532,17 +534,21 @@ pub const Header = struct {
};
const need_bswap = endian != native_endian;
+ // Converting integers to exhaustive enums using `@enumFromInt` could cause a panic.
+ comptime assert(!@typeInfo(OSABI).@"enum".is_exhaustive);
const os_abi: OSABI = @enumFromInt(hdr32.e_ident[EI_OSABI]);
// The meaning of this value depends on `os_abi` so just make it available as `u8`.
const abi_version = hdr32.e_ident[EI_ABIVERSION];
const @"type" = if (need_bswap) blk: {
+ comptime assert(!@typeInfo(ET).@"enum".is_exhaustive);
const value = @intFromEnum(hdr32.e_type);
break :blk @as(ET, @enumFromInt(@byteSwap(value)));
} else hdr32.e_type;
const machine = if (need_bswap) blk: {
+ comptime assert(!@typeInfo(EM).@"enum".is_exhaustive);
const value = @intFromEnum(hdr32.e_machine);
break :blk @as(EM, @enumFromInt(@byteSwap(value)));
} else hdr32.e_machine;