blob: d6f5b74fc8404bc09a242dd680abcfe584e7c5bf [file] [log] [blame]
Marti Bolivar51181cf2017-03-20 11:03:41 -04001/*
2 * Copyright (C) 2017, Linaro Ltd
David Vinczeb75c12a2019-03-22 14:58:33 +01003 * Copyright (c) 2019, Arm Limited
4 *
Marti Bolivar51181cf2017-03-20 11:03:41 -04005 * SPDX-License-Identifier: Apache-2.0
6 */
7
8#ifndef H_TARGETS_TARGET_
9#define H_TARGETS_TARGET_
10
11#if defined(MCUBOOT_TARGET_CONFIG)
Marti Bolivar3d9e3eb2017-09-20 16:28:57 -040012/*
13 * Target-specific definitions are permitted in legacy cases that
14 * don't provide the information via DTS, etc.
15 */
Marti Bolivar51181cf2017-03-20 11:03:41 -040016#include MCUBOOT_TARGET_CONFIG
Marti Bolivar3d9e3eb2017-09-20 16:28:57 -040017#else
18/*
19 * Otherwise, the Zephyr SoC header and the DTS provide most
20 * everything we need.
Marti Bolivar3d9e3eb2017-09-20 16:28:57 -040021 */
22#include <soc.h>
Marti Bolivar51181cf2017-03-20 11:03:41 -040023
Marti Bolivar3d9e3eb2017-09-20 16:28:57 -040024#define FLASH_ALIGN FLASH_WRITE_BLOCK_SIZE
25
Sergey Koziakov3f0738d2019-12-02 22:48:44 +030026#endif /* !defined(MCUBOOT_TARGET_CONFIG) */
27
Kumar Gala9a5b9512020-04-08 12:06:21 -050028#if DT_NODE_HAS_PROP(DT_INST(0, jedec_spi_nor), label)
29#define JEDEC_SPI_NOR_0_LABEL DT_LABEL(DT_INST(0, jedec_spi_nor))
30#endif
31
Marti Bolivardc4c42b2017-09-21 14:20:40 -040032/*
Marti Bolivar3d9e3eb2017-09-20 16:28:57 -040033 * Sanity check the target support.
Marti Bolivar61038df2017-09-01 12:52:56 -040034 */
Kumar Gala32b61f32020-04-08 12:02:03 -050035#if (!defined(CONFIG_XTENSA) && !defined(DT_CHOSEN_ZEPHYR_FLASH_CONTROLLER_LABEL)) || \
Kumar Gala9a5b9512020-04-08 12:06:21 -050036 (defined(CONFIG_XTENSA) && !defined(JEDEC_SPI_NOR_0_LABEL)) || \
Marti Bolivar61038df2017-09-01 12:52:56 -040037 !defined(FLASH_ALIGN) || \
Andrzej Puzdrowskif1d189c2019-12-12 09:34:11 +010038 !defined(DT_FLASH_AREA_IMAGE_0_OFFSET) || \
39 !defined(DT_FLASH_AREA_IMAGE_0_SIZE) || \
40 !defined(DT_FLASH_AREA_IMAGE_1_OFFSET) || \
41 !defined(DT_FLASH_AREA_IMAGE_1_SIZE) || \
42 (!defined(CONFIG_BOOT_SWAP_USING_MOVE) && !defined(DT_FLASH_AREA_IMAGE_SCRATCH_OFFSET)) || \
43 (!defined(CONFIG_BOOT_SWAP_USING_MOVE) && !defined(DT_FLASH_AREA_IMAGE_SCRATCH_SIZE))
Marti Bolivar61038df2017-09-01 12:52:56 -040044#error "Target support is incomplete; cannot build mcuboot."
45#endif
46
David Vinczeb75c12a2019-03-22 14:58:33 +010047#if ((MCUBOOT_IMAGE_NUMBER == 2) && (!defined(FLASH_AREA_IMAGE_2_OFFSET) || \
48 !defined(FLASH_AREA_IMAGE_2_SIZE) || \
49 !defined(FLASH_AREA_IMAGE_3_OFFSET) || \
50 !defined(FLASH_AREA_IMAGE_3_SIZE)))
51#error "Target support is incomplete; cannot build mcuboot."
Marti Bolivar51181cf2017-03-20 11:03:41 -040052#endif
David Vinczeb75c12a2019-03-22 14:58:33 +010053
54#endif /* H_TARGETS_TARGET_ */