blob: b5ffffd4e31e775a374640560548ed2fa5a2c861 [file] [log] [blame]
wdenkf47713f2002-09-08 19:49:36 +00001#
Marian Balakowiczf9328632006-09-01 19:49:50 +02002# (C) Copyright 2002-2006
wdenkf47713f2002-09-08 19:49:36 +00003# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
Wolfgang Denk1a459662013-07-08 09:37:19 +02005# SPDX-License-Identifier: GPL-2.0+
wdenkf47713f2002-09-08 19:49:36 +00006#
7
Marek Vasutc5a543e2016-05-26 18:01:40 +02008lib-$(CONFIG_USE_PRIVATE_LIBGCC) += ashldi3.o ashrdi3.o lshrdi3.o \
Marek Vasut0bf65c62016-05-26 18:01:44 +02009 lib1funcs.o uldivmod.o div0.o \
10 div64.o muldi3.o
wdenkf47713f2002-09-08 19:49:36 +000011
rev13@wp.pl12d8a722015-03-01 12:44:39 +010012ifdef CONFIG_CPU_V7M
13obj-y += vectors_m.o crt0.o
14else ifdef CONFIG_ARM64
David Feng0ae76532013-12-14 11:47:35 +080015obj-y += crt0_64.o
16else
Albert ARIBAUD41623c92014-04-15 16:13:51 +020017obj-y += vectors.o crt0.o
David Feng0ae76532013-12-14 11:47:35 +080018endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090019
Philipp Tomsichb4806d62017-10-10 16:21:13 +020020ifdef CONFIG_ARM64
21obj-y += setjmp_aarch64.o
22else
23obj-y += setjmp.o
24endif
25
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090026ifndef CONFIG_SPL_BUILD
David Feng0ae76532013-12-14 11:47:35 +080027ifdef CONFIG_ARM64
28obj-y += relocate_64.o
29else
30obj-y += relocate.o
31endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090032
Matt Porterf99993c2015-05-05 15:00:23 -040033obj-$(CONFIG_CPU_V7M) += cmd_boot.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090034obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
Bin Chen6808ef92018-01-27 16:59:09 +110035obj-$(CONFIG_CMD_BOOTI) += bootm.o image.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090036obj-$(CONFIG_CMD_BOOTM) += bootm.o
Tom Rini5db28902016-08-12 08:31:15 -040037obj-$(CONFIG_CMD_BOOTZ) += bootm.o zimage.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090038obj-$(CONFIG_SYS_L2_PL310) += cache-pl310.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090039else
40obj-$(CONFIG_SPL_FRAMEWORK) += spl.o
Ladislav Michl431889d2016-07-12 20:28:14 +020041obj-$(CONFIG_SPL_FRAMEWORK) += zimage.o
B, Ravi984a3c82017-04-18 17:27:26 +053042obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090043endif
Tom Rini40d55342017-01-12 13:16:02 -050044obj-$(CONFIG_$(SPL_)USE_ARCH_MEMSET) += memset.o
45obj-$(CONFIG_$(SPL_)USE_ARCH_MEMCPY) += memcpy.o
Darwin Rambo261d2762014-06-09 11:12:59 -070046obj-$(CONFIG_SEMIHOSTING) += semihosting.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090047
Albert ARIBAUDd0b5d9d2014-02-22 17:53:42 +010048obj-y += sections.o
Andreas Bießmann68145d42015-02-06 23:06:45 +010049obj-y += stack.o
rev13@wp.pl12d8a722015-03-01 12:44:39 +010050ifdef CONFIG_CPU_V7M
51obj-y += interrupts_m.o
52else ifdef CONFIG_ARM64
Andre Przywara98db26a2017-04-26 01:32:41 +010053obj-$(CONFIG_FSL_LAYERSCAPE) += ccn504.o
Andre Przywara0cef6cb2017-04-26 01:32:40 +010054ifneq ($(CONFIG_GICV2)$(CONFIG_GICV3),)
David Fengc71645a2014-03-14 14:26:27 +080055obj-y += gic_64.o
Andre Przywara0cef6cb2017-04-26 01:32:40 +010056endif
David Feng0ae76532013-12-14 11:47:35 +080057obj-y += interrupts_64.o
58else
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090059obj-y += interrupts.o
David Feng0ae76532013-12-14 11:47:35 +080060endif
Stephen Warren11636252016-05-12 12:03:35 -060061ifndef CONFIG_SYSRESET
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090062obj-y += reset.o
Simon Glassc6aabe92015-08-30 16:55:18 -060063endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090064
65obj-y += cache.o
David Feng0ae76532013-12-14 11:47:35 +080066ifndef CONFIG_ARM64
Vikas Manochabf4d0492017-03-27 13:02:44 -070067ifndef CONFIG_CPU_V7M
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090068obj-y += cache-cp15.o
David Feng0ae76532013-12-14 11:47:35 +080069endif
Vikas Manochabf4d0492017-03-27 13:02:44 -070070endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090071
Hou Zhiqiang45684ae2016-06-28 20:18:16 +080072obj-y += psci-dt.o
73
Masahiro Yamada51b17d42014-09-01 11:06:34 +090074obj-$(CONFIG_DEBUG_LL) += debug.o
75
Wolfgang Denkf772acf2009-08-17 13:17:29 +020076# For EABI conformant tool chains, provide eabi_compat()
77ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS)))
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090078extra-y += eabi_compat.o
Wolfgang Denkf772acf2009-08-17 13:17:29 +020079endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +020080
81# some files can only build in ARM or THUMB2, not THUMB1
82
Tom Rini3a649402017-03-18 09:01:44 -040083ifdef CONFIG_$(SPL_)SYS_THUMB_BUILD
Marek Vasutc0db6f82016-05-26 18:01:37 +020084asflags-$(CONFIG_HAS_THUMB2) += -DCONFIG_THUMB2_KERNEL
Albert ARIBAUD62e92072015-10-23 18:06:40 +020085ifndef CONFIG_HAS_THUMB2
86
87# for C files, just apend -marm, which will override previous -mthumb*
88
Andre Przywaraebda0cc2017-01-02 11:48:26 +000089ifndef CONFIG_ARM64
Albert ARIBAUD62e92072015-10-23 18:06:40 +020090CFLAGS_cache.o := -marm
91CFLAGS_cache-cp15.o := -marm
Andre Przywaraebda0cc2017-01-02 11:48:26 +000092endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +020093
94# For .S, drop -mthumb* and other thumb-related options.
95# CFLAGS_REMOVE_* would not have an effet, so AFLAGS_REMOVE_*
96# was implemented and is used here.
97# Also, define ${target}_NO_THUMB_BUILD for these two targets
98# so that the code knows it should not use Thumb.
99
100AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork
101AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork
102AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD
103AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD
Albert ARIBAUD62e92072015-10-23 18:06:40 +0200104endif
105endif
Simon Glassdd46eef2016-11-07 08:47:10 -0700106
107# For building EFI apps
108CFLAGS_$(EFI_CRT0) := $(CFLAGS_EFI)
109CFLAGS_REMOVE_$(EFI_CRT0) := $(CFLAGS_NON_EFI)
110
111CFLAGS_$(EFI_RELOC) := $(CFLAGS_EFI)
112CFLAGS_REMOVE_$(EFI_RELOC) := $(CFLAGS_NON_EFI)
113
Alexander Graf95b62b22016-11-17 22:40:10 +0100114extra-$(CONFIG_CMD_BOOTEFI_HELLO_COMPILE) += $(EFI_CRT0) $(EFI_RELOC)
Heinrich Schuchardt8218f7b2018-01-19 19:01:05 +0100115extra-$(CONFIG_CMD_BOOTEFI_SELFTEST) += $(EFI_CRT0) $(EFI_RELOC)
Simon Glassdd46eef2016-11-07 08:47:10 -0700116extra-$(CONFIG_EFI) += $(EFI_CRT0) $(EFI_RELOC)