wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 1 | # |
Marian Balakowicz | f932863 | 2006-09-01 19:49:50 +0200 | [diff] [blame] | 2 | # (C) Copyright 2002-2006 |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
| 4 | # |
Wolfgang Denk | 1a45966 | 2013-07-08 09:37:19 +0200 | [diff] [blame] | 5 | # SPDX-License-Identifier: GPL-2.0+ |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 6 | # |
| 7 | |
Masahiro Yamada | cd2e46c | 2014-03-05 16:59:38 +0900 | [diff] [blame] | 8 | lib-$(CONFIG_USE_PRIVATE_LIBGCC) += _ashldi3.o _ashrdi3.o _divsi3.o \ |
Simon Glass | 9ab6049 | 2016-03-16 07:44:34 -0600 | [diff] [blame] | 9 | _lshrdi3.o _modsi3.o _udivsi3.o _umodsi3.o div0.o \ |
| 10 | _uldivmod.o |
wdenk | f47713f | 2002-09-08 19:49:36 +0000 | [diff] [blame] | 11 | |
rev13@wp.pl | 12d8a72 | 2015-03-01 12:44:39 +0100 | [diff] [blame] | 12 | ifdef CONFIG_CPU_V7M |
| 13 | obj-y += vectors_m.o crt0.o |
| 14 | else ifdef CONFIG_ARM64 |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 15 | obj-y += crt0_64.o |
| 16 | else |
Albert ARIBAUD | 41623c9 | 2014-04-15 16:13:51 +0200 | [diff] [blame] | 17 | obj-y += vectors.o crt0.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 18 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 19 | |
| 20 | ifndef CONFIG_SPL_BUILD |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 21 | ifdef CONFIG_ARM64 |
| 22 | obj-y += relocate_64.o |
| 23 | else |
| 24 | obj-y += relocate.o |
| 25 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 26 | |
Matt Porter | f99993c | 2015-05-05 15:00:23 -0400 | [diff] [blame] | 27 | obj-$(CONFIG_CPU_V7M) += cmd_boot.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 28 | obj-$(CONFIG_OF_LIBFDT) += bootm-fdt.o |
| 29 | obj-$(CONFIG_CMD_BOOTM) += bootm.o |
| 30 | obj-$(CONFIG_SYS_L2_PL310) += cache-pl310.o |
| 31 | obj-$(CONFIG_USE_ARCH_MEMSET) += memset.o |
| 32 | obj-$(CONFIG_USE_ARCH_MEMCPY) += memcpy.o |
| 33 | else |
| 34 | obj-$(CONFIG_SPL_FRAMEWORK) += spl.o |
| 35 | endif |
Darwin Rambo | 261d276 | 2014-06-09 11:12:59 -0700 | [diff] [blame] | 36 | obj-$(CONFIG_SEMIHOSTING) += semihosting.o |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 37 | |
Albert ARIBAUD | d0b5d9d | 2014-02-22 17:53:42 +0100 | [diff] [blame] | 38 | obj-y += sections.o |
Andreas Bießmann | 68145d4 | 2015-02-06 23:06:45 +0100 | [diff] [blame] | 39 | obj-y += stack.o |
rev13@wp.pl | 12d8a72 | 2015-03-01 12:44:39 +0100 | [diff] [blame] | 40 | ifdef CONFIG_CPU_V7M |
| 41 | obj-y += interrupts_m.o |
| 42 | else ifdef CONFIG_ARM64 |
Bhupesh Sharma | 3ffa95c | 2015-07-01 09:58:03 +0530 | [diff] [blame] | 43 | obj-y += ccn504.o |
David Feng | c71645a | 2014-03-14 14:26:27 +0800 | [diff] [blame] | 44 | obj-y += gic_64.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 45 | obj-y += interrupts_64.o |
| 46 | else |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 47 | obj-y += interrupts.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 48 | endif |
Simon Glass | c6aabe9 | 2015-08-30 16:55:18 -0600 | [diff] [blame] | 49 | ifndef CONFIG_RESET |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 50 | obj-y += reset.o |
Simon Glass | c6aabe9 | 2015-08-30 16:55:18 -0600 | [diff] [blame] | 51 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 52 | |
| 53 | obj-y += cache.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 54 | ifndef CONFIG_ARM64 |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 55 | obj-y += cache-cp15.o |
David Feng | 0ae7653 | 2013-12-14 11:47:35 +0800 | [diff] [blame] | 56 | endif |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 57 | |
Masahiro Yamada | 51b17d4 | 2014-09-01 11:06:34 +0900 | [diff] [blame] | 58 | obj-$(CONFIG_DEBUG_LL) += debug.o |
| 59 | |
Wolfgang Denk | f772acf | 2009-08-17 13:17:29 +0200 | [diff] [blame] | 60 | # For EABI conformant tool chains, provide eabi_compat() |
| 61 | ifneq (,$(findstring -mabi=aapcs-linux,$(PLATFORM_CPPFLAGS))) |
Masahiro Yamada | fa8f950 | 2013-10-17 17:34:52 +0900 | [diff] [blame] | 62 | extra-y += eabi_compat.o |
Wolfgang Denk | f772acf | 2009-08-17 13:17:29 +0200 | [diff] [blame] | 63 | endif |
Albert ARIBAUD | 62e9207 | 2015-10-23 18:06:40 +0200 | [diff] [blame] | 64 | |
| 65 | # some files can only build in ARM or THUMB2, not THUMB1 |
| 66 | |
| 67 | ifdef CONFIG_SYS_THUMB_BUILD |
| 68 | ifndef CONFIG_HAS_THUMB2 |
| 69 | |
| 70 | # for C files, just apend -marm, which will override previous -mthumb* |
| 71 | |
| 72 | CFLAGS_cache.o := -marm |
| 73 | CFLAGS_cache-cp15.o := -marm |
| 74 | |
| 75 | # For .S, drop -mthumb* and other thumb-related options. |
| 76 | # CFLAGS_REMOVE_* would not have an effet, so AFLAGS_REMOVE_* |
| 77 | # was implemented and is used here. |
| 78 | # Also, define ${target}_NO_THUMB_BUILD for these two targets |
| 79 | # so that the code knows it should not use Thumb. |
| 80 | |
| 81 | AFLAGS_REMOVE_memset.o := -mthumb -mthumb-interwork |
| 82 | AFLAGS_REMOVE_memcpy.o := -mthumb -mthumb-interwork |
| 83 | AFLAGS_memset.o := -DMEMSET_NO_THUMB_BUILD |
| 84 | AFLAGS_memcpy.o := -DMEMCPY_NO_THUMB_BUILD |
| 85 | |
| 86 | endif |
| 87 | endif |