blob: 9f71376d30af4a54692e0c4be252af4215d00d4e [file] [log] [blame]
wdenkf47713f2002-09-08 19:49:36 +00001#
Marian Balakowiczd62379d2006-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 Denkd79de1d2013-07-08 09:37:19 +02005# SPDX-License-Identifier: GPL-2.0+
wdenkf47713f2002-09-08 19:49:36 +00006#
7
Marek Vasut14fefa02016-05-26 18:01:40 +02008lib-$(CONFIG_USE_PRIVATE_LIBGCC) += ashldi3.o ashrdi3.o lshrdi3.o \
Marek Vasuteb91a462016-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.plb3b57e82015-03-01 12:44:39 +010012ifdef CONFIG_CPU_V7M
13obj-y += vectors_m.o crt0.o
14else ifdef CONFIG_ARM64
David Feng85fd5f12013-12-14 11:47:35 +080015obj-y += crt0_64.o
16else
Albert ARIBAUD9852cc62014-04-15 16:13:51 +020017obj-y += vectors.o crt0.o
David Feng85fd5f12013-12-14 11:47:35 +080018endif
Albert ARIBAUDfacdae52013-01-08 10:18:02 +000019
Allen Martinea74c932012-08-31 08:30:13 +000020ifndef CONFIG_SPL_BUILD
David Feng85fd5f12013-12-14 11:47:35 +080021ifdef CONFIG_ARM64
22obj-y += relocate_64.o
23else
24obj-y += relocate.o
25endif
Simon Glass97bbf182013-03-11 06:49:57 +000026
Matt Porterbd1fef52015-05-05 15:00:23 -040027obj-$(CONFIG_CPU_V7M) += cmd_boot.o
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090028obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o
29obj-$(CONFIG_CMD_BOOTM) += bootm.o
Ladislav Michl9c743722016-07-12 20:28:14 +020030obj-$(CONFIG_CMD_BOOTM) += zimage.o
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090031obj-$(CONFIG_SYS_L2_PL310) += cache-pl310.o
32obj-$(CONFIG_USE_ARCH_MEMSET) += memset.o
33obj-$(CONFIG_USE_ARCH_MEMCPY) += memcpy.o
Tom Rini31dfba42012-08-22 15:31:05 -070034else
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090035obj-$(CONFIG_SPL_FRAMEWORK) += spl.o
Ladislav Michl9c743722016-07-12 20:28:14 +020036obj-$(CONFIG_SPL_FRAMEWORK) += zimage.o
Aneesh V55fc5b62011-07-13 05:11:06 +000037endif
Darwin Rambod32d4112014-06-09 11:12:59 -070038obj-$(CONFIG_SEMIHOSTING) += semihosting.o
wdenkf47713f2002-09-08 19:49:36 +000039
Albert ARIBAUD9d25fa42014-02-22 17:53:42 +010040obj-y += sections.o
Andreas Bießmann25429862015-02-06 23:06:45 +010041obj-y += stack.o
rev13@wp.plb3b57e82015-03-01 12:44:39 +010042ifdef CONFIG_CPU_V7M
43obj-y += interrupts_m.o
44else ifdef CONFIG_ARM64
Bhupesh Sharma8238f342015-07-01 09:58:03 +053045obj-y += ccn504.o
David Feng79bbde02014-03-14 14:26:27 +080046obj-y += gic_64.o
David Feng85fd5f12013-12-14 11:47:35 +080047obj-y += interrupts_64.o
48else
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090049obj-y += interrupts.o
David Feng85fd5f12013-12-14 11:47:35 +080050endif
Stephen Warren859f2562016-05-12 12:03:35 -060051ifndef CONFIG_SYSRESET
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090052obj-y += reset.o
Simon Glass3f67b7d2015-08-30 16:55:18 -060053endif
Stefano Babic84fb0dd2012-03-15 04:01:41 +000054
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090055obj-y += cache.o
David Feng85fd5f12013-12-14 11:47:35 +080056ifndef CONFIG_ARM64
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090057obj-y += cache-cp15.o
David Feng85fd5f12013-12-14 11:47:35 +080058endif
Wolfgang Denkd47f4862009-08-17 13:17:29 +020059
Hou Zhiqiangdae02772016-06-28 20:18:16 +080060obj-y += psci-dt.o
61
Masahiro Yamadadf00e522014-09-01 11:06:34 +090062obj-$(CONFIG_DEBUG_LL) += debug.o
63
Wolfgang Denkd47f4862009-08-17 13:17:29 +020064# For EABI conformant tool chains, provide eabi_compat()
65ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS)))
Masahiro Yamada5a0c0ba2013-10-17 17:34:52 +090066extra-y += eabi_compat.o
Wolfgang Denkc73f44d2009-07-23 13:15:59 +020067endif
Albert ARIBAUDa3823222015-10-23 18:06:40 +020068
Marek Vasutd0869182016-05-26 18:01:37 +020069asflags-y += -DCONFIG_ARM_ASM_UNIFIED
70ifeq ($(CONFIG_SPL_BUILD)$(CONFIG_TEGRA),yy)
71asflags-y += -D__LINUX_ARM_ARCH__=4
72else
73asflags-y += -D__LINUX_ARM_ARCH__=$(CONFIG_SYS_ARM_ARCH)
74endif
75
Albert ARIBAUDa3823222015-10-23 18:06:40 +020076# some files can only build in ARM or THUMB2, not THUMB1
77
78ifdef CONFIG_SYS_THUMB_BUILD
Marek Vasutd0869182016-05-26 18:01:37 +020079asflags-$(CONFIG_HAS_THUMB2) += -DCONFIG_THUMB2_KERNEL
Albert ARIBAUDa3823222015-10-23 18:06:40 +020080ifndef CONFIG_HAS_THUMB2
81
82# for C files, just apend -marm, which will override previous -mthumb*
83
84CFLAGS_cache.o := -marm
85CFLAGS_cache-cp15.o := -marm
86
87# For .S, drop -mthumb* and other thumb-related options.
88# CFLAGS_REMOVE_* would not have an effet, so AFLAGS_REMOVE_*
89# was implemented and is used here.
90# Also, define ${target}_NO_THUMB_BUILD for these two targets
91# so that the code knows it should not use Thumb.
92
93AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork
94AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork
95AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD
96AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD
Albert ARIBAUDa3823222015-10-23 18:06:40 +020097endif
98endif