Commit 0f02a1fcb0

Jakub Konka <kubkon@jakubkonka.com>
2023-08-28 07:31:44
macho: fix 32bit compilation issues
1 parent 8330065
Changed files (2)
src
link
src/link/MachO/zld.zig
@@ -703,7 +703,8 @@ fn writeAtoms(macho_file: *MachO) !void {
                     log.debug("    (with padding {x})", .{padding_size});
                 }
 
-                const offset = this_sym.n_value - header.addr;
+                const offset = math.cast(usize, this_sym.n_value - header.addr) orelse
+                    return error.Overflow;
                 log.debug("  (at offset 0x{x})", .{offset});
 
                 const code = Atom.getAtomCode(macho_file, atom_index);
@@ -749,7 +750,8 @@ fn writeThunks(macho_file: *MachO) !void {
 
     for (macho_file.thunks.items, 0..) |*thunk, i| {
         if (thunk.getSize() == 0) continue;
-        var buffer = try std.ArrayList(u8).initCapacity(gpa, thunk.getSize());
+        const thunk_size = math.cast(usize, thunk.getSize()) orelse return error.Overflow;
+        var buffer = try std.ArrayList(u8).initCapacity(gpa, thunk_size);
         defer buffer.deinit();
         try thunks.writeThunkCode(macho_file, thunk, buffer.writer());
         const thunk_atom = macho_file.getAtom(thunk.getStartAtomIndex());
@@ -763,7 +765,8 @@ fn writeThunks(macho_file: *MachO) !void {
 fn writePointerEntries(macho_file: *MachO, sect_id: u8, table: anytype) !void {
     const gpa = macho_file.base.allocator;
     const header = macho_file.sections.items(.header)[sect_id];
-    var buffer = try std.ArrayList(u8).initCapacity(gpa, header.size);
+    const capacity = math.cast(usize, header.size) orelse return error.Overflow;
+    var buffer = try std.ArrayList(u8).initCapacity(gpa, capacity);
     defer buffer.deinit();
     for (table.entries.items) |entry| {
         const sym = macho_file.getSymbol(entry);
@@ -779,7 +782,8 @@ fn writeStubs(macho_file: *MachO) !void {
     const stubs_header = macho_file.sections.items(.header)[macho_file.stubs_section_index.?];
     const la_symbol_ptr_header = macho_file.sections.items(.header)[macho_file.la_symbol_ptr_section_index.?];
 
-    var buffer = try std.ArrayList(u8).initCapacity(gpa, stubs_header.size);
+    const capacity = math.cast(usize, stubs_header.size) orelse return error.Overflow;
+    var buffer = try std.ArrayList(u8).initCapacity(gpa, capacity);
     defer buffer.deinit();
 
     for (0..macho_file.stub_table.count()) |index| {
@@ -799,7 +803,8 @@ fn writeStubHelpers(macho_file: *MachO) !void {
     const cpu_arch = macho_file.base.options.target.cpu.arch;
     const stub_helper_header = macho_file.sections.items(.header)[macho_file.stub_helper_section_index.?];
 
-    var buffer = try std.ArrayList(u8).initCapacity(gpa, stub_helper_header.size);
+    const capacity = math.cast(usize, stub_helper_header.size) orelse return error.Overflow;
+    var buffer = try std.ArrayList(u8).initCapacity(gpa, capacity);
     defer buffer.deinit();
 
     {
@@ -842,7 +847,8 @@ fn writeLaSymbolPtrs(macho_file: *MachO) !void {
     const la_symbol_ptr_header = macho_file.sections.items(.header)[macho_file.la_symbol_ptr_section_index.?];
     const stub_helper_header = macho_file.sections.items(.header)[macho_file.stub_helper_section_index.?];
 
-    var buffer = try std.ArrayList(u8).initCapacity(gpa, la_symbol_ptr_header.size);
+    const capacity = math.cast(usize, la_symbol_ptr_header.size) orelse return error.Overflow;
+    var buffer = try std.ArrayList(u8).initCapacity(gpa, capacity);
     defer buffer.deinit();
 
     for (0..macho_file.stub_table.count()) |index| {
src/link/MachO.zig
@@ -927,9 +927,7 @@ fn parseDylib(
     const self_cpu_arch = link_options.target.cpu.arch;
 
     const file_stat = try file.stat();
-    var file_size = math.cast(usize, file_stat.size) orelse return error.Overflow;
-
-    file_size -= offset;
+    const file_size = math.cast(usize, file_stat.size - offset) orelse return error.Overflow;
 
     const contents = try file.readToEndAllocOptions(gpa, file_size, file_size, @alignOf(u64), null);
     defer gpa.free(contents);