

This Application Note describes the functionality of the boot loaders for the NXP JN516x, JN514x and JN5139 wireless microcontrollers, covering the following topics:

- Operation of the boot loader after a cold start
- Operation of the boot loader after a warm start
- The Flash image application header
- The serial interface used to communicate with the boot loader

# Introduction

The JN514x and JN5139 devices have a ROM-based boot loader, while the JN516x boot loader is stored in internal Flash memory. The boot loader is executed by the CPU following a reset or on waking from sleep or deep sleep mode, when power is applied.

- The JN514x/JN5139 boot loader is designed to operate with external serial memory (normally Flash memory) connected to the SPI interface it loads the user application into RAM and starts program execution
- The JN516x boot loader executes user applications stored in internal Flash memory

# JN514x/JN5139 Boot Loader Operation

When started, the JN514x/JN5139 boot loader performs one of the following operations:

- Starts execution of the application, already present in RAM
- Copies an application from the external Flash memory device (starting at Flash memory location 0) to RAM and starts application execution
- Enters programming mode

The application must contain two entry points from which execution may begin - a wake-up point and a reset point. The locations of these points are stored in the header information contained within Flash memory.

If the application preserves the contents of the internal RAM when the device goes to sleep via the **vAHI\_Sleep()** function, passing either E\_AHI\_SLEEP\_OSCON\_RAMON or E\_AHI\_SLEEP\_OSCOFF\_RAMON, then the boot loader will restart the application from the wake-up entry point rather than the reset entry point.

If the application is not present in RAM, the boot loader will attempt to load the application from the external Flash memory. If the boot loader finds a valid application at address 0 in Flash memory, this application will be copied into RAM.

Alternatively, the boot loader may enter programming mode if the SPI MISO line is held low when the device is reset, or if no valid application image is found in the external Flash memory.

The boot loader operations for the JN5148, JN5142 and JN5139 devices are illustrated below. **The JN5148-001, JN5148-J01 and JN5148-Z01 variants have different boot loader operations** - the JN5148-J01 and JN5148-Z01 variants have the same boot loader operation as the JN5142 device. JN5142 variants (JN5142-001 and JN5142-J01) have the same bootloader operation and are referred to as JN5142 below.

### JN5148-001 Operation



#### Figure 1: JN5148-001 Boot Loader Operation



### JN5142 and JN5148-J01/Z01 Operation



### **JN5139 Operation**



Figure 3: JN5139 Boot Loader Operation

# **JN516x Boot Loader Operation**

The JN516x boot loader performs one of the following operations:

- Starts execution from internal Flash memory
- Copies application from external Flash memory into internal Flash memory and starts application execution
- Enters programming mode

The application must contain two entry points from which execution may begin - a wake-up point and a reset point. The locations of these points are stored in the header information contained within the internal Flash memory. If the application puts the device to sleep using the **vAHI\_Sleep()** function, on wake-up the boot loader will restart the application code from the wake-up entry point.

If no application is present in the internal Flash memory, the boot loader will search an optional external SPI Flash device for a valid application binary. If a binary is found, it will be loaded into internal Flash memory and executed from the reset entry point.

Alternatively, the boot loader may enter programming mode if the SPI MISO line is held low when the device is reset, or if no valid application image is found in the internal or external Flash memory.

### **JN516x Operation**



Figure 4: JN516x Boot Loader Operation

# **Flash Header**

Any user application programmed into the Flash memory device must include a header that contains information about the program and the device in which it is stored. The format of this header is detailed below for each JN516x/JN514x/JN5139 microcontroller.

