Nick Desaulniers | 231ad7f | 2021-08-02 11:39:09 -0700 | [diff] [blame] | 1 | # Individual arch/{arch}/Makefiles should use -EL/-EB to set intended |
| 2 | # endianness and -m32/-m64 to set word size based on Kconfigs instead of |
| 3 | # relying on the target triple. |
| 4 | CLANG_TARGET_FLAGS_arm := arm-linux-gnueabi |
| 5 | CLANG_TARGET_FLAGS_arm64 := aarch64-linux-gnu |
| 6 | CLANG_TARGET_FLAGS_hexagon := hexagon-linux-musl |
| 7 | CLANG_TARGET_FLAGS_m68k := m68k-linux-gnu |
| 8 | CLANG_TARGET_FLAGS_mips := mipsel-linux-gnu |
| 9 | CLANG_TARGET_FLAGS_powerpc := powerpc64le-linux-gnu |
| 10 | CLANG_TARGET_FLAGS_riscv := riscv64-linux-gnu |
| 11 | CLANG_TARGET_FLAGS_s390 := s390x-linux-gnu |
| 12 | CLANG_TARGET_FLAGS_x86 := x86_64-linux-gnu |
Kees Cook | c7500c1 | 2022-02-16 16:24:02 -0800 | [diff] [blame] | 13 | CLANG_TARGET_FLAGS_um := $(CLANG_TARGET_FLAGS_$(SUBARCH)) |
Nick Desaulniers | 231ad7f | 2021-08-02 11:39:09 -0700 | [diff] [blame] | 14 | CLANG_TARGET_FLAGS := $(CLANG_TARGET_FLAGS_$(SRCARCH)) |
| 15 | |
| 16 | ifeq ($(CROSS_COMPILE),) |
| 17 | ifeq ($(CLANG_TARGET_FLAGS),) |
| 18 | $(error Specify CROSS_COMPILE or add '--target=' option to scripts/Makefile.clang) |
| 19 | else |
| 20 | CLANG_FLAGS += --target=$(CLANG_TARGET_FLAGS) |
| 21 | endif # CLANG_TARGET_FLAGS |
| 22 | else |
Nick Desaulniers | 6f5b41a | 2021-08-02 11:39:08 -0700 | [diff] [blame] | 23 | CLANG_FLAGS += --target=$(notdir $(CROSS_COMPILE:%-=%)) |
Nick Desaulniers | 231ad7f | 2021-08-02 11:39:09 -0700 | [diff] [blame] | 24 | endif # CROSS_COMPILE |
| 25 | |
Nick Desaulniers | f12b034 | 2021-08-06 10:27:01 -0700 | [diff] [blame] | 26 | ifeq ($(LLVM_IAS),0) |
Nathan Chancellor | 2185a7e | 2021-08-16 13:52:47 -0700 | [diff] [blame] | 27 | CLANG_FLAGS += -fno-integrated-as |
Nick Desaulniers | 6f5b41a | 2021-08-02 11:39:08 -0700 | [diff] [blame] | 28 | GCC_TOOLCHAIN_DIR := $(dir $(shell which $(CROSS_COMPILE)elfedit)) |
| 29 | CLANG_FLAGS += --prefix=$(GCC_TOOLCHAIN_DIR)$(notdir $(CROSS_COMPILE)) |
Nick Desaulniers | f12b034 | 2021-08-06 10:27:01 -0700 | [diff] [blame] | 30 | else |
Nathan Chancellor | 2185a7e | 2021-08-16 13:52:47 -0700 | [diff] [blame] | 31 | CLANG_FLAGS += -fintegrated-as |
Nick Desaulniers | 6f5b41a | 2021-08-02 11:39:08 -0700 | [diff] [blame] | 32 | endif |
Nathan Chancellor | 0664684 | 2021-09-16 11:40:17 -0700 | [diff] [blame] | 33 | # By default, clang only warns when it encounters an unknown warning flag or |
| 34 | # certain optimization flags it knows it has not implemented. |
| 35 | # Make it behave more like gcc by erroring when these flags are encountered |
| 36 | # so they can be implemented or wrapped in cc-option. |
Nick Desaulniers | 6f5b41a | 2021-08-02 11:39:08 -0700 | [diff] [blame] | 37 | CLANG_FLAGS += -Werror=unknown-warning-option |
Nathan Chancellor | 0664684 | 2021-09-16 11:40:17 -0700 | [diff] [blame] | 38 | CLANG_FLAGS += -Werror=ignored-optimization-argument |
Nathan Chancellor | db1547c | 2023-01-11 20:05:10 -0700 | [diff] [blame] | 39 | CLANG_FLAGS += -Werror=option-ignored |
| 40 | CLANG_FLAGS += -Werror=unused-command-line-argument |
Nick Desaulniers | 6f5b41a | 2021-08-02 11:39:08 -0700 | [diff] [blame] | 41 | KBUILD_CFLAGS += $(CLANG_FLAGS) |
| 42 | KBUILD_AFLAGS += $(CLANG_FLAGS) |
| 43 | export CLANG_FLAGS |