xref: /openbmc/linux/arch/powerpc/kernel/Makefile (revision 2612e3bbc0386368a850140a6c9b990cd496a5ec)
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