| Bytes            | Word | Contents                                                                                                                                                         |  |  |  |
|------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0x0000 to 0x0003 | 0    | Configuration bytes: 0xAABBCCDD                                                                                                                                  |  |  |  |
|                  |      | AA - Reserved (always set to 0)                                                                                                                                  |  |  |  |
|                  |      | BB - Reserved (AA repeat, always 0)                                                                                                                              |  |  |  |
|                  |      | CC - Flash access configuration byte (see below for details)                                                                                                     |  |  |  |
|                  |      | DD - Flash access configuration byte (repeated)                                                                                                                  |  |  |  |
| 0x0004 to 0x0007 | 1    | The start address in RAM where the application data needs to be copied to (word-<br>aligned). The data copied to this address will start from Flash address 0x30 |  |  |  |
| 0x0008 to 0x000B | 2    | Length of data to copy to RAM from Flash address 0x30                                                                                                            |  |  |  |
|                  |      | (includes sections: .mac, .rodata, .data, .text, .bss)                                                                                                           |  |  |  |
| 0x000C to 0x000F | 3    | Chip ROM version for which the binary was compiled                                                                                                               |  |  |  |
| 0x0010 to 0x0013 | 4    | Must be 0                                                                                                                                                        |  |  |  |
| 0x0014 to 0x0017 | 5    | Start address for .bss segment in RAM (word-aligned)                                                                                                             |  |  |  |
| 0x0018 to 0x001B | 6    | ength of .bss segment in RAM                                                                                                                                     |  |  |  |
| 0x001C to 0x001F | 7    | Vake-up entry point (word-aligned) (address of AppWarmStart())                                                                                                   |  |  |  |
| 0x0020 to 0x0023 | 8    | Reset entry point (word-aligned) (address of AppColdStart())                                                                                                     |  |  |  |
| 0x0024 to 0x0027 | 9    | OAD (Over-Air Download) channel scan                                                                                                                             |  |  |  |
| 0x0028 to 0x0029 | 10   | OAD channel scan bitmap                                                                                                                                          |  |  |  |
| 0x002A to 0x002B |      | OAD application/server identification                                                                                                                            |  |  |  |
| 0x002C to 0x002D | 11   | Unused                                                                                                                                                           |  |  |  |
| 0x002E           |      | Revert and valid flags for OAD                                                                                                                                   |  |  |  |
| 0x002F           |      | Invalid flags for OAD                                                                                                                                            |  |  |  |
| 0x0030 to End    |      | Application data                                                                                                                                                 |  |  |  |
|                  |      | The first 32 bytes contain an 8-byte MAC address and 24 bytes for ZigBee use                                                                                     |  |  |  |

### JN5148-001 Flash Header

#### Table 1: JN5148-001 Flash Header

The Flash header is defined at compile/link time by the chip-specific linker file located in the SDK directory at **Chip\<Chip Name>\Build**.

#### Flash Access Configuration Byte

If the first Flash access configuration byte is 0xFF, this indicates a blank Flash memory. Otherwise, the Flash access configuration byte is interpreted as follows:

| Bit | Contents                                                                                                                                                                                                            |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | Always set to 3                                                                                                                                                                                                     |
| 5   | Address field supported:                                                                                                                                                                                            |
|     | 0 for 16-bit address                                                                                                                                                                                                |
|     | 1 for 24-bit address                                                                                                                                                                                                |
| 4:0 | SPI clock divider value to be used. This will be used to<br>set the SPI divider setting in the SPI master, padded with<br>a 0 as the MSB of the 6-bit divider field (0x1F is not a<br>valid setting for this field) |

The first four bytes will be read from Flash memory with a SPI clock speed of 1 MHz. The boot loader will then use the SPI clock divider from the Flash access configuration byte to set the SPI clock for the remaining reads.

| Bytes               | Word  | Contents                                                    |
|---------------------|-------|-------------------------------------------------------------|
| 0x0000 to 0x000F    | 0 - 3 | 16-byte Boot Image Record                                   |
| 0x0010 to 0x0017    | 4 - 5 | 64-bit MAC address                                          |
| 0x0018 to 0x0027    | 6 - 9 | Encryption Initialisation Vector (ignored if unencrypted)   |
| 0x0028 to 0x0029    | 10    | 16-bit load address for .text segment in RAM (word aligned) |
| 0x002A to 0x002B    | 10    | 16-bit length of .text segment, in 32-bit words             |
| 0x002C to 0x002D    | 11    | 16-bit load address for .bss segment in RAM (word aligned)  |
| 0x002E to 0x002F    | 11    | 16-bit length of .bss segment in RAM, in 32-bit words       |
| 0x0030 to 0x0033    | 12    | 32-bit wake-up entry point (word aligned) – warm start      |
| 0x0034 to 0x0037    | 13    | 32-bit reset entry point (word aligned) – cold start        |
| 0x0038 to (MemA -1) | 14 -  | .text segment                                               |
| MemA to (MemB-1)    |       | .data segment                                               |
| MemB                |       | Overlay segment                                             |

## JN5142 and JN5148-J01/Z01 Flash Header

#### Table 2: JN5142 and JN5148-J01/Z01 Flash Header

