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 155c9a8750SDmitry Vyukov 165416c266SJeremy Fitzhardinge# Make sure load_percpu_segment has no stackprotector 175416c266SJeremy Fitzhardingenostackp := $(call cc-option, -fno-stack-protector) 185416c266SJeremy FitzhardingeCFLAGS_common.o := $(nostackp) 195416c266SJeremy Fitzhardinge 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 27f7627e25SThomas Gleixner 2839f838e0SJosh Triplettobj-$(CONFIG_PROC_FS) += proc.o 299def39beSJosh Triplettobj-$(CONFIG_X86_FEATURE_NAMES) += capflags.o powerflags.o 3039f838e0SJosh Triplett 31be7825c1SKirill A. Shutemovobj-$(CONFIG_CPU_SUP_INTEL) += intel.o intel_pconfig.o 32ff73152cSYinghai Luobj-$(CONFIG_CPU_SUP_AMD) += amd.o 33c9661c1eSPu Wenobj-$(CONFIG_CPU_SUP_HYGON) += hygon.o 348d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_CYRIX_32) += cyrix.o 3548f4c485SSebastian Andrzej Siewiorobj-$(CONFIG_CPU_SUP_CENTAUR) += centaur.o 368d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_TRANSMETA_32) += transmeta.o 378d02c211SThomas Petazzoniobj-$(CONFIG_CPU_SUP_UMC_32) += umc.o 38f7627e25SThomas Gleixner 3921afaf18SBorislav Petkovobj-$(CONFIG_X86_MCE) += mce/ 4027bd0c95SThomas Gleixnerobj-$(CONFIG_MTRR) += mtrr/ 41bad5fa63SBorislav Petkovobj-$(CONFIG_MICROCODE) += microcode/ 42e6d42931SJohannes Weinerobj-$(CONFIG_X86_CPU_RESCTRL) += resctrl/ 43f7627e25SThomas Gleixner 44218cfe4eSBorislav Petkovobj-$(CONFIG_X86_LOCAL_APIC) += perfctr-watchdog.o 457414aa41SH. Peter Anvin 466276a074SBorislav Petkovobj-$(CONFIG_HYPERVISOR_GUEST) += vmware.o hypervisor.o mshyperv.o 476276a074SBorislav Petkov 489def39beSJosh Triplettifdef CONFIG_X86_FEATURE_NAMES 497414aa41SH. Peter Anvinquiet_cmd_mkcapflags = MKCAP $@ 500c0de199SRob Landley cmd_mkcapflags = $(CONFIG_SHELL) $(srctree)/$(src)/mkcapflags.sh $< $@ 517414aa41SH. Peter Anvin 52cd4d09ecSBorislav Petkovcpufeature = $(src)/../../include/asm/cpufeatures.h 537414aa41SH. Peter Anvin 547414aa41SH. Peter Anvintargets += capflags.c 550c0de199SRob Landley$(obj)/capflags.c: $(cpufeature) $(src)/mkcapflags.sh FORCE 567414aa41SH. Peter Anvin $(call if_changed,mkcapflags) 579def39beSJosh Triplettendif 58280dbc57SBjørn Morkclean-files += capflags.c 59