zig

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

commit eb696e453ff770e54188e14acb65e01e87a4eebd (tree)
parent 95e66a915b24cb3763707888ffa9726c01905a37
Author: LemonBoy <thatlemon@gmail.com>
Date:   Fri,  8 Jan 2021 12:48:30 +0100

stage2: Implicitly enable --eh_frame_hdr when compiling c/c++ files

Matches what Clang/GCC driver do.

Closes #7711

Diffstat:
Msrc/main.zig | 9+++++++++
1 file changed, 9 insertions(+), 0 deletions(-)

diff --git a/src/main.zig b/src/main.zig @@ -1007,6 +1007,11 @@ fn buildOutputType( ensure_libc_on_non_freestanding = true; ensure_libcpp_on_non_freestanding = arg_mode == .cpp; want_native_include_dirs = true; + // Clang's driver enables this switch unconditionally. + // Disabling the emission of .eh_frame_hdr can unexpectedly break + // some functionality that depend on it, such as C++ exceptions and + // DWARF-based stack traces. + link_eh_frame_hdr = true; const COutMode = enum { link, @@ -1274,6 +1279,10 @@ fn buildOutputType( image_base_override = std.fmt.parseUnsigned(u64, linker_args.items[i], 0) catch |err| { fatal("unable to parse '{s}': {s}", .{ arg, @errorName(err) }); }; + } else if (mem.eql(u8, arg, "--eh-frame-hdr")) { + link_eh_frame_hdr = true; + } else if (mem.eql(u8, arg, "--no-eh-frame-hdr")) { + link_eh_frame_hdr = false; } else { warn("unsupported linker arg: {s}", .{arg}); }