1 # SPDX-License-Identifier: GPL-2.0-only
3 # Makefile for the RISC-V Linux kernel
7 CFLAGS_REMOVE_ftrace.o = $(CC_FLAGS_FTRACE)
8 CFLAGS_REMOVE_patch.o = $(CC_FLAGS_FTRACE)
9 CFLAGS_REMOVE_sbi.o = $(CC_FLAGS_FTRACE)
11 CFLAGS_syscall_table.o += $(call cc-option,-Wno-override-init,)
14 AFLAGS_kexec_relocate.o := -mcmodel=medany $(call cc-option,-mno-relax)
17 # cmodel=medany and notrace when patching early
18 ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
19 CFLAGS_alternative.o := -mcmodel=medany
20 CFLAGS_cpufeature.o := -mcmodel=medany
22 CFLAGS_REMOVE_alternative.o = $(CC_FLAGS_FTRACE)
23 CFLAGS_REMOVE_cpufeature.o = $(CC_FLAGS_FTRACE)
26 KASAN_SANITIZE_alternative.o := n
27 KASAN_SANITIZE_cpufeature.o := n
32 extra-y += vmlinux.lds
35 obj-$(CONFIG_RISCV_ALTERNATIVE) += alternative.o
45 obj-y += syscall_table.o
49 obj-y += riscv_ksyms.o
54 obj-$(CONFIG_MMU) += vdso.o vdso/
56 obj-$(CONFIG_RISCV_M_MODE) += traps_misaligned.o
57 obj-$(CONFIG_FPU) += fpu.o
58 obj-$(CONFIG_SMP) += smpboot.o
59 obj-$(CONFIG_SMP) += smp.o
60 obj-$(CONFIG_SMP) += cpu_ops.o
62 obj-$(CONFIG_RISCV_BOOT_SPINWAIT) += cpu_ops_spinwait.o
63 obj-$(CONFIG_MODULES) += module.o
64 obj-$(CONFIG_MODULE_SECTIONS) += module-sections.o
66 obj-$(CONFIG_CPU_PM) += suspend_entry.o suspend.o
68 obj-$(CONFIG_FUNCTION_TRACER) += mcount.o ftrace.o
69 obj-$(CONFIG_DYNAMIC_FTRACE) += mcount-dyn.o
71 obj-$(CONFIG_TRACE_IRQFLAGS) += trace_irq.o
73 obj-$(CONFIG_PERF_EVENTS) += perf_callchain.o
74 obj-$(CONFIG_HAVE_PERF_REGS) += perf_regs.o
75 obj-$(CONFIG_RISCV_SBI) += sbi.o
76 ifeq ($(CONFIG_RISCV_SBI), y)
77 obj-$(CONFIG_SMP) += cpu_ops_sbi.o
79 obj-$(CONFIG_HOTPLUG_CPU) += cpu-hotplug.o
80 obj-$(CONFIG_KGDB) += kgdb.o
81 obj-$(CONFIG_KEXEC) += kexec_relocate.o crash_save_regs.o machine_kexec.o
82 obj-$(CONFIG_KEXEC_FILE) += elf_kexec.o machine_kexec_file.o
83 obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
85 obj-$(CONFIG_JUMP_LABEL) += jump_label.o
87 obj-$(CONFIG_EFI) += efi.o
88 obj-$(CONFIG_COMPAT) += compat_syscall_table.o
89 obj-$(CONFIG_COMPAT) += compat_signal.o
90 obj-$(CONFIG_COMPAT) += compat_vdso/