zig

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

commit b6d6152e6514dcb4e67750cbb22b90b38ebedf49 (tree)
parent ff66a18555dc6c00bd928f48462c3fc44f86ab6c
Author: Andrew Kelley <andrew@ziglang.org>
Date:   Tue,  4 Jan 2022 00:11:45 -0700

link: avoid creating stage2 llvm module when using stage1

Diffstat:
Msrc/link/Coff.zig | 5++++-
Msrc/link/Elf.zig | 4+++-
Msrc/link/MachO.zig | 4+++-
Msrc/link/Wasm.zig | 4+++-
4 files changed, 13 insertions(+), 4 deletions(-)

diff --git a/src/link/Coff.zig b/src/link/Coff.zig @@ -409,7 +409,10 @@ pub fn createEmpty(gpa: Allocator, options: link.Options) !*Coff { }, .ptr_width = ptr_width, }; - if (build_options.have_llvm and options.use_llvm) { + + const use_llvm = build_options.have_llvm and options.use_llvm; + const use_stage1 = build_options.is_stage1 and options.use_stage1; + if (use_llvm and !use_stage1) { self.llvm_object = try LlvmObject.create(gpa, options); } return self; diff --git a/src/link/Elf.zig b/src/link/Elf.zig @@ -304,7 +304,9 @@ pub fn createEmpty(gpa: Allocator, options: link.Options) !*Elf { }, .ptr_width = ptr_width, }; - if (build_options.have_llvm and options.use_llvm) { + const use_llvm = build_options.have_llvm and options.use_llvm; + const use_stage1 = build_options.is_stage1 and options.use_stage1; + if (use_llvm and !use_stage1) { self.llvm_object = try LlvmObject.create(gpa, options); } return self; diff --git a/src/link/MachO.zig b/src/link/MachO.zig @@ -396,7 +396,9 @@ pub fn createEmpty(gpa: Allocator, options: link.Options) !*MachO { .needs_prealloc = needs_prealloc, }; - if (build_options.have_llvm and options.use_llvm) { + const use_llvm = build_options.have_llvm and options.use_llvm; + const use_stage1 = build_options.is_stage1 and options.use_stage1; + if (use_llvm and !use_stage1) { self.llvm_object = try LlvmObject.create(gpa, options); } diff --git a/src/link/Wasm.zig b/src/link/Wasm.zig @@ -145,7 +145,9 @@ pub fn createEmpty(gpa: Allocator, options: link.Options) !*Wasm { .allocator = gpa, }, }; - if (build_options.have_llvm and options.use_llvm) { + const use_llvm = build_options.have_llvm and options.use_llvm; + const use_stage1 = build_options.is_stage1 and options.use_stage1; + if (use_llvm and !use_stage1) { self.llvm_object = try LlvmObject.create(gpa, options); } return self;