xref: /openbmc/linux/arch/x86/kernel/cpu/Makefile (revision 7583e8fb)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2f7627e25SThomas Gleixner#
3241771efSIngo Molnar# Makefile for x86-compatible CPU details, features and quirks
4f7627e25SThomas Gleixner#
5f7627e25SThomas Gleixner
60ca59dd9SFrederic Weisbecker# Don't trace early stages of a secondary CPU boot
70ca59dd9SFrederic Weisbeckerifdef CONFIG_FUNCTION_TRACER
80ca59dd9SFrederic WeisbeckerCFLAGS_REMOVE_common.o = -pg
96e3d8330SIngo MolnarCFLAGS_REMOVE_perf_event.o = -pg
100ca59dd9SFrederic Weisbeckerendif
110ca59dd9SFrederic Weisbecker
125c9a8750SDmitry Vyukov# If these files are instrumented, boot hangs during the first second.
135c9a8750SDmitry VyukovKCOV_INSTRUMENT_common.o := n
145c9a8750SDmitry VyukovKCOV_INSTRUMENT_perf_event.o := n
1593324e68SAlexander PotapenkoKMSAN_SANITIZE_common.o := n
165c9a8750SDmitry Vyukov
1740d04110SMarco Elver# As above, instrumenting secondary CPU boot code causes boot hangs.
1840d04110SMarco ElverKCSAN_SANITIZE_common.o := n
1940d04110SMarco Elver
201d200c07SBorislav Petkovobj-y			:= cacheinfo.o scattered.o topology.o
219def39beSJosh Triplettobj-y			+= common.o
2249d859d7SH. Peter Anvinobj-y			+= rdrand.o
23644e9cbbSAndi Kleenobj-y			+= match.o
2462a67e12SBorislav Petkovobj-y			+= bugs.o
257d5905dcSRafael J. Wysockiobj-y			+= aperfmperf.o
260b00de85SAndi Kleenobj-y			+= cpuid-deps.o
27bd688c69SFenghua Yuobj-y			+= umwait.o
28f7627e25SThomas Gleixner
2939f838e0SJosh Triplettobj-$(CONFIG_PROC_FS)	+= proc.o
30*7583e8fbSLukas Bulwahnobj-y += capflags.o powerflags.o
3139f838e0SJosh Triplett
321db2a6e1SSean Christophersonobj-$(CONFIG_IA32_FEAT_CTL) += feat_ctl.o
33be1fcde6SRafael J. Wysockiifdef CONFIG_CPU_SUP_INTEL
3495c5824fSPawan Guptaobj-y			+= intel.o intel_pconfig.o tsx.o
35be1fcde6SRafael J. Wysockiobj-$(CONFIG_PM)	+= intel_epb.o
36be1fcde6SRafael J. Wysockiendif
37ff73152cSYinghai Luobj-$(CONFIG_CPU_SUP_AMD)		+= amd.o
38c9661c1eSPu Wenobj-$(CONFIG_CPU_SUP_HYGON)		+= hygon.o
398d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_CYRIX_32)		+= cyrix.o
4048f4c485SSebastian Andrzej Siewiorobj-$(CONFIG_CPU_SUP_CENTAUR)		+= centaur.o
418d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_TRANSMETA_32)	+= transmeta.o
428d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_UMC_32)		+= umc.o
43761fdd5eSTony W Wang-ocobj-$(CONFIG_CPU_SUP_ZHAOXIN)		+= zhaoxin.o
44639475d4SMarcos Del Sol Vivesobj-$(CONFIG_CPU_SUP_VORTEX_32)		+= vortex.o
45f7627e25SThomas Gleixner
4621afaf18SBorislav Petkovobj-$(CONFIG_X86_MCE)			+= mce/
4727bd0c95SThomas Gleixnerobj-$(CONFIG_MTRR)			+= mtrr/
48bad5fa63SBorislav Petkovobj-$(CONFIG_MICROCODE)			+= microcode/
49e6d42931SJohannes Weinerobj-$(CONFIG_X86_CPU_RESCTRL)		+= resctrl/
50e7e05452SSean Christophersonobj-$(CONFIG_X86_SGX)			+= sgx/
51f7627e25SThomas Gleixner
52218cfe4eSBorislav Petkovobj-$(CONFIG_X86_LOCAL_APIC)		+= perfctr-watchdog.o
537414aa41SH. Peter Anvin
546276a074SBorislav Petkovobj-$(CONFIG_HYPERVISOR_GUEST)		+= vmware.o hypervisor.o mshyperv.o
55ec7972c9SZhao Yakuiobj-$(CONFIG_ACRN_GUEST)		+= acrn.o
566276a074SBorislav Petkov
577414aa41SH. Peter Anvinquiet_cmd_mkcapflags = MKCAP   $@
5814442a15SSean Christopherson      cmd_mkcapflags = $(CONFIG_SHELL) $(srctree)/$(src)/mkcapflags.sh $@ $^
597414aa41SH. Peter Anvin
60cd4d09ecSBorislav Petkovcpufeature = $(src)/../../include/asm/cpufeatures.h
6114442a15SSean Christophersonvmxfeature = $(src)/../../include/asm/vmxfeatures.h
627414aa41SH. Peter Anvin
6314442a15SSean Christopherson$(obj)/capflags.c: $(cpufeature) $(vmxfeature) $(src)/mkcapflags.sh FORCE
647414aa41SH. Peter Anvin	$(call if_changed,mkcapflags)
6587b61864SMasahiro Yamadatargets += capflags.c
66