1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0 214cf11afSPaul Mackerras# 314cf11afSPaul Mackerras# Makefile for the linux kernel. 414cf11afSPaul Mackerras# 514cf11afSPaul Mackerras 6badf436fSRodrigo R. Galvaoifdef CONFIG_PPC64 71fbe9cf2SAnton BlanchardCFLAGS_prom_init.o += $(NO_MINIMAL_TOC) 8bd142b70SStephen Rothwellendif 9badf436fSRodrigo R. Galvaoifdef CONFIG_PPC32 109b6b563cSPaul MackerrasCFLAGS_prom_init.o += -fPIC 11b3491269SPaul MackerrasCFLAGS_btext.o += -fPIC 12cabb5587SStephen Rothwellendif 139b6b563cSPaul Mackerras 14bba49665SChristophe LeroyCFLAGS_early_32.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) 1538addce8SEmese RevfyCFLAGS_cputable.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) 16eac6f8b0SAndrew DonnellanCFLAGS_prom_init.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) 1738addce8SEmese RevfyCFLAGS_btext.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) 1838addce8SEmese RevfyCFLAGS_prom.o += $(DISABLE_LATENT_ENTROPY_PLUGIN) 1938addce8SEmese Revfy 20893ab004SMasahiro YamadaCFLAGS_prom_init.o += -fno-stack-protector 216266a4daSMichael EllermanCFLAGS_prom_init.o += -DDISABLE_BRANCH_PROFILING 228dcd71b4SNathan ChancellorCFLAGS_prom_init.o += -ffreestanding 23be640317SMichael EllermanCFLAGS_prom_init.o += $(call cc-option, -ftrivial-auto-var-init=uninitialized) 24c3ff2a51SChristophe Leroy 25606576ceSSteven Rostedtifdef CONFIG_FUNCTION_TRACER 264e491d14SSteven Rostedt# Do not trace early boot code 272a056f58SNicholas PigginCFLAGS_REMOVE_cputable.o = $(CC_FLAGS_FTRACE) 282a056f58SNicholas PigginCFLAGS_REMOVE_prom_init.o = $(CC_FLAGS_FTRACE) 292a056f58SNicholas PigginCFLAGS_REMOVE_btext.o = $(CC_FLAGS_FTRACE) 302a056f58SNicholas PigginCFLAGS_REMOVE_prom.o = $(CC_FLAGS_FTRACE) 314e491d14SSteven Rostedtendif 324e491d14SSteven Rostedt 33f072015cSChristophe LeroyKASAN_SANITIZE_early_32.o := n 34f072015cSChristophe LeroyKASAN_SANITIZE_cputable.o := n 35f072015cSChristophe LeroyKASAN_SANITIZE_prom_init.o := n 36f072015cSChristophe LeroyKASAN_SANITIZE_btext.o := n 3741b7a347SDaniel AxtensKASAN_SANITIZE_paca.o := n 3841b7a347SDaniel AxtensKASAN_SANITIZE_setup_64.o := n 3941b7a347SDaniel AxtensKASAN_SANITIZE_mce.o := n 4041b7a347SDaniel AxtensKASAN_SANITIZE_mce_power.o := n 41743cdb7bSPaul MackerrasKASAN_SANITIZE_udbg.o := n 42743cdb7bSPaul MackerrasKASAN_SANITIZE_udbg_16550.o := n 4341b7a347SDaniel Axtens 4441b7a347SDaniel Axtens# we have to be particularly careful in ppc64 to exclude code that 4541b7a347SDaniel Axtens# runs with translations off, as we cannot access the shadow with 4641b7a347SDaniel Axtens# translations off. However, ppc32 can sanitize this. 4741b7a347SDaniel Axtensifdef CONFIG_PPC64 4841b7a347SDaniel AxtensKASAN_SANITIZE_traps.o := n 4941b7a347SDaniel Axtensendif 50f072015cSChristophe Leroy 51f072015cSChristophe Leroyifdef CONFIG_KASAN 52f072015cSChristophe LeroyCFLAGS_early_32.o += -DDISABLE_BRANCH_PROFILING 53f072015cSChristophe LeroyCFLAGS_cputable.o += -DDISABLE_BRANCH_PROFILING 54f072015cSChristophe LeroyCFLAGS_btext.o += -DDISABLE_BRANCH_PROFILING 55f072015cSChristophe Leroyendif 56f072015cSChristophe Leroy 572fb857bcSRohan McLureKCSAN_SANITIZE_early_32.o := n 582fb857bcSRohan McLureKCSAN_SANITIZE_early_64.o := n 592fb857bcSRohan McLureKCSAN_SANITIZE_cputable.o := n 602fb857bcSRohan McLureKCSAN_SANITIZE_btext.o := n 612fb857bcSRohan McLureKCSAN_SANITIZE_paca.o := n 622fb857bcSRohan McLureKCSAN_SANITIZE_setup_64.o := n 632fb857bcSRohan McLure 64f4a0318fSXiu Jianfeng#ifdef CONFIG_RANDOMIZE_KSTACK_OFFSET 65f4a0318fSXiu Jianfeng# Remove stack protector to avoid triggering unneeded stack canary 66f4a0318fSXiu Jianfeng# checks due to randomize_kstack_offset. 67f4a0318fSXiu JianfengCFLAGS_REMOVE_syscall.o = -fstack-protector -fstack-protector-strong 68f4a0318fSXiu JianfengCFLAGS_syscall.o += -fno-stack-protector 69f4a0318fSXiu Jianfeng#endif 70f4a0318fSXiu Jianfeng 71afc63868SNicholas Pigginobj-y := cputable.o syscalls.o switch.o \ 720a7601b6SMichal Suchanek irq.o align.o signal_$(BITS).o pmc.o vdso.o \ 73b0ce50aaSThomas Gleixner process.o systbl.o idle.o \ 74698193d8SMichael Ellerman signal.o sysfs.o cacheinfo.o time.o \ 75698193d8SMichael Ellerman prom.o traps.o setup-common.o \ 7668005b67SChristoph Hellwig udbg.o misc.o io.o misc_$(BITS).o \ 77edc8dd99SRavi Bangoria of_platform.o prom_parse.o firmware.o \ 78dbf77fedSAneesh Kumar K.V hw_breakpoint_constraints.o interrupt.o \ 791547db7dSXiu Jianfeng kdebugfs.o stacktrace.o syscall.o 80da9a1c10SChristophe Leroyobj-y += ptrace/ 817d7b28b3SChristophe Leroyobj-$(CONFIG_PPC64) += setup_64.o irq_64.o\ 82344bb20bSChristophe Leroy paca.o nvram_64.o note.o 83e2375062SNicholas Pigginobj-$(CONFIG_PPC32) += sys_ppc32.o 840a7601b6SMichal Suchanekobj-$(CONFIG_COMPAT) += sys_ppc32.o signal_32.o 85bce74491SMasahiro Yamadaobj-$(CONFIG_VDSO32) += vdso32_wrapper.o 8675eb767eSNicholas Pigginobj-$(CONFIG_PPC_WATCHDOG) += watchdog.o 875aae8a53SK.Prasadobj-$(CONFIG_HAVE_HW_BREAKPOINT) += hw_breakpoint.o 88a278e7eaSMichael Neulingobj-$(CONFIG_PPC_DAWR) += dawr.o 892d27cfd3SBenjamin Herrenschmidtobj-$(CONFIG_PPC_BOOK3S_64) += cpu_setup_ppc970.o cpu_setup_pa6t.o 90179ab1cbSMichael Ellermanobj-$(CONFIG_PPC_BOOK3S_64) += cpu_setup_power.o 917c379526SPaolo Bonziniobj-$(CONFIG_PPC_BOOK3S_64) += mce.o mce_power.o 926556fd1aSChristophe Leroyobj-$(CONFIG_PPC_BOOK3E_64) += exceptions-64e.o idle_64e.o 93179ab1cbSMichael Ellermanobj-$(CONFIG_PPC_BARRIER_NOSPEC) += security.o 94bce74491SMasahiro Yamadaobj-$(CONFIG_PPC64) += vdso64_wrapper.o 95e821ea70SBenjamin Herrenschmidtobj-$(CONFIG_ALTIVEC) += vecemu.o 96ed0bc98fSNicholas Pigginobj-$(CONFIG_PPC_BOOK3S_IDLE) += idle_book3s.o 97188917e1SBenjamin Herrenschmidtprocfs-y := proc_powerpc.o 98d3d2176aSDavid Gibsonobj-$(CONFIG_PROC_FS) += $(procfs-y) 99bed59275SStephen Rothwellrtaspci-$(CONFIG_PPC64)-$(CONFIG_PCI) := rtas_pci.o 100838ee286SNicholas Pigginobj-$(CONFIG_PPC_RTAS) += rtas_entry.o rtas.o rtas-rtc.o $(rtaspci-y-y) 1013d541c4bSBenjamin Herrenschmidtobj-$(CONFIG_PPC_RTAS_DAEMON) += rtasd.o 102f4fcbbe9SPaul Mackerrasobj-$(CONFIG_RTAS_FLASH) += rtas_flash.o 103f4fcbbe9SPaul Mackerrasobj-$(CONFIG_RTAS_PROC) += rtas-proc.o 1045a61ef74SNicholas Pigginobj-$(CONFIG_PPC_DT_CPU_FTRS) += dt_cpu_ftrs.o 105d74ee8e9SOliver O'Halloranobj-$(CONFIG_EEH) += eeh.o eeh_pe.o eeh_cache.o \ 106317f06deSGavin Shan eeh_driver.o eeh_event.o eeh_sysfs.o 1078ad200d7SPaul Mackerrasobj-$(CONFIG_GENERIC_TBSYNC) += smp-tbsync.o 1080cc4746cSMichael Ellermanobj-$(CONFIG_CRASH_DUMP) += crash_dump.o 109cd1d55f1SHari Bathiniobj-$(CONFIG_FA_DUMP) += fadump.o 110cd1d55f1SHari Bathiniobj-$(CONFIG_PRESERVE_FA_DUMP) += fadump.o 1116556fd1aSChristophe Leroyobj-$(CONFIG_PPC_85xx) += idle_85xx.o 112d7cceda9SChristophe Leroyobj-$(CONFIG_PPC_BOOK3S_32) += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o 1139b781727SPaul Mackerrasobj-$(CONFIG_TAU) += tau_6xx.o 11490103f93SAnton Vorontsovobj-$(CONFIG_HIBERNATION) += swsusp.o suspend.o 115dfc3095cSChristophe Leroyifdef CONFIG_PPC_85xx 116dfc3095cSChristophe Leroyobj-$(CONFIG_HIBERNATION) += swsusp_85xx.o 11790103f93SAnton Vorontsovelse 11868201fbbSMichael Ellermanobj-$(CONFIG_HIBERNATION) += swsusp_$(BITS).o 11990103f93SAnton Vorontsovendif 1202578bfaeSStephen Rothwellobj64-$(CONFIG_HIBERNATION) += swsusp_asm64.o 12168201fbbSMichael Ellermanobj-$(CONFIG_MODULES) += module.o module_$(BITS).o 12226f571d7SPaul Mackerrasobj-$(CONFIG_44x) += cpu_setup_44x.o 1233e731858SChristophe Leroyobj-$(CONFIG_PPC_E500) += cpu_setup_e500.o 124440bc685SIan Munsieobj-$(CONFIG_PPC_DOORBELL) += dbell.o 125ac5f89c7SMichael Ellermanobj-$(CONFIG_JUMP_LABEL) += jump_label.o 12640ef8cbcSPaul Mackerras 12732164845SMasahiro Yamadaobj-$(CONFIG_PPC64) += head_64.o 12832164845SMasahiro Yamadaobj-$(CONFIG_PPC_BOOK3S_32) += head_book3s_32.o 12932164845SMasahiro Yamadaobj-$(CONFIG_40x) += head_40x.o 13032164845SMasahiro Yamadaobj-$(CONFIG_44x) += head_44x.o 13132164845SMasahiro Yamadaobj-$(CONFIG_PPC_8xx) += head_8xx.o 132ae5b6779SJoel Stanleyobj-$(CONFIG_PPC_85xx) += head_85xx.o 13314cf11afSPaul Mackerrasextra-y += vmlinux.lds 13414cf11afSPaul Mackerras 13568201fbbSMichael Ellermanobj-$(CONFIG_RELOCATABLE) += reloc_$(BITS).o 1369c5f7d39SSuzuki Poulose 1375c810cedSChristophe Leroyobj-$(CONFIG_PPC32) += entry_32.o setup_32.o early_32.o static_call.o 1384fc665b8SBecky Bruceobj-$(CONFIG_PPC64) += dma-iommu.o iommu.o 13917ce452fSJason Wesselobj-$(CONFIG_KGDB) += kgdb.o 1409b6b563cSPaul Mackerrasobj-$(CONFIG_BOOTX_TEXT) += btext.o 1415ad57078SPaul Mackerrasobj-$(CONFIG_SMP) += smp.o 1427568cb4eSPaul Mackerrasobj-$(CONFIG_KPROBES) += kprobes.o 14351c9c084SAnju Tobj-$(CONFIG_OPTPROBES) += optprobes.o optprobes_head.o 144ead514d5SNaveen N. Raoobj-$(CONFIG_KPROBES_ON_FTRACE) += kprobes-ftrace.o 1458b7b80b9SAnanth N Mavinakayanahalliobj-$(CONFIG_UPROBES) += uprobes.o 14613b8a272SPaul Mackerrasobj-$(CONFIG_PPC_UDBG_16550) += legacy_serial.o udbg_16550.o 147ec3cf2ecSBecky Bruceobj-$(CONFIG_SWIOTLB) += dma-swiotlb.o 14811ddce15SChristoph Hellwigobj-$(CONFIG_ARCH_HAS_DMA_SET_MASK) += dma-mask.o 1494c75a6f4SBenjamin Herrenschmidt 150317f06deSGavin Shanpci64-$(CONFIG_PPC64) += pci_dn.o pci-hotplug.o isa-bridge.o 15168201fbbSMichael Ellermanobj-$(CONFIG_PCI) += pci_$(BITS).o $(pci64-y) \ 152fbe65447SGrant Likely pci-common.o pci_of_scan.o 153df87ef55SMichael Ellermanobj-$(CONFIG_PCI_MSI) += msi.o 154467d2782SThiago Jung Bauermann 155b7472e17SMichael Ellermanobj-$(CONFIG_AUDIT) += audit.o 156b7472e17SMichael Ellermanobj64-$(CONFIG_AUDIT) += compat_audit.o 157b7472e17SMichael Ellerman 1583cc30d07SMichael Ellermanobj-$(CONFIG_PPC_IO_WORKAROUNDS) += io-workarounds.o 1593cc30d07SMichael Ellerman 1607853f9c0SNaveen N. Raoobj-y += trace/ 161a1110654SScott Wood 162ecd73cc5SBenjamin Herrenschmidtifneq ($(CONFIG_PPC_INDIRECT_PIO),y) 16368a64357SBenjamin Herrenschmidtobj-y += iomap.o 1644cb3cee0SBenjamin Herrenschmidtendif 1654cb3cee0SBenjamin Herrenschmidt 16698ae22e1SMichael Neulingobj64-$(CONFIG_PPC_TRANSACTIONAL_MEM) += tm.o 16798ae22e1SMichael Neuling 168fc2a5a61SStephen Rothwellifneq ($(CONFIG_XMON)$(CONFIG_KEXEC_CORE)(CONFIG_PPC_BOOK3S),) 169322b4394SAnton Vorontsovobj-y += ppc_save_regs.o 170322b4394SAnton Vorontsovendif 171322b4394SAnton Vorontsov 1722e1ae9c0SLiu Yu-B13201obj-$(CONFIG_EPAPR_PARAVIRT) += epapr_paravirt.o epapr_hcalls.o 173d17051cbSAlexander Grafobj-$(CONFIG_KVM_GUEST) += kvm.o kvm_emul.o 174136bc039SThiago Jung Bauermannifneq ($(CONFIG_PPC_POWERNV)$(CONFIG_PPC_SVM),) 175136bc039SThiago Jung Bauermannobj-y += ucall.o 176136bc039SThiago Jung Bauermannendif 1772a342ed5SAlexander Graf 1789155e234SNayna Jainobj-$(CONFIG_PPC_SECURE_BOOT) += secure_boot.o ima_arch.o secvar-ops.o 179bd5d9c74SNayna Jainobj-$(CONFIG_PPC_SECVAR_SYSFS) += secvar-sysfs.o 1801a8916eeSNayna Jain 181fb0b0a73SAndrew Donnellan# Disable GCOV, KCOV & sanitizers in odd or sensitive code 182a15098c9SMichael EllermanGCOV_PROFILE_prom_init.o := n 183fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_prom_init.o := n 1842fb857bcSRohan McLureKCSAN_SANITIZE_prom_init.o := n 185bf76f73cSDaniel AxtensUBSAN_SANITIZE_prom_init.o := n 186a15098c9SMichael EllermanGCOV_PROFILE_kprobes.o := n 187fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_kprobes.o := n 1882fb857bcSRohan McLureKCSAN_SANITIZE_kprobes.o := n 189bf76f73cSDaniel AxtensUBSAN_SANITIZE_kprobes.o := n 190ead514d5SNaveen N. RaoGCOV_PROFILE_kprobes-ftrace.o := n 191fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_kprobes-ftrace.o := n 1922fb857bcSRohan McLureKCSAN_SANITIZE_kprobes-ftrace.o := n 193ead514d5SNaveen N. RaoUBSAN_SANITIZE_kprobes-ftrace.o := n 1942f26ed17SDaniel AxtensGCOV_PROFILE_syscall_64.o := n 1952f26ed17SDaniel AxtensKCOV_INSTRUMENT_syscall_64.o := n 1962f26ed17SDaniel AxtensUBSAN_SANITIZE_syscall_64.o := n 197bf76f73cSDaniel AxtensUBSAN_SANITIZE_vdso.o := n 198a15098c9SMichael Ellerman 199fb0b0a73SAndrew Donnellan# Necessary for booting with kcov enabled on book3e machines 200fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_cputable.o := n 201fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_setup_64.o := n 202fb0b0a73SAndrew DonnellanKCOV_INSTRUMENT_paca.o := n 203fb0b0a73SAndrew Donnellan 204a7223f5bSArd BiesheuvelCFLAGS_setup_64.o += -fno-stack-protector 205a7223f5bSArd BiesheuvelCFLAGS_paca.o += -fno-stack-protector 206a7223f5bSArd Biesheuvel 20732164845SMasahiro Yamadaobj-$(CONFIG_PPC_FPU) += fpu.o 20832164845SMasahiro Yamadaobj-$(CONFIG_ALTIVEC) += vector.o 2090a4690cfSStephen Rothwell 210*27be2456SNicholas Pigginobj-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_init.o 211*27be2456SNicholas Pigginobj64-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_entry_64.o 2121fdfa4c6SMasahiro Yamadaextra-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_init_check 2135c02cd2fSMichael Ellerman 214*27be2456SNicholas Pigginobj-$(CONFIG_PPC64) += $(obj64-y) 215*27be2456SNicholas Pigginobj-$(CONFIG_PPC32) += $(obj32-y) 216*27be2456SNicholas Piggin 2171fdfa4c6SMasahiro Yamadaquiet_cmd_prom_init_check = PROMCHK $@ 2181fdfa4c6SMasahiro Yamada cmd_prom_init_check = $(CONFIG_SHELL) $< "$(NM)" $(obj)/prom_init.o; touch $@ 2195c02cd2fSMichael Ellerman 2201fdfa4c6SMasahiro Yamada$(obj)/prom_init_check: $(src)/prom_init_check.sh $(obj)/prom_init.o FORCE 2211fdfa4c6SMasahiro Yamada $(call if_changed,prom_init_check) 2221fdfa4c6SMasahiro Yamadatargets += prom_init_check 2235c02cd2fSMichael Ellerman 224e4ccde02SKumar Galaclean-files := vmlinux.lds 225791f9e36SChristophe Leroy 226791f9e36SChristophe Leroy# Force dependency (incbin is bad) 227fd1feadeSChristophe Leroy$(obj)/vdso32_wrapper.o : $(obj)/vdso/vdso32.so.dbg 228fd1feadeSChristophe Leroy$(obj)/vdso64_wrapper.o : $(obj)/vdso/vdso64.so.dbg 229964c33cdSMasahiro Yamada 230964c33cdSMasahiro Yamada# for cleaning 231fd1feadeSChristophe Leroysubdir- += vdso 232