wasm linker: fix off-by-one in function table indexes

This commit is contained in:
Andrew Kelley 2025-01-10 19:31:14 -08:00
parent e44bafe5ff
commit 7b255235d6
2 changed files with 11 additions and 7 deletions

View File

@ -81,7 +81,7 @@ pub fn lowerToCode(emit: *Emit) Error!void {
if (is_obj) {
@panic("TODO");
} else {
leb.writeUleb128(code.fixedWriter(), @intFromEnum(datas[inst].indirect_function_table_index)) catch unreachable;
leb.writeUleb128(code.fixedWriter(), 1 + @intFromEnum(datas[inst].indirect_function_table_index)) catch unreachable;
}
inst += 1;
continue :loop tags[inst];

View File

@ -59,6 +59,10 @@ const IndirectFunctionTableIndex = enum(u32) {
// These are the same since those are added to the table first.
return @enumFromInt(@intFromEnum(i));
}
fn toAbi(i: IndirectFunctionTableIndex) u32 {
return @intFromEnum(i) + 1;
}
};
const DataSegmentGroup = struct {
@ -777,9 +781,9 @@ pub fn finish(f: *Flush, wasm: *Wasm) !void {
for (wasm.func_table_fixups.items) |fixup| {
const table_index: IndirectFunctionTableIndex = .fromZcuIndirectFunctionSetIndex(fixup.table_index);
if (!is64) {
mem.writeInt(u32, wasm.string_bytes.items[fixup.offset..][0..4], @intFromEnum(table_index), .little);
mem.writeInt(u32, wasm.string_bytes.items[fixup.offset..][0..4], table_index.toAbi(), .little);
} else {
mem.writeInt(u64, wasm.string_bytes.items[fixup.offset..][0..8], @intFromEnum(table_index), .little);
mem.writeInt(u64, wasm.string_bytes.items[fixup.offset..][0..8], table_index.toAbi(), .little);
}
}
}
@ -1582,19 +1586,19 @@ fn applyRelocs(code: []u8, code_offset: u32, relocs: Wasm.ObjectRelocation.Itera
}
fn reloc_u32_table_index(code: []u8, i: IndirectFunctionTableIndex) void {
mem.writeInt(u32, code[0..4], @intFromEnum(i), .little);
mem.writeInt(u32, code[0..4], i.toAbi(), .little);
}
fn reloc_u64_table_index(code: []u8, i: IndirectFunctionTableIndex) void {
mem.writeInt(u64, code[0..8], @intFromEnum(i), .little);
mem.writeInt(u64, code[0..8], i.toAbi(), .little);
}
fn reloc_sleb_table_index(code: []u8, i: IndirectFunctionTableIndex) void {
leb.writeSignedFixed(5, code[0..5], @intFromEnum(i));
leb.writeSignedFixed(5, code[0..5], i.toAbi());
}
fn reloc_sleb64_table_index(code: []u8, i: IndirectFunctionTableIndex) void {
leb.writeSignedFixed(11, code[0..11], @intFromEnum(i));
leb.writeSignedFixed(11, code[0..11], i.toAbi());
}
fn reloc_u32_function(code: []u8, function: Wasm.OutputFunctionIndex) void {