MemA = (Length of .text segment x 4) + 0x0038MemB = (Length of .data segment x 4) + MemA

**Note:** A built binary file contains an extra 4 bytes (for the version number) at the beginning of the file which are stripped out when the file is stored in Flash memory.

The Flash header is defined at compile/link time by the chip-specific linker file located in the SDK directory at **Chip\<Chip Name>\Build**.

The 16-byte Boot Image Record (BIR), contained in words 0-3 of the Flash header, is structured as follows:

| Name          | Size     | Comment                                                                                                                             |
|---------------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| Magic Number  | 12 bytes | Pattern to denote start sector of boot image                                                                                        |
| Configuration | 1 byte   | Used to carry configuration information to set up the SPI to suit the Flash device, and size of the image contained in Flash memory |
|               |          | Bits 7:4 – Image size in 32-Kbyte blocks:                                                                                           |
|               |          | 0000: 32K                                                                                                                           |
|               |          | 0001: 64K                                                                                                                           |
|               |          | 0010: 96K                                                                                                                           |
|               |          | 0011: 128K                                                                                                                          |
|               |          | 0100: 160K                                                                                                                          |
|               |          | 0101: 192K                                                                                                                          |
|               |          | 0110: 224K                                                                                                                          |
|               |          | 0111: 256K<br>1000: 288K                                                                                                            |
|               |          | 1000. 288K                                                                                                                          |
|               |          | 1010: 352K                                                                                                                          |
|               |          | 1011: 384K                                                                                                                          |
|               |          | 1100: 416K                                                                                                                          |
|               |          | 1101: 448K                                                                                                                          |
|               |          | 1110: 480K                                                                                                                          |
|               |          | 1111: 512K                                                                                                                          |
|               |          | Bit 3 - Delay Read to next SPI clock edge (DRE) hardware option to enhance reliability of reading data from slower devices:         |
|               |          | 0 = Disabled                                                                                                                        |
|               |          | 1 = Enabled                                                                                                                         |
|               |          |                                                                                                                                     |
|               |          | Bits 2:0 - SPI clock rate:                                                                                                          |
|               |          | 000: 16 MHz                                                                                                                         |
|               |          | 001: 8 MHz                                                                                                                          |
|               |          | 010: 4 MHz                                                                                                                          |

|                |         | 011: 2 MHz<br>100: 1 MHz<br>101: 0.5 MHz<br>110, 111 reserved                      |
|----------------|---------|------------------------------------------------------------------------------------|
| Status         | 1 byte  | 0xFF – empty (erased)<br>0x00 – invalid<br>0x01 – valid<br>0x02 to 0xFE – reserved |
| Application ID | 2 bytes |                                                                                    |

#### Table 3: Boot Image Record (BIR) for JN5142 and JN5148-J01/Z01

The boot loader searches for the first image that is valid and that has an Application ID in **BIR>Configuration>Application ID** which matches the search (default search is 0). If none is found, it enters boot programming mode for communication over the UART. All BIRs are aligned to the minimum image-size boundary of 32 Kbytes. They will be further apart if the images are larger than 32 Kbytes. In such cases, the **BIR>Configuration>Image size** field allows the boot loader to find the next image, assuming that the BIR is deemed valid (note that a BIR is deemed valid if the magic number is correct). The **BIR>Status** field refers to the status of the rest of the image after the BIR.

### **JN5139 Flash Header**

The JN5139 Flash header is as described for the JN5148 device in Table 1 except for the reserved fields at Flash addresses 0x00 and 0x01, which should always be 7 (instead of 0). The information provided for JN5148 on the 'Flash access configuration byte' is also applicable to the JN5139 device.

The Flash header is defined at compile/link time by the chip-specific linker file located in the SDK directory at **Chip\<Chip Name>\Build**.

