1# SPDX-License-Identifier: GPL-2.0 2# 3# Makefile for the linux kernel. 4# 5 6extra-y += vmlinux.lds 7 8CPPFLAGS_vmlinux.lds += -U$(UTS_MACHINE) 9 10ifdef CONFIG_FUNCTION_TRACER 11# Do not profile debug and lowlevel utilities 12CFLAGS_REMOVE_tsc.o = -pg 13CFLAGS_REMOVE_paravirt-spinlocks.o = -pg 14CFLAGS_REMOVE_pvclock.o = -pg 15CFLAGS_REMOVE_kvmclock.o = -pg 16CFLAGS_REMOVE_ftrace.o = -pg 17CFLAGS_REMOVE_early_printk.o = -pg 18CFLAGS_REMOVE_head64.o = -pg 19CFLAGS_REMOVE_head32.o = -pg 20CFLAGS_REMOVE_rethook.o = -pg 21endif 22 23KASAN_SANITIZE_head$(BITS).o := n 24KASAN_SANITIZE_dumpstack.o := n 25KASAN_SANITIZE_dumpstack_$(BITS).o := n 26KASAN_SANITIZE_stacktrace.o := n 27KASAN_SANITIZE_paravirt.o := n 28 29# With some compiler versions the generated code results in boot hangs, caused 30# by several compilation units. To be safe, disable all instrumentation. 31KCSAN_SANITIZE := n 32KMSAN_SANITIZE_head$(BITS).o := n 33KMSAN_SANITIZE_nmi.o := n 34 35# If instrumentation of the following files is enabled, boot hangs during 36# first second. 37KCOV_INSTRUMENT_head$(BITS).o := n 38# These are called from save_stack_trace() on debug paths, 39# and produce large amounts of uninteresting coverage. 40KCOV_INSTRUMENT_stacktrace.o := n 41KCOV_INSTRUMENT_dumpstack.o := n 42KCOV_INSTRUMENT_dumpstack_$(BITS).o := n 43KCOV_INSTRUMENT_unwind_orc.o := n 44KCOV_INSTRUMENT_unwind_frame.o := n 45KCOV_INSTRUMENT_unwind_guess.o := n 46 47CFLAGS_head32.o := -fno-stack-protector 48CFLAGS_head64.o := -fno-stack-protector 49CFLAGS_irq.o := -I $(src)/../include/asm/trace 50 51obj-y += head_$(BITS).o 52obj-y += head$(BITS).o 53obj-y += ebda.o 54obj-y += platform-quirks.o 55obj-y += process_$(BITS).o signal.o signal_$(BITS).o 56obj-y += traps.o idt.o irq.o irq_$(BITS).o dumpstack_$(BITS).o 57obj-y += time.o ioport.o dumpstack.o nmi.o 58obj-$(CONFIG_X86_FRED) += fred.o 59obj-$(CONFIG_MODIFY_LDT_SYSCALL) += ldt.o 60obj-$(CONFIG_X86_KERNEL_IBT) += ibt_selftest.o 61obj-y += setup.o x86_init.o i8259.o irqinit.o 62obj-$(CONFIG_JUMP_LABEL) += jump_label.o 63obj-$(CONFIG_IRQ_WORK) += irq_work.o 64obj-y += probe_roms.o 65obj-$(CONFIG_X86_32) += sys_ia32.o 66obj-$(CONFIG_IA32_EMULATION) += sys_ia32.o signal_32.o 67obj-$(CONFIG_X86_64) += sys_x86_64.o 68obj-$(CONFIG_X86_ESPFIX64) += espfix_64.o 69obj-$(CONFIG_SYSFS) += ksysfs.o 70obj-y += bootflag.o e820.o 71obj-y += pci-dma.o quirks.o kdebugfs.o 72obj-y += alternative.o i8253.o hw_breakpoint.o 73obj-y += tsc.o tsc_msr.o io_delay.o rtc.o 74obj-y += resource.o 75obj-y += irqflags.o 76obj-y += static_call.o 77 78obj-y += process.o 79obj-y += fpu/ 80obj-y += ptrace.o 81obj-$(CONFIG_X86_32) += tls.o 82obj-$(CONFIG_IA32_EMULATION) += tls.o 83obj-y += step.o 84obj-$(CONFIG_INTEL_TXT) += tboot.o 85obj-$(CONFIG_ISA_DMA_API) += i8237.o 86obj-y += stacktrace.o 87obj-y += cpu/ 88obj-y += acpi/ 89obj-y += reboot.o 90obj-$(CONFIG_X86_MSR) += msr.o 91obj-$(CONFIG_X86_CPUID) += cpuid.o 92obj-$(CONFIG_PCI) += early-quirks.o 93apm-y := apm_32.o 94obj-$(CONFIG_APM) += apm.o 95obj-$(CONFIG_SMP) += smp.o 96obj-$(CONFIG_SMP) += smpboot.o 97obj-$(CONFIG_X86_TSC) += tsc_sync.o 98obj-$(CONFIG_SMP) += setup_percpu.o 99obj-$(CONFIG_X86_MPPARSE) += mpparse.o 100obj-y += apic/ 101obj-$(CONFIG_X86_REBOOTFIXUPS) += reboot_fixups_32.o 102obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o 103obj-$(CONFIG_FUNCTION_TRACER) += ftrace_$(BITS).o 104obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o 105obj-$(CONFIG_FTRACE_SYSCALLS) += ftrace.o 106obj-$(CONFIG_X86_TSC) += trace_clock.o 107obj-$(CONFIG_TRACING) += trace.o 108obj-$(CONFIG_RETHOOK) += rethook.o 109obj-$(CONFIG_VMCORE_INFO) += vmcore_info_$(BITS).o 110obj-$(CONFIG_KEXEC_CORE) += machine_kexec_$(BITS).o 111obj-$(CONFIG_KEXEC_CORE) += relocate_kernel_$(BITS).o 112obj-$(CONFIG_KEXEC_FILE) += kexec-bzimage64.o 113obj-$(CONFIG_CRASH_DUMP) += crash_dump_$(BITS).o crash.o 114obj-y += kprobes/ 115obj-$(CONFIG_MODULES) += module.o 116obj-$(CONFIG_X86_32) += doublefault_32.o 117obj-$(CONFIG_KGDB) += kgdb.o 118obj-$(CONFIG_VM86) += vm86_32.o 119obj-$(CONFIG_EARLY_PRINTK) += early_printk.o 120 121obj-$(CONFIG_HPET_TIMER) += hpet.o 122 123obj-$(CONFIG_AMD_NB) += amd_nb.o 124obj-$(CONFIG_AMD_NODE) += amd_node.o 125obj-$(CONFIG_DEBUG_NMI_SELFTEST) += nmi_selftest.o 126 127obj-$(CONFIG_KVM_GUEST) += kvm.o kvmclock.o 128obj-$(CONFIG_PARAVIRT) += paravirt.o 129obj-$(CONFIG_PARAVIRT_SPINLOCKS)+= paravirt-spinlocks.o 130obj-$(CONFIG_PARAVIRT_CLOCK) += pvclock.o 131obj-$(CONFIG_X86_PMEM_LEGACY_DEVICE) += pmem.o 132 133obj-$(CONFIG_JAILHOUSE_GUEST) += jailhouse.o 134 135obj-$(CONFIG_EISA) += eisa.o 136obj-$(CONFIG_PCSPKR_PLATFORM) += pcspeaker.o 137 138obj-$(CONFIG_X86_CHECK_BIOS_CORRUPTION) += check.o 139 140obj-$(CONFIG_OF) += devicetree.o 141obj-$(CONFIG_UPROBES) += uprobes.o 142 143obj-$(CONFIG_PERF_EVENTS) += perf_regs.o 144obj-$(CONFIG_TRACING) += tracepoint.o 145obj-$(CONFIG_SCHED_MC_PRIO) += itmt.o 146obj-$(CONFIG_X86_UMIP) += umip.o 147 148obj-$(CONFIG_UNWINDER_ORC) += unwind_orc.o 149obj-$(CONFIG_UNWINDER_FRAME_POINTER) += unwind_frame.o 150obj-$(CONFIG_UNWINDER_GUESS) += unwind_guess.o 151 152obj-$(CONFIG_CFI_CLANG) += cfi.o 153 154obj-$(CONFIG_CALL_THUNKS) += callthunks.o 155 156obj-$(CONFIG_X86_CET) += cet.o 157 158obj-$(CONFIG_X86_USER_SHADOW_STACK) += shstk.o 159 160### 161# 64 bit specific files 162ifeq ($(CONFIG_X86_64),y) 163 obj-$(CONFIG_AUDIT) += audit_64.o 164 165 obj-$(CONFIG_GART_IOMMU) += amd_gart_64.o aperture_64.o 166 167 obj-$(CONFIG_MMCONF_FAM10H) += mmconf-fam10h_64.o 168 obj-y += vsmp_64.o 169endif 170