cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

Makefile (7053B)


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