Tom Rini | 83d290c | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0+ |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 2 | # |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 3 | # (C) Copyright 2002-2006 |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 4 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 5 | |
Marek Vasut | c5a543e | 2016-05-26 18:01:40 +0200 | [diff] [blame] | 6 | lib-$(CONFIG_USE_PRIVATE_LIBGCC) += ashldi3.o ashrdi3.o lshrdi3.o \ |
Marek Vasut | 0bf65c6 | 2016-05-26 18:01:44 +0200 | [diff] [blame] | 7 | lib1funcs.o uldivmod.o div0.o \ |
| 8 | div64.o muldi3.o |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 9 | |
rev13@wp.pl | 12d8a72 | 2015-03-01 12:44:39 +0100 | [diff] [blame] | 10 | ifdef CONFIG_CPU_V7M |
| 11 | obj-y += vectors_m.o crt0.o |
| 12 | else ifdef CONFIG_ARM64 |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 13 | obj-y += crt0_64.o |
| 14 | else |
Albert ARIBAUD | 41623c9 | 2014-04-15 16:13:51 +0200 | [diff] [blame] | 15 | obj-y += vectors.o crt0.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 16 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 17 | |
Philipp Tomsich | b4806d6 | 2017-10-10 16:21:13 +0200 | [diff] [blame] | 18 | ifdef CONFIG_ARM64 |
| 19 | obj-y += setjmp_aarch64.o |
| 20 | else |
| 21 | obj-y += setjmp.o |
| 22 | endif |
| 23 | |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 24 | ifndef CONFIG_SPL_BUILD |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 25 | ifdef CONFIG_ARM64 |
| 26 | obj-y += relocate_64.o |
| 27 | else |
| 28 | obj-y += relocate.o |
| 29 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 30 | |
Matt Porter | f99993c | 2015-05-05 15:00:23 -0400 | [diff] [blame] | 31 | obj-$(CONFIG_CPU_V7M) += cmd_boot.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 32 | obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o |
Bin Chen | 6808ef9 | 2018-01-27 16:59:09 +1100 | [diff] [blame] | 33 | obj-$(CONFIG_CMD_BOOTI) += bootm.o image.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 34 | obj-$(CONFIG_CMD_BOOTM) += bootm.o |
Tom Rini | 5db2890 | 2016-08-12 08:31:15 -0400 | [diff] [blame] | 35 | obj-$(CONFIG_CMD_BOOTZ) += bootm.o zimage.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 36 | else |
Heiko Stuebner | 22b7b86 | 2019-07-16 10:12:02 +0200 | [diff] [blame] | 37 | obj-$(CONFIG_$(SPL_TPL_)FRAMEWORK) += spl.o |
Nathan Barrett-Morrison | 7a0d880 | 2022-02-02 15:05:18 -0500 | [diff] [blame] | 38 | ifdef CONFIG_SPL_FRAMEWORK |
| 39 | obj-$(CONFIG_CMD_BOOTI) += image.o |
| 40 | obj-$(CONFIG_CMD_BOOTZ) += zimage.o |
| 41 | endif |
B, Ravi | 984a3c8 | 2017-04-18 17:27:26 +0530 | [diff] [blame] | 42 | obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 43 | endif |
Stefan Roese | dbf6b14 | 2021-09-02 17:00:17 +0200 | [diff] [blame] | 44 | ifdef CONFIG_ARM64 |
| 45 | obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMSET) += memset-arm64.o |
| 46 | obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMCPY) += memcpy-arm64.o |
| 47 | else |
Marek Vasut | a821a77 | 2018-04-07 16:06:36 +0200 | [diff] [blame] | 48 | obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMSET) += memset.o |
| 49 | obj-$(CONFIG_$(SPL_TPL_)USE_ARCH_MEMCPY) += memcpy.o |
Stefan Roese | dbf6b14 | 2021-09-02 17:00:17 +0200 | [diff] [blame] | 50 | endif |
Philip Oberfichtner | b6664ea | 2022-08-17 15:07:13 +0200 | [diff] [blame] | 51 | obj-$(CONFIG_$(SPL_TPL_)SYS_L2_PL310) += cache-pl310.o |
Sean Anderson | 8e1c9fe | 2022-03-22 16:59:19 -0400 | [diff] [blame] | 52 | obj-$(CONFIG_$(SPL_TPL_)SEMIHOSTING) += semihosting.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 53 | |
Dzmitry Sankouski | 12a3e1a | 2022-02-22 21:49:52 +0300 | [diff] [blame] | 54 | ifneq ($(filter y,$(CONFIG_SAVE_PREV_BL_INITRAMFS_START_ADDR) $(CONFIG_SAVE_PREV_BL_FDT_ADDR)),) |
| 55 | obj-y += save_prev_bl_data.o |
| 56 | endif |
| 57 | |
| 58 | # obj-$(CONFIG_SAVE_PREV_BL_INITRAMFS_START_ADDR) += save_prev_bl_data.o |
Simon Glass | 59b0d7d | 2020-05-10 14:16:56 -0600 | [diff] [blame] | 59 | obj-y += bdinfo.o |
Albert ARIBAUD | d0b5d9d | 2014-02-22 17:53:42 +0100 | [diff] [blame] | 60 | obj-y += sections.o |
Marek Behún | 8f96965 | 2021-05-20 13:24:22 +0200 | [diff] [blame] | 61 | CFLAGS_REMOVE_sections.o := $(LTO_CFLAGS) |
| 62 | |
Andreas Bießmann | 68145d4 | 2015-02-06 23:06:45 +0100 | [diff] [blame] | 63 | obj-y += stack.o |
rev13@wp.pl | 12d8a72 | 2015-03-01 12:44:39 +0100 | [diff] [blame] | 64 | ifdef CONFIG_CPU_V7M |
| 65 | obj-y += interrupts_m.o |
| 66 | else ifdef CONFIG_ARM64 |
Andre Przywara | 98db26a | 2017-04-26 01:32:41 +0100 | [diff] [blame] | 67 | obj-$(CONFIG_FSL_LAYERSCAPE) += ccn504.o |
Andre Przywara | 0cef6cb | 2017-04-26 01:32:40 +0100 | [diff] [blame] | 68 | ifneq ($(CONFIG_GICV2)$(CONFIG_GICV3),) |
David Feng | c71645a | 2014-03-14 14:26:27 +0800 | [diff] [blame] | 69 | obj-y += gic_64.o |
Andre Przywara | 0cef6cb | 2017-04-26 01:32:40 +0100 | [diff] [blame] | 70 | endif |
Bharat Kumar Reddy Gooty | 0bc4356 | 2019-12-16 09:09:43 -0800 | [diff] [blame] | 71 | obj-$(CONFIG_GIC_V3_ITS) += gic-v3-its.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 72 | obj-y += interrupts_64.o |
| 73 | else |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 74 | obj-y += interrupts.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 75 | endif |
Claudius Heine | b46e6cc | 2020-03-04 15:23:10 +0100 | [diff] [blame] | 76 | ifndef CONFIG_$(SPL_TPL_)SYSRESET |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 77 | obj-y += reset.o |
Simon Glass | c6aabe9 | 2015-08-30 16:55:18 -0600 | [diff] [blame] | 78 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 79 | |
| 80 | obj-y += cache.o |
Lokesh Vutla | f4bcd76 | 2018-04-26 18:21:28 +0530 | [diff] [blame] | 81 | obj-$(CONFIG_SYS_ARM_CACHE_CP15) += cache-cp15.o |
Marek Behún | e5fc903 | 2021-05-20 13:24:11 +0200 | [diff] [blame] | 82 | CFLAGS_REMOVE_cache-cp15.o := $(LTO_CFLAGS) |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 83 | |
Hou Zhiqiang | 45684ae | 2016-06-28 20:18:16 +0800 | [diff] [blame] | 84 | obj-y += psci-dt.o |
| 85 | |
Masahiro Yamada | 51b17d4 | 2014-09-01 11:06:34 +0900 | [diff] [blame] | 86 | obj-$(CONFIG_DEBUG_LL) += debug.o |
| 87 | |
Wolfgang Denk | f772acf | 2009-08-17 13:17:29 +0200 | [diff] [blame] | 88 | # For EABI conformant tool chains, provide eabi_compat() |
| 89 | ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS))) |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 90 | extra-y += eabi_compat.o |
Wolfgang Denk | f772acf | 2009-08-17 13:17:29 +0200 | [diff] [blame] | 91 | endif |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 92 | |
| 93 | # some files can only build in ARM or THUMB2, not THUMB1 |
| 94 | |
Tom Rini | 3a64940 | 2017-03-18 09:01:44 -0400 | [diff] [blame] | 95 | ifdef CONFIG_$(SPL_)SYS_THUMB_BUILD |
Marek Vasut | c0db6f8 | 2016-05-26 18:01:37 +0200 | [diff] [blame] | 96 | asflags-$(CONFIG_HAS_THUMB2) += -DCONFIG_THUMB2_KERNEL |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 97 | ifndef CONFIG_HAS_THUMB2 |
| 98 | |
| 99 | # for C files, just apend -marm, which will override previous -mthumb* |
| 100 | |
Andre Przywara | ebda0cc | 2017-01-02 11:48:26 +0000 | [diff] [blame] | 101 | ifndef CONFIG_ARM64 |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 102 | CFLAGS_cache.o := -marm |
| 103 | CFLAGS_cache-cp15.o := -marm |
Andre Przywara | ebda0cc | 2017-01-02 11:48:26 +0000 | [diff] [blame] | 104 | endif |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 105 | |
| 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 | |
| 112 | AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork |
| 113 | AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork |
| 114 | AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD |
| 115 | AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD |
Sean Anderson | 726a802 | 2023-07-31 17:27:33 -0400 | [diff] [blame] | 116 | |
| 117 | # This is only necessary to force ARM mode on THUMB1 targets. |
| 118 | ifneq ($(CONFIG_SYS_ARM_ARCH),4) |
| 119 | obj-y += bitops.o |
| 120 | endif |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 121 | endif |
| 122 | endif |
Simon Glass | dd46eef | 2016-11-07 08:47:10 -0700 | [diff] [blame] | 123 | |
| 124 | # For building EFI apps |
| 125 | CFLAGS_$(EFI_CRT0) := $(CFLAGS_EFI) |
| 126 | CFLAGS_REMOVE_$(EFI_CRT0) := $(CFLAGS_NON_EFI) |
| 127 | |
| 128 | CFLAGS_$(EFI_RELOC) := $(CFLAGS_EFI) |
| 129 | CFLAGS_REMOVE_$(EFI_RELOC) := $(CFLAGS_NON_EFI) |
| 130 | |
Alexander Graf | 95b62b2 | 2016-11-17 22:40:10 +0100 | [diff] [blame] | 131 | extra-$(CONFIG_CMD_BOOTEFI_HELLO_COMPILE) += $(EFI_CRT0) $(EFI_RELOC) |
Heinrich Schuchardt | e4fd695 | 2018-12-30 10:52:41 +0100 | [diff] [blame] | 132 | # TODO: As of v2019.01 the relocation code for the EFI application cannot |
| 133 | # be built on ARMv7-M. |
| 134 | ifndef CONFIG_CPU_V7M |
| 135 | #extra-$(CONFIG_CMD_BOOTEFI_SELFTEST) += $(EFI_CRT0) $(EFI_RELOC) |
| 136 | endif |
Simon Glass | dd46eef | 2016-11-07 08:47:10 -0700 | [diff] [blame] | 137 | extra-$(CONFIG_EFI) += $(EFI_CRT0) $(EFI_RELOC) |