xref: /linux/arch/arm64/kernel/Makefile (revision a2cce7a9f1b8cc3d4edce106fb971529f1d4d9ce)
1#
2# Makefile for the linux kernel.
3#
4
5CPPFLAGS_vmlinux.lds	:= -DTEXT_OFFSET=$(TEXT_OFFSET)
6AFLAGS_head.o		:= -DTEXT_OFFSET=$(TEXT_OFFSET)
7CFLAGS_efi-stub.o 	:= -DTEXT_OFFSET=$(TEXT_OFFSET)
8CFLAGS_armv8_deprecated.o := -I$(src)
9
10CFLAGS_REMOVE_ftrace.o = -pg
11CFLAGS_REMOVE_insn.o = -pg
12CFLAGS_REMOVE_return_address.o = -pg
13
14# Object file lists.
15arm64-obj-y		:= debug-monitors.o entry.o irq.o fpsimd.o		\
16			   entry-fpsimd.o process.o ptrace.o setup.o signal.o	\
17			   sys.o stacktrace.o time.o traps.o io.o vdso.o	\
18			   hyp-stub.o psci.o psci-call.o cpu_ops.o insn.o	\
19			   return_address.o cpuinfo.o cpu_errata.o		\
20			   cpufeature.o alternative.o cacheinfo.o		\
21			   smp.o smp_spin_table.o topology.o
22
23arm64-obj-$(CONFIG_COMPAT)		+= sys32.o kuser32.o signal32.o 	\
24					   sys_compat.o entry32.o		\
25					   ../../arm/kernel/opcodes.o
26arm64-obj-$(CONFIG_FUNCTION_TRACER)	+= ftrace.o entry-ftrace.o
27arm64-obj-$(CONFIG_MODULES)		+= arm64ksyms.o module.o
28arm64-obj-$(CONFIG_PERF_EVENTS)		+= perf_regs.o perf_callchain.o
29arm64-obj-$(CONFIG_HW_PERF_EVENTS)	+= perf_event.o
30arm64-obj-$(CONFIG_HAVE_HW_BREAKPOINT)	+= hw_breakpoint.o
31arm64-obj-$(CONFIG_CPU_PM)		+= sleep.o suspend.o
32arm64-obj-$(CONFIG_CPU_IDLE)		+= cpuidle.o
33arm64-obj-$(CONFIG_JUMP_LABEL)		+= jump_label.o
34arm64-obj-$(CONFIG_KGDB)		+= kgdb.o
35arm64-obj-$(CONFIG_EFI)			+= efi.o efi-stub.o efi-entry.o
36arm64-obj-$(CONFIG_PCI)			+= pci.o
37arm64-obj-$(CONFIG_ARMV8_DEPRECATED)	+= armv8_deprecated.o
38arm64-obj-$(CONFIG_ACPI)		+= acpi.o
39
40obj-y					+= $(arm64-obj-y) vdso/
41obj-m					+= $(arm64-obj-m)
42head-y					:= head.o
43extra-y					:= $(head-y) vmlinux.lds
44
45# vDSO - this must be built first to generate the symbol offsets
46$(call objectify,$(arm64-obj-y)): $(obj)/vdso/vdso-offsets.h
47$(obj)/vdso/vdso-offsets.h: $(obj)/vdso
48