blob: b1bcd3746625a53b66c41ff98fec3c41e4027244 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
wdenkf47713f2002-09-08 19:49:36 +00002#
Marian Balakowiczf9328632006-09-01 19:49:50 +02003# (C) Copyright 2002-2006
wdenkf47713f2002-09-08 19:49:36 +00004# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenkf47713f2002-09-08 19:49:36 +00005
Marek Vasutc5a543e2016-05-26 18:01:40 +02006lib-$(CONFIG_USE_PRIVATE_LIBGCC) += ashldi3.o ashrdi3.o lshrdi3.o \
Marek Vasut0bf65c62016-05-26 18:01:44 +02007 lib1funcs.o uldivmod.o div0.o \
8 div64.o muldi3.o
wdenkf47713f2002-09-08 19:49:36 +00009
rev13@wp.pl12d8a722015-03-01 12:44:39 +010010ifdef CONFIG_CPU_V7M
11obj-y += vectors_m.o crt0.o
12else ifdef CONFIG_ARM64
David Feng0ae76532013-12-14 11:47:35 +080013obj-y += crt0_64.o
14else
Albert ARIBAUD41623c92014-04-15 16:13:51 +020015obj-y += vectors.o crt0.o
David Feng0ae76532013-12-14 11:47:35 +080016endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090017
Philipp Tomsichb4806d62017-10-10 16:21:13 +020018ifdef CONFIG_ARM64
19obj-y += setjmp_aarch64.o
20else
21obj-y += setjmp.o
22endif
23
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090024ifndef CONFIG_SPL_BUILD
David Feng0ae76532013-12-14 11:47:35 +080025ifdef CONFIG_ARM64
26obj-y += relocate_64.o
27else
28obj-y += relocate.o
29endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090030
Matt Porterf99993c2015-05-05 15:00:23 -040031obj-$(CONFIG_CPU_V7M) += cmd_boot.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090032obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
Bin Chen6808ef92018-01-27 16:59:09 +110033obj-$(CONFIG_CMD_BOOTI) += bootm.o image.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090034obj-$(CONFIG_CMD_BOOTM) += bootm.o
Tom Rini5db28902016-08-12 08:31:15 -040035obj-$(CONFIG_CMD_BOOTZ) += bootm.o zimage.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090036else
Heiko Stuebner22b7b862019-07-16 10:12:02 +020037obj-$(CONFIG_$(SPL_TPL_)FRAMEWORK) += spl.o
Nathan Barrett-Morrison7a0d8802022-02-02 15:05:18 -050038ifdef CONFIG_SPL_FRAMEWORK
39obj-$(CONFIG_CMD_BOOTI) += image.o
40obj-$(CONFIG_CMD_BOOTZ) += zimage.o
41endif
B, Ravi984a3c82017-04-18 17:27:26 +053042obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090043endif
Stefan Roesedbf6b142021-09-02 17:00:17 +020044ifdef CONFIG_ARM64
45obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMSET) += memset-arm64.o
46obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMCPY) += memcpy-arm64.o
47else
Marek Vasuta821a772018-04-07 16:06:36 +020048obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMSET) += memset.o
49obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMCPY) += memcpy.o
Stefan Roesedbf6b142021-09-02 17:00:17 +020050endif
Philip Oberfichtnerb6664ea2022-08-17 15:07:13 +020051obj-$(CONFIG_$(SPL_TPL_)SYS_L2_PL310) += cache-pl310.o
Sean Anderson8e1c9fe2022-03-22 16:59:19 -040052obj-$(CONFIG_$(SPL_TPL_)SEMIHOSTING) += semihosting.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090053
Dzmitry Sankouski12a3e1a2022-02-22 21:49:52 +030054ifneq ($(filter y,$(CONFIG_SAVE_PREV_BL_INITRAMFS_START_ADDR) $(CONFIG_SAVE_PREV_BL_FDT_ADDR)),)
55obj-y += save_prev_bl_data.o
56endif
57
58# obj-$(CONFIG_SAVE_PREV_BL_INITRAMFS_START_ADDR) += save_prev_bl_data.o
Simon Glass59b0d7d2020-05-10 14:16:56 -060059obj-y += bdinfo.o
Albert ARIBAUDd0b5d9d2014-02-22 17:53:42 +010060obj-y += sections.o
Marek Behún8f969652021-05-20 13:24:22 +020061CFLAGS_REMOVE_sections.o := $(LTO_CFLAGS)
62
Andreas Bießmann68145d42015-02-06 23:06:45 +010063obj-y += stack.o
rev13@wp.pl12d8a722015-03-01 12:44:39 +010064ifdef CONFIG_CPU_V7M
65obj-y += interrupts_m.o
66else ifdef CONFIG_ARM64
Andre Przywara98db26a2017-04-26 01:32:41 +010067obj-$(CONFIG_FSL_LAYERSCAPE) += ccn504.o
Andre Przywara0cef6cb2017-04-26 01:32:40 +010068ifneq ($(CONFIG_GICV2)$(CONFIG_GICV3),)
David Fengc71645a2014-03-14 14:26:27 +080069obj-y += gic_64.o
Andre Przywara0cef6cb2017-04-26 01:32:40 +010070endif
Bharat Kumar Reddy Gooty0bc43562019-12-16 09:09:43 -080071obj-$(CONFIG_GIC_V3_ITS) += gic-v3-its.o
David Feng0ae76532013-12-14 11:47:35 +080072obj-y += interrupts_64.o
73else
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090074obj-y += interrupts.o
David Feng0ae76532013-12-14 11:47:35 +080075endif
Claudius Heineb46e6cc2020-03-04 15:23:10 +010076ifndef CONFIG_$(SPL_TPL_)SYSRESET
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090077obj-y += reset.o
Simon Glassc6aabe92015-08-30 16:55:18 -060078endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090079
80obj-y += cache.o
Lokesh Vutlaf4bcd762018-04-26 18:21:28 +053081obj-$(CONFIG_SYS_ARM_CACHE_CP15) += cache-cp15.o
Marek Behúne5fc9032021-05-20 13:24:11 +020082CFLAGS_REMOVE_cache-cp15.o := $(LTO_CFLAGS)
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090083
Hou Zhiqiang45684ae2016-06-28 20:18:16 +080084obj-y += psci-dt.o
85
Masahiro Yamada51b17d42014-09-01 11:06:34 +090086obj-$(CONFIG_DEBUG_LL) += debug.o
87
Wolfgang Denkf772acf2009-08-17 13:17:29 +020088# For EABI conformant tool chains, provide eabi_compat()
89ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS)))
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090090extra-y += eabi_compat.o
Wolfgang Denkf772acf2009-08-17 13:17:29 +020091endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +020092
93# some files can only build in ARM or THUMB2, not THUMB1
94
Tom Rini3a649402017-03-18 09:01:44 -040095ifdef CONFIG_$(SPL_)SYS_THUMB_BUILD
Marek Vasutc0db6f82016-05-26 18:01:37 +020096asflags-$(CONFIG_HAS_THUMB2) += -DCONFIG_THUMB2_KERNEL
Albert ARIBAUD62e92072015-10-23 18:06:40 +020097ifndef CONFIG_HAS_THUMB2
98
99# for C files, just apend -marm, which will override previous -mthumb*
100
Andre Przywaraebda0cc2017-01-02 11:48:26 +0000101ifndef CONFIG_ARM64
Albert ARIBAUD62e92072015-10-23 18:06:40 +0200102CFLAGS_cache.o := -marm
103CFLAGS_cache-cp15.o := -marm
Andre Przywaraebda0cc2017-01-02 11:48:26 +0000104endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +0200105
106# For .S, drop -mthumb* and other thumb-related options.
107# CFLAGS_REMOVE_* would not have an effet, so AFLAGS_REMOVE_*
108# was implemented and is used here.
109# Also, define ${target}_NO_THUMB_BUILD for these two targets
110# so that the code knows it should not use Thumb.
111
112AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork
113AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork
114AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD
115AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD
Sean Anderson726a8022023-07-31 17:27:33 -0400116
117# This is only necessary to force ARM mode on THUMB1 targets.
118ifneq ($(CONFIG_SYS_ARM_ARCH),4)
119obj-y += bitops.o
120endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +0200121endif
122endif
Simon Glassdd46eef2016-11-07 08:47:10 -0700123
124# For building EFI apps
125CFLAGS_$(EFI_CRT0) := $(CFLAGS_EFI)
126CFLAGS_REMOVE_$(EFI_CRT0) := $(CFLAGS_NON_EFI)
127
128CFLAGS_$(EFI_RELOC) := $(CFLAGS_EFI)
129CFLAGS_REMOVE_$(EFI_RELOC) := $(CFLAGS_NON_EFI)
130
Alexander Graf95b62b22016-11-17 22:40:10 +0100131extra-$(CONFIG_CMD_BOOTEFI_HELLO_COMPILE) += $(EFI_CRT0) $(EFI_RELOC)
Heinrich Schuchardte4fd6952018-12-30 10:52:41 +0100132# TODO: As of v2019.01 the relocation code for the EFI application cannot
133# be built on ARMv7-M.
134ifndef CONFIG_CPU_V7M
135#extra-$(CONFIG_CMD_BOOTEFI_SELFTEST) += $(EFI_CRT0) $(EFI_RELOC)
136endif
Simon Glassdd46eef2016-11-07 08:47:10 -0700137extra-$(CONFIG_EFI) += $(EFI_CRT0) $(EFI_RELOC)