blob: a1ab2978c59227f8f1f67d4d3cca6030f8d01b03 [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 \
9 lib1funcs.o uldivmod.o div0.o
wdenkf47713f2002-09-08 19:49:36 +000010
rev13@wp.pl12d8a722015-03-01 12:44:39 +010011ifdef CONFIG_CPU_V7M
12obj-y += vectors_m.o crt0.o
13else ifdef CONFIG_ARM64
David Feng0ae76532013-12-14 11:47:35 +080014obj-y += crt0_64.o
15else
Albert ARIBAUD41623c92014-04-15 16:13:51 +020016obj-y += vectors.o crt0.o
David Feng0ae76532013-12-14 11:47:35 +080017endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090018
19ifndef CONFIG_SPL_BUILD
David Feng0ae76532013-12-14 11:47:35 +080020ifdef CONFIG_ARM64
21obj-y += relocate_64.o
22else
23obj-y += relocate.o
24endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090025
Matt Porterf99993c2015-05-05 15:00:23 -040026obj-$(CONFIG_CPU_V7M) += cmd_boot.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090027obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
28obj-$(CONFIG_CMD_BOOTM) += bootm.o
29obj-$(CONFIG_SYS_L2_PL310) += cache-pl310.o
30obj-$(CONFIG_USE_ARCH_MEMSET) += memset.o
31obj-$(CONFIG_USE_ARCH_MEMCPY) += memcpy.o
32else
33obj-$(CONFIG_SPL_FRAMEWORK) += spl.o
34endif
Darwin Rambo261d2762014-06-09 11:12:59 -070035obj-$(CONFIG_SEMIHOSTING) += semihosting.o
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090036
Albert ARIBAUDd0b5d9d2014-02-22 17:53:42 +010037obj-y += sections.o
Andreas Bießmann68145d42015-02-06 23:06:45 +010038obj-y += stack.o
rev13@wp.pl12d8a722015-03-01 12:44:39 +010039ifdef CONFIG_CPU_V7M
40obj-y += interrupts_m.o
41else ifdef CONFIG_ARM64
Bhupesh Sharma3ffa95c2015-07-01 09:58:03 +053042obj-y += ccn504.o
David Fengc71645a2014-03-14 14:26:27 +080043obj-y += gic_64.o
David Feng0ae76532013-12-14 11:47:35 +080044obj-y += interrupts_64.o
45else
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090046obj-y += interrupts.o
David Feng0ae76532013-12-14 11:47:35 +080047endif
Stephen Warren11636252016-05-12 12:03:35 -060048ifndef CONFIG_SYSRESET
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090049obj-y += reset.o
Simon Glassc6aabe92015-08-30 16:55:18 -060050endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090051
52obj-y += cache.o
David Feng0ae76532013-12-14 11:47:35 +080053ifndef CONFIG_ARM64
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090054obj-y += cache-cp15.o
David Feng0ae76532013-12-14 11:47:35 +080055endif
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090056
Masahiro Yamada51b17d42014-09-01 11:06:34 +090057obj-$(CONFIG_DEBUG_LL) += debug.o
58
Wolfgang Denkf772acf2009-08-17 13:17:29 +020059# For EABI conformant tool chains, provide eabi_compat()
60ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS)))
Masahiro Yamadafa8f9502013-10-17 17:34:52 +090061extra-y += eabi_compat.o
Wolfgang Denkf772acf2009-08-17 13:17:29 +020062endif
Albert ARIBAUD62e92072015-10-23 18:06:40 +020063
Marek Vasutc0db6f82016-05-26 18:01:37 +020064asflags-y += -DCONFIG_ARM_ASM_UNIFIED
65ifeq ($(CONFIG_SPL_BUILD)$(CONFIG_TEGRA),yy)
66asflags-y += -D__LINUX_ARM_ARCH__=4
67else
68asflags-y += -D__LINUX_ARM_ARCH__=$(CONFIG_SYS_ARM_ARCH)
69endif
70
Albert ARIBAUD62e92072015-10-23 18:06:40 +020071# some files can only build in ARM or THUMB2, not THUMB1
72
73ifdef CONFIG_SYS_THUMB_BUILD
Marek Vasutc0db6f82016-05-26 18:01:37 +020074asflags-$(CONFIG_HAS_THUMB2) += -DCONFIG_THUMB2_KERNEL
Albert ARIBAUD62e92072015-10-23 18:06:40 +020075ifndef CONFIG_HAS_THUMB2
76
77# for C files, just apend -marm, which will override previous -mthumb*
78
79CFLAGS_cache.o := -marm
80CFLAGS_cache-cp15.o := -marm
81
82# For .S, drop -mthumb* and other thumb-related options.
83# CFLAGS_REMOVE_* would not have an effet, so AFLAGS_REMOVE_*
84# was implemented and is used here.
85# Also, define ${target}_NO_THUMB_BUILD for these two targets
86# so that the code knows it should not use Thumb.
87
88AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork
89AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork
90AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD
91AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD
Albert ARIBAUD62e92072015-10-23 18:06:40 +020092endif
93endif