| Bytes               | Word  | Contents                                                  |  |  |  |  |
|---------------------|-------|-----------------------------------------------------------|--|--|--|--|
| 0x00 - 0x0F         | 0 - 3 | 16-byte Boot Image Record                                 |  |  |  |  |
| 0x10 – 0x1D         | 4 – 7 | Encryption Initialisation Vector (ignored if unencrypted) |  |  |  |  |
| 0x1E – 0X1F         | 7     | 16-bit Software Configuration Options                     |  |  |  |  |
| 0x20 – 0x23         | 8     | 32-bit Length of Binary Image in bytes                    |  |  |  |  |
| 0x24 – 0x27         | 9     | 32-bit .data section Flash start address                  |  |  |  |  |
| 0x28 – 0x29         | 10    | 16-bit .data section load address in RAM (word aligned)   |  |  |  |  |
| 0x2A – 0x2B         | 10    | 16-bit .data section length in 32-bit words               |  |  |  |  |
| 0x2C - 0x2D         | 11    | 16 bit .bss section start address in RAM (word aligned)   |  |  |  |  |
| 0x2E – 0x2F         | 11    | 16-bit .bss section length in 32-bit words                |  |  |  |  |
| 0x30 – 0x33         | 12    | 32-bit wake-up entry point (word aligned) – warm start    |  |  |  |  |
| 0x34 - 0x37         | 13    | 32-bit reset entry point (word aligned) – cold start      |  |  |  |  |
| 0x0038 to (MemA -1) | 14 -  | .text segment                                             |  |  |  |  |
| MemA                |       | .data segment                                             |  |  |  |  |

#### Table 4: JN516x Flash Header

MemA = (Length of .text segment x 4) + 0x0038MemB = (Length of .data segment x 4) + MemA

**Note:** A built binary file contains an extra 4 bytes (for the version number) at the beginning of the file which are stripped out when the file is stored in Flash memory.

The Flash header is defined at compile/link time by the chip-specific linker file located in the SDK directory at **Chip\<Chip Name>\Build**.

The 16-byte Boot Image Record (BIR) is the same as described in Table 2.

# **Software Configuration**

Before the boot loader jumps to the application entry point, the JTAG debugger is configured as detailed in the options below.

| Bit  | Contents                           |
|------|------------------------------------|
| 2-15 | Unused                             |
| 1    | 0 – JTAG Debug on DIO4-7           |
|      | 1 – JTAG Debug on DIO12-15         |
| 0    | Debug Enable (1 Enable, 0 Disable) |

# **External (Flash) Memory**

The external serial memory must be connected to the SPI port using the SPISEL0 select line.





### **JN5148 Supported Devices**

The JN5148 supports the following devices:

- SST 25VF0101 (128 Kbytes)
- ATMEL AT25F512 (64 Kbytes)
- ST M25P10-A (128 Kbytes)
- ST M25P40 (512 Kbytes)

### **JN5142 Supported Devices**

The JN5142 supports all the above devices (as for JN5148) plus the following devices:

- ST M25P05-A (64 Kbytes)
- ST M25P20-A (256 Kbytes)

### **JN5139 Supported Devices**

The JN5139 supports the following devices:

- SST 25VF0101 (128 Kbytes)
- ATMEL AT25F512 (64 Kbytes)
- ST M25P10-A (128 Kbytes)

# **Memory Maps**

### JN514x/JN5139 Memory Maps

The JN5148 device has 128 Kbytes of RAM, the JN5142 device has 32 Kbytes of RAM, and the JN5139 device has 96 Kbytes of RAM.



Figure 6: JN514x/JN5139 Memory Maps

### JN516x Memory Maps

On the JN516x device, user application code is stored and executed in the internal Flash memory, while user data is stored in RAM. The internal Flash memory is memory-mapped and can be read using normal memory read accesses. However, writes to the internal Flash memory must be done using functions of the JN516x Integrated Peripherals API.



Figure 7: JN516x Memory Maps

**Note:** The MAC address is read-only. A custom MAC address can be programmed which supersedes the production MAC address. However, this is a 'one time programmable' process, which cannot be reversed. The custom MAC address can be programmed via the JN51xx Flash Programmer.

**(i)** 

## **Serial Protocol**

The protocol defines a message structure and set of messages that allow a client to communicate with the JN514x/JN5139 chip, and hence perform operations on the external Flash memory. Serial communication between the PC and boot loader is implemented as 8,N,1,38K4 from the JN514x/JN5139 UART 0.

The JN514x/JN5139 device will respond to the serial protocol when it has entered programming mode, either due to a reset when the MISO line is asserted of if the Flash chip is deemed to be blank.

### **Message Structure**

A message contains four fields and is structured as follows:

| Field | 1      | 2            | 3            | 4        |
|-------|--------|--------------|--------------|----------|
| Bytes | 1      | 1            | (x)          | 1        |
| Data  | Length | Message Type | Message Data | Checksum |

 Table 4: Message Structure

**Length** The number of bytes in the rest of the message, including the checksum. Note that the maximum total message size is 255.

