1fbe934d6SPalmer Dabbelt# This file is included by the global makefile so that you can add your own 28212f898SMasahiro Yamada# architecture-specific flags and dependencies. 3fbe934d6SPalmer Dabbelt# 4fbe934d6SPalmer Dabbelt# This file is subject to the terms and conditions of the GNU General Public 5fbe934d6SPalmer Dabbelt# License. See the file "COPYING" in the main directory of this archive 6fbe934d6SPalmer Dabbelt# for more details. 7fbe934d6SPalmer Dabbelt# 8fbe934d6SPalmer Dabbelt 926e7aacbSAlexandre GhitiLDFLAGS_vmlinux := -z norelro 1039b33072SAlexandre Ghitiifeq ($(CONFIG_RELOCATABLE),y) 1126e7aacbSAlexandre Ghiti LDFLAGS_vmlinux += -shared -Bsymbolic -z notext --emit-relocs 1239b33072SAlexandre Ghiti KBUILD_CFLAGS += -fPIE 1339b33072SAlexandre Ghitiendif 14a1d2a6b4SAlan Kaoifeq ($(CONFIG_DYNAMIC_FTRACE),y) 1539b33072SAlexandre Ghiti LDFLAGS_vmlinux += --no-relax 16afc76b8bSGuo Ren KBUILD_CPPFLAGS += -DCC_USING_PATCHABLE_FUNCTION_ENTRY 17409c8fb2SGuo Renifeq ($(CONFIG_RISCV_ISA_C),y) 18409c8fb2SGuo Ren CC_FLAGS_FTRACE := -fpatchable-function-entry=4 196724a76cSGuo Renelse 206724a76cSGuo Ren CC_FLAGS_FTRACE := -fpatchable-function-entry=2 21409c8fb2SGuo Renendif 22a1d2a6b4SAlan Kaoendif 23aad15bc8SVincent Chen 245d2388dbSKhem Rajifeq ($(CONFIG_CMODEL_MEDLOW),y) 25aad15bc8SVincent ChenKBUILD_CFLAGS_MODULE += -mcmodel=medany 26aad15bc8SVincent Chenendif 27fbe934d6SPalmer Dabbelt 28fbe934d6SPalmer Dabbeltexport BITS 29fbe934d6SPalmer Dabbeltifeq ($(CONFIG_ARCH_RV64I),y) 30fbe934d6SPalmer Dabbelt BITS := 64 31fbe934d6SPalmer Dabbelt UTS_MACHINE := riscv64 32fbe934d6SPalmer Dabbelt 33fbe934d6SPalmer Dabbelt KBUILD_CFLAGS += -mabi=lp64 34fbe934d6SPalmer Dabbelt KBUILD_AFLAGS += -mabi=lp64 35a89757daSAlex Guo 36d503ac53SMasahiro Yamada KBUILD_LDFLAGS += -melf64lriscv 37fbe934d6SPalmer Dabbeltelse 38fbe934d6SPalmer Dabbelt BITS := 32 39fbe934d6SPalmer Dabbelt UTS_MACHINE := riscv32 40fbe934d6SPalmer Dabbelt 41fbe934d6SPalmer Dabbelt KBUILD_CFLAGS += -mabi=ilp32 42fbe934d6SPalmer Dabbelt KBUILD_AFLAGS += -mabi=ilp32 43d503ac53SMasahiro Yamada KBUILD_LDFLAGS += -melf32lriscv 44fbe934d6SPalmer Dabbeltendif 45fbe934d6SPalmer Dabbelt 46ec3a5cb6SKhem Rajifeq ($(CONFIG_LD_IS_LLD),y) 47fccb3d3eSMasahiro Yamadaifeq ($(call test-lt, $(CONFIG_LLD_VERSION), 150000),y) 48ec3a5cb6SKhem Raj KBUILD_CFLAGS += -mno-relax 49ec3a5cb6SKhem Raj KBUILD_AFLAGS += -mno-relax 5052cc02b9SMasahiro Yamadaifndef CONFIG_AS_IS_LLVM 51ec3a5cb6SKhem Raj KBUILD_CFLAGS += -Wa,-mno-relax 52ec3a5cb6SKhem Raj KBUILD_AFLAGS += -Wa,-mno-relax 53ec3a5cb6SKhem Rajendif 54ec3a5cb6SKhem Rajendif 553cebf80eSFangrui Songendif 56ec3a5cb6SKhem Raj 57e8be5302SAlan Kao# ISA string setting 5809afac77SChristoph Hellwigriscv-march-$(CONFIG_ARCH_RV32I) := rv32ima 5909afac77SChristoph Hellwigriscv-march-$(CONFIG_ARCH_RV64I) := rv64ima 609671f706SAlan Kaoriscv-march-$(CONFIG_FPU) := $(riscv-march-y)fd 61e8be5302SAlan Kaoriscv-march-$(CONFIG_RISCV_ISA_C) := $(riscv-march-y)c 62fa8e7cceSGuo Renriscv-march-$(CONFIG_RISCV_ISA_V) := $(riscv-march-y)v 636df2a016SAurelien Jarno 64e89c2e81SNathan Chancellorifdef CONFIG_TOOLCHAIN_NEEDS_OLD_ISA_SPEC 65e89c2e81SNathan ChancellorKBUILD_CFLAGS += -Wa,-misa-spec=2.2 66e89c2e81SNathan ChancellorKBUILD_AFLAGS += -Wa,-misa-spec=2.2 67e89c2e81SNathan Chancellorelse 68e89c2e81SNathan Chancellorriscv-march-$(CONFIG_TOOLCHAIN_NEEDS_EXPLICIT_ZICSR_ZIFENCEI) := $(riscv-march-y)_zicsr_zifencei 69e89c2e81SNathan Chancellorendif 706df2a016SAurelien Jarno 718eb060e1SDao Lu# Check if the toolchain supports Zihintpause extension 72aae538cdSConor Dooleyriscv-march-$(CONFIG_TOOLCHAIN_HAS_ZIHINTPAUSE) := $(riscv-march-y)_zihintpause 738eb060e1SDao Lu 74fa8e7cceSGuo Ren# Remove F,D,V from isa string for all. Keep extensions between "fd" and "v" by 75fa8e7cceSGuo Ren# matching non-v and non-multi-letter extensions out with the filter ([^v_]*) 76fa8e7cceSGuo RenKBUILD_CFLAGS += -march=$(shell echo $(riscv-march-y) | sed -E 's/(rv32ima|rv64ima)fd([^v_]*)v?/\1\2/') 77fa8e7cceSGuo Ren 78e8be5302SAlan KaoKBUILD_AFLAGS += -march=$(riscv-march-y) 79fbe934d6SPalmer Dabbelt 80fbe934d6SPalmer DabbeltKBUILD_CFLAGS += -mno-save-restore 81fbe934d6SPalmer DabbeltKBUILD_CFLAGS += -DCONFIG_PAGE_OFFSET=$(CONFIG_PAGE_OFFSET) 82fbe934d6SPalmer Dabbelt 83fbe934d6SPalmer Dabbeltifeq ($(CONFIG_CMODEL_MEDLOW),y) 84fbe934d6SPalmer Dabbelt KBUILD_CFLAGS += -mcmodel=medlow 85fbe934d6SPalmer Dabbeltendif 86fbe934d6SPalmer Dabbeltifeq ($(CONFIG_CMODEL_MEDANY),y) 87fbe934d6SPalmer Dabbelt KBUILD_CFLAGS += -mcmodel=medany 88fbe934d6SPalmer Dabbeltendif 89ab1ef68eSZong Li 902f394c0eSAndreas Schwab# Avoid generating .eh_frame sections. 912f394c0eSAndreas SchwabKBUILD_CFLAGS += -fno-asynchronous-unwind-tables -fno-unwind-tables 922f394c0eSAndreas Schwab 93e18048daSPalmer Dabbelt# The RISC-V attributes frequently cause compatibility issues and provide no 94e18048daSPalmer Dabbelt# information, so just turn them off. 95e18048daSPalmer DabbeltKBUILD_CFLAGS += $(call cc-option,-mno-riscv-attribute) 96e18048daSPalmer DabbeltKBUILD_AFLAGS += $(call cc-option,-mno-riscv-attribute) 97e18048daSPalmer DabbeltKBUILD_CFLAGS += $(call as-option,-Wa$(comma)-mno-arch-attr) 98e18048daSPalmer DabbeltKBUILD_AFLAGS += $(call as-option,-Wa$(comma)-mno-arch-attr) 99e18048daSPalmer Dabbelt 100ab1ef68eSZong LiKBUILD_CFLAGS_MODULE += $(call cc-option,-mno-relax) 101c1f6eff3SBen DooksKBUILD_AFLAGS_MODULE += $(call as-option,-Wa$(comma)-mno-relax) 102fbe934d6SPalmer Dabbelt 103fbe934d6SPalmer Dabbelt# GCC versions that support the "-mstrict-align" option default to allowing 104fbe934d6SPalmer Dabbelt# unaligned accesses. While unaligned accesses are explicitly allowed in the 105fbe934d6SPalmer Dabbelt# RISC-V ISA, they're emulated by machine mode traps on all extant 106fbe934d6SPalmer Dabbelt# architectures. It's faster to have GCC emit only aligned accesses. 107fbe934d6SPalmer DabbeltKBUILD_CFLAGS += $(call cc-option,-mstrict-align) 108fbe934d6SPalmer Dabbelt 109fea2fed2SGuo Renifeq ($(CONFIG_STACKPROTECTOR_PER_TASK),y) 110fea2fed2SGuo Renprepare: stack_protector_prepare 111fea2fed2SGuo Renstack_protector_prepare: prepare0 112fea2fed2SGuo Ren $(eval KBUILD_CFLAGS += -mstack-protector-guard=tls \ 113fea2fed2SGuo Ren -mstack-protector-guard-reg=tp \ 114fea2fed2SGuo Ren -mstack-protector-guard-offset=$(shell \ 115fea2fed2SGuo Ren awk '{if ($$2 == "TSK_STACK_CANARY") print $$3;}' \ 116fea2fed2SGuo Ren include/generated/asm-offsets.h)) 117fea2fed2SGuo Renendif 118fea2fed2SGuo Ren 119889d746eSLuc Van Oostenryck# arch specific predefines for sparse 120889d746eSLuc Van OostenryckCHECKFLAGS += -D__riscv -D__riscv_xlen=$(BITS) 121889d746eSLuc Van Oostenryck 122c0fbcd99SAnup Patel# Default target when executing plain make 123c0fbcd99SAnup Patelboot := arch/riscv/boot 12444c92257SVitaly Woolifeq ($(CONFIG_XIP_KERNEL),y) 12544c92257SVitaly WoolKBUILD_IMAGE := $(boot)/xipImage 12644c92257SVitaly Woolelse 127c0fbcd99SAnup PatelKBUILD_IMAGE := $(boot)/Image.gz 12844c92257SVitaly Woolendif 129c0fbcd99SAnup Patel 130fbe934d6SPalmer Dabbeltlibs-y += arch/riscv/lib/ 131d7071743SAtish Patralibs-$(CONFIG_EFI_STUB) += $(objtree)/drivers/firmware/efi/libstub/lib.a 132fbe934d6SPalmer Dabbelt 1335a19c7e0SAndreas Schwabifeq ($(KBUILD_EXTMOD),) 134a290f510SPalmer Dabbeltifeq ($(CONFIG_MMU),y) 135fde9c59aSSaleem Abdulrasoolprepare: vdso_prepare 136fde9c59aSSaleem Abdulrasoolvdso_prepare: prepare0 137fde9c59aSSaleem Abdulrasool $(Q)$(MAKE) $(build)=arch/riscv/kernel/vdso include/generated/vdso-offsets.h 1380715372aSGuo Ren $(if $(CONFIG_COMPAT),$(Q)$(MAKE) \ 1390715372aSGuo Ren $(build)=arch/riscv/kernel/compat_vdso include/generated/compat_vdso-offsets.h) 1400715372aSGuo Ren 141a290f510SPalmer Dabbeltendif 1425a19c7e0SAndreas Schwabendif 143fde9c59aSSaleem Abdulrasool 144*adacfc6dSMasahiro Yamadavdso-install-y += arch/riscv/kernel/vdso/vdso.so.dbg 145*adacfc6dSMasahiro Yamadavdso-install-$(CONFIG_COMPAT) += arch/riscv/kernel/compat_vdso/compat_vdso.so.dbg:../compat_vdso/compat_vdso.so 146*adacfc6dSMasahiro Yamada 14744c92257SVitaly Woolifneq ($(CONFIG_XIP_KERNEL),y) 14819ba9cf7SConor Dooleyifeq ($(CONFIG_RISCV_M_MODE)$(CONFIG_ARCH_CANAAN),yy) 14937809df4SChristoph HellwigKBUILD_IMAGE := $(boot)/loader.bin 150405fe7aaSChristoph Hellwigelse 151f5579340SArd Biesheuvelifeq ($(CONFIG_EFI_ZBOOT),) 152405fe7aaSChristoph HellwigKBUILD_IMAGE := $(boot)/Image.gz 153f5579340SArd Biesheuvelelse 154f5579340SArd BiesheuvelKBUILD_IMAGE := $(boot)/vmlinuz.efi 155405fe7aaSChristoph Hellwigendif 15644c92257SVitaly Woolendif 157f5579340SArd Biesheuvelendif 158f5579340SArd BiesheuvelBOOT_TARGETS := Image Image.gz loader loader.bin xipImage vmlinuz.efi 159c0fbcd99SAnup Patel 160405fe7aaSChristoph Hellwigall: $(notdir $(KBUILD_IMAGE)) 161c0fbcd99SAnup Patel 162405fe7aaSChristoph Hellwig$(BOOT_TARGETS): vmlinux 163c0fbcd99SAnup Patel $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ 164405fe7aaSChristoph Hellwig @$(kecho) ' Kernel: $(boot)/$@ is ready' 165c0fbcd99SAnup Patel 166c18d7c17SKefeng WangImage.%: Image 167c18d7c17SKefeng Wang $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ 168c18d7c17SKefeng Wang 169f774f5bbSMasahiro Yamadainstall: KBUILD_IMAGE := $(boot)/Image 170f774f5bbSMasahiro Yamadazinstall: KBUILD_IMAGE := $(boot)/Image.gz 171399c1ec8SMasahiro Yamadainstall zinstall: 172f774f5bbSMasahiro Yamada $(call cmd,install) 1732c42bcbbSKefeng Wang 1745d4595dbSRandy DunlapPHONY += rv32_randconfig 1755d4595dbSRandy Dunlaprv32_randconfig: 1765d4595dbSRandy Dunlap $(Q)$(MAKE) KCONFIG_ALLCONFIG=$(srctree)/arch/riscv/configs/32-bit.config \ 1775d4595dbSRandy Dunlap -f $(srctree)/Makefile randconfig 1785d4595dbSRandy Dunlap 1795d4595dbSRandy DunlapPHONY += rv64_randconfig 1805d4595dbSRandy Dunlaprv64_randconfig: 1815d4595dbSRandy Dunlap $(Q)$(MAKE) KCONFIG_ALLCONFIG=$(srctree)/arch/riscv/configs/64-bit.config \ 1825d4595dbSRandy Dunlap -f $(srctree)/Makefile randconfig 18372f045d1SGuo Ren 18472f045d1SGuo RenPHONY += rv32_defconfig 18572f045d1SGuo Renrv32_defconfig: 18672f045d1SGuo Ren $(Q)$(MAKE) -f $(srctree)/Makefile defconfig 32-bit.config 18777c0c966SJesse Taube 18877c0c966SJesse TaubePHONY += rv32_nommu_virt_defconfig 18977c0c966SJesse Tauberv32_nommu_virt_defconfig: 19077c0c966SJesse Taube $(Q)$(MAKE) -f $(srctree)/Makefile nommu_virt_defconfig 32-bit.config 191