GNU Linux-libre 6.1.90-gnu
[releases.git] / arch / riscv / kernel / Makefile
1 # SPDX-License-Identifier: GPL-2.0-only
2 #
3 # Makefile for the RISC-V Linux kernel
4 #
5
6 ifdef CONFIG_FTRACE
7 CFLAGS_REMOVE_ftrace.o  = $(CC_FLAGS_FTRACE)
8 CFLAGS_REMOVE_patch.o   = $(CC_FLAGS_FTRACE)
9 CFLAGS_REMOVE_sbi.o     = $(CC_FLAGS_FTRACE)
10 CFLAGS_REMOVE_return_address.o  = $(CC_FLAGS_FTRACE)
11 endif
12 CFLAGS_syscall_table.o  += $(call cc-option,-Wno-override-init,)
13 CFLAGS_compat_syscall_table.o += $(call cc-option,-Wno-override-init,)
14
15 ifdef CONFIG_KEXEC
16 AFLAGS_kexec_relocate.o := -mcmodel=medany $(call cc-option,-mno-relax)
17 endif
18
19 # cmodel=medany and notrace when patching early
20 ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
21 CFLAGS_alternative.o := -mcmodel=medany
22 CFLAGS_cpufeature.o := -mcmodel=medany
23 ifdef CONFIG_FTRACE
24 CFLAGS_REMOVE_alternative.o = $(CC_FLAGS_FTRACE)
25 CFLAGS_REMOVE_cpufeature.o = $(CC_FLAGS_FTRACE)
26 endif
27 ifdef CONFIG_KASAN
28 KASAN_SANITIZE_alternative.o := n
29 KASAN_SANITIZE_cpufeature.o := n
30 endif
31 endif
32
33 extra-y += vmlinux.lds
34
35 obj-y   += head.o
36 obj-y   += soc.o
37 obj-$(CONFIG_RISCV_ALTERNATIVE) += alternative.o
38 obj-y   += cpu.o
39 obj-y   += cpufeature.o
40 obj-y   += entry.o
41 obj-y   += irq.o
42 obj-y   += process.o
43 obj-y   += ptrace.o
44 obj-y   += reset.o
45 obj-y   += return_address.o
46 obj-y   += setup.o
47 obj-y   += signal.o
48 obj-y   += syscall_table.o
49 obj-y   += sys_riscv.o
50 obj-y   += time.o
51 obj-y   += traps.o
52 obj-y   += riscv_ksyms.o
53 obj-y   += stacktrace.o
54 obj-y   += cacheinfo.o
55 obj-y   += patch.o
56 obj-y   += probes/
57 obj-$(CONFIG_MMU) += vdso.o vdso/
58
59 obj-$(CONFIG_RISCV_M_MODE)      += traps_misaligned.o
60 obj-$(CONFIG_FPU)               += fpu.o
61 obj-$(CONFIG_SMP)               += smpboot.o
62 obj-$(CONFIG_SMP)               += smp.o
63 obj-$(CONFIG_SMP)               += cpu_ops.o
64
65 obj-$(CONFIG_RISCV_BOOT_SPINWAIT) += cpu_ops_spinwait.o
66 obj-$(CONFIG_MODULES)           += module.o
67 obj-$(CONFIG_MODULE_SECTIONS)   += module-sections.o
68
69 obj-$(CONFIG_CPU_PM)            += suspend_entry.o suspend.o
70
71 obj-$(CONFIG_FUNCTION_TRACER)   += mcount.o ftrace.o
72 obj-$(CONFIG_DYNAMIC_FTRACE)    += mcount-dyn.o
73
74 obj-$(CONFIG_TRACE_IRQFLAGS)    += trace_irq.o
75
76 obj-$(CONFIG_PERF_EVENTS)       += perf_callchain.o
77 obj-$(CONFIG_HAVE_PERF_REGS)    += perf_regs.o
78 obj-$(CONFIG_RISCV_SBI)         += sbi.o
79 ifeq ($(CONFIG_RISCV_SBI), y)
80 obj-$(CONFIG_SMP) += cpu_ops_sbi.o
81 endif
82 obj-$(CONFIG_HOTPLUG_CPU)       += cpu-hotplug.o
83 obj-$(CONFIG_KGDB)              += kgdb.o
84 obj-$(CONFIG_KEXEC_CORE)        += kexec_relocate.o crash_save_regs.o machine_kexec.o
85 obj-$(CONFIG_KEXEC_FILE)        += elf_kexec.o machine_kexec_file.o
86 obj-$(CONFIG_CRASH_DUMP)        += crash_dump.o
87
88 obj-$(CONFIG_JUMP_LABEL)        += jump_label.o
89
90 obj-$(CONFIG_EFI)               += efi.o
91 obj-$(CONFIG_COMPAT)            += compat_syscall_table.o
92 obj-$(CONFIG_COMPAT)            += compat_signal.o
93 obj-$(CONFIG_COMPAT)            += compat_vdso/