**Message Type** Defined below.

Message DataVariable length and dependent on message type.May be zero-length (i.e. not present)

**Note:** For Flash/RAM Read/Write requests, a maximum of 128 bytes should be read or written.

**Checksum** Calculated over the preceding part of the message, including the Length field, by implementing a logical Exclusive-OR operation on the previous bytes.

### **Byte Transfer Timeout**

A timeout is applied to the reception of each individual byte of a message. This timeout depends on the CPU clock frequency. When using the 16-MHz clock, in your download program you are advised not to allow more than 5 seconds between bytes transmitted.

## Message Types

Message types are as follows (N/A means that an optional field is not present):

| Message<br>Type | Meaning                                       | Originator        | Supported<br>Devices                 | # Parms | Message Parameters                                                                                                                                                                             | Response<br>Message<br>Type |
|-----------------|-----------------------------------------------|-------------------|--------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x00 to<br>0x06 | Reserved                                      | N/A               | N/A                                  | N/A     | N/A                                                                                                                                                                                            | N/A                         |
| 0x07            | Flash<br>erase<br>request<br>(All<br>Sectors) | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 0       | N/A                                                                                                                                                                                            | 0x08                        |
| 0x08            | Flash<br>erase<br>response                    | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | <ul> <li>#1: Status (1 byte):</li> <li>0x00: Erase successful</li> <li>0xFF: Parameter error</li> <li>0xF7: Auth error</li> </ul>                                                              | N/A                         |
| 0x09            | Flash<br>program<br>request                   | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul> <li>#1: Flash address (4 bytes), LSB first</li> <li>#2: Up to 128 bytes of data</li> <li>Note: Data should not span page write boundary as defined by the Flash specification.</li> </ul> | 0x0A                        |
| 0x0A            | Flash<br>program<br>response                  | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | <ul> <li>#1: Status (1 byte):</li> <li>0x00: Program successful</li> <li>0xFF: Readback verify failed</li> <li>0xF7: Auth error</li> </ul>                                                     | N/A                         |
| 0x0B            | Flash<br>read<br>request                      | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul> <li>#1: Flash address (4 bytes), LSB first</li> <li>#2: Length (2 bytes), LSB first</li> <li>(Length should not be greater than<br/>128 bytes)</li> </ul>                                 | 0x0C                        |
| 0x0C            | Flash<br>read<br>response                     | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul> <li>#1: Status (1 byte):</li> <li>0x00 (success)</li> <li>0xF7 (Auth error)</li> <li>#2: Bytes read from Flash</li> </ul>                                                                 | N/A                         |
| 0x0D            | Sector<br>erase<br>request                    | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: Sector to erase (1 Byte)<br><b>Note:</b> Ensure the write protection is<br>disabled by writing 0 to the status<br>register using message 0x0F.                                             | 0x0E                        |
| 0x0E            | Sector<br>erase<br>response                   | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | <ul> <li>#1: Status (1 byte):</li> <li>0x00: Erase successful</li> <li>0xFF: Erase error</li> <li>0xF7: Auth error</li> </ul>                                                                  | N/A                         |
| 0x0F            | Write SR<br>(status<br>register)<br>request   | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: SR Value (1 byte)                                                                                                                                                                          | 0x10                        |
| 0x10            | Write SR<br>response                          | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: Status (1 byte):<br>0x00: Write successful<br>0xFF: Write error<br>0xF7: Auth error                                                                                                        | N/A                         |
| 0x1D            | RAM write<br>request                          | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul><li>#1: RAM address (4 bytes), LSB first</li><li>#2: Bytes to write into RAM (Up to 128 bytes)</li></ul>                                                                                   | 0x1E                        |

