# **MCU Flashloader Reference Manual**



## Contents

| Chapter 1 Introduction                         | 5  |
|------------------------------------------------|----|
| 1.1 Introduction                               |    |
| 1.2 Terminology                                |    |
| 1.3 Block diagram                              |    |
| 1.4 Features supported                         |    |
| 1.5 Components supported                       |    |
|                                                |    |
| Chapter 2 MCU Flashloaderprotocol API          |    |
| 2.1 Introduction                               |    |
| 2.2 Command with no data phase                 |    |
| 2.3 Command with incoming data phase           |    |
| 2.4 Command with outgoing data phase           |    |
| _ · · · · · · · · · · · · · · · · · · ·        |    |
| Chapter 3 Flashloader packet types             |    |
| 3.1 Introduction                               |    |
| 3.2 Framing packet                             |    |
| 3.3 CRC16 algorithm                            | 14 |
| 3.4 Ping packet                                |    |
| 3.5 Ping response packet                       |    |
| 3.6 Command packet                             |    |
| 3.7 Response packet                            |    |
|                                                |    |
| Chapter 4 MCU Flashloader command API          | 21 |
| 4.1 Introduction                               |    |
| 4.2 GetProperty command                        |    |
| 4.3 SetProperty command                        |    |
| 4.4 FlashEraseAll command                      |    |
| 4.5 FlashEraseRegion command                   |    |
| 4.6 ReadMemory command.                        |    |
| 4.7 WriteMemory command                        |    |
| 4.8 FillMemory command                         |    |
| 4.9 Execute command                            |    |
| 4.10 Call command                              |    |
| 4.11 Reset command                             |    |
| 4.12 FlashProgramOnce/eFuseProgramOnce command |    |
| 4.13 FlashReadOnce/eFuseReadOnce command       |    |
| 4.14 Configure Memory command                  |    |
| 4.15 ReceiveSBFile command                     |    |
| 4.16 GenerateKeyBlob command                   |    |
|                                                |    |
| Chapter 5 Supported peripherals                |    |
| 5.1 Introduction                               |    |
| 5.2 UART peripheral                            | 41 |
| 5.3 USB HID peripheral                         |    |
| 5.3.1 Device descriptor                        |    |
| 5.3.2 Endpoints                                |    |
| 5.3.3 HID reports                              |    |

| Chapter 6 External memory support46                                                      |
|------------------------------------------------------------------------------------------|
| 6.1 Introduction46                                                                       |
| 6.2 Serial NOR Flash through FlexSPI                                                     |
| 6.2.1 FlexSPI NOR Configuration Block                                                    |
| 6.2.2 FlexSPI NOR Configuration Option Block                                             |
| 6.2.2.1 Typical use cases for FlexSPI NOR Configuration Block                            |
| 6.2.2.2 Programming Serial NOR Flash device using FlexSPI NOR Configuration Option Block |
| 6.2.2.3 Select the FLEXSPI instance                                                      |
|                                                                                          |
| 6.2.2.4 FlexSPI Instance Selection using FlexSPI NOR Configuration Option Block          |
| 6.2.3 FlexSPI NOR On-chip OTFAD Pre-encryption Option Block                              |
| 6.2.3.1 On-chip pre-encryption using the Option Block                                    |
| 6.3 Serial NAND Flash through FlexSPI                                                    |
| 6.3.1 FlexSPI NAND Firmware Configuration Block (FCB)                                    |
| 6.3.2 FlexSPI NAND Configuration Block                                                   |
| 6.3.3 FlexSPI NAND FCB option block                                                      |
| 6.3.4 FlexSPI NAND Configuration Option Block60                                          |
| 6.3.5 Example usage with Flashloader61                                                   |
| 6.4 SD/eMMC through uSDHC62                                                              |
| 6.4.1 SD Configuration Block                                                             |
| 6.4.2 Example usage with Flashloader64                                                   |
| 6.4.3 eMMC Configuration Block64                                                         |
| 6.4.4 Example usage with Flashloader                                                     |
| 6.5 Parallel NAND Flash through SEMC69                                                   |
| 6.5.1 SEMC NAND Firmware Configuration Block                                             |
| 6.5.2 SEMC NAND Configuration Block                                                      |
| 6.5.3 SEMC NAND Configuration Option Block                                               |
| 6.5.4 Example usage with Flashloader                                                     |
| 6.5.4.1 FCB/DBBT management                                                              |
| 6.5.4.2 Example configuration                                                            |
| 6.6 1-bit SPI EEPROM/NOR Flash through LPSPI                                             |
| 6.6.1 SPI EEPROM/NOR Configuration Option Block                                          |
| 6.6.2 Example usage with Flashloader                                                     |
|                                                                                          |
| Chapter 7 Security utilities                                                             |
| 7.1 Introduction                                                                         |
| 7.2 Image encryption and programming83                                                   |
| 7.2.1 Example to generate encrypted image and program to Flash                           |
| 7.3 KeyBlob generation and programming                                                   |
| 7.3.1 KeyBlob                                                                            |
| 7.3.2 KeyBlob Option Block                                                               |
| 7.3.3 Example to generate and program KeyBlob                                            |
| Chapter 9 Devision history                                                               |
| Chapter 8 Revision history                                                               |
| Appendix A Status and error codes                                                        |
| Appendix B GetProperty and SetProperty commands 93                                       |

| , appoindix D C   | ou ropolity un | 001111101100 | <br>  |
|-------------------|----------------|--------------|-------|
| Legal information |                | <br>         | <br>0 |

| gal information |
|-----------------|
|                 |

## Chapter 1 Introduction

## 1.1 Introduction

The MCU flashloader is a configurable flash programming utility that operates over a serial connection on MCUs. It enables quick and easy programming of MCUs through the entire product life cycle, including application development, final product manufacturing, and more. The MCU flashloader will be delivered as binary or full source code that is highly configurable. Host-side command line and GUI tools are available to communicate with the flashloader. Users can utilize host tools to upload and/or download application code via the flashloader.

## 1.2 Terminology

target

The device running the bootloader firmware (ROM).

host

The device sending commands to the target for execution.

source

The initiator of a communications sequence. For example, the sender of a command or data packet.

destination

Receiver of a command or data packet.

incoming

From host to target.

outgoing

From target to host.

## 1.3 Block diagram

This block diagram describes the overall structure of the MCU flashloader.



## 1.4 Features supported

Here are some of the features supported by the MCU flashloader:

- Supports UART and USB peripheral interfaces.
- Automatic detection of the active peripheral.
- Ability to disable any peripheral.
- UART peripheral implements autobaud.
- Common packet-based protocol for all peripherals.
- Packet error detection and retransmit.
- Protection of RAM used by the flashloader while it is running.
- Provides command to read properties of the device, such as RAM size.
- · Support for serial QuadSPI and other external memories.
- Support for encrypted image download.

#### 1.5 Components supported

Components for the flashloader firmware:

• Startup code (clocking, pinmux, etc.)

- · Command phase state machine
- · Command handlers
  - GenericResponse
  - FlashEraseAll
  - FlashEraseRegion
  - ReadMemory
  - ReadMemoryResponse
  - WriteMemory
  - FillMemory
  - GetProperty
  - GetPropertyResponse
  - ReceiveSbFile
  - Execute
  - Call
  - Reset
  - SetProperty
  - FlashProgramOnce/EfuseProgramOnce
  - FlashReadOnce/EfuseReadOnce
  - FlashReadOnceResponse
  - ConfigureMemory
  - GenerateKeyBlob
  - GenerateKeyBlobResponse
- · SB file state machine
  - Unencrypted SB image support
- · Packet interface
  - Framing packetizer
  - Command/data packet processor
- · Memory interface
  - Abstract interface
  - Internal RAM/device memory interface
  - FlexSPI NOR Memory Interface
  - FlexSPI NAND Memory Interface
  - SEMC NOR Memory Interface
  - SEMC NAND Memory Interface
  - SD Card Memory Interface
  - eMMC Memory Interface
  - SPI NOR FLASH/EEPROM Memory Interface
- · Peripheral drivers

Introduction

- UART
  - Auto-baud detector
- USB device
  - USB controller driver
  - USB framework
  - ∘ USB HID class
- Property interface
  - Get or set bootloader property
  - Security support
  - Generate key blob for HAB encrypted boot.

NOTE

Different components are available on different targets. Therefore, some features might not be supported on some targets.

## Chapter 2 MCU Flashloaderprotocol API

## 2.1 Introduction

This section explains the general protocol for the packet transfers between the host and the MCU flashloader. The description includes the transfer of packets for different transactions, such as commands with no data phase, and commands with an incoming or outgoing data phase. The next section describes the various packet types used in a transaction.

Each command sent from the host is replied to with a response command.

Commands may include an optional data phase.

- · If the data phase is incoming (from the host to MCU flashloader), it is part of the original command.
- If the data phase is outgoing (from MCU flashloader to host), it is part of the response command.

## 2.2 Command with no data phase

**NOTE** In these diagrams, the Ack sent in response to a Command or Data packet can arrive at any time before, during, or after the Command/Data packet has processed.

#### Command with no data phase

The protocol for a command with no data phase contains:

- Command packet (from host)
- · Generic response command packet (to host)



## 2.3 Command with incoming data phase

The protocol for a command with incoming data phase contains:

- Command packet (from host)(kCommandFlag\_HasDataPhase set)
- Generic response command packet (to host)
- · Incoming data packets (from host)
- · Generic response command packet (to host)



#### Notes

- The host may not send any further packets while it is waiting for the response to a command.
- The data phase is aborted if, prior to the start of the data phase, the Generic Response packet does not have a status of kStatus\_Success.

- Data phases may be aborted by the receiving side by sending the final Generic Response early with a status of kStatus\_AbortDataPhase. The host may abort the data phase early by sending a zero-length data packet.
- The final Generic Response packet sent after the data phase includes the status for the entire operation.

## 2.4 Command with outgoing data phase

The protocol for a command with an outgoing data phase contains:

- · Command packet (from host)
- ReadMemory Response command packet (to host)(kCommandFlag\_HasDataPhase set)
- Outgoing data packets (to host)
- Generic response command packet (to host)



#### Note

- The data phase is considered part of the response command for the outgoing data phase sequence.
- The host may not send any further packets while the host is waiting for the response to a command.
- The data phase is aborted if, prior to the start of the data phase, the ReadMemory Response command packet does not contain the kCommandFlag\_HasDataPhase flag.
- Data phases may be aborted by the host sending the final Generic Response early with a status of kStatus\_AbortDataPhase. The sending side may abort the data phase early by sending a zero-length data packet.
- The final Generic Response packet sent after the data phase includes the status for the entire operation.

## Chapter 3 Flashloader packet types

#### 3.1 Introduction

The MCU Flashloader device works in slave mode. A host initiates all the data communication, which is either a PC or embedded host. The MCU Flashloader device is the target, which receives a command or data packet. All data communication between host and target is packetized.

NOTE The term "target" refers to the "MCU Flashloader device".

There are 6 types of packets used:

- · Framing packet
- CRC16 algorithm
- · Ping packet
- Ping response packet
- · Command packet
- Response packet

All fields in the packets are in little-endian byte order.

#### 3.2 Framing packet

The framing packet is used for flow control and error detection for the communications links that do not have such features built-in. The framing packet structure sits between the link layer and command layer. It wraps command and data packets as well.

Every framing packet containing data sent in one direction results in a synchronizing response framing packet in the opposite direction.

The framing packet described in this section is used for serial peripheral UART. The USB HID peripheral does not use framing packets. Instead, the packetization inherent in the USB protocol itself is used.

| Table | 1. | Framing | packet | format |
|-------|----|---------|--------|--------|
|-------|----|---------|--------|--------|

| Byte # | Parameter                      | Description                                                                                                                                               |
|--------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | start byte                     | Value - 0x5A                                                                                                                                              |
| 1      | packetType                     |                                                                                                                                                           |
| 2      | length_low                     | Length is a 16-bit field that specifies the entire command                                                                                                |
| 3      | length_high                    | or data packet size in bytes.                                                                                                                             |
| 4      | crc16_low                      | This is a 16-bit field. The CRC16 value covers entire                                                                                                     |
| 5      | crc16_high                     | framing packet, including the start byte and command or<br>data packets, but does not include the CRC bytes. See<br>the CRC16 algorithm after this table. |
| 6n     | Command or Data packet payload |                                                                                                                                                           |

A special framing packet that contains only a start byte and a packet type is used for synchronization between the host and target.

#### Table 2. Special framing packet format

| Byte # | Value        | Parameter  |
|--------|--------------|------------|
| 0      | 0x5A         | start byte |
| 1      | 0xA <i>n</i> | packetType |

The Packet Type field specifies the type of the packet from one of the defined types (below):

#### Table 3. packetType field

| packetType | Name                            | Description                                                                            |
|------------|---------------------------------|----------------------------------------------------------------------------------------|
| 0xA1       | kFramingPacketType_Ack          | The previous packet was received successfully; the sending of more packets is allowed. |
| 0xA2       | kFramingPacketType_Nak          | The previous packet was corrupted and must be re-sent.                                 |
| 0xA3       | kFramingPacketType_AckAbort     | Data phase is being aborted.                                                           |
| 0xA4       | kFramingPacketType_Command      | The framing packet contains a command packet payload.                                  |
| 0xA5       | kFramingPacketType_Data         | The framing packet contains a data packet payload.                                     |
| 0xA6       | kFramingPacketType_Ping         | Sent to verify the other side is alive. Also used for UART autobaud.                   |
| 0xA7       | kFramingPacketType_PingResponse | A response to Ping; contains the framing protocol version number and options.          |

### 3.3 CRC16 algorithm

This section provides the CRC16 algorithm.

The CRC is computed over each byte in the framing packet header, excluding the crc16 field itself, plus all payload bytes. The CRC algorithm is the XMODEM variant of CRC-16.

The characteristics of the XMODEM variant are:

| width        | 16     |
|--------------|--------|
| polynomial   | 0x1021 |
| init value   | 0x0000 |
| reflect in   | false  |
| reflect out  | false  |
| xor out      | 0x0000 |
| check result | 0x31c3 |

The check result is computed by running the ASCII character sequence "123456789" through the algorithm.

```
uint16_t crc16_update(const uint8_t * src, uint32_t lengthInBytes)
{
    uint32_t crc = 0;
    uint32_t j;
    for (j=0; j < lengthInBytes; ++j)
    //
</pre>
```

```
uint32_t i;
uint32_t byte = src[j];
crc ^= byte << 8;
for (i = 0; i < 8; ++i)
{
    uint32_t temp = crc << 1;
    if (crc & 0x8000)
    {
       temp ^= 0x1021;
    }
    crc = temp;
    }
}
return crc;
}
```

## 3.4 Ping packet

The Ping packet can be sent from host to target any time when the target is expecting a command packet. If the selected peripheral is UART, a ping packet must be sent before any other communication in order to run autobaud. For other serial peripherals it is optional, but is recommended in order to determine the serial protocol version.

In response to a Ping packet, the target sends a Ping Response packet, discussed in following section.

#### Table 5. Ping packet format

| Byte # | Value | Name       |
|--------|-------|------------|
| 0      | 0x5A  | start byte |
| 1      | 0xA6  | ping       |



## 3.5 Ping response packet

The target sends a Ping Response packet back to the host after receiving a Ping packet. If communication is over a UART peripheral, the target uses the incoming Ping packet to determine the baud rate before replying with the Ping Response packet. After the Ping Response packet is received by the host, the connection is established, and the host starts sending commands to the target.

| Table 6. | Ping | Response | packet format |
|----------|------|----------|---------------|
|----------|------|----------|---------------|

| Byte # | Value | Parameter                  |
|--------|-------|----------------------------|
| 0      | 0x5A  | start byte                 |
| 1      | 0xA7  | Ping response code         |
| 2      |       | Protocol bugfix            |
| 3      |       | Protocol minor             |
| 4      |       | Protocol major             |
| 5      |       | Protocol name = 'P' (0x50) |
| 6      |       | Options low                |
| 7      |       | Options high               |
| 8      |       | CRC16 low                  |
| 9      |       | CRC16 high                 |

## 3.6 Command packet

The command packet carries a 32-bit command header and a list of 32-bit parameters.

#### Table 7. Command packet format

|        | Command packet format (32 bytes)                                    |        |                |                    |                    |                    |                    |                    |                    |                    |
|--------|---------------------------------------------------------------------|--------|----------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| Com    | Command header (4 bytes) 28 bytes for parameters (Max 7 parameters) |        |                |                    |                    |                    |                    |                    |                    |                    |
| Tag    | Flags                                                               | Rsvd   | Param<br>Count | Param1<br>(32-bit) | Param2<br>(32-bit) | Param3<br>(32-bit) | Param4<br>(32-bit) | Param5<br>(32-bit) | Param6<br>(32-bit) | Param7<br>(32-bit) |
| byte 0 | byte 1                                                              | byte 2 | byte 3         | -                  | -                  | -                  | -                  | -                  | -                  | -                  |

#### Table 8. Command header format

| Byte # | Command header field      |
|--------|---------------------------|
| 0      | Command or Response tag   |
| 1      | Flags                     |
| 2      | Reserved. Should be 0x00. |
| 3      | ParameterCount            |

The header is followed by 32-bit parameters up to the value of the ParameterCount field specified in the header.

Command packets are also used by the target to send responses back to the host. As described in section 3.4, command packets and data packets are embedded into framing packets for all UART transfers.

#### Table 9. Command Tags

| Command Tag | Name              |                                                                                  |
|-------------|-------------------|----------------------------------------------------------------------------------|
| 0x01        | FlashEraseAll     | The command tag specifies one of the                                             |
| 0x02        | FlashEraseRegion  | commands supported by the MCU flashloader.<br>The valid command tags for the MCU |
| 0x03        | ReadMemory        | flashloader are listed here.                                                     |
| 0x04        | WriteMemory       |                                                                                  |
| 0x05        | FillMemory        |                                                                                  |
| 0x07        | GetProperty       |                                                                                  |
| 0x08        | Reserved          |                                                                                  |
| 0x09        | Execute           |                                                                                  |
| 0x0A        | Call              |                                                                                  |
| 0x0B        | Reset             |                                                                                  |
| 0x0C        | SetProperty       |                                                                                  |
| 0x0E        | eFuseProgram      |                                                                                  |
| 0x0F        | eFuseRead         |                                                                                  |
| 0x10        | FlashReadResource |                                                                                  |
| 0x11        | ConfigureMemory   |                                                                                  |

Table continues on the next page ....

| Command Tag | Name            |  |
|-------------|-----------------|--|
| 0x12        | ReliableUpdate  |  |
| 0x13        | GenerateKeyBlob |  |
| 0x14        | Reserved        |  |

#### Table 9. Command Tags (continued)

#### Table 10. Response Tags

| Response Tag | Name                                                                                     |                                                                                               |
|--------------|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| 0xA0         | GenericResponse                                                                          | The response tag specifies one of the responses                                               |
| 0xA3         | ReadMemoryResponse (used for sending responses to ReadMemory command only)               | the MCU flashloader (target) returns to the host.<br>The valid response tags are listed here. |
| 0xA7         | GetPropertyResponse (used for sending responses to GetProperty command only)             |                                                                                               |
| 0xAF         | FlashReadOnceResponse (used for sending responses to FlashReadOnce command only)         |                                                                                               |
| 0xB0         | FlashReadResourceResponse (used for sending responses to FlashReadResource command only) |                                                                                               |
| 0xB3         | GenerateKeyBlobResponse                                                                  |                                                                                               |
| 0xB4         | ReservedResponse                                                                         |                                                                                               |

**Flags:** Each command packet contains a Flag byte. Only bit 0 of the flag byte is used. If bit 0 of the flag byte is set to 1, then data packets follow in the command sequence. The number of bytes that are transferred in the data phase is determined by a command-specific parameter in the parameters array.

ParameterCount: The number of parameters included in the command packet.

**Parameters:** The parameters are word-length (32 bits). With the default maximum packet size of 32 bytes, a command packet can contain up to 7 parameters.

## 3.7 Response packet

Response packets use the same format as command packets (refer to section 3.6). Types of responses include:

- GenericResponse
- GetPropertyResponse
- ReadMemoryResponse
- FlashReadOnceResponse
- FlashReadResourceResponse

**GenericResponse:** After the MCU flashloader has processed a command, the flashloader sends a generic response with status and command tag information to the host. The generic response is the last packet in the command protocol sequence. The generic response packet contains the command packet data (with generic response tag = 0xA0) and a list of parameters (defined in the next section). The parameter count field in the header is always set to 2, for status code and command tag parameters.

