mirror of
https://github.com/ziglang/zig.git
synced 2026-02-18 23:39:17 +00:00
link: don't link system libs by the wasm linker
The only allowed system libraries that we can link are libraries that are part of the sysroot such as libc or WASI emulated subcomponents. This is required as Wasm allows to defer symbol resolution until load time. For example, the following import in Zig ```zig extern "wasi_snapshot_preview1" fn proc_exit() void; ``` would normally result in appending `-lwasi_snapshot_preview1` flag to the linker line. However, for Wasm/WASI, the symbol is provided at load rather than link time, therefore, the linker should not be concerned with resolving the symbol. As a result, we should not consider system libs by the Wasm linker.
This commit is contained in:
parent
e8e305b67c
commit
b82d6422ac
@ -701,17 +701,6 @@ fn linkWithLLD(self: *Wasm, comp: *Compilation) !void {
|
||||
const is_exe_or_dyn_lib = self.base.options.output_mode == .Exe or
|
||||
(self.base.options.output_mode == .Lib and self.base.options.link_mode == .Dynamic);
|
||||
if (is_exe_or_dyn_lib) {
|
||||
const system_libs = self.base.options.system_libs.keys();
|
||||
|
||||
for (system_libs) |link_lib| {
|
||||
if (mem.eql(u8, "wasi_snapshot_preview1", link_lib)) {
|
||||
// Any referenced symbol from this lib, will be undefined until
|
||||
// runtime as this lib is provided directly by the runtime.
|
||||
continue;
|
||||
}
|
||||
try argv.append(try std.fmt.allocPrint(arena, "-l{s}", .{link_lib}));
|
||||
}
|
||||
|
||||
const wasi_emulated_libs = self.base.options.wasi_emulated_libs;
|
||||
for (wasi_emulated_libs) |crt_file| {
|
||||
try argv.append(try comp.get_libc_crt_file(
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user