aboutsummaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorAleksandr Nogikh <nogikh@google.com>2025-04-16 16:12:58 +0200
committerAleksandr Nogikh <nogikh@google.com>2025-04-17 07:57:15 +0000
commitb3008567ea0fa2942115d4c4013a16f3ff0e4952 (patch)
tree1ba093e631ae9f70a915c4d1a9f77770da58a0f9 /sys
parent5b14b31251d4cc2e33eb313e29b037262c597679 (diff)
all: use LLVM=1 for building Linux with clang
This is the standard way now. Since our configuration permits multiple parameter value combinations, explicitly check for the compiler and linker that were to be passed via CC and LD, and replace that with LLVM=1 if they were clang and ld.lld correspondingly. Update syz-kconf to rely on pkg/build's exported functionality for generating Linux kernel build arguments.
Diffstat (limited to 'sys')
-rw-r--r--sys/targets/targets.go11
1 files changed, 8 insertions, 3 deletions
diff --git a/sys/targets/targets.go b/sys/targets/targets.go
index 2cf001473..50f5c5121 100644
--- a/sys/targets/targets.go
+++ b/sys/targets/targets.go
@@ -881,6 +881,11 @@ func (target *Target) Timeouts(slowdown int) Timeouts {
return timeouts
}
+const (
+ DefaultLLVMCompiler = "clang"
+ DefaultLLVMLinker = "ld.lld"
+)
+
func (target *Target) setCompiler(clang bool) {
// setCompiler may be called effectively twice for target.other,
// so first we remove flags the previous call may have added.
@@ -895,9 +900,9 @@ func (target *Target) setCompiler(clang bool) {
}
target.CFlags = target.CFlags[:pos]
if clang {
- target.CCompiler = "clang"
- target.KernelCompiler = "clang"
- target.KernelLinker = "ld.lld"
+ target.CCompiler = DefaultLLVMCompiler
+ target.KernelCompiler = DefaultLLVMCompiler
+ target.KernelLinker = DefaultLLVMLinker
if target.Triple != "" {
target.CFlags = append(target.CFlags, "--target="+target.Triple)
}