-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuser_config.mk
152 lines (124 loc) · 5.54 KB
/
user_config.mk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
################################################################################
# \file user_config.mk
# \version 1.0
#
# \brief
# Holds configuration and error checking that are common to both the Bootloader
# and DFU applications. Ensure that this file is included in the application's
# Makefile.
#
################################################################################
# \copyright
# Copyright 2023-2024, Cypress Semiconductor Corporation (an Infineon company)
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
################################################################################
################################################################################
# Shared Configuration
################################################################################
# Include the common make file
include ../common.mk
# Flashmap JSON file name
FLASH_MAP?=xmc7000_overwrite_single.json
# Device family name. Ex: PSOC6, XMC7000
FAMILY=XMC7000
# Device platform name. Ex: PLATFORM=XMC7200, PLATFORM=XMC7100
PLATFORM=$(if $(filter CAT1C4M,$(DEVICE_COMPONENTS)),XMC7100,$(if $(filter CAT1C8M,$(DEVICE_COMPONENTS)),XMC7200))
# XMC7000 devices platform configuration
# E.g. xmc7200_platform.json for XMC7200 device, Ex: xmc7100_platform.json for XMC7100 device
PLATFORM_CONFIG=$(if $(filter CAT1C4M,$(DEVICE_COMPONENTS)),xmc7100_platform.json,$(if $(filter CAT1C8M,$(DEVICE_COMPONENTS)),xmc7200_platform.json))
# Application core ID.
# Ex: APP_CORE_ID=0 for user app run by CM7_0, APP_CORE_ID=1 for user app run by CM7_1
APP_CORE_ID?=0
# User app core
APP_CORE=CM7
# Name of the key file, used in two places.
# 1. #included in keys.c for embedding it in the Bootloader app, used for image
# authentication.
# 2. Passed as a parameter to the Python module "imgtool" for signing the image
# in the DFU app Makefile. The path of this key file is set in the DFU
# app Makefile.
SIGN_KEY_FILE=cypress-test-ec-p256
# Path of the key file passed as a parameter to the imgtool or cysecuretools for
# signing the image. Name of the key file is set in shared_config.mk
# as a common parameter to both the Bootloader app and Blinky app.
SIGN_KEY_FILE_PATH=../keys
# Flash and RAM size for MCUBoot Bootloader app run by CM0+
BOOTLOADER_APP_RAM_SIZE=0x20000
# RAM size for user app (DFU) run by CM7
USER_APP_RAM_SIZE=0x60000
# MCUBoot header size
# Must be a multiple of 1024 because of the following reason.
# CM4 image starts right after the header and the CM4 image begins with the
# interrupt vector table. The starting address of the table must be 1024-bytes
# aligned. See README.md for details.
# Number of bytes to be aligned to = Number of interrupt vectors x 4 bytes.
# (1024 = 256 x 4)
#
# Header size is used in two places.
# 1. The location of CM4 image is offset by the header size from the ORIGIN
# value specified in the linker script.
# 2. Passed to the imgtool while signing the image. The imgtool fills the space
# of this size with zeroes and then adds the actual header from the beginning of
# the image.
MCUBOOT_HEADER_SIZE=0x400
# Default memory single chunk size
# Default upgrade method
PLATFORM_DEFAULT_USE_OVERWRITE?=0
PLATFORM_CHUNK_SIZE=0x200
# Minimum erase size of underlying memory hardware
PLATFORM_MEMORY_ALIGN=0x200
PLATFORM_MAX_TRAILER_PAGE_SIZE=0x8000
# Encrypted image support
# This code example not supported the encrypted image at the moment
ENC_IMG=0
ifneq ($(ENC_IMG), 0)
$(error This code example not supported the encrypted image at the moment)
endif
################################################################################
# MCUBOOT App Configuration
################################################################################
# To prepare a secure MCUBoot image, set the variable to '1'
USE_SECURE_MODE_FOR_MCUBOOT?=1
# Secure boot key file name and type
SECURE_MODE_KEY_TYPE=RSA2048
SECURE_MODE_KEY_FILE=cypress-test-rsa2k
# Downgrade prevention, to avoid older firmware version for upgrade
USE_SW_DOWNGRADE_PREV?=1
# When set to `1` and Swap mode is enabled, the application in the secondary slot will overwrite the primary slot if the primary slot application is invalid.
USE_BOOTSTRAP?=1
################################################################################
# User App Configuration
################################################################################
# Default DFU transport set to I2C.
#
# Supported options are I2C, SPI and UART
#
# Select transport here, as required.
SELECTED_TRANSPORT?=I2C
# image type can be BOOT or UPGRADE
IMG_TYPES:=BOOT UPGRADE
# Supported values: BOOT, UPGRADE
# The Blinky app defines the LED period differently depending on whether the
# image is BOOT or UPGRADE.
# BOOT: Use when image is built for the primary slot.
# --pad argument is not passed to the imgtool or cysecuretools.
# UPGRADE: Use when image is built for secondary slot.
# --pad argument is passed to the imgtool or cysecuretools.
IMG_TYPE?=BOOT
# Image ID
IMG_ID=1
ifneq ($(IMG_ID), 1)
$(error This code example not supported the multi-image configuration at the moment)
endif