1### Blinking LED test application for MCUboot bootloader
2
3### Description
4
5Implements simple Blinky LED CM4 application to demonstrate MCUboot Application operation in terms of BOOT and UPGRADE process.
6
7It is started by MCUboot Application which is running on CM0p.
8
9Functionality:
10
11* Blinks RED led with 2 different rates, depending on type of image - BOOT or UPGRADE.
12* Prints debug info and version of itself to terminal at 115200 baud.
13* Can be built for BOOT slot or UPGRADE slot of bootloader.
14
15Currently supported platforms
16
17* PSOC_062_2M
18* PSOC_062_1M
19* PSOC_062_512K
20
21### Hardware limitations
22
23Since this application is created to demonstrate MCUboot library features and not as reference examples some considerations are taken.
24
251. Port/pin `P5_0` and `P5_1` used to configure serial port for debug prints. These pins are the most commonly used for serial port connection among available Cypress PSoC 6 kits. If you try to use custom hardware with this application - change definitions of `CY_DEBUG_UART_TX` and `CY_DEBUG_UART_RX` in `main.c` of BlinkyApp to port/pin pairs corresponding to your design.
262. Port `GPIO_PRT13` pin `7U` used to define user connection LED. This pin is the most commonly used for USER_LED connection among available Cypress PSoC 6 kits. If you try to use custom hardware with this application - change definitions of `LED_PORT` and `LED_PIN` in `main.c` of BlinkyApp to port/pin pairs corresponding to your design.
27
28### Pre-build action
29
30Pre-build action is implemented for defining start address and size of flash, as well as RAM start address and size for BlinkyApp.
31These values are set by specifing following macros: `-DUSER_APP_SIZE`, `-DUSER_APP_START`, `-DRAM_SIZE`, `-DRAM_START` in makefile.
32
33Pre-build action calls GCC preprocessor which intantiates defines for particular values in `BlinkyApp_template.ld`.
34
35Default values set for currently supported targets:
36* `BlinkyApp.mk` to `-DUSER_APP_START=0x10018000`
37
38**Important**: make sure RAM areas of CM4-based BlinkyApp and CM0p-based MCUBootApp bootloader do not overlap.
39Memory (stack) corruption of CM0p application can cause failure if SystemCall-served operations invoked from CM4.
40
41### Building an application
42
43Root directory for build is **boot/cypress.**
44
45The following command will build regular HEX file of a BlinkyApp for BOOT slot. Substitute `PLATFORM=` to a paltform name you use in all following commands.
46
47    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=BOOT
48
49This have following defaults suggested:
50
51    BUILDCFG=Debug
52    IMG_TYPE=BOOT
53
54To build UPGRADE image use following command:
55
56    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=UPGRADE HEADER_OFFSET=0x10000
57
58    Note: HEADER_OFFSET=%SLOT_SIZE%
59
60Example command-line for single-image:
61
62    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=BOOT
63
64**Building Multi-Image**
65
66`BlinkyApp` can be built to use in multi-image bootloader configuration.
67
68To get appropriate artifacts to use with multi image MCUBootApp, makefile flag `HEADER_OFFSET=` can be used.
69
70Example usage:
71
72Considering default config:
73
74* first image BOOT (PRIMARY) slot start `0x10018000`
75* slot size `0x10000`
76* second image BOOT (PRIMARY) slot start `0x10038000`
77
78To get appropriate artifact for second image PRIMARY slot run this command:
79
80    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=BOOT HEADER_OFFSET=0x20000
81
82*Note:* only 2 images are supported at the moment.
83
84**How to build upgrade image for external memory:**
85
86To prepare MCUBootApp for work with external memory please refer to `MCUBootApp/ExternalMemory.md`.
87
88For build BlinkyApp upgrade image for external memory use command:
89
90    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=UPGRADE HEADER_OFFSET=0x7FE8000 ERASED_VALUE=0xff
91
92`HEADER_OFFSET` defines the offset from original boot image address. This one in line above suggests secondary slot will start from `0x18000000`.
93
94`ERASED_VALUE` defines the memory cell contents in erased state. It is `0x00` for PSoC6's internal Flash and `0xff` for S25FL512S.
95
96In case of using muti-image configuration, upgrade image for second application can be built using next command:
97
98    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=UPGRADE HEADER_OFFSET=0x8028000 ERASED_VALUE=0xff
99
100    Note: for S25FL512S block address shuld be mutiple by 0x40000
101
102**How to build encrypted upgrade image :**
103
104To prepare MCUBootApp for work with encrypted upgrade image please refer to `MCUBootApp/Readme.md`.
105
106To obtain encrypted upgrade image of BlinkyApp extra flag `ENC_IMG=1` should be passed in command line, for example:
107
108    make app APP_NAME=BlinkyApp PLATFORM=PSOC_062_2M IMG_TYPE=UPGRADE HEADER_OFFSET=0x20000 ENC_IMG=1
109
110This also suggests user already placed corresponing `*.pem` key in `\keys` folder. The key variables are defined in root `Makefile` as `SIGN_KEY_FILE` and `ENC_KEY_FILE`
111
112### Post-build
113
114Post build action is executed at compile time for `BlinkyApp`. In case of build for `PSOC_062_2M` platform it calls `imgtool` from `MCUboot` scripts and adds signature to compiled image.
115
116Flags passed to `imgtool` for signature are defined in `SIGN_ARGS` variable in BlinkyApp.mk.
117
118### How to program an application
119
120Use any preferred tool for programming hex files.
121
122Hex file names to use for programming:
123
124`BlinkyApp` always produce build artifacts in 2 separate folders - `boot` and `upgrade`.
125
126`BlinkyApp` built to run with `MCUBootApp` produces files with name BlinkyApp.hex in `boot` directory and `BlinkyApp_upgrade.hex` in `upgrade` folder. These files are ready to be flashed to the board.
127
128`BlinkyApp_unsigned.hex` hex file is also preserved in both cases for possible troubleshooting.
129
130Files to use for programming are:
131
132`BOOT` - boot/BlinkyApp.hex
133`UPGRADE` - upgrade/BlinkyApp_upgrade.hex
134
135**Flags:**
136- `BUILDCFG` - configuration **Release** or **Debug**
137- `MAKEINFO` - 0 (default) - less build info, 1 - verbose output of compilation.
138- `HEADER_OFFSET` - 0 (default) - no offset of output hex file, 0x%VALUE% - offset for output hex file. Value 0x10000 is slot size MCUboot Bootloader in this example.
139- `IMG_TYPE` - `BOOT` (default) - build image for BOOT slot of MCUboot Bootloader, `UPGRADE` - build image for UPGRADE slot of MCUboot Bootloader.
140- `ENC_IMG` - 0 (default) - build regular upgrade image, `1` - build encrypted upgrade image (MCUBootApp should also be built with this flash set 1)
141
142**NOTE**: In case of `UPGRADE` image `HEADER_OFFSET` should be set to MCUboot Bootloader slot size.
143
144### Example terminal output
145
146When user application programmed in BOOT slot:
147
148    ===========================
149    [BlinkyApp] BlinkyApp v1.0 [CM4]
150    ===========================
151    [BlinkyApp] GPIO initialized
152    [BlinkyApp] UART initialized
153    [BlinkyApp] Retarget I/O set to 115200 baudrate
154    [BlinkyApp] Red led blinks with 1 sec period
155
156When user application programmed in UPRADE slot and upgrade procedure was successful:
157
158    ===========================
159    [BlinkyApp] BlinkyApp v2.0 [+]
160    ===========================
161
162    [BlinkyApp] GPIO initialized
163    [BlinkyApp] UART initialized
164    [BlinkyApp] Retarget I/O set to 115200 baudrate
165    [BlinkyApp] Red led blinks with 0.25 sec period
166