| Message<br>Type | Meaning                            | Originator        | Supported<br>Devices                 | # Parms | Message Parameters                                                                                                                                                      | Response<br>Message<br>Type |
|-----------------|------------------------------------|-------------------|--------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x1E            | RAM write<br>response              | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: Status (1 byte):<br>0x00 (success)<br>0xF7 (Auth error)                                                                                                             | N/A                         |
| 0x1F            | RAM read request                   | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | #1: RAM address (4 bytes), LSB first<br>#2: No. of bytes to read (2 bytes), LSB<br>first (should not be greater than 128<br>bytes)                                      | 0x20                        |
| 0x20            | RAM read<br>response               | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul> <li>#1: Status (1 byte):</li> <li>0x00 (success)</li> <li>0xF7 (Auth error)</li> <li>#2: x bytes read from RAM</li> </ul>                                          | N/A                         |
| 0x21            | Run<br>request                     | PC                | JN5148<br>JN5139<br>JN516x           | 1       | #1: Address to jump to (4 bytes), LSB first                                                                                                                             | 0x22                        |
| 0x22            | Run<br>response                    | JN514x/<br>JN5139 | JN5148<br>JN5139<br>JN516x           | 1       | #1: Status (1 byte):<br>0x00 (success)<br>0xF7 (Auth error)                                                                                                             | N/A                         |
| 0x25            | Read<br>Flash ID<br>request        | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 0       | N/A                                                                                                                                                                     | 0x26                        |
| 0x26            | Read<br>Flash ID<br>response       | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 3       | <ul> <li>#1: Status (1 byte):<br/>0x00 (success)<br/>0xF7 (Auth error)</li> <li>#2: Flash manufacturer ID (1 byte)</li> <li>#3: Flash device ID (1 byte)</li> </ul>     | N/A                         |
| 0x27            | Change<br>Baud<br>Rate<br>Request  | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: Serial Clock Divisor<br>1 = 100000<br>2 = 500000<br>9 = 115200 (approx.)<br>26 = 38400 (approx.)                                                                    | N/A                         |
| 0x28            | Change<br>Baud<br>Rate<br>Response | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1: Status (1 byte):<br>0x00 (success)                                                                                                                                  | 0x27                        |
| 0x2C            | Select<br>Flash type               | PC                | JN5148<br>JN5142<br>JN5139<br>JN516x | 2       | <ul> <li>#1 : Flash type (1 byte)<br/>(see table below for mapping)</li> <li>#2: Custom programming jump<br/>address (4 bytes), LSB first<br/>(set to 0000),</li> </ul> | 0x2D                        |
| 0x2D            | Select<br>Flash type<br>response   | JN514x/<br>JN5139 | JN5148<br>JN5142<br>JN5139<br>JN516x | 1       | #1 byte: Status                                                                                                                                                         | N/A                         |
| 0x32            | Get<br>Chip ID<br>Request          | PC                | JN5148<br>JN5142<br>JN516x           | 0       | N/A<br><b>Note:</b> The Chip ID for the JN5139 and<br>JN5121 can be obtained by a RAM<br>read on address 0x100000FC                                                     | N/A                         |

#### JN51xx Boot Loader Operation

| Message<br>Type | Meaning                    | Originator | Supported<br>Devices       | # Parms | Message Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                               | Response<br>Message<br>Type |
|-----------------|----------------------------|------------|----------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| 0x33            | Get<br>Chip ID<br>Response | JN514x     | JN5148<br>JN5142<br>JN516x | 2       | <ul> <li>#1: Status (1 byte):<br/>0x00 (success)</li> <li>#2: Chip ID (4 bytes) (MSB first):</li> <li>Note: The Chip ID for the JN5139 can<br/>be obtained by a RAM read of 4 bytes<br/>from address 0x100000FC</li> <li>The Chip IDs for the current range of<br/>microcontrollers are:<br/>JN5148: 0x10404686</li> <li>JN5142: 0x00005686</li> <li>JN5139: 0x10002000</li> <li>The above IDs are subject to change<br/>with further chip revisions.</li> </ul> | 0x32                        |

#### Table 5: Message Types

### Mapping Flash IDs to Flash Device Types

The JN516x, JN5148, JN5142 and JN5139 devices support multiple Flash device types. It is the responsibility of the PC application to instruct the boot loader which Flash device to use. To determine the Flash device type connected, issue a Read Flash ID request (0x25). The device will respond with the Manufacturer ID and Device ID shown in Table 6. To select a Flash device type, issue a Select Flash Type request (0x2C), with the appropriate Select Flash Type in Table 6.

| Manufacturer ID | Device ID | Select Flash Type | Туре                            |
|-----------------|-----------|-------------------|---------------------------------|
| 0x05            | 0x05      | 4                 | ST M25P05-A                     |
| 0x10            | 0x10      | 0                 | ST M25P10-A                     |
| 0x11            | 0x11      | 5                 | ST M25P20-A                     |
| 0x12            | 0x12      | 3                 | ST M25P40                       |
| 0xBF            | 0x49      | 1                 | SST 25VF010A                    |
| 0x1F            | 0x60      | 2                 | Atmel 25F512                    |
| 0xCC            | 0xEE      | 8                 | Internal Flash<br>(JN516x only) |

