mirror of
https://github.com/ziglang/zig.git
synced 2026-02-21 16:54:52 +00:00
link.Elf: Skip invoking LLD for zig build-obj for unsupported targets.
LLD doesn't support these yet. Doing this hack will at least allow basic experimentation for these targets.
This commit is contained in:
parent
b16c094926
commit
3e7708b02b
@ -1663,7 +1663,18 @@ fn linkWithLLD(self: *Elf, arena: Allocator, tid: Zcu.PerThread.Id, prog_node: s
|
||||
// copy when generating relocatables. Normally, we would expect `lld -r` to work.
|
||||
// However, because LLD wants to resolve BPF relocations which it shouldn't, it fails
|
||||
// before even generating the relocatable.
|
||||
if (output_mode == .Obj and (comp.config.lto != .none or target.cpu.arch.isBpf())) {
|
||||
//
|
||||
// For m68k, we go through this path because LLD doesn't support it yet, but LLVM can
|
||||
// produce usable object files.
|
||||
if (output_mode == .Obj and
|
||||
(comp.config.lto != .none or
|
||||
target.cpu.arch.isBpf() or
|
||||
target.cpu.arch == .lanai or
|
||||
target.cpu.arch == .m68k or
|
||||
target.cpu.arch.isSPARC() or
|
||||
target.cpu.arch == .ve or
|
||||
target.cpu.arch == .xcore))
|
||||
{
|
||||
// In this case we must do a simple file copy
|
||||
// here. TODO: think carefully about how we can avoid this redundant operation when doing
|
||||
// build-obj. See also the corresponding TODO in linkAsArchive.
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user