Tom Rini | 83d290c | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0+ |
Stefan Roese | 41e5ee5 | 2014-10-22 12:13:17 +0200 | [diff] [blame] | 2 | # |
Stefan Roese | f61aefc | 2016-05-17 15:00:30 +0200 | [diff] [blame] | 3 | # Copyright (C) 2014-2016 Stefan Roese <sr@denx.de> |
Stefan Roese | 41e5ee5 | 2014-10-22 12:13:17 +0200 | [diff] [blame] | 4 | |
Stefan Roese | f61aefc | 2016-05-17 15:00:30 +0200 | [diff] [blame] | 5 | ifdef CONFIG_ARM64 |
| 6 | |
| 7 | obj-$(CONFIG_ARMADA_3700) += armada3700/ |
Stefan Roese | 21b29fc | 2016-05-25 08:13:45 +0200 | [diff] [blame] | 8 | obj-$(CONFIG_ARMADA_8K) += armada8k/ |
| 9 | obj-y += arm64-common.o |
Stefan Roese | f61aefc | 2016-05-17 15:00:30 +0200 | [diff] [blame] | 10 | |
| 11 | else # CONFIG_ARM64 |
| 12 | |
Trevor Woerner | bb0fb4c | 2020-05-06 08:02:40 -0400 | [diff] [blame] | 13 | ifdef CONFIG_ARCH_KIRKWOOD |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 14 | |
| 15 | obj-y = dram.o |
| 16 | obj-y += gpio.o |
Chris Packham | 8ef078b | 2019-03-13 20:47:03 +1300 | [diff] [blame] | 17 | obj-y += mbus.o |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 18 | obj-y += timer.o |
| 19 | |
Trevor Woerner | bb0fb4c | 2020-05-06 08:02:40 -0400 | [diff] [blame] | 20 | else # CONFIG_ARCH_KIRKWOOD |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 21 | |
Stefan Roese | 41e5ee5 | 2014-10-22 12:13:17 +0200 | [diff] [blame] | 22 | obj-y = cpu.o |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 23 | obj-y += dram.o |
Pali Rohár | 5bb2c55 | 2022-05-06 11:05:14 +0200 | [diff] [blame] | 24 | obj-y += lowlevel.o |
Pali Rohár | 35e29e8 | 2021-12-21 12:20:18 +0100 | [diff] [blame] | 25 | obj-$(CONFIG_DM_RESET) += system-controller.o |
Stefan Roese | 0ceb2da | 2015-08-06 14:43:13 +0200 | [diff] [blame] | 26 | ifndef CONFIG_SPL_BUILD |
Stefan Roese | 09e89ab | 2016-02-10 07:23:00 +0100 | [diff] [blame] | 27 | obj-$(CONFIG_ARMADA_375) += ../../../drivers/ddr/marvell/axp/xor.o |
Stefan Roese | 81e33f4 | 2015-12-21 13:56:33 +0100 | [diff] [blame] | 28 | obj-$(CONFIG_ARMADA_38X) += ../../../drivers/ddr/marvell/a38x/xor.o |
| 29 | obj-$(CONFIG_ARMADA_XP) += ../../../drivers/ddr/marvell/axp/xor.o |
Chris Packham | 0d0df46 | 2019-04-11 22:22:50 +1200 | [diff] [blame] | 30 | obj-$(CONFIG_ARMADA_MSYS) += ../../../drivers/ddr/marvell/axp/xor.o |
Pali Rohár | 10154b8 | 2022-02-23 14:15:45 +0100 | [diff] [blame] | 31 | |
| 32 | ifdef CONFIG_ARMADA_38X |
Mario Six | a1b6b0a | 2017-01-11 16:01:00 +0100 | [diff] [blame] | 33 | obj-$(CONFIG_MVEBU_EFUSE) += efuse.o |
Pali Rohár | 10154b8 | 2022-02-23 14:15:45 +0100 | [diff] [blame] | 34 | endif |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 35 | |
| 36 | extra-y += kwbimage.cfg |
| 37 | |
Pali Rohár | 29c6a9c | 2022-01-12 18:20:44 +0100 | [diff] [blame] | 38 | ifneq ($(CONFIG_ARMADA_370)$(CONFIG_ARMADA_XP),) |
| 39 | KWB_REPLACE += CPU |
| 40 | KWB_CFG_CPU = SHEEVA |
| 41 | else ifneq ($(CONFIG_ARMADA_375)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),) |
| 42 | KWB_REPLACE += CPU |
| 43 | KWB_CFG_CPU = A9 |
| 44 | endif |
| 45 | |
Pali Rohár | a2b1db4 | 2022-01-12 18:20:45 +0100 | [diff] [blame] | 46 | KWB_REPLACE += LOAD_ADDRESS |
| 47 | KWB_CFG_LOAD_ADDRESS = $(CONFIG_SPL_TEXT_BASE) |
| 48 | |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 49 | KWB_REPLACE += BOOT_FROM |
| 50 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_SPI),) |
| 51 | KWB_CFG_BOOT_FROM=spi |
| 52 | endif |
| 53 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_MMC),) |
| 54 | KWB_CFG_BOOT_FROM=sdio |
| 55 | endif |
Baruch Siach | 22c6545 | 2019-05-16 13:03:58 +0300 | [diff] [blame] | 56 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_SATA),) |
| 57 | KWB_CFG_BOOT_FROM=sata |
| 58 | endif |
Baruch Siach | 72c4e67 | 2018-06-18 21:56:26 +0300 | [diff] [blame] | 59 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_UART),) |
| 60 | KWB_CFG_BOOT_FROM=uart |
| 61 | endif |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 62 | |
| 63 | ifneq ($(CONFIG_SECURED_MODE_IMAGE),) |
| 64 | KWB_REPLACE += CSK_INDEX |
| 65 | KWB_CFG_CSK_INDEX = $(CONFIG_SECURED_MODE_CSK_INDEX) |
| 66 | |
| 67 | KWB_REPLACE += SEC_BOOT_DEV |
Chris Packham | bfbd62f | 2022-05-29 11:13:16 +1200 | [diff] [blame] | 68 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_SPI),) |
| 69 | KWB_CFG_SEC_BOOT_DEV=0x34 |
| 70 | endif |
| 71 | ifneq ($(CONFIG_MVEBU_SPL_BOOT_DEVICE_MMC),) |
| 72 | KWB_CFG_SEC_BOOT_DEV=0x31 |
| 73 | endif |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 74 | |
| 75 | KWB_REPLACE += SEC_FUSE_DUMP |
| 76 | KWB_CFG_SEC_FUSE_DUMP = a38x |
| 77 | endif |
| 78 | |
Pali Rohár | 18d85d6 | 2022-01-12 18:20:47 +0100 | [diff] [blame] | 79 | ifdef CONFIG_ARMADA_38X |
| 80 | # BootROM output is by default enabled on pre-A38x and disabled on A38x |
| 81 | # DEBUG flag on A38x for non-UART boot source only enable BootROM output and nothing more |
| 82 | KWB_REPLACE += DEBUG |
| 83 | KWB_CFG_DEBUG = 1 |
| 84 | endif |
| 85 | |
Pali Rohár | 6329d44 | 2022-01-12 18:20:39 +0100 | [diff] [blame] | 86 | quiet_cmd_kwbcfg = KWBCFG $@ |
Pali Rohár | a2b1db4 | 2022-01-12 18:20:45 +0100 | [diff] [blame] | 87 | cmd_kwbcfg = sed -ne '$(foreach V,$(KWB_REPLACE),s/\#@$(V)/$(V) $(KWB_CFG_$(V))/;)p' \ |
Pali Rohár | 6329d44 | 2022-01-12 18:20:39 +0100 | [diff] [blame] | 88 | <$< >$(dir $@)$(@F) |
| 89 | |
Bin Meng | 6cdd177 | 2019-10-28 07:25:01 -0700 | [diff] [blame] | 90 | $(obj)/kwbimage.cfg: $(src)/kwbimage.cfg.in include/autoconf.mk \ |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 91 | include/config/auto.conf |
Pali Rohár | 6329d44 | 2022-01-12 18:20:39 +0100 | [diff] [blame] | 92 | $(call cmd,kwbcfg) |
Baruch Siach | ca1a4c8 | 2018-06-18 21:56:25 +0300 | [diff] [blame] | 93 | |
Stefan Roese | f61aefc | 2016-05-17 15:00:30 +0200 | [diff] [blame] | 94 | endif # CONFIG_SPL_BUILD |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 95 | obj-y += gpio.o |
| 96 | obj-y += mbus.o |
| 97 | obj-y += timer.o |
Stefan Roese | b0f80b9 | 2015-01-19 11:33:42 +0100 | [diff] [blame] | 98 | obj-$(CONFIG_SPL_BUILD) += spl.o |
| 99 | obj-$(CONFIG_SPL_BUILD) += lowlevel_spl.o |
Stefan Roese | d078765 | 2015-04-25 06:29:46 +0200 | [diff] [blame] | 100 | |
Stefan Roese | 81e33f4 | 2015-12-21 13:56:33 +0100 | [diff] [blame] | 101 | obj-$(CONFIG_ARMADA_38X) += serdes/a38x/ |
| 102 | obj-$(CONFIG_ARMADA_XP) += serdes/axp/ |
Stefan Roese | 29b103c | 2015-04-20 09:28:12 +0200 | [diff] [blame] | 103 | |
Trevor Woerner | bb0fb4c | 2020-05-06 08:02:40 -0400 | [diff] [blame] | 104 | endif # CONFIG_ARCH_KIRKWOOD |
Stefan Roese | f61aefc | 2016-05-17 15:00:30 +0200 | [diff] [blame] | 105 | endif # CONFIG_ARM64 |