zig

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

commit 6553359f398ccc3be10a4975d99cb325a5b7c1fd (tree)
parent 7b1a644d6ee50740196328bd8f7b1a46ac46b4d2
Author: Jacob Young <jacobly0@users.noreply.github.com>
Date:   Sat,  4 Nov 2023 04:58:42 -0400

x86_64: fix ub that the llvm backend was hiding

Diffstat:
Msrc/arch/x86_64/Encoding.zig | 12+++---------
1 file changed, 3 insertions(+), 9 deletions(-)

diff --git a/src/arch/x86_64/Encoding.zig b/src/arch/x86_64/Encoding.zig @@ -62,8 +62,7 @@ pub fn findByMnemonic( .rex, .rex_short => if (!rex_required) continue, else => {}, } - for (input_ops, data.ops) |input_op, data_op| - if (!input_op.isSubset(data_op)) continue :next; + for (input_ops, data.ops) |input_op, data_op| if (!input_op.isSubset(data_op)) continue :next; const enc = Encoding{ .mnemonic = mnemonic, .data = data }; if (shortest_enc) |previous_shortest_enc| { @@ -828,18 +827,13 @@ const mnemonic_to_encodings_map = init: { for (&data_storage, entries, 0..) |*data, entry, data_index| { data.* = .{ .op_en = entry[1], - .ops = undefined, + .ops = (entry[2] ++ .{.none} ** (data.ops.len - entry[2].len)).*, .opc_len = entry[3].len, - .opc = undefined, + .opc = (entry[3] ++ .{undefined} ** (data.opc.len - entry[3].len)).*, .modrm_ext = entry[4], .mode = entry[5], .feature = entry[6], }; - // TODO: use `@memcpy` for these. When I did that, I got a false positive - // compile error for this copy happening at compile time. - std.mem.copyForwards(Op, &data.ops, entry[2]); - std.mem.copyForwards(u8, &data.opc, entry[3]); - while (mnemonic_int < @intFromEnum(entry[0])) : (mnemonic_int += 1) { mnemonic_map[mnemonic_int] = data_storage[mnemonic_start..data_index]; mnemonic_start = data_index;