]> asedeno.scripts.mit.edu Git - linux.git/blob - arch/powerpc/kernel/Makefile
bb57d168d6f44c3ad981121345291e092f5323bc
[linux.git] / arch / powerpc / kernel / Makefile
1 # SPDX-License-Identifier: GPL-2.0
2 #
3 # Makefile for the linux kernel.
4 #
5
6 CFLAGS_ptrace.o         += -DUTS_MACHINE='"$(UTS_MACHINE)"'
7
8 # Disable clang warning for using setjmp without setjmp.h header
9 CFLAGS_crash.o          += $(call cc-disable-warning, builtin-requires-header)
10
11 ifdef CONFIG_PPC64
12 CFLAGS_prom_init.o      += $(NO_MINIMAL_TOC)
13 endif
14 ifdef CONFIG_PPC32
15 CFLAGS_prom_init.o      += -fPIC
16 CFLAGS_btext.o          += -fPIC
17 endif
18
19 CFLAGS_cputable.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
20 CFLAGS_prom_init.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
21 CFLAGS_btext.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
22 CFLAGS_prom.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
23
24 CFLAGS_prom_init.o += $(call cc-option, -fno-stack-protector)
25 CFLAGS_prom_init.o += -DDISABLE_BRANCH_PROFILING
26
27 ifdef CONFIG_FUNCTION_TRACER
28 # Do not trace early boot code
29 CFLAGS_REMOVE_cputable.o = $(CC_FLAGS_FTRACE)
30 CFLAGS_REMOVE_prom_init.o = $(CC_FLAGS_FTRACE)
31 CFLAGS_REMOVE_btext.o = $(CC_FLAGS_FTRACE)
32 CFLAGS_REMOVE_prom.o = $(CC_FLAGS_FTRACE)
33 endif
34
35 KASAN_SANITIZE_early_32.o := n
36 KASAN_SANITIZE_cputable.o := n
37 KASAN_SANITIZE_prom_init.o := n
38 KASAN_SANITIZE_btext.o := n
39
40 ifdef CONFIG_KASAN
41 CFLAGS_early_32.o += -DDISABLE_BRANCH_PROFILING
42 CFLAGS_cputable.o += -DDISABLE_BRANCH_PROFILING
43 CFLAGS_btext.o += -DDISABLE_BRANCH_PROFILING
44 endif
45
46 obj-y                           := cputable.o ptrace.o syscalls.o \
47                                    irq.o align.o signal_32.o pmc.o vdso.o \
48                                    process.o systbl.o idle.o \
49                                    signal.o sysfs.o cacheinfo.o time.o \
50                                    prom.o traps.o setup-common.o \
51                                    udbg.o misc.o io.o misc_$(BITS).o \
52                                    of_platform.o prom_parse.o
53 obj-$(CONFIG_PPC64)             += setup_64.o sys_ppc32.o \
54                                    signal_64.o ptrace32.o \
55                                    paca.o nvram_64.o firmware.o note.o
56 obj-$(CONFIG_VDSO32)            += vdso32/
57 obj-$(CONFIG_PPC_WATCHDOG)      += watchdog.o
58 obj-$(CONFIG_HAVE_HW_BREAKPOINT)        += hw_breakpoint.o
59 obj-$(CONFIG_PPC_DAWR)          += dawr.o
60 obj-$(CONFIG_PPC_BOOK3S_64)     += cpu_setup_ppc970.o cpu_setup_pa6t.o
61 obj-$(CONFIG_PPC_BOOK3S_64)     += cpu_setup_power.o
62 obj-$(CONFIG_PPC_BOOK3S_64)     += mce.o mce_power.o
63 obj-$(CONFIG_PPC_BOOK3E_64)     += exceptions-64e.o idle_book3e.o
64 obj-$(CONFIG_PPC_BARRIER_NOSPEC) += security.o
65 obj-$(CONFIG_PPC64)             += vdso64/
66 obj-$(CONFIG_ALTIVEC)           += vecemu.o
67 obj-$(CONFIG_PPC_970_NAP)       += idle_power4.o
68 obj-$(CONFIG_PPC_P7_NAP)        += idle_book3s.o
69 procfs-y                        := proc_powerpc.o
70 obj-$(CONFIG_PROC_FS)           += $(procfs-y)
71 rtaspci-$(CONFIG_PPC64)-$(CONFIG_PCI)   := rtas_pci.o
72 obj-$(CONFIG_PPC_RTAS)          += rtas.o rtas-rtc.o $(rtaspci-y-y)
73 obj-$(CONFIG_PPC_RTAS_DAEMON)   += rtasd.o
74 obj-$(CONFIG_RTAS_FLASH)        += rtas_flash.o
75 obj-$(CONFIG_RTAS_PROC)         += rtas-proc.o
76 obj-$(CONFIG_PPC_DT_CPU_FTRS)   += dt_cpu_ftrs.o
77 obj-$(CONFIG_EEH)              += eeh.o eeh_pe.o eeh_dev.o eeh_cache.o \
78                                   eeh_driver.o eeh_event.o eeh_sysfs.o
79 obj-$(CONFIG_GENERIC_TBSYNC)    += smp-tbsync.o
80 obj-$(CONFIG_CRASH_DUMP)        += crash_dump.o
81 obj-$(CONFIG_FA_DUMP)           += fadump.o
82 obj-$(CONFIG_PRESERVE_FA_DUMP)  += fadump.o
83 ifdef CONFIG_PPC32
84 obj-$(CONFIG_E500)              += idle_e500.o
85 endif
86 obj-$(CONFIG_PPC_BOOK3S_32)     += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o
87 obj-$(CONFIG_TAU)               += tau_6xx.o
88 obj-$(CONFIG_HIBERNATION)       += swsusp.o suspend.o
89 ifdef CONFIG_FSL_BOOKE
90 obj-$(CONFIG_HIBERNATION)       += swsusp_booke.o
91 else
92 obj-$(CONFIG_HIBERNATION)       += swsusp_$(BITS).o
93 endif
94 obj64-$(CONFIG_HIBERNATION)     += swsusp_asm64.o
95 obj-$(CONFIG_MODULES)           += module.o module_$(BITS).o
96 obj-$(CONFIG_44x)               += cpu_setup_44x.o
97 obj-$(CONFIG_PPC_FSL_BOOK3E)    += cpu_setup_fsl_booke.o
98 obj-$(CONFIG_PPC_DOORBELL)      += dbell.o
99 obj-$(CONFIG_JUMP_LABEL)        += jump_label.o
100
101 extra-y                         := head_$(BITS).o
102 extra-$(CONFIG_40x)             := head_40x.o
103 extra-$(CONFIG_44x)             := head_44x.o
104 extra-$(CONFIG_FSL_BOOKE)       := head_fsl_booke.o
105 extra-$(CONFIG_PPC_8xx)         := head_8xx.o
106 extra-y                         += vmlinux.lds
107
108 obj-$(CONFIG_RELOCATABLE)       += reloc_$(BITS).o
109
110 obj-$(CONFIG_PPC32)             += entry_32.o setup_32.o early_32.o
111 obj-$(CONFIG_PPC64)             += dma-iommu.o iommu.o
112 obj-$(CONFIG_KGDB)              += kgdb.o
113 obj-$(CONFIG_BOOTX_TEXT)        += btext.o
114 obj-$(CONFIG_SMP)               += smp.o
115 obj-$(CONFIG_KPROBES)           += kprobes.o
116 obj-$(CONFIG_OPTPROBES)         += optprobes.o optprobes_head.o
117 obj-$(CONFIG_KPROBES_ON_FTRACE) += kprobes-ftrace.o
118 obj-$(CONFIG_UPROBES)           += uprobes.o
119 obj-$(CONFIG_PPC_UDBG_16550)    += legacy_serial.o udbg_16550.o
120 obj-$(CONFIG_STACKTRACE)        += stacktrace.o
121 obj-$(CONFIG_SWIOTLB)           += dma-swiotlb.o
122 obj-$(CONFIG_ARCH_HAS_DMA_SET_MASK) += dma-mask.o
123
124 pci64-$(CONFIG_PPC64)           += pci_dn.o pci-hotplug.o isa-bridge.o
125 obj-$(CONFIG_PCI)               += pci_$(BITS).o $(pci64-y) \
126                                    pci-common.o pci_of_scan.o
127 obj-$(CONFIG_PCI_MSI)           += msi.o
128 obj-$(CONFIG_KEXEC_CORE)        += machine_kexec.o crash.o \
129                                    machine_kexec_$(BITS).o
130 obj-$(CONFIG_KEXEC_FILE)        += machine_kexec_file_$(BITS).o kexec_elf_$(BITS).o
131 ifdef CONFIG_HAVE_IMA_KEXEC
132 ifdef CONFIG_IMA
133 obj-y                           += ima_kexec.o
134 endif
135 endif
136
137 obj-$(CONFIG_AUDIT)             += audit.o
138 obj64-$(CONFIG_AUDIT)           += compat_audit.o
139
140 obj-$(CONFIG_PPC_IO_WORKAROUNDS)        += io-workarounds.o
141
142 obj-y                           += trace/
143
144 ifneq ($(CONFIG_PPC_INDIRECT_PIO),y)
145 obj-y                           += iomap.o
146 endif
147
148 obj64-$(CONFIG_PPC_TRANSACTIONAL_MEM)   += tm.o
149
150 obj-$(CONFIG_PPC64)             += $(obj64-y)
151 obj-$(CONFIG_PPC32)             += $(obj32-y)
152
153 ifneq ($(CONFIG_XMON)$(CONFIG_KEXEC_CORE)(CONFIG_PPC_BOOK3S),)
154 obj-y                           += ppc_save_regs.o
155 endif
156
157 obj-$(CONFIG_EPAPR_PARAVIRT)    += epapr_paravirt.o epapr_hcalls.o
158 obj-$(CONFIG_KVM_GUEST)         += kvm.o kvm_emul.o
159 ifneq ($(CONFIG_PPC_POWERNV)$(CONFIG_PPC_SVM),)
160 obj-y                           += ucall.o
161 endif
162
163 obj-$(CONFIG_PPC_SECURE_BOOT)   += secure_boot.o ima_arch.o secvar-ops.o
164 obj-$(CONFIG_PPC_SECVAR_SYSFS)  += secvar-sysfs.o
165
166 # Disable GCOV, KCOV & sanitizers in odd or sensitive code
167 GCOV_PROFILE_prom_init.o := n
168 KCOV_INSTRUMENT_prom_init.o := n
169 UBSAN_SANITIZE_prom_init.o := n
170 GCOV_PROFILE_machine_kexec_64.o := n
171 KCOV_INSTRUMENT_machine_kexec_64.o := n
172 UBSAN_SANITIZE_machine_kexec_64.o := n
173 GCOV_PROFILE_machine_kexec_32.o := n
174 KCOV_INSTRUMENT_machine_kexec_32.o := n
175 UBSAN_SANITIZE_machine_kexec_32.o := n
176 GCOV_PROFILE_kprobes.o := n
177 KCOV_INSTRUMENT_kprobes.o := n
178 UBSAN_SANITIZE_kprobes.o := n
179 GCOV_PROFILE_kprobes-ftrace.o := n
180 KCOV_INSTRUMENT_kprobes-ftrace.o := n
181 UBSAN_SANITIZE_kprobes-ftrace.o := n
182 UBSAN_SANITIZE_vdso.o := n
183
184 # Necessary for booting with kcov enabled on book3e machines
185 KCOV_INSTRUMENT_cputable.o := n
186 KCOV_INSTRUMENT_setup_64.o := n
187 KCOV_INSTRUMENT_paca.o := n
188
189 extra-$(CONFIG_PPC_FPU)         += fpu.o
190 extra-$(CONFIG_ALTIVEC)         += vector.o
191 extra-$(CONFIG_PPC64)           += entry_64.o
192 extra-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE)  += prom_init.o
193
194 extra-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE)  += prom_init_check
195
196 quiet_cmd_prom_init_check = PROMCHK $@
197       cmd_prom_init_check = $(CONFIG_SHELL) $< "$(NM)" $(obj)/prom_init.o; touch $@
198
199 $(obj)/prom_init_check: $(src)/prom_init_check.sh $(obj)/prom_init.o FORCE
200         $(call if_changed,prom_init_check)
201 targets += prom_init_check
202
203 clean-files := vmlinux.lds