| Byte # | Parameter   | Description                                                                                                                                              |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 - 3  | Status code | The Status codes are errors encountered during the execution of a command by the target. If a command succeeds, then a kStatus_Success code is returned. |
| 4 - 7  | Command tag | The Command tag parameter identifies the response to the command sent by the host.                                                                       |

#### Table 11. GenericResponse parameters

**GetPropertyResponse:** The GetPropertyResponse packet is sent by the target in response to the host query that uses the GetProperty command. The GetPropertyResponse packet contains the command packet data, with the command/response tag set to a GetPropertyResponse tag value (0xA7).

The parameter count field in the header is set to greater than 1, to always include the status code and one or many property values.

Table 12. GetPropertyResponse parameters

| Byte # | Value | Parameter                                                                                                   |
|--------|-------|-------------------------------------------------------------------------------------------------------------|
| 0 - 3  |       | Status code                                                                                                 |
| 4 - 7  |       | Property value                                                                                              |
|        |       |                                                                                                             |
|        |       | Can be up to maximum 6 property values, limited to the size of the 32-bit command packet and property type. |

**ReadMemoryResponse:** The ReadMemoryResponse packet is sent by the target in response to the host sending a ReadMemory command. The ReadMemoryResponse packet contains the command packet data, with the command/response tag set to a ReadMemoryResponse tag value (0xA3), the flags field set to kCommandFlag\_HasDataPhase (1).

The parameter count is set to 2 for the status code and the data byte count parameters shown below.

#### Table 13. ReadMemoryResponse Parameters

| Byte # | Parameter       | Descripton                                        |
|--------|-----------------|---------------------------------------------------|
| 0 - 3  | Status code     | The status of the associated Read Memory command. |
| 4 - 7  | Data byte count | The number of bytes sent in the data phase.       |

**FlashReadOnceResponse:**The FlashReadOnceResponse packet is sent by the target in response to the host sending a FlashReadOnce command. The FlashReadOnceResponse packet contains the command packet data, with the command/ response tag set to a FlashReadOnceResponse tag value (0xAF), and the flags field set to 0. The parameter count is set to 2 plus *the number of words* requested to be read in the FlashReadOnceCommand.

| Byte # | Value | Parameter                                     |
|--------|-------|-----------------------------------------------|
| 0 – 3  |       | Status Code                                   |
| 4 – 7  |       | Byte count to read                            |
|        |       |                                               |
|        |       | Can be up to 20 bytes of requested read data. |

**GenerateKeyBlobResponse**: The GenerateKeyBlobResponse packet is sent by the target in response to the host sending a GenerateKeyBlob command. The GenerateKeyBlobResponse packet contains the command packet data with the command/ response tag set to a GenerateKeyBlobResponse tag value (0xB3), and the flags field set to KCommandFlag\_HasDataPhase(1).

The parameter count is set to 2 for the status code and the byte count of the key blob generated by the target.

#### Table 15. GenerateKeyBlobResponse Parameters

| Byte # | Parameter       | Description                                           |  |
|--------|-----------------|-------------------------------------------------------|--|
| 0-3    | Status code     | The status of the associated<br>GenerateKeyBlob       |  |
| 4-7    | Blob byte count | The byte count of the key blob sent in the data phase |  |

## Chapter 4 MCU Flashloader command API

### 4.1 Introduction

All MCU flashloader command APIs follows the command packet format wrapped by the framing packet as explained in previous sections.

See Table 3-9 for a list of commands supported by MCU flashloader.

For a list of status codes returned by MCU flashloader, see Appendix A.

## 4.2 GetProperty command

The GetProperty command is used to query the flashloader about various properties and settings. Each supported property has a unique 32-bit tag associated with it. The tag occupies the first parameter of the command packet. The target returns a GetPropertyResponse packet with the values for the property identified with the tag in the GetProperty command.

Properties are the defined units of data that can be accessed with the GetProperty or SetProperty commands. Properties may be read-only or read-write. All read-write properties are 32-bit integers, so they can easily be carried in a command parameter.

For a list of properties and their associated 32-bit property tags supported by MCU flashloader, see Appendix B, "GetProperty and SetProperty commands".

The 32-bit property tag is the only parameter required for GetProperty command.

#### Table 16. Parameters for GetProperty command

| Byte # | Command                                                                       |
|--------|-------------------------------------------------------------------------------|
| 0 - 3  | Property tag                                                                  |
| 4 - 7  | External Memory Identifier (only applies to get property for external memory) |



Table 17. GetProperty packet format example

| GetProperty    | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | start byte     | 0x5A                             |
|                | packetType     | 0xA4, kFramingPacketType_Command |
|                | length         | 0x0C 0x00                        |
|                | crc16          | 0x4B 0x33                        |
| Command packet | commandTag     | 0x07 – GetProperty               |
|                | flags          | 0x00                             |
|                | reserved       | 0x00                             |
|                | parameterCount | 0x02                             |
|                | propertyTag    | 0x0000001 - CurrentVersion       |
|                | Memory ID      | 0x00000000 - Internal Flash      |

The GetProperty command has no data phase.

**Response:** In response to a GetProperty command, the target sends a GetPropertyResponse packet with the response tag set to 0xA7. The parameter count indicates the number of parameters sent for the property values, with the first parameter showing status code 0, followed by the property value(s). The next table shows an example of a GetPropertyResponse packet.

Table 18. GetProperty response packet format example

| GetPropertyResponse | Parameter  | Value |
|---------------------|------------|-------|
| Framing packet      | start byte | 0x5A  |

Table continues on the next page...

| GetPropertyResponse | Parameter      | Value                            |
|---------------------|----------------|----------------------------------|
|                     | packetType     | 0xA4, kFramingPacketType_Command |
|                     | length         | 0x0c 0x00 (12 bytes)             |
|                     | crc16          | 0xf4 9d                          |
| Command packet      | responseTag    | 0xA7                             |
|                     | flags          | 0x00                             |
|                     | reserved       | 0x00                             |
|                     | parameterCount | 0x02                             |
|                     | status         | 0x0000000                        |
|                     | propertyValue  | 0x4b020600 - CurrentVersion      |

 Table 18. GetProperty response packet format example (continued)

## 4.3 SetProperty command

The SetProperty command is used to change or alter the values of the properties or options of the flashloader. The command accepts the same property tags used with the GetProperty command. However, only some properties are writable--see Appendix B. If an attempt to write a read-only property is made, an error is returned indicating the property is read-only and cannot be changed.

The property tag and the new value to set are the two parameters required for the SetProperty command.

#### Table 19. Parameters for SetProperty command

| Byte # | Command        |
|--------|----------------|
| 0 - 3  | Property tag   |
| 4 - 7  | Property value |



#### Table 20. SetProperty packet format example

| SetProperty    | Parameter      | Value                                   |
|----------------|----------------|-----------------------------------------|
| Framing packet | start byte     | 0x5A                                    |
|                | packetType     | 0xA4, kFramingPacketType_Command        |
|                | length         | 0x0C 0x00                               |
|                | crc16          | 0x67 0x8D                               |
| Command packet | commandTag     | 0x0C – SetProperty with property tag 10 |
|                | flags          | 0x00                                    |
|                | reserved       | 0x00                                    |
|                | parameterCount | 0x02                                    |
|                | propertyTag    | 0x000000A - VerifyWrites                |
|                | propertyValue  | 0x0000001                               |

The SetProperty command has no data phase.

**Response:** The target returns a GenericResponse packet with one of following status codes:

Table 21. SetProperty response status codes

Status Code

kStatus\_Success

Table continues on the next page ...

Table 21. SetProperty response status codes (continued)

| Status Code             |
|-------------------------|
| kStatus_ReadOnly        |
| kStatus_UnknownProperty |
| kStatus_InvalidArgument |

## 4.4 FlashEraseAll command

The FlashEraseAll command performs an erase of the entire flash memory. If any flash regions are protected, then the FlashEraseAll command fails and returns an error status code. Executing the FlashEraseAll command releases flash security if it (flash security) was enabled, by setting the FTFA\_FSEC register. However, the FSEC field of the flash configuration field is erased, so unless it is reprogrammed, the flash security is re-enabled after the next system reset. The Command tag for FlashEraseAll command is 0x01 set in the commandTag field of the command packet.

The FlashEraseAll command requires a memory ID. If the memory ID is not specified, the internal flash (memory ID =0) will be selected as default.

| Byte # | Par |
|--------|-----|
|        |     |

Table 22. Parameter for FlashEraseAll command

| Byte # | Parameter | Parameter                                |  |
|--------|-----------|------------------------------------------|--|
| 0-3    | Memory ID |                                          |  |
|        | 0x000     | Internal Flash                           |  |
|        | 0x010     | Execute-only region in<br>Internal Flash |  |
|        | 0x001     | Serial NOR through QuadSPI               |  |
|        | 0×008     | Parallel NOR through SEMC                |  |
|        | 0x009     | Serial NOR through FlexSPI               |  |
|        | 0x100     | SLC Raw NAND<br>through SEMC             |  |
|        | 0x101     | Serial NAND through FlexSPI              |  |
|        | 0x110     | Serial NOR/EEPROM<br>through SPI         |  |
|        | 0x120     | SD through uSDHC                         |  |
|        | 0x121     | eMMC through uSDHC                       |  |
|        |           |                                          |  |



Table 23. FlashEraseAll packet format example

| FlashEraseAll  | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | start byte     | 0x5A                             |
|                | packetType     | 0xA4, kFramingPacketType_Command |
|                | length         | 0x08 0x00                        |
|                | crc16          | 0x0C 0x22                        |
| Command packet | commandTag     | 0x01 - FlashEraseAll             |
|                | flags          | 0x00                             |
|                | reserved       | 0x00                             |
|                | parameterCount | 0x01                             |
|                | Memory ID      | refer to the above table         |

The FlashEraseAll command has no data phase.

**Response:** The target returns a GenericResponse packet with status code either set to kStatus\_Success for successful execution of the command, or set to an appropriate error status code.

#### 4.5 FlashEraseRegion command

The FlashEraseRegion command performs an erase of one or more sectors of the flash memory.

The start address and number of bytes are the 2 parameters required for the FlashEraseRegion command. The start and byte count parameters must be 4-byte aligned ([1:0] = 00), or the FlashEraseRegion command fails and returns kStatus\_FlashAlignmentError(101). If the region specified does not fit in the flash memory space, the FlashEraseRegion

command fails and returns kStatus\_FlashAddressError(102). If any part of the region specified is protected, the FlashEraseRegion command fails and returns kStatus\_MemoryRangeInvalid(10200).