Table 6: Flash IDs

### **Response Status Code**

| Status Type      | ID   |  |
|------------------|------|--|
| ОК               | 0    |  |
| Not supported    | 0xFF |  |
| Write fail       | 0xFE |  |
| Invalid response | 0xFD |  |
| CRC error        | 0xFC |  |
| Assert fail      | 0xFB |  |
| User interrupt   | 0xFA |  |
| Read fail        | 0xF9 |  |
| TST error        | 0xF8 |  |
| Auth error       | 0xF7 |  |
| No response      | 0xF6 |  |

 Table 7: Response Status Codes

# **Binary Version**

### **Binary Version on JN514x and JN5139**

When a binary file is built, the ROM version for which it was built is stored in the binary file at offset 0x0C for JN5148 and JN5139, and at offset 0x00 for JN5142. This is configured in the linker configuration file stored in the chip build directory, i.e. one of:

- Chip\JN5148\Build\AppBuild\_JN5148.Id
- Chip\JN5142\Build\AppBuild\_JN5142.Id
- Chip\JN513x\Build\AppBuild\_JN5139.Id

To verify that the binary file is correct for the target device, the boot loader should perform a RAM read of 4 bytes from address 0x00000004. If the two versions do not match then the binary file has been built for the wrong target.

### **Binary Version on JN516x**

The device version is stored in the application binary at offset 0x00. This is configured in the linker configuration file stored in the chip build directory:

#### Chip\<Chip> \AppBuild\_<Chip>.Id

The version number is 4 bytes long and is configured as shown in the table below.

| Byte  | Contents                                                                                       | JN5168 | JN5164 | JN5161 |
|-------|------------------------------------------------------------------------------------------------|--------|--------|--------|
| 0     | Flash size in<br>increments of 32K<br>0x00 – 32K<br>0x01 – 64K<br>0x02 – 96K<br><br>0x07- 256K | 0x07   | 0x04   | 0x01   |
| 1     | RAM size in<br>increments of 8K<br>0x00 – 8K<br>0x01 – 16K<br>0x02 – 24K<br>0x03 – 32K         | 0x03   | 0x03   | 0x00   |
| 2 - 3 | Chip Type<br>JN516x = 0x0008                                                                   | 0x0008 | 0x0008 | 0x0008 |

Table 8: JN516x Version

# **Example Programming Sequence**

The PC application must dynamically determine which Flash device is connected to the wireless microcontroller. This is achieved by issuing the FL\_READ\_ID\_REQ message. The response will give the Manufacturer ID and Device ID of the Flash device attached.



#### Figure 8: Flash Device Type Selection Sequence

Once the Flash device type is known, the type can be set within the boot loader by sending a FL\_SELECT\_FLASH\_TYPE\_REQUEST.

After the Flash type has been selected, the programming sequence is the same for all JN51xx devices, as illustrated below.



Figure 9: Flash Programming Sequence

# **Revision History**

| Version | Notes                                                                                                                                                                                       |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0     | Initial Release                                                                                                                                                                             |
| 1.1     | Corrected Flowchart                                                                                                                                                                         |
| 1.2     | Added Boot Loader Timing Parameters                                                                                                                                                         |
| 1.3     | Re-templated                                                                                                                                                                                |
| 1.4     | Corrected Flowchart                                                                                                                                                                         |
| 1.5     | <ul> <li>New format</li> <li>Corrected JN5121 details</li> <li>Added information for the JN5139 and JN5148 devices</li> <li>Merged with JN-AN-1007 "Boot Loader Serial Protocol"</li> </ul> |
| 1.6     | Internal version with JN5142 device added                                                                                                                                                   |
| 1.7     | Differences between JN5148 variants described and JN5121 device removed                                                                                                                     |
| 1.8     | Added reference to JN5142-J01                                                                                                                                                               |
| 1.9     | Added information for JN516x series                                                                                                                                                         |

## **Important Notice**

**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.

**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.

All trademarks are the property of their respective owners.

NXP Laboratories UK Ltd (Formerly Jennic Ltd) Furnival Street Sheffield S1 4QT United Kingdom

Tel: +44 (0)114 281 2655 Fax: +44 (0)114 281 2951

www.nxp.com/jennic