From 3fd6e93f4f6f34658d5e198064f54e1dad09e241 Mon Sep 17 00:00:00 2001 From: Luuk de Gram Date: Mon, 17 Jul 2023 18:38:02 +0200 Subject: [PATCH] wasm-linker: prevent double-free on parse failure --- src/link/Wasm/Object.zig | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/link/Wasm/Object.zig b/src/link/Wasm/Object.zig index 8e4df417ae..6feec26aea 100644 --- a/src/link/Wasm/Object.zig +++ b/src/link/Wasm/Object.zig @@ -353,9 +353,14 @@ fn Parser(comptime ReaderType: type) type { var debug_names = std.ArrayList(u8).init(gpa); errdefer { - while (relocatable_data.popOrNull()) |rel_data| { - gpa.free(rel_data.data[0..rel_data.size]); - } else relocatable_data.deinit(); + // only free the inner contents of relocatable_data if we didn't + // assign it to the object yet. + if (parser.object.relocatable_data.len == 0) { + for (relocatable_data.items) |rel_data| { + gpa.free(rel_data.data[0..rel_data.size]); + } + relocatable_data.deinit(); + } gpa.free(debug_names.items); debug_names.deinit(); }