xref: /linux/arch/riscv/kernel/Makefile (revision 77acc6b5)
1# SPDX-License-Identifier: GPL-2.0-only
2#
3# Makefile for the RISC-V Linux kernel
4#
5
6ifdef CONFIG_FTRACE
7CFLAGS_REMOVE_ftrace.o	= $(CC_FLAGS_FTRACE)
8CFLAGS_REMOVE_patch.o	= $(CC_FLAGS_FTRACE)
9CFLAGS_REMOVE_sbi.o	= $(CC_FLAGS_FTRACE)
10CFLAGS_REMOVE_return_address.o	= $(CC_FLAGS_FTRACE)
11endif
12CFLAGS_syscall_table.o	+= $(call cc-option,-Wno-override-init,)
13CFLAGS_compat_syscall_table.o += $(call cc-option,-Wno-override-init,)
14
15ifdef CONFIG_KEXEC_CORE
16AFLAGS_kexec_relocate.o := -mcmodel=medany $(call cc-option,-mno-relax)
17endif
18
19# cmodel=medany and notrace when patching early
20ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
21CFLAGS_alternative.o := -mcmodel=medany
22CFLAGS_cpufeature.o := -mcmodel=medany
23ifdef CONFIG_FTRACE
24CFLAGS_REMOVE_alternative.o = $(CC_FLAGS_FTRACE)
25CFLAGS_REMOVE_cpufeature.o = $(CC_FLAGS_FTRACE)
26endif
27ifdef CONFIG_RELOCATABLE
28CFLAGS_alternative.o += -fno-pie
29CFLAGS_cpufeature.o += -fno-pie
30endif
31ifdef CONFIG_KASAN
32KASAN_SANITIZE_alternative.o := n
33KASAN_SANITIZE_cpufeature.o := n
34endif
35endif
36
37extra-y += vmlinux.lds
38
39obj-y	+= head.o
40obj-y	+= soc.o
41obj-$(CONFIG_RISCV_ALTERNATIVE) += alternative.o
42obj-y	+= cpu.o
43obj-y	+= cpufeature.o
44obj-y	+= entry.o
45obj-y	+= irq.o
46obj-y	+= process.o
47obj-y	+= ptrace.o
48obj-y	+= reset.o
49obj-y	+= return_address.o
50obj-y	+= setup.o
51obj-y	+= signal.o
52obj-y	+= syscall_table.o
53obj-y	+= sys_riscv.o
54obj-y	+= sys_hwprobe.o
55obj-y	+= time.o
56obj-y	+= traps.o
57obj-y	+= riscv_ksyms.o
58obj-y	+= stacktrace.o
59obj-y	+= cacheinfo.o
60obj-y	+= patch.o
61obj-y	+= probes/
62obj-y	+= tests/
63obj-$(CONFIG_MMU) += vdso.o vdso/
64
65obj-$(CONFIG_RISCV_MISALIGNED)	+= traps_misaligned.o
66obj-$(CONFIG_RISCV_MISALIGNED)	+= unaligned_access_speed.o
67obj-$(CONFIG_RISCV_PROBE_UNALIGNED_ACCESS)	+= copy-unaligned.o
68
69obj-$(CONFIG_FPU)		+= fpu.o
70obj-$(CONFIG_FPU)		+= kernel_mode_fpu.o
71obj-$(CONFIG_RISCV_ISA_V)	+= vector.o
72obj-$(CONFIG_RISCV_ISA_V)	+= kernel_mode_vector.o
73obj-$(CONFIG_SMP)		+= smpboot.o
74obj-$(CONFIG_SMP)		+= smp.o
75obj-$(CONFIG_SMP)		+= cpu_ops.o
76
77obj-$(CONFIG_RISCV_BOOT_SPINWAIT) += cpu_ops_spinwait.o
78obj-$(CONFIG_MODULES)		+= module.o
79obj-$(CONFIG_MODULE_SECTIONS)	+= module-sections.o
80
81obj-$(CONFIG_CPU_PM)		+= suspend_entry.o suspend.o
82obj-$(CONFIG_HIBERNATION)	+= hibernate.o hibernate-asm.o
83
84obj-$(CONFIG_FUNCTION_TRACER)	+= mcount.o ftrace.o
85obj-$(CONFIG_DYNAMIC_FTRACE)	+= mcount-dyn.o
86
87obj-$(CONFIG_PERF_EVENTS)	+= perf_callchain.o
88obj-$(CONFIG_HAVE_PERF_REGS)	+= perf_regs.o
89obj-$(CONFIG_RISCV_SBI)		+= sbi.o
90ifeq ($(CONFIG_RISCV_SBI), y)
91obj-$(CONFIG_SMP)		+= sbi-ipi.o
92obj-$(CONFIG_SMP) += cpu_ops_sbi.o
93endif
94obj-$(CONFIG_HOTPLUG_CPU)	+= cpu-hotplug.o
95obj-$(CONFIG_PARAVIRT)		+= paravirt.o
96obj-$(CONFIG_KGDB)		+= kgdb.o
97obj-$(CONFIG_KEXEC_CORE)	+= kexec_relocate.o crash_save_regs.o machine_kexec.o
98obj-$(CONFIG_KEXEC_FILE)	+= elf_kexec.o machine_kexec_file.o
99obj-$(CONFIG_CRASH_DUMP)	+= crash_dump.o
100obj-$(CONFIG_VMCORE_INFO)	+= vmcore_info.o
101
102obj-$(CONFIG_JUMP_LABEL)	+= jump_label.o
103
104obj-$(CONFIG_CFI_CLANG)		+= cfi.o
105
106obj-$(CONFIG_EFI)		+= efi.o
107obj-$(CONFIG_COMPAT)		+= compat_syscall_table.o
108obj-$(CONFIG_COMPAT)		+= compat_signal.o
109obj-$(CONFIG_COMPAT)		+= compat_vdso/
110
111obj-$(CONFIG_64BIT)		+= pi/
112obj-$(CONFIG_ACPI)		+= acpi.o
113