| Table 24. | Parameters  | for FlashEraseRegion     | command  |
|-----------|-------------|--------------------------|----------|
|           | i aramotoro | Ior Flaoriciacor (ogiori | oominana |

| Byte # | Parameter     |
|--------|---------------|
| 0 - 3  | Start address |
| 4 - 7  | Byte count    |
| 8 - 11 | Memory ID     |

The FlashEraseRegion command has no data phase.

Response: The target returns a GenericResponse packet with one of following error status codes.

#### Table 25. FlashEraseRegion response status codes

| Status code                            |
|----------------------------------------|
| kStatus_Success (0)                    |
| kStatus_MemoryRangeInvalid (10200)     |
| kStatus_FlashAlignmentError (101)      |
| kStatus_FlashAddressError (102)        |
| kStatus_FlashAccessError (103)         |
| kStatus_FlashProtectionViolation (104) |
| kStatus_FlashCommandFailure (105)      |

### 4.6 ReadMemory command

The ReadMemory command returns the contents of memory at the given address, for a specified number of bytes. This command can read any region of memory accessible by the CPU and is not protected by security.

The start address and number of bytes are the two parameters required for ReadMemory command. The memory ID is optional. Internal memory is selected as default if memory ID is not specified.

Table 26. Parameters for read memory command

| Byte | Parameter     | Description                                  |
|------|---------------|----------------------------------------------|
| 0-3  | Start address | Start address of memory to read from         |
| 4-7  | Byte count    | Number of bytes to read and return to caller |
| 8-11 | Memory ID     | Internal or extermal memory Identifier       |



| ReadMemory     | Parameter  | Value                      |
|----------------|------------|----------------------------|
| Framing packet | Start byte | 0x5A0xA4,                  |
|                | packetType | kFramingPacketType_Command |
|                | length     | 0x10 0x00                  |
|                | crc16      | 0xF4 0x1B                  |
| Command packet | commandTag | 0x03 - readMemory          |
|                | flags      | 0x00                       |

Table continues on the next page ...

| ReadMemory | Parameter      | Value      |
|------------|----------------|------------|
|            | reserved       | 0x00       |
|            | parameterCount | 0x03       |
|            | startAddress   | 0x20000400 |
|            | byteCount      | 0x0000064  |
|            | memoryID       | 0x0        |

Data Phase: The ReadMemory command has a data phase. Because the target works in slave mode, the host needs to pull data packets until the number of bytes of data specified in the byteCount parameter of the ReadMemory command are received by host.

**Response:** The target returns a ReadMemoryResponse packet in response to the host sending a ReadMemory command. And returns a GenericResponse in response to the result of the data phase.

#### 4.7 WriteMemory command

The WriteMemory command writes data provided in the data phase to a specified range of bytes in memory (flash or RAM). However, if flash protection is enabled, then writes to protected sectors fail.

Special care must be taken when writing to flash.

- First, any flash sector written to must have been previously erased with a FlashEraseAll, FlashEraseRegion, or FlashEraseAllUnsecure command.
- Writing to flash requires the start address to be page size aligned.
- The byte count is rounded up to a multiple of page size, and trailing bytes are filled with the flash erase pattern (0xff).
- If the VerifyWrites property is set to true, then writes to flash also perform a flash verify program operation.

When writing to RAM, the start address does not need to be aligned, and the data is not padded.

The start address and number of bytes are the 2 parameters required for the WriteMemory command. The memory ID is optional. Internal memory will be selected as default if a memory ID is not specified.

| Byte # | Command       |
|--------|---------------|
| 0 - 3  | Start address |
| 4 - 7  | Byte count    |
| 8 - 11 | Memory ID     |



#### Table 29. WriteMemory packet format example

| WriteMemory    | Parameter  | Value                            |
|----------------|------------|----------------------------------|
| Framing packet | start byte | 0x5A                             |
|                | packetType | 0xA4, kFramingPacketType_Command |
|                | length     | 0x10 0x00                        |
|                | crc16      | 0x97 0xDD                        |

Table continues on the next page ...

| WriteMemory    | Parameter      | Value              |
|----------------|----------------|--------------------|
| Command packet | commandTag     | 0x04 - writeMemory |
|                | flags          | 0x01               |
|                | reserved       | 0x00               |
|                | parameterCount | 0x03               |
|                | startAddress   | 0x20000400         |
|                | byteCount      | 0x0000064          |
|                | memoryID       | 0x0                |

Table 29. WriteMemory packet format example (continued)

**Data Phase:** The WriteMemory command has a data phase. The host sends data packets until the number of bytes of data specified in the byteCount parameter of the WriteMemory command are received by the target.

**Response:** The target returns a GenericResponse packet with a status code set to kStatus\_Success upon successful execution of the command or to an appropriate error status code.

#### 4.8 FillMemory command

The FillMemory command fills a range of bytes in memory with a data pattern. It follows the same rules as the WriteMemory command. The difference between FillMemory and WriteMemory is that a data pattern is included in the FillMemory command parameter, and there is no data phase for the FillMemory command, while WriteMemory does have a data phase.

Table 30. Parameters for FillMemory command

| Byte # | Command                                                                |
|--------|------------------------------------------------------------------------|
| 0 - 3  | Start address of memory to fill                                        |
| 4 - 7  | Number of bytes to write with the pattern                              |
|        | <ul> <li>The start address should be 32-bit aligned.</li> </ul>        |
|        | <ul> <li>The number of bytes must be evenly divisible by 4.</li> </ul> |
|        | NOTE                                                                   |
|        | For any part that uses FTFE flash, the start address should            |
|        | be 64-bit aligned, and the number of bytes must be evenly              |
|        | divisible by 8.                                                        |
| 8 - 11 | 32-bit pattern                                                         |

• To fill with a byte pattern (8-bit), the byte must be replicated 4 times in the 32-bit pattern.

• To fill with a short pattern (16-bit), the short value must be replicated 2 times in the 32-bit pattern.

For example, to fill a byte value with 0xFE, the word pattern is 0xFEFEFEFE; to fill a short value 0x5AFE, the word pattern is 0x5AFE5AFE.

Special care must be taken when writing to flash.

- First, any flash sector written to must have been previously erased with a FlashEraseAll or FlashEraseRegion command.
- Writing to flash requires the start address to be page size aligned.
- If the VerifyWrites property is set to true, then writes to flash also performs a flash verify program operation.

When writing to RAM, the start address does not need to be aligned.



#### Table 31. FillMemory packet format example

| FillMemory     | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | start byte     | 0x5A                             |
|                | packetType     | 0xA4, kFramingPacketType_Command |
|                | length         | 0x10 0x00                        |
|                | crc16          | 0xE4 0x57                        |
| Command packet | commandTag     | 0x05 – FillMemory                |
|                | flags          | 0x00                             |
|                | Reserved       | 0x00                             |
|                | parameterCount | 0x03                             |
|                | startAddress   | 0x00007000                       |
|                | byteCount      | 0x0000800                        |
|                | patternWord    | 0x12345678                       |

The FillMemory command has no data phase.

**Response:** upon successful execution of the command, the target (MCU flashloader) returns a GenericResponse packet with a status code set to kStatus\_Success, or to an appropriate error status code.

#### 4.9 Execute command

The execute command results in the flashloader setting the program counter to the code at the provided jump address, R0 to the provided argument, and a Stack pointer to the provided stack pointer address. Prior to the jump, the system is returned to the reset state.

The Jump address, function argument pointer, and stack pointer are the parameters required for the Execute command. If the stack pointer is set to zero, the called code is responsible for setting the processor stack pointer before using the stack.

| Byte # | Command               |
|--------|-----------------------|
| 0 - 3  | Jump address          |
| 4 - 7  | Argument word         |
| 8 - 11 | Stack pointer address |

The Execute command has no data phase.

**Response:** Before running the Execute command, the target validates the parameters and returns a GenericResponse packet with a status code either set to kStatus\_Success or an appropriate error status code.

## 4.10 Call command

The Call command executes a function that is written in memory at the address sent in the command. The address needs to be a valid memory location residing in accessible flash (internal or external) or in RAM. The command supports the passing of one 32-bit argument. Although the command supports a stack address, at this time the call still takes place using the current stack pointer. After execution of the function, a 32-bit value is returned in the generic response message.



| Table 33. | Parameters | for Call | command |
|-----------|------------|----------|---------|
|-----------|------------|----------|---------|

| Byte # | Command       |
|--------|---------------|
| 0 - 3  | Call address  |
| 4 - 7  | Argument word |
| 8 - 11 | Stack pointer |

**Response:** The target returns a GenericResponse packet with a status code either set to the return value of the function called or set to kStatus\_InvalidArgument (105).

### 4.11 Reset command

The Reset command results in the flashloader resetting the chip.

The Reset command requires no parameters.



#### Table 34. Reset command packet format example

| Reset          | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | start byte     | 0x5A                             |
|                | packetType     | 0xA4, kFramingPacketType_Command |
|                | length         | 0x04 0x00                        |
|                | crc16          | 0x6F 0x46                        |
| Command packet | commandTag     | 0x0B - reset                     |
|                | flags          | 0x00                             |
|                | reserved       | 0x00                             |
|                | parameterCount | 0x00                             |

The Reset command has no data phase.

Response: The target returns a GenericResponse packet with status code set to kStatus\_Success before resetting the chip.

The Reset command can also be used to switch boot from flash after successful flash image provisioning via the flashloader. After issuing the reset command, allow 5 seconds for the user application to start running from flash.

## 4.12 FlashProgramOnce/eFuseProgramOnce command

The FlashProgramOnce/ eFuseProgramOnce command writes data (that is provided in a command packet) to a specified range of bytes in the program once field. Special care must be taken when writing to the program once field.

- The program once field only supports programming once, so any attempt to reprogram a program once field gets an error response.
- Writing to the program once field requires the byte count to be 4.

The FlashProgramOnce command uses three parameters: index, byteCount, and data.

Table 35. Parameters for FlashProgramOnce command

| Byte #  | Command                                                                            |
|---------|------------------------------------------------------------------------------------|
| 0 - 3   | Index of program once/ eFuse field                                                 |
| 4 - 7   | Byte count (must be 4 or 8 for a FlashProgramOnce; must be 4 for eFuseProgramOnce) |
| 8 - 11  | Data                                                                               |
| 12 - 16 | Data                                                                               |



#### Table 36. FlashProgramOnce packet format example

| FlashProgramOnce | Parameter  | Value                            |
|------------------|------------|----------------------------------|
| Framing packet   | start byte | 0x5A                             |
|                  | packetType | 0xA4, kFramingPacketType_Command |
|                  | length     | 0x10 0x00                        |

Table continues on the next page ...

| FlashProgramOnce | Parameter      | Value                   |
|------------------|----------------|-------------------------|
|                  | crc16          | 0x7E4 0x89              |
| Command packet   | commandTag     | 0x0E – FlashProgramOnce |
|                  | flags          | 0                       |
|                  | reserved       | 0                       |
|                  | parameterCount | 3                       |
|                  | index          | 0x0000_0000             |
|                  | byteCount      | 0x0000_0004             |
|                  | data           | 0x1234_5678             |

Table 36. FlashProgramOnce packet format example (continued)

**Response:** upon successful execution of the command, the target (MCU flashloader) returns a GenericResponse packet with a status code set to kStatus\_Success, or to an appropriate error status code.

## 4.13 FlashReadOnce/eFuseReadOnce command

The FlashReadOnce/eFuseReadOnce command returns the contents of the program once field by given index and byte count. The FlashReadOnce command uses 2 parameters: index and byteCount.

Table 37. Parameters for FlashReadOnce command

| Byte # | Parameter | Description                                                                    |
|--------|-----------|--------------------------------------------------------------------------------|
| 0 - 3  | index     | Index of the program once field (to read from)                                 |
| 4 - 7  | byteCount | Number of bytes to read and return to the caller (must be 4 for eFuseReadOnce) |



Table 38. FlashReadOnce packet format example

| FlashReadOnce  | Parameter      | Value                |
|----------------|----------------|----------------------|
| Framing packet | start byte     | 0x5A                 |
|                | packetType     | 0xA4                 |
|                | length         | 0x0C 0x00            |
|                | crc            | 0xC1 0xA5            |
| Command packet | commandTag     | 0x0F – FlashReadOnce |
|                | flags          | 0x00                 |
|                | reserved       | 0x00                 |
|                | parameterCount | 0x02                 |
|                | index          | 0x0000_0000          |
|                | byteCount      | 0x0000_0004          |

#### Table 39. FlashReadOnce response format example

| FlashReadOnce<br>response | Parameter  | Value     |
|---------------------------|------------|-----------|
| Framing packet            | start byte | 0x5A      |
|                           | packetType | 0xA4      |
|                           | length     | 0x10 0x00 |

| FlashReadOnce<br>response | Parameter      | Value       |
|---------------------------|----------------|-------------|
|                           | crc            | 0x3F 0x6F   |
| Command packet            | commandTag     | 0xAF        |
|                           | flags          | 0x00        |
|                           | reserved       | 0x00        |
|                           | parameterCount | 0x03        |
|                           | status         | 0x0000_0000 |
|                           | byteCount      | 0x0000_0004 |
|                           | data           | 0x1234_5678 |

Table 39. FlashReadOnce response format example (continued)

**Response:** Upon successful execution of the command, the target returns a FlashReadOnceResponse packet with a status code set to kStatus\_Success, a byte count and corresponding data read from Program Once Field upon successful execution of the command, or returns with a status code set to an appropriate error status code and a byte count set to 0.

# 4.14 Configure Memory command

The Configure Memory command configures an external memory device using a pre-programmed configuration image. The parameters passed are memory ID and memory address containing the configuration data. The configuration data is written to a RAM or flash location and then this command directs the flashloader to use the data at that location to configure the external memory devices. See Chapter 6, External Memory Support, for configuration data details.

Table 40. Parameters for Configure Memory command

| Byte # | Parameter                   |
|--------|-----------------------------|
| 0 - 3  | Memory ID                   |
| 4 - 7  | Configuration block address |

**Response:** The target (MCU flashloader) returns a GenericResponse packet with a status code either set to kStatus\_Success upon successful execution of the command, or set to an appropriate error code.



# 4.15 ReceiveSBFile command

The ReceiveSBFile command starts the transfer of an SB file to the target. The command only specifies the size in bytes of the SB file that is sent in the data phase. The SB file is processed as it is received by the flashloader.

#### Table 41. Parameters for ReceiveSBFile command

| Byte # | Parameter  |
|--------|------------|
| 0 - 3  | Byte count |

**Data Phase:** The ReceiveSBFile command has a data phase. The host sends data packets until the number of bytes of data specified in the byteCount parameter of the ReceiveSBFile command are received by the target.

**Response:** The target returns a GenericResponse packet with a status code set to the kStatus\_Success upon successful execution of the command, or set to an appropriate error code.

## 4.16 GenerateKeyBlob command

The GenerateKeyBlob command has two steps. The first step starts the transfer of the data encryption key (DEK) to the target. While the second step tells bootloader to generate the key blob, and then starts the transfer of the key blob from the target.

Table 42. Parameters for GenerateKeyBlob Command

| Byte # | Parameter      | Description                                                                                                                                                 |  |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0-3    | Key selection  | The blob key encryption key(BKEK) selected to wrap the blob key(BK)                                                                                         |  |
|        |                | • 0   1: OTPMK(default)                                                                                                                                     |  |
|        |                | 2: ZMK from SNVS                                                                                                                                            |  |
|        |                | • 3: CMK from SNVS.                                                                                                                                         |  |
| 4-7    | Key length     | The byte count of DEK                                                                                                                                       |  |
| 8-11   | Operation step | The step of the<br>GenerateKeyBlob command<br>0: sending DEK to the target<br>1: let the target to generate the key blob,<br>and receive it from the target |  |

#### NOTE

· Not all targets support selecting ZMK or CMK as the BKEK.

• The GenerateKeyBlob must start with "Operation phase = 0", and end with "Operation phase = 1". The behavior is unpredictable for any other sequence.

Data Phase The GenerateKeyBlob command has a data phase.

At the first step (Operation phase = 0), the host sends data packets until the number of bytes of DEK specified in the "Key length" parameter of the GenerateKeyBlob command are received by the target.

At the second step (Operation phase = 1), the host pulls data packets until the number of bytes of data specified in the "Blob byte count" parameter of the GenerateKeyBlobResponse.

Response The target returns two type of response packet for each steps.

At the first step, the target returns a GenericResponse packet with a status code.

At the second step, the target returns a GenerateKeyBlobResponse packet with a status code and the byte count of the key blob.

At the end of the data phase for each steps, the target returns a GenericResponse packet in response to the result of the data phase.



# Chapter 5 Supported peripherals

## 5.1 Introduction

This section describes the peripherals supported by the MCU flashloader.

# 5.2 UART peripheral

The MCU flashloader integrates an autobaud detection algorithm for the UART peripheral, thereby providing flexible baud rate choices.

Autobaud feature: If UART*n* is used to connect to the flashloader, then the UART*n*\_RX pin must be kept high and not left floating during the detection phase in order to comply with the autobaud detection algorithm. After the flashloader detects the ping packet (0x5A 0xA6) on UART*n*\_RX, the flashloader firmware executes the autobaud sequence. If the baudrate is successfully detected, then the flashloader sends a ping packet response [(0x5A 0xA7), protocol version (4 bytes), protocol version options (2 bytes), and crc16 (2 bytes)] at the detected baudrate. The MCU flashloader then enters a loop, waiting for flashloader commands via the UART peripheral.

NOTE

The data bytes of the ping packet must be sent continuously (with no more than 80 ms between bytes) in a fixed UART transmission mode (8-bit data, no parity bit, and 1 stop bit). If the bytes of the ping packet are sent one-by-one with more than an 80 ms delay between them, then the autobaud detection algorithm may calculate an incorrect baud rate.

**Supported baud rates:** The baud rate is closely related to the MCU core and system clock frequencies. Typical baud rates supported are 9600, 19200, 38400, and 57600.

**Packet transfer:** After autobaud detection succeeds, flashloader communications can take place over the UART peripheral. The following flow charts show:

- · How the host detects an ACK from the target
- · How the host detects a ping response from the target
- · How the host detects a command response from the target





# 5.3 USB HID peripheral

The MCU flashloader supports loading data into flash via the USB peripheral. The target is implemented as a USB HID class.

USB HID does not use framing packets. Instead, the packetization inherent in the USB protocol itself is used. The ability for the device to NAK Out transfers (until they can be received) provides the required flow control. The built-in CRC of each USB packet provides the required error detection.

# 5.3.1 Device descriptor

The MCU Flashloader configures the default USB VID/PID/Strings as shown below:

Default VID/PID:

- For legacy FSL device
  - VID = 0x15A2
  - PID = 0x0073
- For NXP device
  - VID = 0x1FC9
  - PID = 0x007F

#### Default Strings:

- For legacy FSL device
  - Manufacturer [1] = "Freescale Semiconductor Inc."
  - Product [2] = "Kinetis bootloader"
- For NXP device
  - Manufacturer [1] = "NXP Semiconductor Inc."
  - Product [2] = "Kinetis bootloader"

## 5.3.2 Endpoints

The HID peripheral uses 3 endpoints:

- Control (0)
- Interrupt IN (1)
- Interrupt OUT (2)

The Interrupt OUT endpoint is optional for HID class devices, but the MCU flashloader uses it as a pipe, where the firmware can NAK send requests from the USB host.

## 5.3.3 HID reports

There are 4 HID reports defined and used by the flashloader USB HID peripheral. The report ID determines the direction and type of packet sent in the report. Otherwise, the contents of all reports are the same.

#### Table 43. HID reports

| Report ID | Packet type | Direction |
|-----------|-------------|-----------|
| 1         | Command     | OUT       |
| 2         | Data        | OUT       |
| 3         | Command     | IN        |
| 4         | Data        | IN        |

#### For all reports, these properties apply:

#### Table 44. Report properties

| Usage Min    | 1   |
|--------------|-----|
| Usage Max    | 1   |
| Logical Min  | 0   |
| Logical Max  | 255 |
| Report Size  | 8   |
| Report Count | 34  |

Each report has a maximum size of 34 bytes. This is derived from the minimum flashloader packet size of 32 bytes, plus a 2-byte report header that indicates the length (in bytes) of the packet sent in the report.

**NOTE** In the future, the maximum report size may be increased, to support transfers of larger packets. Alternatively, additional reports may be added with larger maximum sizes.

The actual data sent in all of the reports looks like:

#### Table 45. Report data

| 0 | Report ID         |
|---|-------------------|
| 1 | Packet Length LSB |
| 2 | Packet Length MSB |
| 3 | Packet[0]         |

#### Table 45. Report data (continued)

| 4     | Packet[1]   |
|-------|-------------|
| 5     | Packet[2]   |
|       |             |
| N+3-1 | Packet[N-1] |

This data includes the Report ID, which is required if more than one report is defined in the HID report descriptor. The actual data sent and received has a maximum length of 35 bytes. The Packet Length header is written in little-endian format, and it is set to the size (in bytes) of the packet sent in the report. This size does not include the Report ID or the Packet Length header itself. During a data phase, a packet size of 0 indicates a data phase abort request from the receiver.

# Chapter 6 External memory support

# 6.1 Introduction

This section describes the external memory devices supported by the MCU flashloader. To use an external memory device correctly, the device must be enabled with the corresponding configuration profile. If the external memory device is not enabled, then it cannot be accessed by the flashloader. The MCU flashloader enables specific external memory devices using memory identifiers, as shown below.

| Table 46. | Memory | ID | for | external | memory | devices |
|-----------|--------|----|-----|----------|--------|---------|

| Memory identifier | External memory device              |
|-------------------|-------------------------------------|
| 0x01              | Serial NOR over QuadSPI module      |
| 0x08              | Parallel NOR over SEMC module       |
| 0x09              | Serial NOR over FlexSPI module      |
| 0x0a              | Serial NOR over SPIFI               |
| 0x100             | SLC raw NAND over SEMC module       |
| 0x101             | Serial NAND over FlexSPI module     |
| 0x110             | Serial NOR/EEPROM over LPSPI module |
| 0x111             | I2C NOR/EEPROM memory               |
| 0x120             | SD over uSDHC                       |
| 0x121             | eMMC over uSDHC                     |

# 6.2 Serial NOR Flash through FlexSPI

The MCU Flashloader supports read, write, and erase of external Serial NOR Flash devices via the FlexSPI Module. Before accessing Serial NOR Flash devices, the FlexSPI module must be configured properly using a simplified FlexSPI NOR Config option block or a complete 512-byte FlexSPI NOR Configuration Block. The flashloader can generate the 512-byte FlexSPI NOR Configuration Block for most Serial NOR Flash devices in the market. To protect Intellectual Property on external Serial NOR Flash, the Flashloader also supports image encryption and programming using OTPMK/SNVS keys if the chip includes the BEE or OTFAD module. See the Security Utilities and FlexSPI NOR On-chip OTFAD Pre-encryption Option Block chapters for additional information.

# 6.2.1 FlexSPI NOR Configuration Block

| Name    | Offset | Size (bytes) | Description              |
|---------|--------|--------------|--------------------------|
| Тад     | 0x000  | 4            | 0x42464346, ascii:"FCFB" |
| Version | 0x004  | 4            | 0x56010000               |
|         |        |              | [07:00] bugfix           |
|         |        |              | [15:08] minor            |

Table 47. Memory ID for external memory devices

| Name                | Offset | Size (bytes) | Description                                                                               |
|---------------------|--------|--------------|-------------------------------------------------------------------------------------------|
|                     |        |              | [23:16] major = 1                                                                         |
|                     |        |              | [31:24] ascii 'V'                                                                         |
| -                   | 0x008  | 4            | Reserved                                                                                  |
| readSampleClkSrc    | 0x00c  | 1            | 0 – Internal loopback                                                                     |
|                     |        |              | 1 – loopback from DQS pad                                                                 |
|                     |        |              | 3 – Flash provided DQS                                                                    |
| csHoldTime          | 0x00d  | 1            | Serial Flash CS Hold Time                                                                 |
|                     |        |              | Recommend default value is 0x03                                                           |
| csSetupTime         | 0x00e  | 1            | Serial Flash CS Setup Time                                                                |
|                     |        |              | Recommend default value is 0x03                                                           |
| columnAdressWidth   | 0x00f  | 1            | 3 – For<br>HyperFlash/HyperRAM                                                            |
|                     |        |              | 12/13 – For Serial NAND, see datasheet to find correct value                              |
|                     |        |              | 0 – Other devices                                                                         |
| deviceModeCfgEnable | 0x010  | 1            | Device Mode Configuration<br>Enable feature                                               |
|                     |        |              | 0 – Disabled                                                                              |
|                     |        |              | 1 – Enabled                                                                               |
| deviceModeType      | 0x011  | 1            | Specify the Configuration command type                                                    |
|                     |        |              | 0 - Generic Command                                                                       |
|                     |        |              | 1 - Quad Enable                                                                           |
|                     |        |              | 2 - SPI to OPI                                                                            |
|                     |        |              | Others - Reserved                                                                         |
| waitTimeCfgCommands | 0x012  | 2            | Wait time for all configuration commands, unit: 100us.                                    |
|                     |        |              | 0 - Use read status command<br>to determine the busy status<br>for configuration commands |
|                     |        |              | Others - Delay<br>"waitTimeCfgCommads"                                                    |

Table 47. Memory ID for external memory devices (continued)

| Name                 | Offset | Size (bytes) | Description                                                                             |
|----------------------|--------|--------------|-----------------------------------------------------------------------------------------|
|                      |        |              | * 100us for configuration commands                                                      |
| deviceModeSeq        | 0x014  | 4            | Sequence parameter for device mode configuration                                        |
|                      |        |              | [7:0] LUT sequence number                                                               |
|                      |        |              | [15:8] LUT sequence index for this sequence                                             |
|                      |        |              | [31:16] Reserved for future use                                                         |
| deviceModeArg        | 0x018  | 4            | Device Mode argument,<br>effective only when<br>deviceModeCfgEnable = 1                 |
| configCmdEnable      | 0x01c  | 1            | Config Command<br>Enable feature                                                        |
|                      |        |              | 0 – Disabled                                                                            |
|                      |        |              | 1 – Enabled                                                                             |
| configModeType       | 0x01d  | 3            | Configure mode type,<br>the same definition<br>as "deviceModeType"                      |
| configCmdSeqs        | 0x020  | 12           | Sequences for Config<br>Command, allow 4<br>separate configuration<br>command sequences |
| -                    | 0x02c  | 4            | Reserved                                                                                |
| cfgCmdArgs           | 0x030  | 12           | Arguments for each<br>separate configuration<br>command sequence                        |
| -                    | 0x03c  | 4            | Reserved                                                                                |
| controllerMiscOption | 0x040  | 4            | Bit0 – Enable differential clock                                                        |
|                      |        |              | Bit2 – Enable Parallel Mode                                                             |
|                      |        |              | Bit3 – Enable<br>Word Addressable                                                       |
|                      |        |              | Bit4 – Enable Safe Config Freq                                                          |
|                      |        |              | Bit5 – Enable Pad<br>Setting Override                                                   |
|                      |        |              | Bit6 – Enable DDR Mode                                                                  |
|                      |        |              | Others - Reserved                                                                       |

| Table 47. | Memory ID | for external | memory | devices | (continued) |
|-----------|-----------|--------------|--------|---------|-------------|
|-----------|-----------|--------------|--------|---------|-------------|

| Name                   | Offset | Size (bytes) | Description                                                                           |
|------------------------|--------|--------------|---------------------------------------------------------------------------------------|
| deviceType             | 0x044  | 1            | 1 - Serial NOR                                                                        |
|                        |        |              | 2 - Serial NAND                                                                       |
| sflashPadType          | 0x045  | 1            | 1 – Single pad                                                                        |
|                        |        |              | 2 – Dual pads                                                                         |
|                        |        |              | 4 – Quad pads                                                                         |
|                        |        |              | 8 – Octal pads                                                                        |
|                        |        |              | Others - Invalid value                                                                |
| serialClkFreq          | 0x046  | 1            | Device specific value, check<br>System Boot chapter in the<br>SoC RM for more details |
| lutCustomSeqEnable     | 0x047  | 1            | 0 - Use pre-defined LUT sequence index and number                                     |
|                        |        |              | 1 - Use LUT sequence<br>parameters provided in<br>this block                          |
| Reserved               | 0x048  | 8            | Reserved                                                                              |
| sflashA1Size           | 0x050  | 4            | For SPI NOR, need to fill with actual size                                            |
|                        |        |              | For SPI NAND, need to fill with actual size * 2                                       |
| sflashA2Size           | 0x054  | 4            | For SPI NOR, need to fill with actual size                                            |
|                        |        |              | For SPI NAND, need to fill with actual size * 2                                       |
| sflashB1Size           | 0x058  | 4            | For SPI NOR, need to fill with actual size                                            |
|                        |        |              | For SPI NAND, need to fill with actual size * 2                                       |
| sflashB2Size           | 0x05c  | 4            | For SPI NOR, need to fill with actual size                                            |
|                        |        |              | For SPI NAND, need to fill with actual size * 2                                       |
| csPadSettingOverride   | 0x060  | 4            | Set to 0 if it is not supported                                                       |
| sclkPadSettingOverride | 0x064  | 4            | Set to 0 if it is not supported                                                       |
| dataPadSettingOverride | 0x068  | 4            | Set to 0 if it is not supported                                                       |
| dqsPadSettingOverride  | 0x06c  | 4            | Set to 0 if it is not supported                                                       |

| Table 47. | Memory | ID for | external | memory | devices | (continued) |
|-----------|--------|--------|----------|--------|---------|-------------|
|-----------|--------|--------|----------|--------|---------|-------------|

| Name               | Offset | Size (bytes) | Description                                                                                                                                                          |
|--------------------|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| timeoutInMs        | 0x070  | 4            | Maximum wait time during read/write                                                                                                                                  |
|                    |        |              | Not used in ROM                                                                                                                                                      |
| commandInterval    | 0x074  | 4            | Unit: ns                                                                                                                                                             |
|                    |        |              | Currently, it is used<br>for SPI NAND at high<br>working frequency                                                                                                   |
| dataValidTime      | 0x078  | 4            | Time from clock edge to data valid edge, unit ns                                                                                                                     |
|                    |        |              | This field is used when the<br>FlexSPI Root clock is less<br>than 100MHz and the read<br>sample clock source is device<br>provided DQS signal without<br>CK2 support |
|                    |        |              | [31:16] data valid time for<br>DLLB in terms of 0.1ns                                                                                                                |
|                    |        |              | [15:0] data valid time for DLLA<br>in terms of 0.1ns                                                                                                                 |
| busyOffset         | 0x07c  | 2            | busy bit offset,<br>valid range :0-31                                                                                                                                |
| busyBitPolarity    | 0x07e  | 2            | 0 – busy bit is 1 if device<br>is busy                                                                                                                               |
|                    |        |              | 1 – busy bit is 0 if device<br>is busy                                                                                                                               |
| lookupTable        | 0x080  | 256          | Lookup table                                                                                                                                                         |
| lutCustomSeq       | 0x180  | 48           | Customized LUT sequence, see below table for details                                                                                                                 |
| -                  | 0x1b0  | 16           | Reserved                                                                                                                                                             |
| pageSize           | 0x1c0  | 4            | Flash Page size                                                                                                                                                      |
| sectorSize         | 0x1c4  | 4            | Flash Sector Size                                                                                                                                                    |
| ipCmdSerialClkFreq | 0x1c8  | 1            | IP Command Clock<br>Frequency, the same<br>definition as "serialClkFreq"                                                                                             |
| isUniformBlockSize | 0x1c9  | 1            | Sector / Block size is identical<br>or not                                                                                                                           |
| -                  | 0x1ca  | 2            | -                                                                                                                                                                    |
| serialNorType      | 0x1cc  | 1            | Serial NOR Flash Type:                                                                                                                                               |

| Name                 | Offset | Size (bytes) | Description                                                                                      |
|----------------------|--------|--------------|--------------------------------------------------------------------------------------------------|
|                      |        |              | 0 - Extended SPI                                                                                 |
|                      |        |              | 1 - HyperBus                                                                                     |
|                      |        |              | 2 - Octal DDR                                                                                    |
| needExitNoCmdMode    | 0x1cd  | 1            | Reserved, set to 0                                                                               |
| halfClkForNonReadCmd | 0x1ce  | 1            | Divide the clock for SDR command by 2                                                            |
|                      |        |              | Need to set for the device<br>that only supports DDR<br>read, other commands are<br>SDR commands |
| needrestorNoCmdMode  | 0x1cf  | 1            | Reserved, set 0                                                                                  |
| blockSize            | 0x1d0  | 4            | Flash Block size                                                                                 |
| -                    | 0x1d4  | 44           | Reserved                                                                                         |

#### Table 47. Memory ID for external memory devices (continued)

#### NOTE

To customize the LUT sequence for some specific device, users need to enable "**lutCustomSeqEnable**" and fill in corresponding "**lutCustomSeq**" field specified by the command index below.

For Serial (SPI) NOR, the pre-defined LUT index is as following:

| Table 48. Lo | okup table inc | lex pre-assignment | for FlexSPI NOR |
|--------------|----------------|--------------------|-----------------|
|--------------|----------------|--------------------|-----------------|

| Name           | Index in lookup table | Description                                               |  |
|----------------|-----------------------|-----------------------------------------------------------|--|
| Read           | 0                     | Read command Sequence                                     |  |
| ReadStatus     | 1                     | Read Status command                                       |  |
| ReadStatusXpi  | 2                     | Read Status command under OPI mode                        |  |
| WriteEnable    | 3                     | Write Enable command sequence                             |  |
| WriteEnableXpi | 4                     | Write Enable command under OPI mode                       |  |
| EraseSector    | 5                     | Erase Sector Command                                      |  |
| EraseBlock     | 8                     | Erase Block Command                                       |  |
| PageProgram    | 9                     | Page Program Command                                      |  |
| ChipErase      | 11                    | Full Chip Erase                                           |  |
| ExitNoCmd      | 15                    | Exit No Command Mode as needed                            |  |
| Reserved       | 6,7,10,12,13,14       | All reserved indexes can be freely used for other purpose |  |

# 6.2.2 FlexSPI NOR Configuration Option Block

The FlexSPI NOR Configuration Option Block is organized by 4-bit unit. It is expandable, and current definition of the block is as shown in the following table.

The Flashloader detects FNORCB using the read SFDP command supported by most flash devices that are JESD216(A/B)compliant. However, JESD216A/B only defines the dummy cycles for Quad SDR reads. In order to get the dummy cycles for DDR/DTR read mode, the flashloader supports auto probing by writing test patterns to offset 0x200 on the external memory devices. To get optimal timing, the readSampleClkSrc is set to 1 for Flash devices that do not support external provided DQS pad input. It is set to 3 for flash devices that do support external provided DQS pad input, such as HyperFlash. FlexSPI\_DQS pad is not used for any other purpose.

| Offset | Field    | Description                    |                                                   |                                                                                                                                                                                  |                                   |                             |                                                                                                                                                                                                                                                              |                                                                                     |                                                                                              |  |
|--------|----------|--------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--|
| 0      | Option0  |                                |                                                   |                                                                                                                                                                                  |                                   |                             |                                                                                                                                                                                                                                                              |                                                                                     |                                                                                              |  |
|        |          | TAG<br>[31:28]                 | Option size<br>[27:24]                            | Device<br>detection<br>type<br>[23:20]                                                                                                                                           | Query<br>CMD<br>Pad(s)<br>[19:16] | CMD<br>Pad(s)<br>[15:12]    | Quad<br>Enable<br>Type [11:8]                                                                                                                                                                                                                                | Misc [7:4]                                                                          | Max Freq<br>[3:0]                                                                            |  |
|        |          | 0x0C                           | Size in<br>bytes =<br>(Option<br>Size + 1) *<br>4 | 0 -<br>QuadSPI<br>SDR<br>1 -<br>QuadSPI<br>DDR<br>2 -<br>HyperFLA<br>SH 1V8<br>3 -<br>HyperFLA<br>SH 3V<br>4 - MXIC<br>OPI DDR<br>6 - Micron<br>OPI DDR<br>8 - Adesto<br>OPI DDR | 0 - 1<br>2 - 4<br>3 - 8           | 0 - 1<br>2 - 4<br>3 - 8     | <ol> <li>1 - QE bit is<br/>bit 6 in<br/>StatusReg</li> <li>2 - QE bit is<br/>bit 1 in<br/>StatusReg</li> <li>3 - QE bit is<br/>in bit7 in<br/>StatusReg</li> <li>4 - QE bit is<br/>bit 1 in<br/>StatusReg</li> <li>enable<br/>command<br/>is 0x31</li> </ol> | order is<br>swapped<br>under OPI<br>DDR mode<br>5 - Internal<br>loopback<br>6 - SPI | Device-<br>specific,<br>see<br>System<br>Boot<br>chapter in<br>SoC RM for<br>more<br>details |  |
| 4      | Option1  |                                |                                                   |                                                                                                                                                                                  |                                   |                             |                                                                                                                                                                                                                                                              |                                                                                     |                                                                                              |  |
|        | Optional | flash_conne                    | ction[31:28]                                      | drive_strer                                                                                                                                                                      | ngth[27:24]                       | Reserved                    | Reserved [15:8]                                                                                                                                                                                                                                              |                                                                                     | Dummy Cycle [7:0]                                                                            |  |
|        |          | 0 - PortA<br>1 - Parallel Mode | of FlexSPI                                        | The drive strength<br>of FlexSPI pad.<br>See IOMUXC chapter                                                                                                                      |                                   | dqs_pinmux_group<br>[23:20] |                                                                                                                                                                                                                                                              | p-probing<br>le                                                                     |                                                                                              |  |
|        |          | 2 - PORTB                      |                                                   | in SoC RM<br>more deta                                                                                                                                                           | 1 for                             | 1 - second                  | 0 - primary group<br>1 - secondary group                                                                                                                                                                                                                     |                                                                                     | mmy cycles<br>data sheet                                                                     |  |
|        |          |                                |                                                   |                                                                                                                                                                                  |                                   |                             | oup [19:16]                                                                                                                                                                                                                                                  |                                                                                     |                                                                                              |  |
|        |          |                                |                                                   |                                                                                                                                                                                  |                                   | 0 - primary<br>1 - second   |                                                                                                                                                                                                                                                              |                                                                                     |                                                                                              |  |
|        |          |                                |                                                   |                                                                                                                                                                                  |                                   |                             | - , <u>j</u>                                                                                                                                                                                                                                                 |                                                                                     |                                                                                              |  |

| Table 49. | FlexSPI NOF  | R Configuration | Option Block |
|-----------|--------------|-----------------|--------------|
|           | 110/01/11101 | v oormgaraaon   | opaon bioon  |

• Tag - Fixed as 0x0C.

- Option Size Provide scalability for future use, the option block size equals to (Option size + 1) \* 4 bytes.
- Device Detection type Software defined device types used for config block auto detection.
- Query Command Pad(s) Command pads (1/4/8) for the SFDP command.
- CMD pad(s) Commands pads for the Flash device (1/4/8). For devices that use 1-1-4, 1-4-4, 1-1-8, or 1-8-8 mode, CMD pad(s) value is always 0x0. For devices that only support 4-4-4 mode for high performance, CMD pads value is 2. For devices that only support 8-8-8 mode for high performance, CMD pads value is 3.
- Quad Enable Type Specify the Quad Enable sequence. Only applicable for devices that are JESD216-compliant. This field is ignored if device supports JESD216A or later version.
- · Misc Specify miscellaneous mode for selected flash type.
- · Max Frequency The maximum frequency for the specified flash device.
- Dummy Cycle User provided dummy cycles for SDR/DDR read command.

6.2.2.1 Typical use cases for FlexSPI NOR Configuration Block

- QuadSPI NOR Quad SDR Read: option0 = 0xc0000006 (100 MHz).
- QuadSPI NOR Quad DDR Read: option0 = 0xc0100003 (60 MHz).
- HyperFlash 1V8: option0 = 0xc0233007 (133 MHz).
- HyperFlash 3V0: option0 = 0xc0333006 (100 MHz).
- MXIC OPI DDR: option0 = 0xc0403006 (100 MHz), for devices where data order is consistent between SDR mode and DDR mode, option0 = 0xc0403036, for device that the data order is inconsistent between SDR mode and DDR mode.
- Micron Octal DDR: option0=0xc0600006 (100 MHz).
- Micron OPI DDR: option0=0xc0603006 (100 MHz), SPI->OPI DDR.
- Micron OPI DDR (DDR read enabled by default): option0=0xc0633006(100 MHz).
- Adesto OPI DDR: option0=0xc0803007(133 MHz).

#### 6.2.2.2 Programming Serial NOR Flash device using FlexSPI NOR Configuration Option Block

The MCU Flashloader supports generating complete FNORCB using the configure-memory command. It also supports programming the generated FNORCB to the correct offset (0x0/0x400, depending on the MCU model) of the flash memory using a specific option "0xF000000F". An example for configuring and accessing HyperFlash (assuming it is a blank HyperFlash device) is mentioned below.

blhost -u -- fill-memory 0x2000 0x04 0xc0233007 (write option block to SRAM address 0x2000) blhost -u -- configure-memory 0x09 0x2000 (configure HyperFLASH using option block) blhost -u -- fill-memory 0x3000 0x04 0xf000000f (write specific option to SRAM address 0x3000) blhost -u -- configure-memory 0x09 0x3000 (program FNORCB to the correct offset of HyperFLASH) blhost -u -- write-memory <addr> image.bin

#### 6.2.2.3 Select the FLEXSPI instance

The MCU Flashloader supports selecting the FLEXSPI instance via 0xcf90000<x> on the SoC which supports multiple FLEXSPI instances, here the x is the index of the FLEXSPI instance.

Take RT1170 as an example, below is the sequence to select the FLEXSPI instance via the Flashloader:

```
blhost -u -- fill-memory 0x2000 4 0xcf900001
blhost -u -- configure-memory 9 0x2000
```

## 6.2.2.4 FlexSPI Instance Selection using FlexSPI NOR Configuration Option Block

For certain MCU parts, multiple instances are available. The MCU Flashloader supports instance selection via the FlexSPI NOR Configuration Option Block.

#### Table 50. FlexSPI NOR Configuration Option Block option

| Offset | Field   | Description |               |                                                                             |  |
|--------|---------|-------------|---------------|-----------------------------------------------------------------------------|--|
| 0      | Option0 | TAG[31:20]  | Instance[3:0] |                                                                             |  |
|        |         | 0xCF9       | Set 0         | 1 - Instance 1 selected<br>2 - Instance 2 selected<br>Otherwise - Undefined |  |

Below is an example of instance selection.

blhost -u -- fill-memory 0x20000000 4 0xcf900002 (Instance 2 to be chosen)

blhost -u -- configure-memory 9 0x20000000 (Issue the option)

If an instance selection option is issued, it is highly recommended to perform a thorough FlexSPI NOR configuration just following the selection.

NOTE -

This section applies to RT1176 Flashloader only.

## 6.2.3 FlexSPI NOR On-chip OTFAD Pre-encryption Option Block

OTFAD module performs in-place decryption of a pre-encrypted boot image in a serial NOR flash via FlexSPI. When an SNVS key is intended to be the OTFAD KEK, the pre-encryption has to be done on-chip and the flow is implemented in the MCU flashloader as a reference. Prior to the on-chip encryption, the On-chip OTFAD Pre-encryption Option Block is required for the flashloader.

The definition of the option block is shown in the following table.

| Offset | Field  | Descriptio     | Description         |                                                                           |                                                                |                                                  |  |
|--------|--------|----------------|---------------------|---------------------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------|--|
| 0      | Option |                |                     |                                                                           |                                                                |                                                  |  |
|        |        | TAG<br>[31:28] | Reserved<br>[27:16] | SNVS<br>High 128b<br>Selected<br>[15:12]                                  | Context<br>Count<br>[11:8]                                     | Keyblob<br>Offset in<br>256k [7:0]               |  |
|        |        | 0x0E           |                     | 0 -<br>SNVS[12<br>7:0]<br>1 -<br>SNVS[25<br>5:128]<br>Else -<br>Forbidden | 1,2,3,4 –<br>OTFAD<br>context<br>number<br>Else -<br>Forbidden | OTFAD<br>keyblob<br>storage<br>offset in<br>256k |  |

| Offset | Field                   | Description                                                                 |
|--------|-------------------------|-----------------------------------------------------------------------------|
| 4      | Context 1<br>Start Addr | Bus address of the mandatory first context's start. For example, 0x60001000 |
| 8      | Context 1 End Addr      | Bus address of the mandatory first context's end. For example, 0x60001fff   |
| 12     | Context 2<br>Start Addr | Bus address of the optional 2nd context's start. For example, 0x60002000    |
| 16     | Context 2 End Addr      | Bus address of the optional 2nd context's end. For example, 0x60002fff      |
| 20     | Context 3<br>Start Addr | Bus address of the optional 3rd context's start. For example, 0x60003000    |
| 24     | Context 3 End Addr      | Bus address of the optional 3rd context's end. For example, 0x60003fff      |
| 28     | Context 4<br>Start Addr | Bus address of the optional 4th context's start. For example, 0x60004000    |
| 32     | Context 4 End Addr      | Bus address of the optional 4th context's end. For example, 0x60007fff      |

Table 51. FlexSPI NOR Configuration Option Block (continued)

- · Tag Fixed as 0x0E.
- SNVS High 128b Selected Decides which part of SNVS is selected as the KEK. 0 stands for SNVS[127:0] and 1 for SNVS[255:128]. The given value should be equivalent to the eFuse OTFAD\_KEY\_SEL
- Context Count Number of OTFAD contexts following the option block. There should be 1 to 4 contexts
- Keyblob Offset in 256k Specify the OTFAD keyblob storage offset in 256k from the base address of FlexSPI NOR flash. Typically, 0 is used with the pre-encryption of a normal boot image, and a non-zero value with a redundant boot image. The given value should be equivalent to the eFuse XSPI\_FLASH\_SEC\_IMG\_OFFSET\_VALUE
- Context # Start Addr AHB bus address of the corresponding context's start. The address should be 1k-aligned
- Context # End Addr AHB bus address of the corresponding context's end. The address plus 1 should be 1k-aligned. There is at least one context so start and end addresses of context 1 must exist. The segment specified in a context should be within the FlexSPI NOR flash's address space, and should not overlap another segment or the keyblob

NOTE This section is applicable to RT1011 Flashloader only.

#### 6.2.3.1 On-chip pre-encryption using the Option Block

An example of configuring and accessing a blank serial NOR flash is given below. Prior to the example, the flash should have been configured as stated in FlexSPI NOR Configuration Block

```
blhost -u -- fill-memory 0x3000 0x04 0xe0001100 (context count is 1)
blhost -u -- fill-memory 0x3004 4 0x60001000 (context 1 start addr, 2 does not exist)
blhost -u -- fill-memory 0x3008 4 0x6000ffff (context 1 end addr)
blhost -u -- configure-memory 9 0x3000 (configure the flash)
```

Once configuration is complete, the flashloader generates an OTFAD keyblob, encrypts it with the KEK, and programs it to the correct location of a serial NOR flash (typically offset 0x0 from the base address of FlexSPI NOR flash). For confidentiality, the AES-CTR keys and counters in the keyblob is randomly generated with TRNG instead of specified manually.

blhost -u -- write-memory 0x60001000 image.bin (plaintext image encrypted and programmed)

Data to be written to the address space 0x60001000~0x6000ffff is automatically encrypted before being programmed.

Below is another example where the Keyblob Offset in 256k field is non-zero.

```
blhost -u -- fill-memory 0x3000 0x04 0xe0001101 (256k offset)
blhost -u -- fill-memory 0x3004 4 0x60001000 (no offset on context addresses)
blhost -u -- fill-memory 0x3008 4 0x6000ffff
blhost -u -- configure-memory 9 0x3000
```

The OTFAD keyblob is now programmed with an extra 256k (0x40000) offset. It is necessary that the FNORCB be programmed with the identical offset, so it is highly recommended that the FNORCB be embedded in image.bin at the correct offset.

blhost -u -- write-memory 0x60041000 image.bin (also be programmed with the identical offset)

**NOTE** SNVS keys are constantly 0 if HAB is open. To obtain full confidentiality, the flow above should be performed on a HAB-closed part with a signed flashloader. In this case, the bootable image.bin should also be pre-signed.

# 6.3 Serial NAND Flash through FlexSPI

Some MCUs support booting from Serial NAND Flash devices via BootROM. The MCU Flashloader works as a companion to program the boot image into the Serial NAND. The Flashloader supports generating corresponding boot data structures like the FlexSPI NAND Firmware Configuration Block (FCB) and Discovered Bad Block Table (DBBT) required by the BootROM. See the System Boot Chapter in the device reference manual for details regarding FlexSPI NAND boot flow. This chapter only focuses on generating FCB, DBBT, and programming FCB, DBBT, and boot images using Flashloader.

The Flashloader can configure Serial NAND devices using FCB, or a simplified FCB option block. The Flashloader can generate a complete FCB based on the simplified FCB option block.

## 6.3.1 FlexSPI NAND Firmware Configuration Block (FCB)

FCB is a 1024-byte data structure that contains the optimum NAND timings, page address of Discovered Bad Block Table (DBBT) Search Area firmware info (including the start page address and page count), and more.

| Name                    | Offset | Size (bytes) | Description                                                                                                                               |
|-------------------------|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| crcChecksum             | 0x000  | 4            | Checksum                                                                                                                                  |
| fingerprint             | 0x004  | 4            | 0x4E46_4342<br>ASCII: "NFCB"                                                                                                              |
| version                 | 0x008  | 4            | 0x0000_0001                                                                                                                               |
| DBBTSearchStartPa<br>ge | 0x00c  | 4            | Start Page address for bad block table search area                                                                                        |
| searchStride            | 0x010  | 2            | Search stride for DBBT and FCB search<br>Not used by ROM, max value is defined in Fusemap. See the<br>Fusemap in SoC RM for more details. |
| searchCount             | 0x012  | 2            | Copies on DBBT and FCB<br>Not used by ROM, max value is defined in Fusemap. See the<br>Fusemap in SoC RM for more details.                |

Table 52. FlexSPI NAND Firmware Configuration Block Definition

| Name               | Offset | Size (bytes) | Description                                  |             |                             |  |
|--------------------|--------|--------------|----------------------------------------------|-------------|-----------------------------|--|
| firmwareCopies     | 0x014  | 4            | Firmware copies<br>Valid range 1-8           |             |                             |  |
| Reserved           | 0x018  | 40           | Reserved for future use<br>Must be set to 0  |             |                             |  |
| firmwareInfoTable  | 0x40   | 64           | This table consists of (up to 8 entries):    |             |                             |  |
|                    |        |              | Field                                        | Size(Bytes) | Description                 |  |
|                    |        |              | StartPage                                    | 4           | Start page of this firmware |  |
|                    |        |              | pageCount                                    | 4           | Pages in this firmware      |  |
| Reserved           | 0x080  | 128          | Reserved<br>Must be set to 0                 |             |                             |  |
| spiNandConfigBlock | 0x100  | 512          | Serial NAND configuration block over FlexSPI |             |                             |  |
| Reserved           | 0x300  | 256          | Reserved<br>Must be set to 0                 |             |                             |  |

Table 52. FlexSPI NAND Firmware Configuration Block Definition (continued)

# 6.3.2 FlexSPI NAND Configuration Block

The optimum Serial NAND parameters are defined in FlexSPI NAND Configuration Block (FNANDCB). FNANDCB is a 512-byte data structure as shown in the following table.

| Table 53. FlexSPI NAND Configuration Block |
|--------------------------------------------|
|--------------------------------------------|

| Name             | Offset | Size (bytes) | Description                                                                         |
|------------------|--------|--------------|-------------------------------------------------------------------------------------|
| memCfg           | 0x00   | 480          | The same definition as the<br>first 480 bytes in FlexSPI NOR<br>Configuration Block |
| pageDataSize     | 0x1c0  | 480          | Page size in bytes. In general,<br>it is 2048 or 4096                               |
| pageTotalSize    | 0x1c4  | 4            | It equals to 2 ^ width of column address                                            |
| pagesPerBlock    | 0x1c8  | 4            | Pages per Block                                                                     |
| bypassReadStatus | 0x1cc  | 1            | 0 - Perform Read Status<br>1 - Bypass Read Status                                   |
| bypassEccRead    | 0x1cd  | 1            | 0 - Perform ECC Read                                                                |

| Name                 | Offset | Size (bytes) | Description                                                                           |
|----------------------|--------|--------------|---------------------------------------------------------------------------------------|
|                      |        |              | 1 - Bypass ECC Read                                                                   |
| hasMultiPlanes       | 0x1ce  | 1            | 0 - Device has only 1 plane                                                           |
|                      |        |              | 1 - Device has 2 planes                                                               |
| -                    | 0x1cf  | 1            | Reserved                                                                              |
| eccCheckCustomEnable | 0x1d0  | 1            | 0 - Use the commonly<br>used ECC check command<br>and masks                           |
|                      |        |              | 1 - Use ECC check<br>related masks provide in this<br>configuration block             |
| ipCmdSerialClkFreq   | 0x1d1  | 1            | Chip specific value, set to 0                                                         |
| readPageTimeUs       | 0x1d2  | 2            | Wait time during page<br>read, only effective if<br>"bypassReadStatus" is set to 1    |
| eccStatusMask        | 0x1d4  | 4            | ECC status mask,<br>only effective if<br>"eccCheckCustomEnable" is<br>set to 1        |
| eccFailureMask       | 0x1d8  | 4            | ECC Check Failure<br>mask, only effective if<br>"eccCheckCustomEnable" is<br>set to 1 |
| blocksPerDevice      | 0x1dc  | 4            | Blocks in a Serial<br>NAND device                                                     |
| -                    | 0x1e0  | 32           | Reserved                                                                              |

Table 53. FlexSPI NAND Configuration Block Definition (continued)

NOTE

For Serial (SPI) NAND, the pre-defined LUT index is as follows:

| Table 54. | Lookup Table | index pre-as | ssianment for       | FlexSPI |
|-----------|--------------|--------------|---------------------|---------|
|           |              |              | ooigi iii iioi iioi |         |

| Command Index | Name          | Index in lookup table | Description        |
|---------------|---------------|-----------------------|--------------------|
| 0             | ReadFromCache | 0                     | Read From cache    |
| 1             | ReadStatus    | 1                     | Read Status        |
| 2             | WriteEnable   | 3                     | Write Enable       |
| 3             | BlockErase    | 5                     | Erase block        |
| 4             | ProgramLoad   | 9                     | Program Load       |
| 5             | ReadPage      | 11                    | Read page to cache |
| 6             | ReadEccStatus | 13                    | Read ECC Status    |

| Command Index | Name             | Index in lookup table | Description                                                |
|---------------|------------------|-----------------------|------------------------------------------------------------|
| 7             | ProgramExecute   | 14                    | Program Execute                                            |
| 8             | ReadFromCacheOdd | 4                     | Read from Cache while page in odd plane                    |
| 9             | ProgramLoadOdd   | 10                    | -                                                          |
| -             | Reserved         | 2, 6, 7, 8, 12, 15    | All reserved indexes can be freely used for other purposes |

Table 54. Lookup Table index pre-assignment for FlexSPI (continued)

## 6.3.3 FlexSPI NAND FCB option block

FlexSPI NAND FCB option block defines the major parameters required by FCB, such as image info. The detailed configuration block definition is shown below.

Table 55. FlexSPI NAND FCB option block

| Offset | Field          | Size | Description     |                      |                                                              |  |  |
|--------|----------------|------|-----------------|----------------------|--------------------------------------------------------------|--|--|
| 0      | option0        | 4    |                 |                      |                                                              |  |  |
|        |                |      | Offset          | Field                | Description                                                  |  |  |
|        |                |      | 31:28           | tag                  | Fixed to 0x0C                                                |  |  |
|        |                |      | 27:24           | searchCount          | Valid value:                                                 |  |  |
|        |                |      |                 |                      | 1-4                                                          |  |  |
|        |                |      | 23:20           | searchStride         | 0 - 64 pages                                                 |  |  |
|        |                |      |                 |                      | 1 - 128 pages                                                |  |  |
|        |                |      |                 |                      | 2 - 256 pages                                                |  |  |
|        |                |      |                 |                      | 3 - 32 pages                                                 |  |  |
|        |                |      |                 |                      | NOTE                                                         |  |  |
|        |                |      |                 |                      | This field is                                                |  |  |
|        |                |      |                 |                      | aligned with<br>Fuse definition                              |  |  |
|        |                |      | 19:12           | Reserved             | -                                                            |  |  |
|        |                |      | 11:8            | addressType          | 0 - byte address                                             |  |  |
|        |                |      |                 |                      | 1 - block address                                            |  |  |
|        |                |      | 7:4             | Reserved             | -                                                            |  |  |
|        |                |      | 3:0             | Option size          | Option size in longword,<br>Min size is 3, Max size<br>is 10 |  |  |
| 4      | nandOptionAddr | 4    | Address of NANE | option defined above |                                                              |  |  |

| Field     | Size | Description                                                |                                                             |                                                                                   |  |
|-----------|------|------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| imageInfo | 4-32 | Image info is a map of below info, maximum entry size is 8 |                                                             |                                                                                   |  |
|           |      | Field Size Description                                     |                                                             |                                                                                   |  |
|           |      | blockCount                                                 | 2                                                           | Maximum allowed blocks for this image                                             |  |
|           |      | blockId                                                    | 2                                                           | Start block index for this image                                                  |  |
|           |      |                                                            | imageInfo 4-32 Image info is a map o<br>Field<br>blockCount | imageInfo 4-32 Image info is a map of below info, maximum Field Size blockCount 2 |  |

Table 55. FlexSPI NAND FCB option block (continued)

#### NOTE

- "searchCount" should match the one provisioned in eFUSE
- "searchStride" should match the one provisioned in eFUSE
- "addressType" specifies the address type for the start address of erase, write and read operation in Flashloader
- · "Option size" specifies the total size of the option block size in longwords
- "nandOptionAddr" specifies the address that stores FlexSPI NAND Configuration Option
- "imageInfo" is an array that holds each image info used during boot. For example, 0x00040002 means the block Id is 4, maximum allowed block count is 2

## 6.3.4 FlexSPI NAND Configuration Option Block

Currently, all Serial NAND devices in the market support the same commands. The differences are the NAND size, page size, and more. This option block focuses on these differences, and the detailed block definitions are shown below:

| Offset | Field    | Description    | Description                                       |                      |                                               |                                   |                                        |                                   |                                     |
|--------|----------|----------------|---------------------------------------------------|----------------------|-----------------------------------------------|-----------------------------------|----------------------------------------|-----------------------------------|-------------------------------------|
| 0      | option 0 |                |                                                   |                      |                                               |                                   |                                        |                                   |                                     |
|        |          | TAG<br>[31:28] | Option<br>size<br>[27:24]                         | Reserve<br>d [23:20] | Flash<br>size<br>[19:16]                      | Has<br>multiplan<br>es<br>[15:12] | Pages<br>Per<br>Block<br>[11:8]        | Page<br>Size<br>(Kbytes)<br>[7:4] | Max<br>Freq<br>[3:0]                |
|        |          | 0x0c           | Size in<br>bytes =<br>(Option<br>Size + 1)<br>* 4 | 0                    | 0 -<br>512Mb<br>1 - 1Gb<br>2 - 2Gb<br>4 - 4Gb | 0 - 1<br>plane<br>1 - 2<br>planes | 0 - 64<br>1 - 128<br>2 - 256<br>3 - 32 | 2 - 2KB<br>4 - 4KB                | NAND<br>Freq:<br>Device<br>specific |
| 4      | option 1 | This field     | is optional,                                      | it is effecti        | ve if optior                                  | n size in opt                     | ion0 is gre                            | ater than 0                       |                                     |

Table 56. FlexSPI NAND Configuration Option Block

| Offset | Field | Description                 | Description                              |                         |                                                                                                                                                   |  |  |
|--------|-------|-----------------------------|------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |       |                             |                                          |                         |                                                                                                                                                   |  |  |
|        |       | Flash_connection<br>[31:28] | Pinmux_group<br>[27:24]                  | Reserved [23:8]         | Manufacturer<br>ID [7:0]                                                                                                                          |  |  |
|        |       | 0 - PortA<br>2 - PortB      | 0 - Primary group<br>1 - Secondary group | Reserved for future use | Actual<br>Manufacturer ID<br>provided in Serial<br>NAND device<br>datasheet. For<br>example, 0x2C is<br>the manufacture ID<br>assigned to Micron. |  |  |

| Table 56. FlexSPI NANE | Configuration Option | Block (continued) |
|------------------------|----------------------|-------------------|
|------------------------|----------------------|-------------------|

## 6.3.5 Example usage with Flashloader

Flashloader can generate FCB and DBBT based on a specified FlexSPI NAND FCB option block.

Assuming FCB parameters are:

- FCB and DBBT copies are 2.
- Firmware copies are 2.
- Firmware 0 starts at block 4, maximum block count is 2.
- Firmware 1 starts at block 8, maximum block count is 2.

Assuming Serial NAND parameters are:

- · Flash size: 1 Gb
- Plane number:1
- Pages Per Block: 64
- Page Size: 2 KB
- Maximum Frequency: 80 MHz

Below are the example steps for generating FlexSPI NAND Configuration Option block.

Write FlexSPI NAND Configuration Option Block to SRAM:

blhost -u -- fill-memory 0x2030 0x4 0xc0010025

Write FlexSPI NAND FCB Option Block to SRAM:

```
blhost -u -- fill-memory 0x2000 0x4 0xc2000104
blhost -u -- fill-memory 0x2004 0x4 0x2030 // nandOptionAddr = 0x2030
blhost -u -- fill-memory 0x2008 0x4 0x00040002 // blockId = 4, blockCount = 2
blhost -u -- fill-memory 0x200c 0x4 0x00080002 // blockId = 8, blockCount = 2
```

Configure Serial NAND using FCB option and NAND option:

```
blhost -u -- configure-memory 0x101 0x2000
```

Erase and Program image

```
blhost -u -- flash-erase-region 0x4 0x2 0x101 // Erase 2 blocks starting from block 4
blhost -u -- write-memory 0x4 image.bin 0x101 // Program image.bin to block 4
blhost -u -- flash-erase-region 0x8 0x2 0x101 // Erase 2 blocks starting from block 8
blhost -u -- write-memory 0x8 image.bin 0x101 // Program image.bin to block 8
```

## 6.4 SD/eMMC through uSDHC

Some MCUs supports booting from SD/eMMC devices via BootROM. The MCU Flashloader supports flashing the boot image into the SD/eMMC devices. This section explains the usage of SD/eMMC via Flashloader.

#### 6.4.1 SD Configuration Block

The SD Card must be initialized before the Flashloader accesses SD memory. The SD configuration block is a combination of several necessary SD configurations used by Flashloader to initialize the card.

Table 6-10 lists the detailed description of each bits in the SD configuration block.

| Word index | Bit field | Name          | Description                                                                |
|------------|-----------|---------------|----------------------------------------------------------------------------|
| Word0      | [31:28]   | TAG           | SD configuration block tag<br>used to mark if the block is<br>valid or not |
|            |           |               | 0xD: Valid block                                                           |
|            |           |               | Others: Invalid                                                            |
|            | [27:26]   | RSV           | 0x0                                                                        |
|            | [25:24]   | PWR_DOWN_TIME | SD power down delay time before power up the SD card                       |
|            |           |               | Only valid when<br>PWR_CYCLE_ENABLE<br>is enable                           |
|            |           |               | 0: 20 ms                                                                   |
|            |           |               | 1: 10 ms                                                                   |
|            |           |               | 2: 5 ms                                                                    |
|            |           |               | 3: 2.5 ms                                                                  |
|            | 23        | PWR_POLARITY  | SD power control polarity                                                  |

Table 57. SD Configuration Block Definition

| Table 57. | SD | Configuration | <b>Block Definition</b> | (continued) |
|-----------|----|---------------|-------------------------|-------------|
|-----------|----|---------------|-------------------------|-------------|

|       |         |                  | 1                                                                            |
|-------|---------|------------------|------------------------------------------------------------------------------|
|       |         |                  | Only valid when<br>PWR_CYCLE_ENABLE<br>is enabled                            |
|       |         |                  | 0: Power down when<br>uSDHC.RST is set low                                   |
|       |         |                  | 1: Power down when<br>uSDHC.RST is set high                                  |
|       | [22:21] | RSV              | 0x0                                                                          |
|       | 20      | PWR_UP_TIME      | SD power up delay time to wait voltage regulator output stable               |
|       |         |                  | Only valid when<br>PWR_CYCLE_ENABLE<br>is enabled                            |
|       |         |                  | 0: 5 ms                                                                      |
|       |         |                  | 1: 2.5 ms                                                                    |
|       | 19      | PWR_CYCLE_ENABLE | Executes a power cycle<br>before starting the initialization<br>progress [1] |
|       |         |                  | 0: Disable for non-UHSI<br>timing [2]                                        |
|       |         |                  | Enable for UHSI timing                                                       |
|       |         |                  | 1: Enable                                                                    |
|       | [18:15] | RSV              | 0x0                                                                          |
|       | [14:12] | TIMING_INTERFACE | SD speed timing selection.                                                   |
|       |         |                  | 0: Normal/SDR12                                                              |
|       |         |                  | 1: High/SDR25                                                                |
|       |         |                  | 2: SDR50                                                                     |
|       |         |                  | 3: SDR104                                                                    |
|       |         |                  | 4: DDR50 (not support yet)                                                   |
|       |         |                  | 5-7: Reserved                                                                |
|       | [11:9]  | RSV              | 0x0                                                                          |
|       | 8       | BUS_WIDTH        | SD bus width selection.                                                      |
|       |         |                  | 0: 1 bit                                                                     |
|       |         |                  | 4-bit for UHSI timing                                                        |
|       |         |                  | 1: 4 bit                                                                     |
|       | [7:0]   | RSV              | 0x0                                                                          |
| Word1 | [31:0]  | RSV              | 0x0                                                                          |

NOTE

Flashloader toggles the uSDHC.RST pin to execute the power cycle progress. This needs board-level hardware support. If the hardware does not support controlling SD power, the power cycle progress cannot fully reset the SD card.

NOTE UHSI timing includes SDR50, SDR104, and DDR50.

## 6.4.2 Example usage with Flashloader

This section uses the SDR25 timing and 4-bit bus width as an example. To make sure the SD card is reset before the initialization progress, it is suggested to enable the power cycle. Choose the default settings of power cycle.

The hex of the SD configuration block is 0xD0082100.

· Write the configuration block to MCU internal RAM.

blhost -u -- fill-memory 0x2000000 0x4 0xD0082100

RAM address 0x20000000 is selected as an example. User can select any RAM position which is available to use. The user can also select an address located at an XIP external memory, such as Flex SPI NOR Flash.

· Execute the initialization progress using configure-memory command.

blhost -u -- configure-memory 0x120 0x20000000

0x120 is the memory ID of eMMC card device. If the eMMC card is initialized successfully, then a "Success" message is received and SD memory is available to be accessed by Flashloader. If an error occurred, see *Chapter 8 Appendix A, "Status and error codes".* for debugging.

After SD is initialized, the user can use get the property 25 command to check the SD card capacity.

blhost -u -- get-property 25 0x120

• To program the boot image, the user needs to erase the SD card memory first, then program the image.

blhost -u -- flash-erase-region 0x0 0x1000 0x120 blhost -u -- write-memory 0x400 C:\Image\bootImage.bin 0x120

0x0 at the flash-erase-region command line and 0x400 at the write-memory command line is the byte offset of the SD memory, not the sector offset. That means 4 K bytes starting from the start address of SD memory are erased, then the boot image *C:I/magelbootImage.bin* is written to the space starting from SD second Block.

• To check if the boot image is programmed successfully, the user can read the data out.

blhost -u -- read-memory 0x400 0x1000 0x120

In most cases, the user does not need to read the data out to verify if the boot image is written successfully or not. Flashloader guarantees this.

#### 6.4.3 eMMC Configuration Block

Similar to the SD Card, eMMC also must be initialized before accessing it. The eMMC configuration block is used to tell Flashloader how to initialize the eMMC device. To use the fast boot feature offered by BootROM, eMMC also must be pre-configured. The fast boot configuration is also included in the eMMC configuration block.

The below table lists the detailed description of each bits in the eMMC configuration block.

### Table 58. eMMC Configuration Block Definition

| Word index | Bit field | Name                  | Description                                                                  |
|------------|-----------|-----------------------|------------------------------------------------------------------------------|
| Word0      | [31:28]   | TAG                   | eMMC configuration block tag<br>used to mark if the block is<br>valid or not |
|            |           |                       | 0xC: Valid block                                                             |
|            |           |                       | Others: Invalid                                                              |
|            | 27        | RSV                   | 0x0                                                                          |
|            | [26:24]   | PARTITION_ACCESS      | Select eMMC partition which<br>the Flashloader write the<br>image or data to |
|            |           |                       | 0: User data area                                                            |
|            |           |                       | 1: Boot partition 1                                                          |
|            |           |                       | 2: Boot partition 2                                                          |
|            |           |                       | 3: RPMB                                                                      |
|            |           |                       | 4: General Purpose parition 1                                                |
|            |           |                       | 5: General Purpose parition 2                                                |
|            |           |                       | 6: General Purpose parition 3                                                |
|            |           |                       | 7: General Purpose parition 4                                                |
|            | 23        | RSV                   | 0x0                                                                          |
|            | [22:20]   | BOOT_PARTITION_ENABLE | Select the boot partition used for fast boot                                 |
|            |           |                       | Only valid when<br>BOOT_CONFIG_ENABLE<br>is set                              |
|            |           |                       | 0: Not enabled                                                               |
|            |           |                       | 1: Boot partition 1                                                          |
|            |           |                       | 2: Boot partition 2                                                          |
|            |           |                       | 3-6: Reserved                                                                |
|            |           |                       | 7: User data area                                                            |
|            | [19:18]   | RSV                   | 0x0                                                                          |
|            | [17:16]   | BOOT_BUS_WIDTH        | Select the bus width used for fast boot                                      |
|            |           |                       | 0: x1(SDR),                                                                  |
|            |           |                       | x4(DDR)                                                                      |
|            |           |                       | 1: x4(SDR,DDR)                                                               |
|            |           |                       |                                                                              |

Table 58. eMMC Configuration Block Definition (continued)

|         |                               | 3: Reserved                                                            |
|---------|-------------------------------|------------------------------------------------------------------------|
| [15:12] | TIMING_INTERFACE              | Select the bus timing<br>when Flashloader accesses<br>eMMC memory      |
|         |                               | 0: Normal                                                              |
|         |                               | 1: HS                                                                  |
|         |                               | 2: HS200(Not support yet)                                              |
|         |                               | 3: HS400(Not support yet)                                              |
|         |                               | 4-15: Reserved                                                         |
| [11:8]  | BUS_WIDTH                     | Select the bus width<br>when Flashloader accesses<br>eMMC memory       |
|         |                               | 0: x1 SDR                                                              |
|         |                               | 1: x4 SDR                                                              |
|         |                               | 2: x8 SDR                                                              |
|         |                               | 3-4: Reserved                                                          |
|         |                               | 5: x4 DDR                                                              |
|         |                               | 6: x8 DDR                                                              |
|         |                               | 7-15: Reserved                                                         |
| [7:6]   | RSV                           | 0x0                                                                    |
| [5:4]   | BOOT_MODE                     | 0: Normal                                                              |
|         |                               | 1: HS                                                                  |
|         |                               | 2: DDR                                                                 |
|         |                               | 3: Reserved                                                            |
| 3       | RESET_BOOT_BUS_CONDI<br>TIONS | Configure eMMC behavior after exiting fast boot                        |
|         |                               | 0: Reset to x1,SDR,Normal                                              |
|         |                               | 1: Retain boot config                                                  |
| 2       | BOOT_ACK                      | Configure eMMC ACK behavior at fast boot.                              |
|         |                               | 0: NO ACK                                                              |
|         |                               | 1: ACK                                                                 |
| 1       | RSV                           | 0x0                                                                    |
| 0       | BOOT_CONFIG_ENABLE            | Determine if write fast boot<br>configurations into eMMC or<br>not [2] |

|       |         |                  | 0: Boot configuration will be ignored                                   |
|-------|---------|------------------|-------------------------------------------------------------------------|
|       |         |                  | 1: Boot configuration will be written into device                       |
| Word1 | [31:26] | RSV              | 0x0                                                                     |
|       | [25:24] | PWR_DOWN_TIME    | eMMC power down delay<br>time before power up the<br>eMMC card          |
|       |         |                  | Only valid when<br>PWR_CYCLE_ENABLE<br>is enabled                       |
|       |         |                  | 0: 20 ms                                                                |
|       |         |                  | 1: 10 ms                                                                |
|       |         |                  | 2: 5 ms                                                                 |
|       |         |                  | 3: 2.5 ms                                                               |
|       | 23      | PWR_POLARITY     | eMMC power control polarity.                                            |
|       |         |                  | Only valid when<br>PWR_CYCLE_ENABLE<br>is enabled                       |
|       |         |                  | 0: Power down when<br>uSDHC.RST set low                                 |
|       |         |                  | 1: Power down when<br>uSDHC.RST set high                                |
|       | [22:21] | RSV              | 0x0                                                                     |
|       | 20      | PWR_UP_TIME      | eMMC power up delay time<br>to wait voltage regulator<br>output stable  |
|       |         |                  | Only valid when<br>PWR_CYCLE_ENABLE<br>is enabled                       |
|       |         |                  | 0: 5 ms                                                                 |
|       |         |                  | 1: 2.5 ms                                                               |
|       | 19      | PWR_CYCLE_ENABLE | Execute a power cycle<br>before start the SD<br>initialization progress |
|       |         |                  | 0: Disable                                                              |
|       |         |                  | 1: Enable                                                               |
|       | 18      | 1V8_ENABLE       | Select if set<br>uSDHC.VSELECT pin                                      |

| Table 58. eMMC Configuration | Block Definition (continued) |
|------------------------------|------------------------------|
|------------------------------|------------------------------|

|        |     | 0: Not set vselect pin  |
|--------|-----|-------------------------|
|        |     | 1: Set vselect pin high |
| [17:0] | RSV | 0x0                     |

NOTE

Fast boot configuration includes BOOT\_PARTITION\_ENABLE, BOOT\_BUS\_WIDTH, BOOT\_MODE, RESET\_BOOT\_BUS\_CONDITIONS, and BOOT\_ACK.

### 6.4.4 Example usage with Flashloader

This section uses the 8-bit DDR mode as an example, and boot image is written to the user data area. After writing the boot image, the user wants boot ROM to boot the image via fast boot to decrease the boot time. Fast boot also uses the same mode (8-bit DDR mode). ACK is enabled for fast boot.

The hex of the eMMC configuration block is 0xC0721625, 0x00000000

• Write the configuration block to MCU internal RAM.

```
blhost -u -- fill-memory 0x20000000 0x4 0xC0721625
blhost -u -- fill-memory 0x20000004 0x4 0x0000000
```

RAM address 0x20000000 is selected as an example. The user can select any RAM position which is available to use. The user also can select an address located at an XIP external memory, such as Flex SPI NOR Flash.

· Execute the initialization progress using configure-memory command.

blhost -u -- configure-memory 0x121 0x2000000

0x121 is the memory ID of eMMC card device. If the eMMC card is initialized successfully, then a "Success" message is recieved. If an error occurred, see *Chapter 9, "Appendix A: status and error codes"* for debugging.

- After step 2, eMMC is available to access. The user can use get the property 25 command to check the eMMC card capacity. blhost -u -- get-property 25 0x121
- To program the boot image, the user needs to erase the eMMC card memory before program the image.

```
blhost -u -- flash-erase-region 0x0 0x2000 0x121
blhost -u -- write-memory 0x400 C:\Image\bootImage.bin 0x121
```

the address of eMMC memory in the command line is byte address, not sector address. That means 8 K bytes starting from the start address of eMMC memory are erased, then the boot image *C:I/magelbootImage.bin* writes to eMMC 1st Block.

• To check if the boot image is programmed successfully, the user can read the data out.

blhost -u -- read-memory 0x200 0x2000 0x121

In most cases, the user does not need to read the data out to verify if the boot image is written successfully or not. Flashloader guarantees this when the user gets a "Success" status for write-memory command.

If user wants to switch to other partitions of the eMMC device, they need to re-configure the eMMC devices two times.

 Select the Boot partition 1, bus width and speed timing are kept unchanged. Fast boot configuration is not necessary if user does not want to update it.

```
blhost -u -- fill-memory 0x2000000 0x4 0xC1001600
blhost -u -- configure-memory 0x121 0x2000000
blhost -u -- flash-erase-region 0x0 0x1000 0x121
blhost -u -- write-memory 0x400 C:\Image\bootPartitionOneImage.bin 0x121
```

# 6.5 Parallel NAND Flash through SEMC

Certain MCUs support booting from parallel NAND flash devices via BootROM. The MCU Flashloader works as a companion to program the parallel NAND flash with the boot image. The flashloader supports generating corresponding boot data structures like the SEMC NAND Firmware Configuration Block (FCB) and Discovered Bad Block Table (DBBT) required by the BootROM. This section is only intended for generating and writing FCB, DBBT, and writing boot images using Flashloader. For details on SEMC NAND boot flow, see the System Boot chapter in the device reference manual.

The flashloader can configure parallel NAND devices directly using FCB or by a simplified configuration option block, based on which flashloader can also implicitly generate a complete FCB.

## 6.5.1 SEMC NAND Firmware Configuration Block

Firmware Configuration Block (FCB) is a 1024-byte data structure containing the optimum NAND timings and page address of DBBT search area firmware information (including the start page address and page count), etc.

| Name                | Offset (in bytes) | Size (in bytes) | Description                                                                                                                            |  |
|---------------------|-------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|--|
| crcChecksum         | 0x000             | 4               | CRC checksum                                                                                                                           |  |
| Fingerprint         | 0x004             | 4               | Fixed 0x4e464342                                                                                                                       |  |
|                     |                   |                 | ASCII: "NFCB"                                                                                                                          |  |
| Version             | 0x008             | 4               | Fixed 0x00000001                                                                                                                       |  |
| DBBTSearchStartPage | 0x00c             | 4               | Start page address for bad block table search area                                                                                     |  |
| searchStride        | 0x010             | 2               | Stride in blocks of DBBT/FCB search                                                                                                    |  |
|                     |                   |                 | Not used by ROM, max value is defined in Fusemap. Refer to the fusemap in SoC RM for more details.                                     |  |
| searchCount         | 0x012             | 2               | Copies of DBBT and FCB                                                                                                                 |  |
|                     |                   |                 | Not used by ROM, max value is defined in Fusemap. Refer to the fusemap in SoC RM for more details.                                     |  |
| firmwareCopies      | 0x014             | 4               | Firmware copies                                                                                                                        |  |
|                     |                   |                 | Valid range 1~8                                                                                                                        |  |
| Reserved            | 0x018             | 40              | Reserved for future use                                                                                                                |  |
|                     |                   |                 | Must be set to 0                                                                                                                       |  |
| firmwareInfoTable   | 0x040             | 8*8             | This table consists of 8 entries in the form below. Entries 0~ <i>firmwareCopies</i> -1 are valid. Invalid entries should be 0-filled. |  |

Table 59. SEMC NAND Firmware Configuration Block

| Name                | Offset (in bytes) | Size (in bytes) | Description                        |                        |                                   |
|---------------------|-------------------|-----------------|------------------------------------|------------------------|-----------------------------------|
|                     |                   |                 |                                    |                        |                                   |
|                     |                   |                 | Field                              | Size (in bytes)        | Description                       |
|                     |                   |                 | startPage                          | 4                      | Start page of this firmware       |
|                     |                   |                 | pageCount                          | 4                      | # of pages to store this firmware |
| Reserved            | 0x080             | 128             | Reserved                           |                        |                                   |
|                     |                   |                 | Must be set to 0                   |                        |                                   |
| semcNandConfigBlock | 0x100             | 256             | Parallel NAND cor<br>SEMC NAND Con | nfiguration block over | SEMC, see section                 |
| Reserved            | 0x200             | 512             | Reserved<br>Must be 0              |                        |                                   |

 Table 59.
 SEMC NAND Firmware Configuration Block (continued)

# 6.5.2 SEMC NAND Configuration Block

The SEMC NAND parameters are defined in the SEMC NAND configuration block regarding a specific flash device. It is a 256-byte data structure.

| Table 60. SEMC | NAND | <b>Configuration Block</b> |
|----------------|------|----------------------------|
|----------------|------|----------------------------|

| Name                  | Offset | Size (in bytes) | Description                                                                 |        |
|-----------------------|--------|-----------------|-----------------------------------------------------------------------------|--------|
| tag                   | 0x000  | 4               | 0x434d4553<br>ASCII:"SEMC"                                                  |        |
| version               | 0x004  | 4               | Version number<br>Typ. value 0x00010000                                     |        |
|                       |        |                 | Offset                                                                      | Field  |
|                       |        |                 | 31:16                                                                       | major  |
|                       |        |                 | 15:8                                                                        | minor  |
|                       |        |                 | 7:0                                                                         | bugfix |
| deviceMemType         | 0x008  | 1               | Device Memory Type<br>1 - parallel NAND                                     |        |
| accessCommand<br>Type | 0x009  | 1               | Access Command Type<br>0 - Access via IP commands<br>1 - Access via AXI bus |        |

| Name                  | Offset | Size (in bytes) | Description                                   |
|-----------------------|--------|-----------------|-----------------------------------------------|
| Reserved              | 0x00a  | 2               | Reserved                                      |
|                       |        |                 | Must be set to 0                              |
| asyncClkFreq          | 0x00c  | 1               | Asynchronous Clock Frequency                  |
|                       |        |                 | 0 – 33MHz                                     |
|                       |        |                 | 1 – 40MHz                                     |
|                       |        |                 | 2 – 50MHz                                     |
|                       |        |                 | 3 – 66MHz                                     |
|                       |        |                 | 4 – 108MHz                                    |
|                       |        |                 | 5 – 133MHz                                    |
|                       |        |                 | 6 – 166MHz                                    |
|                       |        |                 | 7 - Max possible frequency                    |
| busTimeoutCycle       | 0x00d  | 1               | Bus Timeout Clock Cycles                      |
| S                     |        |                 | 0 – 255*1024 cycles                           |
|                       |        |                 | n – n*1024 cycles                             |
| commandExecuti        | 0x00e  | 1               | Command Timeout Clock Cycles                  |
| onTimeoutCycles       |        |                 | 0 – 255*1024 cycles                           |
|                       |        |                 | n – n*1024 cycles                             |
| readStrobeMode        | 0x00f  | 1               | Read Strobe Mode                              |
|                       |        |                 | 0 – Dummy read strobe loopbacked internally   |
|                       |        |                 | 1 – Dummy read strobe loopbacked from DQS pad |
| axiMemBaseAddr<br>ess | 0x010  | 4               | SoC level base address for NAND AXI command   |
| axiMemSizeInByt<br>e  | 0x014  | 4               | SoC level memory size for NAND AXI command    |
| ipgMemBaseAddr<br>ess | 0x018  | 4               | SoC level base address for NAND IPG command   |
| ipgMemSizeInByt<br>e  | 0x01c  | 4               | SoC level memory size for NAND IPG command    |
| edoMode               | 0x020  | 1               | EDO Mode Enable                               |
|                       |        |                 | 0 - Disabled                                  |
|                       |        |                 | 1 - Enabled                                   |
| ioPortWidth           | 0x021  | 1               | I/O Port Bit Width                            |
|                       |        |                 | 16 - 16-bit wide                              |

| Table 60. | SEMC NAND | <b>Configuration Block</b> | (continued) |
|-----------|-----------|----------------------------|-------------|
|-----------|-----------|----------------------------|-------------|

| Table 60. | SEMC NAND | Configuration | Block | (continued) |
|-----------|-----------|---------------|-------|-------------|
|-----------|-----------|---------------|-------|-------------|

| Name                   | Offset | Size (in bytes) | Description                   |
|------------------------|--------|-----------------|-------------------------------|
|                        |        |                 | 8 - 8-bit wide                |
| arrayAddressOpti       | 0x022  | 1               | Array Address Option          |
| on                     |        |                 | 0 - 2-byte CA, 3-byte RA      |
|                        |        |                 | 1 - 1-byte CA, 3-byte RA      |
|                        |        |                 | 2 - 2-byte CA, 2-byte RA      |
|                        |        |                 | 3 - 1-byte CA, 2-byte RA      |
|                        |        |                 | 4 - 2-byte CA, 1-byte RA      |
|                        |        |                 | 7 - 1-byte CA, 1-byte RA      |
| columnAddressWi<br>dth | 0x023  | 1               | Column Address Bit Width      |
| burstLengthInByt<br>es | 0x024  | 1               | Burst Length in Bytes         |
| columnAddressO         | 0x025  | 1               | Column Address Option         |
| ption                  |        |                 | 0 - Page data access only     |
|                        |        |                 | 1 - Spare area access enabled |
| Reserved               | 0x026  | 10              | Reserved                      |
|                        |        |                 | Must be set to 0              |
| cePortOutputSele       | 0x030  | 1               | CE Port Output Selection      |
| ction                  |        |                 | 0 - CSX0                      |
|                        |        |                 | 1 - CSX1                      |
|                        |        |                 | 2 - CSX2                      |
|                        |        |                 | 3 - CSX3                      |
| rdyPortPolarity        | 0x031  | 1               | RDY Port Polarity             |
|                        |        |                 | 0 - Low active                |
|                        |        |                 | 1 - High active               |
| Reserved               | 0x032  | 14              | Reserved                      |
|                        |        |                 | Must be set to 0              |
| ceSetupTime            | 0x040  | 1               | CE Setup Time                 |
|                        |        |                 | value[3:0] + 1 cycles         |
| ceMinHoldTime          | 0x041  | 1               | CE Minimum Hold Time          |
|                        |        |                 | value[3:0] + 1 cycles         |

| Name                    | Offset | Size (in bytes) | Description              |
|-------------------------|--------|-----------------|--------------------------|
| ceMinIntervalTim        | 0x042  | 1               | CE Minimum Interval      |
| e                       |        |                 | value[3:0] + 1 cycles    |
| weLowTime               | 0x043  | 1               | WE Low Time              |
|                         |        |                 | value[3:0] + 1 cycles    |
| weHighTime              | 0x044  | 1               | WE High Time             |
|                         |        |                 | value[3:0] + 1 cycles    |
| reLowTime               | 0x045  | 1               | RE Low Time              |
|                         |        |                 | value[3:0] + 1 cycles    |
| reHighTime              | 0x046  | 1               | RE High Time             |
|                         |        |                 | value[3:0] + 1 cycles    |
| weHighToReLow           | 0x047  | 1               | WE High to RE Low Time   |
| Time                    |        |                 | value[3:0] + 1 cycles    |
| reHighToWeLowT          | 0x048  | 1               | RE High to WE Low Time   |
| ime                     |        |                 | value[3:0] + 1 cycles    |
| aleToDataStartTi        | 0x049  | 1               | ALE to Data Time         |
| me                      |        |                 | value[3:0] + 1 cycles    |
| readyToReLowTi          | 0x04a  | 1               | RDY to RE Low Time       |
| me                      |        |                 | value[3:0] + 1 cycles    |
| weHighToBusyTi          | 0x04b  | 1               | WE High to BUSY Time     |
| me                      |        |                 | value[3:0] + 1 cycles    |
| asyncTurnaround<br>Time | 0x04c  | 1               | Async Turnaround Time    |
| TIME                    |        |                 | value[3:0] + 1 cycles    |
| Reserved                | 0x04d  | 3               | Reserved                 |
|                         |        |                 | Must be set to 0         |
| vendorType              | 0x050  | 1               | Vendor Type              |
|                         |        |                 | 0 - Micron               |
|                         |        |                 | 1 - Spansion             |
|                         |        |                 | 2 - Samsung              |
|                         |        |                 | 3 - Winbond<br>4 - Hynix |
|                         |        |                 |                          |

Table 60. SEMC NAND Configuration Block (continued)

| Table 60. | SEMC NAND | Configuration | Block | (continued) |
|-----------|-----------|---------------|-------|-------------|
|-----------|-----------|---------------|-------|-------------|

| Name             | Offset | Size (in bytes) | Description                      |
|------------------|--------|-----------------|----------------------------------|
|                  |        |                 | 5 - Toshiba                      |
|                  |        |                 | 6 - Macronix                     |
|                  |        |                 | 7 - Unknown                      |
| cellTechnology   | 0x051  | 1               | Cell Technology                  |
|                  |        |                 | 0 - SLC                          |
|                  |        |                 | 1 - MLC                          |
| onfiVersion      | 0x052  | 1               | ONFI Compliance                  |
|                  |        |                 | 0 - None                         |
|                  |        |                 | 1 - ONFI 1.0                     |
|                  |        |                 | 2 - ONFI 2.0                     |
|                  |        |                 | 3 - ONFI 3.0                     |
|                  |        |                 | 4 - ONFI 4.0                     |
| acTimingTableInd | 0x053  | 1               | Timing Mode                      |
| ex               |        |                 | 0 - User defined                 |
|                  |        |                 | 1~6 - ONFI 1.0 mode 0~5          |
|                  |        |                 | 7 - Fastest mode                 |
| enableEccCheck   | 0x054  | 1               | ECC Enable                       |
|                  |        |                 | 0 - Enabled                      |
|                  |        |                 | 1 - Disabled                     |
| eccCheckType     | 0x055  | 1               | ЕСС Туре                         |
|                  |        |                 | 0 - Device ECC                   |
|                  |        |                 | 1 - External/Software ECC        |
| deviceEccStatus  | 0x056  | 1               | Device ECC Default Status        |
|                  |        |                 | 0 - Enabled                      |
|                  |        |                 | 1 - Disabled                     |
| swEccAlgorithm   | 0x057  | 1               | Software ECC Algorithm           |
|                  |        |                 | Refer to SoC RM for details      |
| swEccBlockBytes  | 0x058  | 4               | Software ECC Block Size in Bytes |
| readyCheckOptio  | 0x05c  | 1               | Ready Check Option               |
| n                |        |                 | 0 - Via status register          |
|                  |        |                 | 1 - Via R/B# signal              |

| Table 60. S | SEMC NAND | Configuration | Block | (continued) |
|-------------|-----------|---------------|-------|-------------|
|-------------|-----------|---------------|-------|-------------|

| Name                          | Offset | Size (in bytes) | Description                                                 |
|-------------------------------|--------|-----------------|-------------------------------------------------------------|
| statusCommandT<br>ype         | 0x05d  | 1               | Status Command Type<br>0 - Common<br>1 - Enhanced           |
| readyCheckTime<br>outInMs     | 0x05e  | 2               | Ready Check Timeout in ms                                   |
| readyCheckInterv<br>allnUs    | 0x060  | 2               | Ready Check Interval in us                                  |
| Reserved                      | 0x062  | 30              | Reserved<br>Must be set to 0                                |
| userOnfiAcTiming<br>ModeCode  | 0x080  | 1               | User ONFI AC Timing Mode                                    |
| Reserved                      | 0x081  | 31              | Reserved<br>Must be set to 0                                |
| bytesInPageData<br>Area       | 0x0a0  | 4               | Data Area Size in Bytes per Page                            |
| bytesInPageSpar<br>eArea      | 0x0a4  | 4               | Spare Area Size in bytes per Page                           |
| pagesInBlock                  | 0x0a8  | 4               | Pages per Block                                             |
| blocksInPlane                 | 0x0ac  | 4               | Blocks per Plane                                            |
| planesInDevice                | 0x0b0  | 4               | Planes in Device                                            |
| Reserved                      | 0x0b4  | 44              | Reserved<br>Must be set to 0                                |
| enableReadback<br>Verify      | 0x0e0  | 1               | Readback Verification Enable<br>0 - Enabled<br>1 - Disabled |
| Reserved                      | 0x0e1  | 3               | Reserved<br>Must be set to 0                                |
| readbackPageBuf<br>ferAddress | 0x0e4  | 1               | Readback Page Buffer Address                                |
| Reserved                      | 0x0e8  | 24              | Reserved<br>Must be set to 0                                |

## 6.5.3 SEMC NAND Configuration Option Block

SEMC configuration option block defines the key parameters required by FCB. Currently a uniform command set is applicable across mainstream ONFI-compliant parallel NAND devices in the market. Their major differences lie in the ECC type. The configuration option block covers these differences so as to simplify the configuration.

| Table 61. SE | MC NAND | configuration | option | block | definition |
|--------------|---------|---------------|--------|-------|------------|
|--------------|---------|---------------|--------|-------|------------|

| Offset | Field      | Size | Description      |                |                                                                                            |
|--------|------------|------|------------------|----------------|--------------------------------------------------------------------------------------------|
| 0      | nandOption | 4    | NAND configurati | on options     |                                                                                            |
|        |            |      | Offset           | Field          | Description                                                                                |
|        |            |      | 31:28            | tag            | Fixed 0x0d                                                                                 |
|        |            |      | 27:18            | Reserved       | Set to 0                                                                                   |
|        |            |      | 17               | eccStatus      | Initial device ECC status                                                                  |
|        |            |      |                  |                | Refer to deviceEccStatus<br>in SEMC NAND<br>Configuration Block<br>for definition          |
|        |            |      | 16               | ессТуре        | ECC Type                                                                                   |
|        |            |      |                  |                | Refer to eccCheckType<br>in SEMC NAND<br>Configuration Block<br>for definition             |
|        |            |      | 15               | Reserved       | Set to 0                                                                                   |
|        |            |      | 14:12            | pcsSelection   | CE port selection                                                                          |
|        |            |      |                  |                | Refer to<br>cePortOutputSelection<br>in SEMC NAND<br>Configuration Block<br>for definition |
|        |            |      | 11:10            | Reserved       | Set to 0                                                                                   |
|        |            |      | 9:8              | ioPortDiv8     | I/O port byte width                                                                        |
|        |            |      |                  |                | 1 - 8-bit wide                                                                             |
|        |            |      |                  |                | 2 - 16-bit wide                                                                            |
|        |            |      | 7                | Reserved       | Set to 0                                                                                   |
|        |            |      | 6:4              | onfiTimingMode | ONFI timing mode                                                                           |
|        |            |      |                  |                | Refer to<br>acTimingTableIndex<br>in SEMC NAND<br>Configuration Block<br>for definition    |
|        |            |      | 3                | edoMode        | EDO mode enable                                                                            |

| Offset | Field           | Size | Description                               | Description                 |                                                                                               |  |  |  |
|--------|-----------------|------|-------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------|--|--|--|
|        |                 |      |                                           |                             |                                                                                               |  |  |  |
|        |                 |      | Offset                                    | Field                       | Description                                                                                   |  |  |  |
|        |                 |      |                                           |                             | Refer to edoMode<br>in SEMC NAND<br>Configuration Block<br>for definition                     |  |  |  |
|        |                 |      | 2:0                                       | onfiVersion                 | ONFI Version<br>Refer to onfiVersion<br>in SEMC NAND<br>Configuration Block<br>for definition |  |  |  |
| 4      | 4 bcbOption 4   |      | Key FCB and DBI                           | Key FCB and DBBT parameters |                                                                                               |  |  |  |
|        |                 |      | Offset                                    | Field                       | Description                                                                                   |  |  |  |
|        |                 |      | 31:20                                     | Reserved                    | Set to 0                                                                                      |  |  |  |
|        |                 |      | 19:16                                     | imgCopies                   | Firmware copies<br>Refer to firmwareCopies in<br>for definition                               |  |  |  |
|        |                 |      | 15:8                                      | searchStride                | Search stride in blocks                                                                       |  |  |  |
|        |                 |      | 7:4                                       | Reserved                    | Set to 0                                                                                      |  |  |  |
|        |                 |      | 3:0                                       | searchCount                 | Search count                                                                                  |  |  |  |
| 8      | 3 imageInfo 4*8 |      | Image info is a ma<br>Invalid entries sho |                             | . Entries 0~ <i>imgCopies</i> -1 are valid.                                                   |  |  |  |
|        |                 |      | Offset                                    | Field                       | Description                                                                                   |  |  |  |
|        |                 |      | 31:16                                     | blockId                     | Start block index of the image                                                                |  |  |  |
|        |                 |      | 15:0                                      | blockCount                  | Occupied blocks of the image                                                                  |  |  |  |

#### NOTE

• *searchStride* should match the one provisioned in eFuse.

• *searchCount* should match the one provisioned in eFuse.

## 6.5.4 Example usage with Flashloader

#### 6.5.4.1 FCB/DBBT management

It is not recommended to manually program NAND devices with the FCB and the DBBT. The flashloader implicitly writes them into NAND during configuration.

The FCB, DBBT and firmware images will be loaded into NAND in the layout given below (*n* stands for search count, *m* for search stride).

| Block 0: FCB1                                   |
|-------------------------------------------------|
|                                                 |
|                                                 |
| Block <i>m</i> . FCB2                           |
|                                                 |
| Block ( <i>n</i> -1)* <i>m</i> : FCB <i>n</i>   |
| Block n*m: DBBT1                                |
|                                                 |
| Block (n+1)*m. DBBT2                            |
|                                                 |
| Block (2 <i>n</i> -1)* <i>m</i> . DBBT <i>n</i> |
| Image1                                          |
| Image2                                          |
|                                                 |
| Image8 (assuming <i>imgCopies</i> is 8)         |

#### 6.5.4.2 Example configuration

- Flashloader can generate an FCB and DBBT based on a specified SEMC NAND configuration option block. Assuming the FCB parameters are:
  - 1 copy of FCB and DBBT
  - 1 copy of firmware
  - Firmware intended to start at block 2, and occupy 1 block
- And parallel NAND parameters are:
  - ONFI-compliant
  - 8-bit wide I/O port
  - CSX0 connected to NAND device's CE port
  - Device ECC applied

Below are the example steps for generating SEMC NAND configuration option block:

blhost -u -- fill-memory 0x20000000 0x4 0xd0000101 # NAND parameters

blhost -u -- fill-memory 0x20000004 0x4 0x00010101 # 1 copy of firmware, search stride 1, search step 1

blhost -u -- fill-memory 0x20000008 0x4 0x00020001 # firmware starts at block 2, occupies 1 block

Configure the NAND flash using the option block above:

blhost -u -- configure-memory 0x100 0x2000000

MCU Flashloader Reference Manual, Rev. 11, 29 March 2022

Erasure, programming and readback:

blhost -u -- flash-erase-region 0x80000 0x40000 0x100 # erasure starts from block 2 (64 pp/block, 4KB/page), 1 block is erased

blhost -u -- write-memory 0x80000 image.bin 0x100

blhost -u -- read-memory 0x80400 16 0x100 # bootable image's IVT offset should be 0x400

## 6.6 1-bit SPI EEPROM/NOR Flash through LPSPI

Certain MCUs support recovery boot from an external EEPROM/NOR flash through the LPSPI under 1-bit mode. The MCU Flashloader works as a companion to program the external SPI EEPROM/NOR device with the boot image. This section is only intended for write boot images using Flashloader. For details on the recovery boot flow, see the System Boot Chapter in the device reference manual.

The Flashloader can configure SPI EEPROM/NOR devices using a simplified configuration option block.

#### 6.6.1 SPI EEPROM/NOR Configuration Option Block

SPI EEPROM/NOR configuration option block defines the parameters required for data interaction.

| Table 62 | . SPI EEPROM/NOR | configuration | option | block definition |
|----------|------------------|---------------|--------|------------------|
|----------|------------------|---------------|--------|------------------|

| Offset | Field   | Size | Description         |                     |                                                                                                                           |
|--------|---------|------|---------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------|
| 0      | option0 | 4    | EEPROM<br>configura | /NOR<br>tion option | 5                                                                                                                         |
|        |         |      | Offset              | Field               | Descripti<br>on                                                                                                           |
|        |         |      | 31:28               | tag                 | Fixed<br>0x0c                                                                                                             |
|        |         |      | 27:14               | option_s<br>ize     | Option<br>size in<br>32-bit<br>words<br>0 - Only<br>option0<br>given<br>1 -<br>Option0<br>and<br>option1<br>both<br>given |
|        |         |      | 32:20               | spi_inde<br>x       | LPSPI<br>instance<br>index<br>1~4 -<br>LPSPI1<br>~LPSPI<br>4                                                              |

| Offset | Field | Size | Description | on              |                                                                          |
|--------|-------|------|-------------|-----------------|--------------------------------------------------------------------------|
|        |       |      | Offset      | Field           | Descripti<br>on                                                          |
|        |       |      |             |                 | Refer to<br>SoC RM<br>for<br>details                                     |
|        |       |      | 19:16       | pcs_ind<br>ex   | CS<br>index of<br>the<br>LPSPI<br>module                                 |
|        |       |      |             |                 | 0 - PCS0                                                                 |
|        |       |      |             |                 | 1 - PCS1<br>2 - PCS2                                                     |
|        |       |      |             |                 | 3 - PCS3                                                                 |
|        |       |      |             |                 | Refer to<br>SoC RM<br>for<br>details                                     |
|        |       |      | 15:12       | memory<br>_type | Memory<br>device<br>type                                                 |
|        |       |      |             |                 | 0 - NOR,<br>paramet<br>ers<br>specifie<br>d                              |
|        |       |      |             |                 | 1 -<br>EEPRO<br>M,<br>paramet<br>ers<br>specifie<br>d                    |
|        |       |      |             |                 | 2 - NOR,<br>paramet<br>ers auto<br>detected<br>(bits<br>11:0<br>omitted) |
|        |       |      | 11:8        | memory<br>_size | Memory<br>size                                                           |

| Offset | Field                 | Size | Descripti | on              |                                    |
|--------|-----------------------|------|-----------|-----------------|------------------------------------|
|        |                       |      | 0.5       | E. L.           | Desist                             |
|        |                       |      | Offset    | Field           | Descripti<br>on                    |
|        |                       |      |           |                 | n(0≤n≤1<br>1):<br>512KB*<br>2n     |
|        |                       |      |           |                 | n(12≤n≤<br>15):<br>32KB*2<br>n-12  |
|        |                       |      | 7:4       | sector_s<br>ize | Sector<br>size                     |
|        |                       |      |           |                 | n(0≤n≤1<br>):<br>4KB*2n            |
|        |                       |      |           |                 | n(2≤n≤5<br>):<br>32KB*2<br>n-2     |
|        |                       |      | 3:0       | page_si<br>ze   | Page<br>size                       |
|        |                       |      |           |                 | n(0≤n≤2<br>):<br>256B*2n           |
|        |                       |      |           |                 | n(3≤n≤5<br>):<br>32B*2n-<br>3      |
| 4      | option1<br>(optional) | 4    | SPI spee  | ed option       |                                    |
|        |                       |      | Offset    | Field           | Descripti<br>on                    |
|        |                       |      | 31:4      | Reserve<br>d    | Reserve<br>d for<br>future<br>uses |
|        |                       |      | 3:0       | speed           | SPI<br>clock<br>speed              |

| Offset | Field | Size | Descript | ion   |                           |
|--------|-------|------|----------|-------|---------------------------|
|        |       |      |          |       | _                         |
|        |       |      | Offset   | Field | Descripti<br>on           |
|        |       |      |          |       | 0 -<br>20MHz<br>(default) |
|        |       |      |          |       | 1 -<br>10MHz              |
|        |       |      |          |       | 2 - 5MHz                  |
|        |       |      |          |       | 3 - 2MHz                  |

### 6.6.2 Example usage with Flashloader

Assume a SPI NOR is connected to LPSPI1, and that PCS0 of LPSPI1 is used as the NOR device's chip-select signal.

The configuration option block should be generated with the command

blhost -u -- fill-memory 0x20000000 0x4 0xc0002000 # auto detect NOR's parameters

Or if the NOR device's parameters to be manually specified are:

- 4MB (32Mb) total memory size
- 4KB sector size
- 256B page size

The configuration option block should be instead generated with

blhost -u -- fill-memory 0x2000000 0x4 0xc0000300

Configure the NOR flash using the option block above:

blhost -u -- configure-memory 0x110 0x2000000

Erasure, programming and readback:

blhost -u -- flash-erase-region 0x0 0x8000 0x110

blhost -u -- write-memory 0x0 image.bin 0x110

blhost -u -- read-memory 0x400 16 0x110 # bootable image's IVT offset should be 0x400

## Chapter 7 Security utilities

## 7.1 Introduction

The MCU Flashloader supports certain security utilities that can generate security related blocks easily. See that the Flashloader itself must be signed first to enable the security utilities correctly.

## 7.2 Image encryption and programming

For devices with the BEE module, it supports two encrypted regions using two unique crypto keys. Each encrypted region can support up to 3 sub-divided FAC regions. See the details of the image decryption and data structure required for image decryption in System Boot Chapter in SoC's RM. In the section, it focuses on encrypted image generation and programming using Flashloader. Flashloader generates encrypted images based on a simplified PRDB option block, which is defined below.

NOTE

The Flashloader only supports image encryption and programming for the first encrypted region using the OTPMK/SNVS key.

| Offset | Field          | Size<br>(bytes) | Descripti      | on                       |                 |                                   |                                           |                                          |                                         |                      |
|--------|----------------|-----------------|----------------|--------------------------|-----------------|-----------------------------------|-------------------------------------------|------------------------------------------|-----------------------------------------|----------------------|
| 0      | Option         | 4               |                |                          |                 |                                   |                                           |                                          |                                         |                      |
|        |                |                 | Tag<br>[31:28] | Key<br>source<br>[27:24] | Mode<br>[23:20] | FAC<br>Region<br>Count<br>[19:16] | Region1<br>Protectio<br>n Mode<br>[15:12] | Region2<br>Protectio<br>n Mode<br>[11:8] | Region3<br>Protectio<br>n Mode<br>[7:4] | LockOpti<br>on [3:0] |
|        |                |                 | 0xE            | 0 -<br>OTPMK /<br>SNVS   | 1-AES<br>CTR    | 1/2/3                             | 0/1/                                      | 0/1                                      | 0/1                                     | 0 - No<br>Lock       |
| 4      | Fac            | 8-24            |                |                          |                 |                                   |                                           |                                          |                                         |                      |
|        | Region<br>info |                 | Offset         |                          |                 | Field                             |                                           | Descr                                    | iption                                  |                      |
|        |                |                 | 0              |                          | Start           |                                   | Fac R                                     | Fac Region Start                         |                                         |                      |
|        |                |                 | 4              |                          | Size            |                                   | Fac R                                     | Fac Region Size                          |                                         |                      |

#### Table 63. PRDB option block

NOTE

- Tag is fixed as 0x0E.
- Key Source can be OTPMK/SNVS [255:128].
- Mode: It is recommended to use AES-CTR mode.
- FAC Region Count: Maximum allowed FAC region number is 3 (shared by encrypted region 0 and encrypted region 1).
- Region n Protection mode: 0 No protection, 1 Debug disabled.
- Lock Option: Must be 0.

### 7.2.1 Example to generate encrypted image and program to Flash

Take HyperFlash as an example, assuming the encrypted info is:

- Key source: OTPMK/SNVS [255:128].
- FAC region Count: 2.
- Region Protection mode: 1.

Below are the steps to create a PRDB option block.

Configure HyperFlash using FlexSPI NOR Configuration Option Block:

```
blhost -u -- fill-memory 0x2000 0x04 0xc0233007 //(133MHz)
blhost -u -- configure-memory 0x9 0x2000
blhost -u -- fill-memory 0x3000 0x04 0xf000000f
blhost -u -- configure-memory 0x09 0x3000
```

Prepare PRDB0 info using PRDB option block:

```
blhost -u -- fill-memory 0x4000 0x04 0xe0121100
blhost -u -- configure-memory 0x09 0x4000
//Program HyperFLASH
blhost -u -- write-memory <addr> image.bin
```

## 7.3 KeyBlob generation and programming

### 7.3.1 KeyBlob

KeyBlob is a data structure that wraps the DEK for image decryption using AES-CCM algorithm. The whole KeyBlob data structure is shown below.

#### Table 64. KeyBlob Data structure

| Size (bytes) | Description |                                                                      |                                                                                                               |  |
|--------------|-------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|
| 4            |             |                                                                      |                                                                                                               |  |
|              | Offset      | Field                                                                | Description                                                                                                   |  |
|              | 0           | tag                                                                  | Fixed value: 0x81                                                                                             |  |
|              | 1-2         | len                                                                  | Length of KeyBlob<br>block, 16-bit big-<br>endian order                                                       |  |
|              | 3           | par                                                                  | KeyBlob Version,<br>set to 0x42 or 0x43                                                                       |  |
| 4            |             |                                                                      |                                                                                                               |  |
|              | Offset      | Field                                                                | Description                                                                                                   |  |
|              | 0           | mode                                                                 | Fixed to 0x66,<br>CCM mode                                                                                    |  |
|              | 4           | 4<br>Offset<br>0<br>1-2<br>3<br>4<br>4<br>Offset<br>Offset<br>Offset | Matrix         Offset         Field           0         tag           1-2         len           3         par |  |

| Field | Size (bytes)                                                                      | Description                                                                                                       |                                 |                                            |
|-------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------|
|       |                                                                                   |                                                                                                                   |                                 |                                            |
|       |                                                                                   | Offset                                                                                                            | Field                           | Description                                |
|       |                                                                                   | 1                                                                                                                 | alg                             | Fixed to<br>0x55, Crypto<br>Algorithm: AES |
|       |                                                                                   | 2                                                                                                                 | mac_bytes                       | Fixed to 16                                |
|       |                                                                                   | 3                                                                                                                 | aad_bytes                       | Fixed to 0                                 |
|       |                                                                                   |                                                                                                                   |                                 |                                            |
| EBK   | 16 / 32                                                                           | Blob key is used for generated by TRNG                                                                            | DEK encryption, it is<br>engine | a random number                            |
|       | Blob key is encrypted to EBK by a key derived from<br>Engine such as SNVS or CAAM |                                                                                                                   | erived from Security            |                                            |
| EDEK  | 16 / 24 / 32                                                                      | DEK is used for boot image encryption, it is encrypted to EDEK<br>by the BK with AES algorithm using AES-CCM mode |                                 |                                            |
| MAC   | 16                                                                                | MAC is generated d                                                                                                | luring DEK encryption           | n                                          |

## 7.3.2 KeyBlob Option Block

The MCU Flashloader supports KeyBlob generation and programming using a simplified option block called KeyBlob Option Block.

| Tabla | 65  | KoyBlob | Data | etructure |
|-------|-----|---------|------|-----------|
| Iable | 00. | Reyblub | Dala | structure |

| Offset | Field  | Size | Description |       |                                                                                                                                                        |
|--------|--------|------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | option | 4    |             |       |                                                                                                                                                        |
|        |        |      | Offset      | Field | Description                                                                                                                                            |
|        |        |      | 31:28       | Tag   | Fixed to 0x0B                                                                                                                                          |
|        |        |      | 27:24       | type  | 0 - Update,<br>used to update<br>the keyblob<br>context<br>1 - Program -<br>used to notify<br>memory driver<br>to program<br>Keyblob to<br>destination |
|        |        |      | 23:20       | size  | keyblob_info<br>size<br>must equal to 3<br>if type = 0,<br>ignored if type<br>= 1                                                                      |

| Offset | Field          | Size | Description    |                                                                 |                                                  |
|--------|----------------|------|----------------|-----------------------------------------------------------------|--------------------------------------------------|
|        |                |      |                |                                                                 |                                                  |
|        |                |      | Offset         | Field                                                           | Description                                      |
|        |                |      | 19:8           | Reserved                                                        | -                                                |
|        |                |      | 7:4            | dek_size                                                        | DEK size                                         |
|        |                |      |                |                                                                 | 0 - 128 bits                                     |
|        |                |      |                |                                                                 | 1 - 192 bits                                     |
|        |                |      |                |                                                                 | 2 - 256 bits                                     |
|        |                |      |                |                                                                 | Effective if type<br>= 0, ignored if<br>type = 1 |
|        |                |      | 3:0            | image_index                                                     | Boot image<br>index                              |
|        |                |      |                |                                                                 | For example,<br>index for<br>firmwareTable       |
|        |                |      |                |                                                                 | effective if type<br>= 1, ignored if<br>type = 0 |
| 1      | dek_addr       | 4    | Start addres   | s for the memory h                                              | olds DEK                                         |
| 2      | keyblob_offset | 4    | The relative   | Keyblob offset in th                                            | ne selected image                                |
|        |                |      |                | e, a signed image th<br>pplication, CSF, Ke                     |                                                  |
|        |                |      | IVT is at offs | set 0x400                                                       |                                                  |
|        |                |      | Encrypted ir   | mage is at offset 0x                                            | 2000                                             |
|        |                |      | CSF is at of   | fset 0xA000                                                     |                                                  |
|        |                |      | KeyBlob is a   | at offset 0xB000                                                |                                                  |
|        |                |      |                | NOTE<br>For NAND device,<br>keyblob_offset must<br>page aligned | be                                               |

## 7.3.3 Example to generate and program KeyBlob

### Generate KeyBlob

// Write DEK to RAM

blhost -u -- write-memory 0x2100 dek.bin

#### // Construct KeyBlob option

```
blhost -u -- fill-memory 0x2080 4 0xb0300000 // tag = 0x0b, type = 0, size = 3, dek_size = 0 (128bits)

blhost -u -- fill-memory 0x2084 4 0x2100 // dek_addr = 0x2100

blhost -u -- fill-memory 02088 4 0x80000 // keybob_offset = 0x80000, keybob is located at

offset 0x80000 in application image
```

#### // Update KeyBlob Info

blhost -u -- configure-memory 0x101 0x2080 // Update KeyBlob Info (memory id: 0x101 - FlexSPI NAND)

#### // Program KeyBlob

```
blhost -u -- fill-memory 0x2080 0xb1000000 // tag = 0x0b, type = 1, image_index = 0
blhost -u -- configure-memory 0x101 0x2080 // Generate KeyBlob and program it into offset
<keyblob_offset> in the selected Image <image_idex> memory region
```

## Chapter 8 Revision history

This table shows the revision history of the document.

#### Table 66. Revision history

| Revision number | Date             | Substantive changes                                                                                                        |
|-----------------|------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0               | 04/2016          | Kinetis Bootloader v2.0.0 release                                                                                          |
| 1               | 10/2017          | Update for Flashloader application for<br>i.MX RT Series of devices                                                        |
| 2               | 01/2018          | Update for Flashloader application for<br>QuadSPI NOR Flash device that is<br>only JESD216-compliant                       |
| 3               | 05/2018          | MCU Bootloader v2.5.0 release                                                                                              |
| 4               | 09/2018          | MCU Bootloader v2.6.0 release                                                                                              |
| 5               | 11/2018          | MCU Bootloader v2.7.0 release                                                                                              |
| 6               | 09/2019          | Added section FlexSPI NOR On-chip<br>OTFAD Pre-encryption Option Block                                                     |
| 7               | 03/2020          | Updated for RT1170 Flashloader EAR<br>release, added section Select the<br>FLEXSPI instance                                |
| 8               | 28 December 2020 | Updated for MCUXpresso SDK<br>v2.9.0 release                                                                               |
| 9               | 01 June 2021     | Updated for MCUXpresso SDK<br>v2.10.0 release                                                                              |
| 10              | 17 October 2021  | Updated size for ipCmdSerialClkFreq,<br>isUniformBlockSize, and<br>needExitNoCmdMode in FlexSPI NOR<br>Configuration Block |
| 11              | 29 March 2022    | Updated Table 56 for MCUBOOT SDK<br>2.11.0 RT1180 EAR                                                                      |

## Appendix A Status and error codes

Status and error codes are grouped by component. Each component that defines errors has a group number. This expression is used to construct a status code value.

status\_code = (group \* 100) + code

Component group numbers are listed in this table.

#### Table 67. Component group numbers

| Group | Component        |
|-------|------------------|
| 0     | Generic errors   |
| 100   | Bootloader       |
| 101   | SB loader        |
| 102   | Memory interface |
| 103   | Property store   |
| 104   | CRC checker      |
| 105   | Packetizer       |
| 106   | Reliable update  |

The following table lists all of the error and status codes.

#### Table 68. Error and status codes

| Name                                     | Value | Description                                        |
|------------------------------------------|-------|----------------------------------------------------|
| kStatus_Success                          | 0     | Operation succeeded without error                  |
| kStatus_Fail                             | 1     | Operation failed with a generic error              |
| kStatus_ReadOnly                         | 2     | Property cannot be changed because it is read-only |
| kStatus_OutOfRange                       | 3     | Requested value is out of range                    |
| kStatus_InvalidArgument                  | 4     | The requested command's argument is undefined      |
| kStatus_Timeout                          | 5     | A timeout occurred                                 |
| kStatus_NoTransferInProgress             | 6     | The current transfer status is idle                |
| kStatus_SDMMC_NotSupportYet              | 1800  | Not supported this feature                         |
| kStatus_SDMMC_TransferFailed             | 1801  | Failed to communicate with the device              |
| kStatus_SDMMC_SetCardBlockSizeFail<br>ed | 1802  | Failed to set the block size                       |
| kStatus_SDMMC_HostNotSupport             | 1803  | Host doesn't support this feature                  |
| kStatus_SDMMC_CardNotSupport             | 1804  | The card does not support this feature             |
| kStatus_SDMMC_AllSendCidFailed           | 1805  | Failed to send CID                                 |

Table 68. Error and status codes (continued)

| Name                                                | Value | Description                          |
|-----------------------------------------------------|-------|--------------------------------------|
| kStatus_SDMMC_SendRelativeAddress<br>Failed         | 1806  | Failed to send relative address      |
| kStatus_SDMMC_SendCsdFailed                         | 1807  | Failed to send CSD                   |
| kStatus_SDMMC_SelectCardFailed                      | 1808  | Failed to select card                |
| kStatus_SDMMC_SendScrFailed                         | 1809  | Failed to send SCR                   |
| kStatus_SDMMC_SetDataBusWidthFail<br>ed             | 1810  | Failed to set bus width              |
| kStatus_SDMMC_GoldleFailed                          | 1811  | Go idle failed                       |
| kStatus_SDMMC_HandShakeOperation<br>ConditionFailed | 1812  | Failed to send operation condition   |
| kStatus_SDMMC_SendApplicationCom mandFailed         | 1813  | Failed to send application command   |
| kStatus_SDMMC_SwitchFailed                          | 1814  | Switch command failed                |
| kStatus_SDMMC_StopTransmissionFail<br>ed            | 1815  | Stop transmission failed             |
| kStatus_SDMMC_WaitWriteCompleteF<br>ailed           | 1816  | Failed to wait write complete        |
| kStatus_SDMMC_SetBlockCountFailed                   | 1817  | Failed to set block count            |
| kStatus_SDMMC_SetRelativeAddressF<br>ailed          | 1818  | Failed to set relative address       |
| kStatus_SDMMC_SwitchBusTimingFail<br>ed             | 1819  | Failed to switch high speed          |
| kStatus_SDMMC_SendExtendedCsdFai<br>led             | 1820  | Failed to send EXT_CSD               |
| kStatus_SDMMC_ConfigureBootFailed                   | 1821  | Failed to configure boot             |
| kStatus_SDMMC_ConfigureExtendedC<br>sdFailed        | 1822  | Failed to configure EXT_CSD          |
| kStatus_SDMMC_EnableHighCapacityE<br>raseFailed     | 1823  | Failed to enable high capacity erase |
| kStatus_SDMMC_SendTestPatternFaile<br>d             | 1824  | Failed to send test pattern          |
| kStatus_SDMMC_ReceiveTestPatternF<br>ailed          | 1825  | Failed to receive test pattern       |
| kStatus_SDMMC_InvalidVoltage                        | 1829  | Invalid voltage                      |
| kStatus_SDMMC_TuningFail                            | 1833  | Tuning failed                        |
| kStatus_SDMMC_SwitchVoltageFail                     | 1834  | Failed to switch voltage             |
| kStatus_SDMMC_SetPowerClassFail                     | 1837  | Set power class fail                 |

Table 68. Error and status codes (continued)

| Name                                             | Value | Description                                             |
|--------------------------------------------------|-------|---------------------------------------------------------|
| kStatus_UnknownCommand                           | 10000 | The requested command value is undefined                |
| kStatus_SecurityViolation                        | 10001 | Command is disallowed because flash security is enabled |
| kStatus_AbortDataPhase                           | 10002 | Abort the data phase early                              |
| kStatus_Ping                                     | 10003 | Internal: Received ping during command phase            |
| kStatus_NoResponse                               | 10004 | There is no response for the command                    |
| kStatus_NoResponseExpected                       | 10005 | There is no response expected for the command           |
| kStatusRomLdrSectionOverrun                      | 10100 | ROM SB loader section overrun                           |
| kStatusRomLdrSignature                           | 10101 | ROM SB loader incorrect signature                       |
| kStatusRomLdrSectionLength                       | 10102 | ROM SB loader incorrect section length                  |
| kStatusRomLdrUnencryptedOnly                     | 10103 | ROM SB loader does not support plain text image         |
| kStatusRomLdrEOFReached                          | 10104 | ROM SB loader EOF reached                               |
| kStatusRomLdrChecksum                            | 10105 | ROM SB loader checksum error                            |
| kStatusRomLdrCrc32Error                          | 10106 | ROM SB loader CRC32 error                               |
| kStatusRomLdrUnknownCommand                      | 10107 | ROM SB loader unknown command                           |
| kStatusRomLdrldNotFound                          | 10108 | ROM SB loader ID not found                              |
| kStatusRomLdrDataUnderrun                        | 10109 | ROM SB loader data underrun                             |
| kStatusRomLdrJumpReturned                        | 10110 | ROM SB loader return from jump command occurred         |
| kStatusRomLdrCallFailed                          | 10111 | ROM SB loader call command failed                       |
| kStatusRomLdrKeyNotFound                         | 10112 | ROM SB loader key not found                             |
| kStatusRomLdrSecureOnly                          | 10113 | ROM SB loader security state is secured only            |
| kStatusRomLdrResetReturned                       | 10114 | ROM SB loader return from reset occurred                |
| kStatusMemoryRangeInvalid                        | 10200 | Memory range conflicts with a protected region          |
| kStatusMemoryReadFailed                          | 10201 | Failed to read from memory range                        |
| kStatusMemoryWriteFailed                         | 10202 | Failed to write to memory range                         |
| StatusMemoryCumulativeWrite                      | 10203 | Failed to write to unerased memory range                |
| kStatusMemoryAppOverlapWithExecute<br>OnlyRegion | 10204 | Memory range contains a protected executed only region  |
| kStatusMemoryNotConfigured                       | 10205 | Failed to access to un-configured external memory       |
| kStatusMemoryAlignmentError                      | 10206 | Address alignment Error                                 |
| kStatusMemoryVerifyFailed                        | 10207 | Failed to verify the write operation                    |
| kStatusMemoryWriteProtected                      | 10208 | Memory range contains protected memory region           |
| kStatus_UnknownProperty                          | 10300 | The requested property value is undefined               |
| kStatus_ReadOnlyProperty                         | 10301 | The requested property value cannot be written          |

| Name                                                  | Value | Description                                                         |  |
|-------------------------------------------------------|-------|---------------------------------------------------------------------|--|
| kStatus_InvalidPropertyValue                          | 10302 | The specified property value is invalid                             |  |
| kStatus_AppCrcCheckPassed                             | 10400 | CRC check passed                                                    |  |
| kStatus_AppCrcCheckFailed                             | 10401 | CRC check failed                                                    |  |
| kStatus_AppCrcCheckInactive                           | 10402 | CRC checker is not enabled                                          |  |
| kStatus_AppCrcCheckInvalid                            | 10403 | Invalid CRC checker                                                 |  |
| kStatus_AppCrcCheckOutOfRange                         | 10404 | CRC check is valid but addresses are out of range                   |  |
| kStatus_NoPingResponse                                | 10500 | Packetizer did not receive any response for the ping packet         |  |
| kStatus_InvalidPacketType                             | 10501 | Packet type is invalid                                              |  |
| kStatus_InvalidCRC                                    | 10502 | Invalid CRC in the packet                                           |  |
| kStatus_NoCommandResponse                             | 10503 | No response received for the command                                |  |
| kStatus_ReliableUpdateSuccess                         | 10600 | Reliable update process completed successfully                      |  |
| kStatus_ReliableUpdateFail                            | 10601 | Reliable update process failed                                      |  |
| kStatus_ReliableUpdateInacive                         | 10602 | Reliable update feature is inactive                                 |  |
| kStatus_ReliableUpdateBackupApplicati<br>onInvalid    | 10603 | Backup application image is invalid                                 |  |
| kStatus_ReliableUpdateStillInMainAppli cation         | 10604 | Next boot will still be with Main Application image                 |  |
| kStatus_ReliableUpdateSwapSystemNo<br>tReady          | 10605 | Cannot swap flash by default because swap system is not ready       |  |
| kStatus_ReliableUpdateBackupBootloa<br>derNotReady    | 10606 | Cannot swap flash because there is no valid backup bootloader image |  |
| kStatus_ReliableUpdateSwapIndicatorA<br>ddressInvalid | 10607 | Cannot swap flash because provided swap indicator is invalid        |  |

#### Table 68. Error and status codes (continued)

## Appendix B GetProperty and SetProperty commands

Properties are the defined units of data that can be accessed with the GetProperty or SetProperty commands. Properties may be read-only or read-write. All read-write properties are 32-bit integers, so they can easily be carried in a command parameter. Not all properties are available on all platforms. If a property is not available, GetProperty and SetProperty return kStatus\_UnknownProperty.

The tag values shown in the table below are used with the GetProperty and SetProperty commands to query information about the flashloader.

| Name                 | Writable | Tag value | Size | Description                                                                                                           |
|----------------------|----------|-----------|------|-----------------------------------------------------------------------------------------------------------------------|
| CurrentVersion       | no       | 0x01      | 4    | Current<br>flashloader version                                                                                        |
| AvailablePeripherals | no       | 0x02      | 4    | Set of peripherals supported on this chip                                                                             |
| FlashStartAddress    | no       | 0x03      | 4    | Start address of program flash                                                                                        |
| FlashSizeInBytes     | no       | 0x04      | 4    | Size in bytes of program flash                                                                                        |
| FlashSectorSize      | no       | 0x05      | 4    | Size in bytes of one<br>sector of program flash,<br>this is the minimum<br>erase size                                 |
| FlashBlockCount      | no       | 0x06      | 4    | Number of blocks in the flash array                                                                                   |
| AvailableCommands    | no       | 0x07      | 4    | Set of commands<br>supported by<br>the flashloader                                                                    |
| CRCCheckStatus       | no       | 0x08      | 4    | Status of the application CRC check                                                                                   |
| Reserved             | n/a      | 0x09      | n/a  |                                                                                                                       |
| VerifyWrites         | yes      | 0x0a      | 4    | Controls whether the<br>bootloader verifies<br>writes to flash. The<br>VerifyWrites feature is<br>enabled by default. |
|                      |          |           |      | 0 - No verification<br>is done                                                                                        |
|                      |          |           |      | 1 - Enable verification                                                                                               |
| MaxPacketSize        | no       | 0x0b      | 4    | Maximum supported packet size for                                                                                     |

Table 69. Tag values GetProperty and SetProperty

| Name               | Writable | Tag value | Size | Description                                                                                                                                                                                                              |
|--------------------|----------|-----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |          |           |      | the currently active peripheral interface                                                                                                                                                                                |
| ReservedRegions    | no       | 0x0c      | n    | List of memory<br>regions reserved<br>by the flashloader.<br>Returned as value<br>pairs ( <start-address-<br>of-region&gt;,<end-<br>address-of-region&gt;)</end-<br></start-address-<br>                                 |
|                    |          |           |      | <ul> <li>If HasDataPhase<br/>flag is not set, then<br/>Response packet<br/>parameter count<br/>indicates number<br/>of pairs</li> </ul>                                                                                  |
|                    |          |           |      | <ul> <li>If HasDataPhase<br/>flag is set, then the<br/>second parameter<br/>is the number<br/>of bytes in the<br/>data phase</li> </ul>                                                                                  |
| RAMStartAddress    | no       | 0x0e      | 4    | Start address of RAM                                                                                                                                                                                                     |
| RAMSizeInBytes     | no       | 0x0f      | 4    | Size in bytes of RAM                                                                                                                                                                                                     |
| SystemDeviceId     | no       | 0x10      | 4    | Value of the<br>Kinetis System Device<br>Identification register                                                                                                                                                         |
| FlashSecurityState | no       | 0x11      | 4    | Indicates whether<br>Flash security<br>is enabled<br>0 - Flash security<br>is disabled<br>1 - Flash security<br>is enabled                                                                                               |
| UniqueDeviceId     | no       | 0x12      | n    | Unique device<br>identification. This<br>value is the<br>concatenation of<br>the Kinetis Unique<br>Identification registers.<br>For details, see the<br>Unique Identification<br>registers located in the<br>SIM module. |

#### Table 69. Tag values GetProperty and SetProperty (continued)

| Table 69. | Tag values | GetProperty | and SetProperty | (continued) |
|-----------|------------|-------------|-----------------|-------------|
|-----------|------------|-------------|-----------------|-------------|

| Name                         | Writable | Tag value | Size | Description                                                                                                                                                                                               |
|------------------------------|----------|-----------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FlashFacSupport              | no       | 0x13      | 4    | FAC (Flash Access<br>Control) support flag<br>0 - FAC not supported<br>1 - FAC supported                                                                                                                  |
| FlashAccessSegmentS<br>ize   | no       | 0x14      | 4    | Size in bytes of 1<br>segment of flash                                                                                                                                                                    |
| FlashAccessSegmentC<br>ount  | no       | 0x15      | 4    | FAC segment count<br>(The count of flash<br>access segments<br>within the flash model)                                                                                                                    |
| FlashReadMargin              | yes      | 0x16      | 4    | The margin level<br>setting for flash<br>erase and program<br>verify commands<br>0=Normal<br>1=User<br>2=Factory                                                                                          |
| QspilnitStatus               | no       | 0x17      | 4    | The result of the<br>QSPI or OTFAD<br>initialization process<br>405 - QSPI is<br>not initialized<br>0 - QSPI is initialized                                                                               |
| TargetVersion                | no       | 0x18      | 4    | Target build version number                                                                                                                                                                               |
| ExternalMemoryAttribut<br>es | no       | 0x19      | 24   | List of attributes<br>supported by the<br>specified memory Id<br>(0=Internal Flash,<br>1=QuadSpi0), see<br>description for the<br>return value in the<br>section<br>ExternalMemoryAttribu<br>tes Property |

## Legal information

### Definitions

**Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

## Disclaimers

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk. **Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

Terms and conditions of commercial sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at http://www.nxp.com/profile/terms, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

Suitability for use in non-automotive qualified products — Unless this data sheet expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

**Translations** — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

Security — Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately.

Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

#### Trademarks

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

NXP — wordmark and logo are trademarks of NXP B.V.

AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Kell, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile — are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved.

Airfast — is a trademark of NXP B.V.

Bluetooth — the Bluetooth wordmark and logos are registered trademarks owned by Bluetooth SIG, Inc. and any use of such marks by NXP Semiconductors is under license.

Cadence — the Cadence logo, and the other Cadence marks found at www.cadence.com/go/trademarks are trademarks or registered trademarks of Cadence Design Systems, Inc. All rights reserved worldwide.

**CodeWarrior** — is a trademark of NXP B.V. **ColdFire** — is a trademark of NXP B.V.

**ColdFire+**— is a trademark of NXP B.V.

EdgeLock — is a trademark of NXP B.V.

EdgeScale — is a trademark of NXP B.V.

EdgeVerse — is a trademark of NXP B.V.

elQ — is a trademark of NXP B.V.

FeliCa — is a trademark of Sony Corporation.

Freescale — is a trademark of NXP B.V.

**HITAG** — is a trademark of NXP B.V.

ICODE and I-CODE — are trademarks of NXP B.V.

**Immersiv3D** — is a trademark of NXP B.V.

I2C-bus - logo is a trademark of NXP B.V.

Kinetis — is a trademark of NXP B.V.

Layerscape — is a trademark of NXP B.V.

Mantis — is a trademark of NXP B.V.

MIFARE — is a trademark of NXP B.V.

MOBILEGT — is a trademark of NXP B.V.

NTAG — is a trademark of NXP B.V.

Processor Expert — is a trademark of NXP B.V.

QorIQ — is a trademark of NXP B.V.

SafeAssure — is a trademark of NXP B.V.

SafeAssure — logo is a trademark of NXP B.V.

**StarCore** — is a trademark of NXP B.V.

Synopsys — Portions Copyright <sup>©</sup> 2021 Synopsys, Inc. Used with permission. All rights reserved.

Tower — is a trademark of NXP B.V.

UCODE - is a trademark of NXP B.V.

VortiQa — is a trademark of NXP B.V.

# arm

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

© NXP B.V. 2016-2021.

#### All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com

> Date of release: 29 March 2022 Document identifier: MCUFLSHLDRRM