Copyright 2020 © Embedded Artists AB

# How to program and access fuses on Embedded Artists i.MX based boards



### **Embedded Artists AB**

Jörgen Ankersgatan 12 SE-211 45 Malmö Sweden

http://www.EmbeddedArtists.com

### Copyright 2020 © Embedded Artists AB. All rights reserved.

No part of this publication may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language or computer language, in any form or by any means, electronic, mechanical, magnetic, optical, chemical, manual or otherwise, without the prior written permission of Embedded Artists AB.

### Disclaimer

Embedded Artists AB makes no representation or warranties with respect to the contents hereof and specifically disclaim any implied warranties or merchantability or fitness for any particular purpose. Information in this publication is subject to change without notice and does not represent a commitment on the part of Embedded Artists AB.

### Feedback

We appreciate any feedback you may have for improvements on this document. Send your comments by using the contact form: <u>www.embeddedartists.com/contact</u>.

### Trademarks

All brand and product names mentioned herein are trademarks, services marks, registered trademarks, or registered service marks of their respective owners and should be treated as such.

## **Table of Contents**

| 1                                                                                                                                                                      | Document Revision History 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2                                                                                                                                                                      | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2.1                                                                                                                                                                    | Conventions in the document                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3                                                                                                                                                                      | Fuses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3.1                                                                                                                                                                    | Organization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3.2                                                                                                                                                                    | How to get bank and word index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3.3                                                                                                                                                                    | User's Manual reference: OCOTP memory map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3.4                                                                                                                                                                    | User's Manual reference: Fusemap Descriptions table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4                                                                                                                                                                      | Examples in Linux9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4.1                                                                                                                                                                    | OCOTP register mapped to sysfs9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4.2                                                                                                                                                                    | Example: iMX7 Dual – Get silicon revision9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4.3                                                                                                                                                                    | Example: iMX6 SoloX – Get speed grading                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5                                                                                                                                                                      | Examples in U-boot 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5.1                                                                                                                                                                    | Fuse command 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5.2                                                                                                                                                                    | Example: iMX7 Dual – Get silicon revision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5.3                                                                                                                                                                    | Example: iMX6 SoloX – Get speed grading 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6                                                                                                                                                                      | Boot from eMMC 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>6.1                                                                                                                                                               | Boot from eMMC 11<br>Supported COM boards 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>6</b><br>6.1<br>6.2                                                                                                                                                 | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6<br>6.1<br>6.2<br>6.3                                                                                                                                                 | Boot from eMMC         11           Supported COM boards         11           COM Carrier Board v2         11           iMX6 SoloX COM         12                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>6.1<br>6.2<br>6.3                                                                                                                                                 | Boot from eMMC         11           Supported COM boards         11           COM Carrier Board v2         11           iMX6 SoloX COM         12           1         Instructions         14                                                                                                                                                                                                                                                                                                                                                                          |
| 6<br>6.1<br>6.2<br>6.3<br>6.3.<br>6.4                                                                                                                                  | Boot from eMMC         11           Supported COM boards         11           COM Carrier Board v2         11           iMX6 SoloX COM         12           1         Instructions         14           iMX6 UltraLite COM         14                                                                                                                                                                                                                                                                                                                                  |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> </ul>                                                                                                         | Boot from eMMC         11           Supported COM boards         11           COM Carrier Board v2         11           iMX6 SoloX COM         12           1 Instructions         14           iMX6 UltraLite COM         14           1 Instructions         16                                                                                                                                                                                                                                                                                                      |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.3.</li> <li>6.4</li> <li>6.5</li> </ul>                                                                              | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16                                                                                                                                                                                                                                                                                                 |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4.</li> <li>6.5.</li> </ul>                                                                             | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       17                                                                                                                                                                                                                                                                                                 |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4.</li> <li>6.5.</li> <li>6.6</li> <li>6.6</li> </ul>                                                   | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       17         iMX8M Quad COM       17                                                                                                                                                                                                                                                                 |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.6</li> </ul>                                                     | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       17         iMX8M Quad COM       17         1 Instructions       19                                                                                                                                                                                                                                 |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4.</li> <li>6.5.</li> <li>6.6</li> <li>6.6.</li> <li>6.7</li> <li>6.7</li> </ul>                        | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19                                                                                                                                                                |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.7</li> <li>6.7</li> <li>6.8</li> </ul>                           | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19         1 Instructions       20                                                                                                                                |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.6</li> <li>6.7</li> <li>6.8</li> <li>6.8</li> </ul>              | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19         1 Instructions       20         iMX8M Nano uCOM       20         1 Instructions       20                                                               |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.7</li> <li>6.7</li> <li>6.8</li> <li>6.8</li> <li>6.9</li> </ul>              | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19         1 Instructions       20         iMX8M Nano uCOM       20         1 Instructions       22                                                               |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.7</li> <li>6.8</li> <li>6.8</li> <li>6.9</li> <li>6.9</li> </ul> | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19         1 Instructions       20         iMX8M Nano uCOM       20         1 Instructions       22         iMX7ULP uCOM       22                                 |
| <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.4</li> <li>6.5</li> <li>6.6</li> <li>6.6</li> <li>6.7</li> <li>6.8</li> <li>6.8</li> <li>6.9</li> </ul> | Boot from eMMC       11         Supported COM boards       11         COM Carrier Board v2       11         iMX6 SoloX COM       12         1 Instructions       14         iMX6 UltraLite COM       14         1 Instructions       16         iMX7 Dual COM       16         1 Instructions       17         iMX8M Quad COM       17         1 Instructions       19         iMX8M Mini uCOM       19         1 Instructions       20         iMX8M Nano uCOM       20         1 Instructions       22         iMX7ULP uCOM       22         1 Instructions       22 |

# **1** Document Revision History

| Revision | Date       | Description                                                               |
|----------|------------|---------------------------------------------------------------------------|
| A        | 2016-09-06 | First release                                                             |
| В        | 2020-03-18 | Added chapters 6 – Boot from eMMC and chapter 7 – Program Fuses from UUU. |

### 2 Introduction

The i.MX processors have One Time Programmable (OTP) fuses which are used to store different kinds of permanent configuration settings. This could, for example, be boot configuration, MAC address, secure boot settings, and so on.

This document describes how to access and program these fuses from within the u-boot bootloader and Linux.

### 2.1 Conventions in the document

A number of conventions have been used throughout to help the reader better understand the content of the document.

Constant width text - is used for file system paths and command, utility and tool names.

```
$ This field illustrates user input in a terminal running on the
development workstation, i.e., on the workstation where you edit,
configure and build Linux
```

```
# This field illustrates user input on the target hardware, i.e.,
input given to the terminal attached to the COM Board
```

```
This field is used to illustrate example code or excerpt from a document.
```

This field is used to highlight important information

### 3 Fuses

### 3.1 Organization

On the i.MX processor the fuses are normally organized in a number of banks where each bank consists of a number of words and each word is typically 32 bits. Each bit can be a one-time-programmable fuse.

As an example, the i.MX7 Dual processor has 16 pieces of 128-bit wide banks with four words in each bank.

**NOTE**: Always refer to the User's Manual for the processor you are using to get the exact description of the fuses on that specific processor.

### 3.2 How to get bank and word index

If you need to determine which bank and word index a specific fuse is located at the easiest is to look at the OCOTP memory map table in the User's Manual for the processor you are working with.

As an example, look at Figure 1 and see that OCOTP\_LOCK is located at Bank0 Word0.

| 3035_0400 Value of OTP Banko World (LOCK Controls) 32 R/W 0000_0000h 1131 |
|---------------------------------------------------------------------------|
|---------------------------------------------------------------------------|

Table continues on the next page...

i.MX 7Dual Applications Processor Reference Manual, Rev. 1, 01/2018

1116

Chapter 6 SNVS, Reset, Fuse and Boot

NXP Semiconductors

| Absolute<br>address<br>(hex) | Register name                                                                  | Width<br>(in bits) | Access | Reset value | Section/<br>page  |  |  |  |  |
|------------------------------|--------------------------------------------------------------------------------|--------------------|--------|-------------|-------------------|--|--|--|--|
| 3035_0410                    | Value of OTP Bank0 Word1 (Tester Information)<br>(OCOTP_TESTER0)               | 32                 | R/W    | 0000_0000h  | 6.4.5.18/<br>1133 |  |  |  |  |
| 3035_0420                    | Value of OTP Bank0 Word2 (Tester Information)<br>(OCOTP_TESTER1)               | 32                 | R/W    | 0000_0000h  | 6.4.5.19/<br>1133 |  |  |  |  |
| 3035_0430                    | Value of OTP Bank0 Word3 (Tester Information)<br>(OCOTP_TESTER2)               | 32                 | R/W    | 0000_0000h  | 6.4.5.20/<br>1134 |  |  |  |  |
| 3035_0440                    | Value of OTP Bank1 Word0 (Tester Information)<br>(OCOTP_TESTER3)               | 32                 | R/W    | 0000_0000h  | 6.4.5.21/<br>1134 |  |  |  |  |
| 3035_0450                    | Value of OTP Bank1 Word1 (Tester Information)<br>(OCOTP_TESTER4)               | 32                 | R/W    | 0000_0000h  | 6.4.5.22/<br>1135 |  |  |  |  |
| 3035_0460                    | Value of OTP Bank1 Word2 (Tester Information)<br>(OCOTP_TESTER5)               | 32                 | R/W    | 0000_0000h  | 6.4.5.23/<br>1135 |  |  |  |  |
| 3035_0470                    | Value of OTP Bank1 Word3 (Boot Configuration Information)<br>(OCOTP_BOOT_CFG0) | 32                 | R/W    | 0000_0000h  | 6.4.5.24/<br>1136 |  |  |  |  |
| 3035_0480                    | Value of OTP Bank2 Word0 (Boot Configuration Information)<br>(OCOTP_BOOT_CFG1) | 32                 | R/W    | 0000_0000h  | 6.4.5.25/<br>1136 |  |  |  |  |
| 3035_0490                    | Value of OTP Bank2 Word1 (Boot Configuration Information)<br>(OCOTP_BOOT_CFG2) | 32                 | R/W    | 0000_0000h  | 6.4.5.26/<br>1137 |  |  |  |  |

#### OCOTP memory map (continued)

Figure 1 OCOTP memory map for iMX7 Dual

The table in Figure 1 also specifies the absolute address of the register which for OCOTP\_LOCK is 0x30350400. The last part of this address (0x400) is the fuse address usually listed in the Fusemap table in the User's manual, see Figure 2.

| Fuse<br>Address | Fuses Name                                          | Numbe<br>r of<br>Fuses | Fuses Function                                    | Setting      | Used by                    |
|-----------------|-----------------------------------------------------|------------------------|---------------------------------------------------|--------------|----------------------------|
| 0x400[1:0]      | TESTER_LOCK                                         | 2                      | Lock for tester related fuses                     | 00 - Unlock  | Programmed to              |
|                 |                                                     |                        | at 0x400-0x460.                                   | 10 - OP      | 11 by NXP during<br>device |
|                 |                                                     |                        |                                                   | 01 - WP      | manufacturing.             |
|                 |                                                     |                        |                                                   | 11 - OP + WP |                            |
| 0x400[3:2]      | BOOT_CFG_LOCK                                       | 2                      | Lock for BOOT related fuses                       | 00 - Unlock  | OCOTP                      |
|                 |                                                     |                        | at 0x470-4B0.                                     | 10 - OP      |                            |
|                 |                                                     |                        |                                                   | 01 - WP      |                            |
|                 |                                                     |                        |                                                   | 11 - OP + WP |                            |
| 0x400[9]        | SRK_LOCK                                            | 1                      | Locking SRK_HASH[255:0] 0 - Unlock<br>1 - OP + WP |              | OCOTP                      |
|                 |                                                     |                        |                                                   |              |                            |
| 0x400[10]       | SJC_RESP_LOCK                                       | 1                      | Lock for SJC_RESP[55:0]                           | 0 - Unlock   | OCOTP                      |
|                 |                                                     |                        | tuses.                                            | 1 - Lock     |                            |
| 0x400[13:12]    | USB_ID_LOCK                                         | 2                      | Lock for USB_PID and                              | 00 - Unlock  | OCOTP                      |
|                 |                                                     |                        | USB_VID tuses.                                    | 10 - OP      |                            |
|                 |                                                     |                        |                                                   | 01 - WP      |                            |
|                 |                                                     |                        |                                                   | 11 - OP + WP |                            |
| 0x400[15:14]    | MAC_ADDR_LOCK                                       | 2                      | Lock MAC_ADDR fuses.                              | 00 - Unlock  | OCOTP                      |
|                 |                                                     |                        |                                                   | 10 - OP      |                            |
|                 |                                                     |                        |                                                   | 01 - WP      |                            |
|                 |                                                     |                        |                                                   | 11 - OP + WP |                            |
| 0x400[21:20]    | 0] GP1_LOCK 2 Lock for GP1[63:0] fuses. 00 - Unlock |                        | 00 - Unlock                                       | OCOTP        |                            |
|                 |                                                     |                        |                                                   | 10 - OP      |                            |
|                 |                                                     | 7                      | able continues on the next pa                     | ge           |                            |

| Table 6-19. | Fusemap | Descriptions |
|-------------|---------|--------------|
|-------------|---------|--------------|

i.MX 7Dual Applications Processor Reference Manual, Rev. 1, 01/2018

NXP Semiconductors

1101

Figure 2 - Fusemap table for iMX7 Dual

### 3.3 User's Manual reference: OCOTP memory map

The table below contains the section number in the User's Manual to the OCOTP memory map for a specific processor. The revision of the manual is given so if you are using a different revision the section number can also be different.

| Processor       | Manual revision | Section  |
|-----------------|-----------------|----------|
| i.MX6 Dual/Quad | Rev 5           | 46.5     |
| i.MX6 SoloX     | Rev 3           | 44.5     |
| i.MX6 UltraLite | Rev 2           | 35.5     |
| i.MX7 Dual      | Rev 1           | 6.4.5    |
| i.MX8 M         | Rev 2           | 6.3.5    |
| i.MX8 M Mini    | Rev 2           | 6.3.4    |
| i.MX8 M Nano    | Rev 0           | 6.3.4    |
| i.MX7ULP        | Rev 0           | 34.7.1.1 |

### 3.4 User's Manual reference: Fusemap Descriptions table

The table below contains the section number in the User's Manual to the Fusemap Descriptions table for a specific processor. The revision of the manual is given so if you are using a different revision the section number can also be different.

| Processor       | Manual revision | Section                                                                                              |
|-----------------|-----------------|------------------------------------------------------------------------------------------------------|
| i.MX6 Dual/Quad | Rev 5           | 5.2                                                                                                  |
| i.MX6 SoloX     | Rev 3           | 5.3                                                                                                  |
| i.MX6 UltraLite | Rev 2           | 5.3                                                                                                  |
| i.MX7 Dual      | Rev 1           | 6.3.3                                                                                                |
| i.MX8 M         | Rev 2           | 6.2.3                                                                                                |
| i.MX8 M Mini    | Rev 2           | 6.2.3                                                                                                |
| i.MX8 M Nano    | Rev 0           | 6.2.3                                                                                                |
| i.MX7ULP        | Rev 0           | Not available in the User's Manual at the time of writing this document. Must be requested from NXP. |

### 4 Examples in Linux

**NOTE**: Not all kernel versions support OCOTP access. The recommended way of accessing the OTP fuses are via u-boot as described in chapter 5

### 4.1 OCOTP register mapped to sysfs

In Linux it is quite easy to access the fuses since the OCOTP registers are mapped as files in sysfs, more specifically in the directory /sys/fsl\_otp. All the files/registers have the prefix HW\_OCOTP\_ followed by the register name. As an example, the register OCOTP\_LOCK described in section 3.2 has the name HW\_OCOTP\_LOCK in the file system.

Get value of a register:

```
# cat /sys/fsl_otp/HW_OCOTP_LOCK
0xa0030103
```

Write fuses in a register:

# echo 0x11223344 > HW\_OCOTP\_YOUR\_REGISTER

**NOTE:** Double or even triple check the value written to a register because once written it cannot be undone.

#### 4.2 Example: iMX7 Dual – Get silicon revision

In the Fusemap description table in the User's manual (section 6.3.3 in Rev 1 of the manual) it is specified that the silicon revision is available at address 0x440[3:0], that is, bits 0 to 3 at address 0x440. In the OCOTP memory map table (section 6.4.5 in rev 1) absolute address 0x30350440 is called OCOTP\_TESTER3 and located at bank 1 word 0.

```
# cat /sys/fsl_otp/HW_OCOTP_TESTER3
0x20000200
```

#### 4.3 Example: iMX6 SoloX – Get speed grading

In the Fusemap description table in the User's manual (section 5.3 in Rev 3 of the manual) it is specified that speed grading is available at address 0x440[17:16], that is, bits 16 and 17 at address 0x440. In the OCOTP memory map table (section 44.5 in rev 3 manual) absolute address 0x021BC440 is called OCOTP\_CFG3 and located at bank 0 word 4.

```
# cat /sys/fsl_otp/HW_OCOTP_CFG3
0x420002
```

This means that the binary value of bits 16 and 17 is 10b. According to the manual this means that the speed grade is 1000 MHz

### 5 Examples in U-boot

### 5.1 Fuse command

In the u-boot the fuse command is available that let you read and write fuses. Bank and word index must be specified when accessing the fuses.

Read fuses:

=> fuse read 0 0

Write fuses (bank and word should be changed to the bank index and word index):

```
=> fuse prog bank word 0x11223344
```

**NOTE:** Double or even triple check the value written to a register because once written it cannot be undone.

### 5.2 Example: iMX7 Dual – Get silicon revision

In the Fusemap description table in the User's manual (section 6.3.3 in Rev 1 of the manual) it is specified that the silicon revision is available at address 0x440[3:0], that is, bits 0 to 3 at address 0x440. In the OCOTP memory map table (section 6.4.5 in rev 1) absolute address 0x30350440 is called OCOTP\_TESTER3 and located at bank 1 word 0.

```
=> fuse read 1 0
Word 0x00000000: 20000200
```

### 5.3 Example: iMX6 SoloX – Get speed grading

In the Fusemap description table in the User's manual (section 5.3 in Rev 3 of the manual) it is specified that the speed grading is available at address 0x440[17:16], that is, bits 16 and 17 at address 0x440. In the OCOTP memory map table (section 44.5 in rev 3 manual) absolute address 0x021BC440 is called OCOTP\_CFG3 and located at bank 0 word 4.

```
=> fuse read 0 4
Word 0x00000004: 00420002
```

This means that the binary value of bits 16 and 17 is 10b. According to the manual this means that the speed grade is 1000 MHz.

### 6 Boot from eMMC

An i.MX application processor can boot its software from different boot devices such as eMMC, SDcard, NAND-flash, and so on. Which device to boot from can be selected by for example boot mode pins or by programming fuses. On Embedded Artists COM boards boot mode pins are used by default and these have been setup to use eMMC as boot device.

There can be situations where using boot mode pins can cause problems, for example, if you need to externally drive these pins during reset or if you need to use these pins for other purposes. In this case it is better to program the on-chip OTP fuses for eMMC boot. Please note that you can program the fuses to boot from a different device as well, but the instructions in this chapter only describe booting from eMMC.

### 6.1 Supported COM boards

Booting from eMMC via fuses is not supported by all COM boards or all revisions of a COM board. The table below lists the COM boards (and from which revision) this feature is supported.

| COM Board          | Board revision |
|--------------------|----------------|
| iMX6 SoloX COM     | Rev B2         |
| iMX6 UltraLite COM | Rev B          |
| iMX7 Dual COM      | Rev B          |
| iMX8MQ COM         | All revisions  |
| iMX8M Mini uCOM    | All revisions  |
| iMX8M Nano uCOM    | All revisions  |
| iMX7ULP uCOM       | All revisions  |

### 6.2 COM Carrier Board v2

You can test eMMC booting via fuses using a COM Carrier Board v2, rev E or later. Open (remove) jumper J27, highlighted in Figure 3, and you will boot from fuses. Please note that if fuses haven't been programmed the board will default to USB OTG download (serial download) if J27 is removed.

If you have an older revision of the carrier board you won't be able to easily test booting via fuses. The reason is that on the older revisions the BOOT\_CTRL pin is always grounded.



Figure 3 - COM Carrier board v2

### 6.3 iMX6 SoloX COM

Section 5.1 (Boot Fusemap) in the i.MX6 SoloX User's Manual contains the table shown in Figure 4 below. In this table you can see that for MMC/eMMC boot BOOT\_CFG[6] and BOOT\_CFG[5] must be set to 1 while BOOT\_CFG[7] must be 0.

|           | Boot Device | BOOT_CFG1[7] | BOOT_CFG1[6] | BOOT_CFG1[5] | BOOT_CFG1[4] | BOOT_CFG1[3]  |
|-----------|-------------|--------------|--------------|--------------|--------------|---------------|
|           | QSPI        | 0            | 0            | 0            | 1            | QXIP Instance |
|           |             |              |              |              |              | 0: QuadSPI0   |
|           |             |              |              |              |              | 1: QuadSPI1   |
|           | EIM         | 0            | 0            | 0            | 0            | Memory Type:  |
|           |             |              |              |              |              | 0 - NOR Flash |
|           |             |              |              |              |              | 1 - OneNAND   |
|           | Serial-ROM  | 0            | 0            | 1            | 1            | x             |
|           | SD/eSD      | 0            | 1            | 0            | x            | x             |
| $\langle$ | MMC/eMMC    | 0            | 1            | 1            | x            | x             |
|           | NAND        | 1            | x            | x            | x            | x             |

Table 5-1. Boot Device Select

Figure 4 - Boot Device Select for i.MX6 SoloX (Table 5-1)

There is a more detailed fusemap table specifically for MMC/eMMC booting, see Figure 5. For the iMX6 SoloX COM board the eMMC is on the eSDHC3 interface. This means that Port Select must be set to 10, that is, bit 12 must be set to 1.

| Addr                       | 7 | 6                                                                                                                                       | 5             | 4                                                      | 3                                                 | 2                                                                                            | 1                                                                                                                       | 0                                                                                                                    |
|----------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| 0x450[7:0]<br>(BOOT_CFG1)  | 0 | 1                                                                                                                                       | 1             | Fast Boot:<br>0 - Regular<br>1 - Fast<br>Boot          | SD/MMC<br>Speed<br>0 - High<br>1- Normal          | Fast Boot<br>Acknowledg<br>e Disable:<br>0 - Boot Ack<br>Enabled<br>1 - Boot Ack<br>Disabled | SD Power<br>Cycle<br>Enable<br>0 - No<br>power cycle<br>1 - Enabled<br>via<br>USDHC_RS<br>T pad<br>(uSDHC3 &<br>4 only) | SD<br>Loopback<br>Clock<br>Source Sel<br>(for SDR50<br>and<br>SDR104<br>only)<br>0 - through<br>SD pad<br>1 - direct |
| 0x450[15:8]<br>(BOOT_CFG2) | C | Bus Width:<br>000 - 1-bit<br>001 - 4-bit<br>010 - 8-bit<br>101 - 4-bit<br>0DR (MMC 4.4<br>110 - 8-bit<br>0DR (MMC 4.4<br>Else - Reserve | ()<br>1)<br>d | Port 5<br>00 - e5<br>01 - 65<br>10 - eSDHC:<br>11 - 65 | Select:<br>SDHC1<br>SDHC2<br>3 (eMMC4.4)<br>SDHC4 | Boot<br>Frequencies<br>(ARM/DDR)<br>0 - 792 /<br>400 MHz<br>1 - 528 /<br>307 MHz             | SD3<br>VOLTAGE<br>SELECTIO<br>N<br>0 - 3.3V<br>1 - 1.8V                                                                 | Reserved                                                                                                             |

#### Table 5-6. MMC/eMMC Boot Fusemap

Figure 5 - MMC/eMMC Boot Fusemap for i.MX6 SoloX (Table 5-6)

The *Fuse Description Table* from section 5.3 in the i.MX6 SoloX User's Manual gives that BOOT\_CFG is at fuse address **0x450**, see Figure 6. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses. This fuse is available at address **0x460**.



Figure 6 - Fusemap Description Table for i.MX6 SoloX (Table 5-9)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x450 and 0x460 is mapped to. As shown in Figure 7 below this is **Bank0 Word5** and **Bank0 Word6**.

#### OCOTP memory map (continued)

|  | Absolute<br>address<br>(hex) | Register name                                                                    | Width<br>(in bits) | Access | Reset value | Section/<br>page |
|--|------------------------------|----------------------------------------------------------------------------------|--------------------|--------|-------------|------------------|
|  | 21B_C450                     | Value of OTP Bank0 Word5 (Configuration and<br>Manufacturing Info.) (OCOTP_CFG4) | 32                 | R/W    | 0000_0000h  | 44.5.14/<br>2814 |
|  | 21B_C460                     | Value of OTP Bank0 Word6 (Configuration and<br>Manufacturing Info.) (OCOTP_CFG5) | 32                 | R/W    | 0000_0000h  | 44.5.15/<br>2814 |
|  | 21B_C470                     | Value of OTP Bank0 Word7 (Configuration and<br>Manufacturing Info.) (OCOTP_CFG6) | 32                 | R/W    | 0000_0000h  | 44.5.16/<br>2815 |
|  |                              | Value of OTP Rank1 Word0 (Memory Related Info.)                                  |                    |        |             | 11 5 17/         |

Figure 7 - OCOTP memory map for i.MX6 SoloX

With this information we can now determine that bank0 and word5 should be programmed with a value where bit 5, bit 6 and bit 12 (BOOT\_CFG) are set to 1. The hexadecimal value that corresponds to these bits being set to 1 is 0x00001060.

For bank0 word6, bit 4 (BT\_FUSE\_SEL) should be set to 1. The hexadecimal value is 0x00000010.

### 6.3.1 Instructions

From the **u-boot console** run the following commands to program the fuses:

NOTE: These commands cannot be undone.

=> fuse prog 0 5 00001060 => fuse prog 0 6 00000010

### 6.4 iMX6 UltraLite COM

Section 5.1 (Boot Fusemap) in the i.MX6 UltraLite User's Manual contains the table shown in Figure 8 below. In this table you can see that for MMC/eMMC boot, BOOT\_CFG[6] and BOOT\_CFG[5] must be set to 1 while BOOT\_CFG[7] must be 0.

|   | Boot<br>Device | BOOT_CF<br>G1[7] | BOOT_CF<br>G1[6]  | BOOT_CF<br>G1[5]                                                 | BOOT_CF<br>G1[4]                                                 | BOOT_CF<br>G1[3]                                                                | BOOT_CF<br>G1[2]                                                                             | BOOT_CF<br>G1[1]                                                                                                           | BOOT_CF<br>G1[0]                                                                                                 |
|---|----------------|------------------|-------------------|------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| C | MMC/eMMC       |                  | 1                 | 1                                                                | Fast boot:<br>0 - Regular<br>1 - Fast boot                       | SD/MMC<br>speed:<br>0 - Normal<br>1 - High                                      | Fast boot<br>acknowledg<br>e disable:<br>0 - Boot ack<br>enabled<br>1 - Boot ack<br>disabled | SD power<br>cycle<br>enable:<br>0 - No<br>power cycle<br>1 - Enabled<br>via<br>USDHC_RS<br>T pad<br>(uSDHC3<br>and 4 only) | SD loopback<br>clock source<br>sel ( for<br>SDR50 and<br>SDR104<br>only):<br>0 - Through<br>SD pad<br>1 - Direct |
|   | NAND           | 1                | BT_TOGGL<br>EMODE | Pages in<br>block:<br>00 - 128<br>01 - 64<br>10 - 32<br>11 - 256 | Pages in<br>block:<br>00 - 128<br>01 - 64<br>10 - 32<br>11 - 256 | Nand<br>number of<br>devices:<br>00 - 1<br>01 - 2<br>10 - 4<br>11 -<br>Reserved | Nand<br>number of<br>devices:<br>00 - 1<br>01 - 2<br>10 - 4<br>11 -<br>Reserved              | Nand_Row_<br>address_byt<br>es:<br>00 - 3<br>01 - 2<br>10 - 4<br>11 - 5                                                    | Nand_Row_<br>address_byt<br>es:<br>00 - 3<br>01 - 2<br>10 - 4<br>11 - 5                                          |

Table 5-1. Boot Device Select (continued)

Figure 8 - Boot Device Select for i.MX6 UltraLite (Table 5-1)

There is a more detailed fusemap table specifically for MMC/eMMC booting, see Figure 9. For the iMX6 UltraLite COM board the eMMC is on the eSDHC2 interface. This means that Port Select must be set to 01, that is, bit 11 must be set to 1.

| Addr                       | 7 | 6                                                                                                                                       | 5        | 4                                                  | 3                                        | 2                                                                                            | 1                                                                                               | 0                                                                                                                    |
|----------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| 0x450[7:0]<br>(BOOT_CFG1)  |   | 1                                                                                                                                       | 1        | Fast Boot:<br>0 - Regular<br>1 - Fast<br>Boot      | SD/MMC<br>Speed<br>0 - High<br>1- Normal | Fast Boot<br>Acknowledg<br>e Disable:<br>0 - Boot Ack<br>Enabled<br>1 - Boot Ack<br>Disabled | SD Power<br>Cycle<br>Enable<br>0 - No<br>power cycle<br>1 - Enabled<br>via<br>USDHC_RS<br>T pad | SD<br>Loopback<br>Clock<br>Source Sel<br>(for SDR50<br>and<br>SDR104<br>only)<br>0 - through<br>SD pad<br>1 - direct |
| 0x450[15:8]<br>(BOOT_CFG2) | C | Bus Width:<br>000 - 1-bit<br>001 - 4-bit<br>010 - 8-bit<br>101 - 4-bit<br>0DR (MMC 4.4<br>110 - 8-bit<br>0DR (MMC 4.4<br>Else - Reserve | t)<br>t) | Port S<br>00 - 66<br>01 - 65<br>10 - Re<br>11 - Re | Select:<br>SDHC1<br>SDHC2<br>served      | Boot<br>Frequencies<br>(ARM/DDR)<br>0 - 500 /<br>400 MHz<br>1 - 250 /<br>200 MHz             | SD<br>VOLTAGE<br>SELECTIO<br>N<br>0 - 3.3V<br>1 - 1.8V                                          | Reserved                                                                                                             |

Figure 9 - MMC/eMMC Boot Fusemap for i.MX6 UltraLite (Table 5-6)

The *Fuse Description Table* from section 5.3 in the i.MX6 UltraLite User's Manual gives that BOOT\_CFG is at fuse address **0x450**, see Figure 10. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses. This fuse is available at address **0x460**.

| < | 0x450[7:0]  | BOOT_CFG1  | 8 | BOOT configuration register<br>#1, Usage varies, depending<br>on selected boot device. | 0x0000XXXX - WEIM (NOR/<br>OneNAND) boot<br>0x0011XXXX - Serial ROM<br>(I2C/SPI) boot<br>0x1XXXXXXX - NAND<br>FLASH boot 0x010XXXXX -<br>SD/eSD 0x011XXXXX -<br>MMC/eMMC boot Others -<br>Reserved Refer to Fuse<br>Map for details. | SRC         |
|---|-------------|------------|---|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|   | 0x450[15:8] | BOOT_CFG2  | 8 | BOOT configuration register<br>#2, Usage varies, depending<br>on selected boot device. | See fuse-map tab for details.                                                                                                                                                                                                        | SRC         |
| - |             |            |   |                                                                                        | is not allowed                                                                                                                                                                                                                       |             |
| < | 0x460[4]    | BT USE_SEL | 1 | Determines, whether using<br>fuses for boot configuration,<br>or GPIO /Serial loader.  | If boot_mode="00"<br>(Development) 0=Boot<br>mode configuration is taken<br>from GPIOs. 1=Boot mode<br>configuration is taken from                                                                                                   | SRC SW(ROM) |

Figure 10 - Fusemap Description Table for i.MX6 UltraLite (Table 5-9)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x450 and 0x460 is mapped to. As shown in Figure 11 below this is **Bank0** Word5 and Bank0 Word6.

| L 1 |          |                                                                                  |    |     |            |                  |
|-----|----------|----------------------------------------------------------------------------------|----|-----|------------|------------------|
|     | 21B_C450 | Value of OTP Bank0 Word5 (Configuration and<br>Manufacturing Info.) (OCOTP_CFG4) | 32 | R/W | 0000_0000h | 35.5.16/<br>2190 |
|     | 21B_C460 | Value of OTP Bank0 Word6 (Configuration and<br>Manufacturing Info.) (OCOTP_CFG5) | 32 | R/W | 0000_0000h | 35.5.17/<br>2190 |
| F   |          |                                                                                  |    |     |            |                  |

Figure 11 - OCOTP memory map for i.MX6 UltraLite

With this information we can now determine that bank0 and word5 should be programmed with a value where bit 5, bit 6 and bit 11 (BOOT\_CFG) are set to 1. The hexadecimal value that corresponds to these bits being set to 1 is 0x00000860.

For bank0 word6, bit 4 (BT\_FUSE\_SEL) should be set to 1. The hexadecimal value is 0x00000010.

### 6.4.1 Instructions

From the **u-boot console** run the following commands to program the fuses:

```
NOTE: These commands cannot be undone.
```

```
=> fuse prog 0 5 00000860
=> fuse prog 0 6 0000010
```

### 6.5 iMX7 Dual COM

Section 6.3.1 (Boot Fusemap) in the i.MX7 Dual User's Manual contains the table shown in Figure 12 below. In this table you can see that for MMC/eMMC boot, BOOT\_CFG[13] must be set to 1 while BOOT\_CFG[12], BOOT\_CFG[14], and BOOT\_CFG[15] must be 0.

| Boot Devic | e | BOOT_CFG[15] | BOOT_CFG[14] | BOOT_CFG[13] | BOOT_CFG[12] | BOOT_CFG[11]  |
|------------|---|--------------|--------------|--------------|--------------|---------------|
| SD/eSD     |   | 0            | 0            | 0            | 1            | x             |
| MMC/eMMC   |   | 0            | 0            | 1            | 0            | x             |
| NAND       |   | 0            | 0            | 1            | 1            | x             |
| QSPI       |   | 0            | 1            | 0            | 0            | x             |
| EIM        |   | 0            | 1            | 0            | 1            | Memory Type:  |
|            |   |              |              |              |              | 0 - NOR Flash |
|            |   |              |              |              |              | 1 - OneNAND   |
| SPI/NOR    |   | 0            | 1            | 1            | 0            | x             |

Table 6-10. Boot Device Select

Figure 12 - Boot Device Select for i.MX7 Dual (Table 6-10)

For iMX7 Dual COM board, eMMC is attached to the USDHC3 interface. Fuses must be programmed to select the correct USDHC port. This is described in section 6.6.5.3.1 – Expansion device eFUSE configuration – in the User's Manual for the i.MX7 Dual processor, see Figure 13. BOOT\_CFG[11:10] must be set to 10 to choose USDHC-3.

| BOOT_CFG[15:12] | OEM | Boot device selection | Yes | 0000 | 0001 - Boot from SD/eSD   |
|-----------------|-----|-----------------------|-----|------|---------------------------|
|                 |     |                       |     |      | 0010 - Boot from MMC/eMMC |
| BOOT_CFG[11:10] | OEM | USDHC port selection  | Yes | 00   | 00 - USDHC-1              |
|                 |     |                       |     |      | 01 - USDHC-2              |
|                 |     |                       |     |      | 10 - USDHC-3              |
|                 |     |                       |     |      | else - reserved           |

Figure 13 - USDHC boot eFUSE descriptions for i.MX7 Dual (Table 6-42)

The *Fuse Description Table* from section 6.3.3 in the i.MX7 Dual User's Manual gives that BOOT\_CFG is at fuse address **0x470**, see Figure 14. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses. This fuse is also available at address **0x470**.

|             | I           | 1  | L                                                                                     |                                                                                                                                                                                                                                                                                                     | I           |
|-------------|-------------|----|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0x470[19:0] | BOOT_CFG    | 20 | BOOT configuration register,<br>Usage varies, depending on<br>selected boot device.   | See "Boot" sheet                                                                                                                                                                                                                                                                                    | SRC SW(ROM) |
| 0x470[28]   | BT_FUSE_SEL | 1  | Determines, whether using<br>fuses for boot configuration,<br>or GPIO /Serial loader. | If boot_mode="00"<br>(Development):<br>• 0=Boot mode<br>configuration is taken<br>from GPIOs.<br>• 1=Boot mode<br>configuration is taken<br>from fuses.<br>If boot_mode="10"<br>(Production):<br>• 0 - Boot using Serila<br>Loader (USB)<br>• 1- Boot mode<br>configuration is taken<br>from fuses. | SRC SW(ROM) |

Figure 14 - Fusemap Description Table for i.MX7 Dual (Table 6-19)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x470 is mapped to. As shown in Figure 15 below this is **Bank1 Word3**.

|   | 3035_0460 | Value of OTP Bank1 Word2 (Tester Information)<br>(OCOTP_TESTER5)               | 32 | R/W | 0000_0000h | 6.4.5.23/<br>1135 |
|---|-----------|--------------------------------------------------------------------------------|----|-----|------------|-------------------|
| 4 | 3035_0470 | Value of OTP Bank1 Word3 (Boot Configuration Information)<br>(OCOTP_BOOT_CFG0) | 32 | R/W | 0000_0000h | 6.4.5.24/<br>1136 |
|   | 3035_0480 | Value of OTP Bank2 Word0 (Boot Configuration Information)<br>(OCOTP_BOOT_CFG1) | 32 | R/W | 0000_0000h | 6.4.5.25/<br>1136 |

Figure 15 - OCOTP memory map for i.MX7 Dual

With this information we can now determine that bank1 and word3 should be programmed with a value where bit 11 (port selection), bit 13 (device selection) and bit 28 (BT\_FUSE\_SEL) are set to 1. The hexadecimal value that corresponds to these bits being set to 1 is 0x10002800.

#### 6.5.1 Instructions

From the **u-boot console** run the following command to program the fuses:

NOTE: This command cannot be undone.

### 6.6 iMX8M Quad COM

Section 6.2.1 (Boot Fusemap) in the i.MX8 M User's Manual contains the table shown in Figure 16 below. In this table you can see that for MMC/eMMC boot, BOOT\_CFG[13] must be set to 1 while both BOOT\_CFG[12] and BOOT\_CFG[14] must be 0.

|   | Boot Device | BOOT_CFG[14] | BOOT_CFG[13] | BOOT_CFG[12] |
|---|-------------|--------------|--------------|--------------|
|   | SD/eSD      | 0            | 0            | 1            |
| C | MMC/eMMC    | 0            | 1            | 0            |
|   | NAND        | 0            | 1            | 1            |

Figure 16 - Boot Device Select for i.MX8 M (Table 6-37)

There is a more detailed fusemap table specifically for MMC/eMMC booting, see Figure 17. For the iMX8M Quad COM board the eMMC is on the SD1 interface. This means that Port Select must be set to 00 which is the default value so there is no need to change these fuse bits.

| Addr        | 7           | 6       | 5              | 4       | 3                                    | 2            | 1                                                     | 0                                                                      |
|-------------|-------------|---------|----------------|---------|--------------------------------------|--------------|-------------------------------------------------------|------------------------------------------------------------------------|
| 0x470[15:8] | Reserved    | Во      | ot Device Sel  | ect     | Port Select:<br>00 - SD1<br>01 - SD2 |              | Power<br>Cycle<br>Enable<br>0 - Disable<br>1 - Enable | SD<br>Loopback<br>Clock<br>Source SEL<br>(SDR50 and<br>SDR104<br>Only) |
|             |             |         |                |         |                                      |              |                                                       | 1 - Enable                                                             |
| 0x470[7:0]  | Fast Boot:  |         | Bus Width:     |         | Sp                                   | eed          | USDHC1 IO                                             | USDHC2 IO                                                              |
|             | 0 - Regular |         | 000 - 1-bit    |         | 00 - N                               | lormal       | SELECTIO                                              | VOLTAGE<br>SELECTIO                                                    |
|             | 1 - Fast    |         | 001 - 4-bit    |         | 01 -                                 | High         | Ν                                                     | N                                                                      |
|             | Boot        |         | 010 - 8-bit    |         | 10 - Reserve                         | ed for HS200 | 0 - 3.3V                                              | 0 - 3.3V                                                               |
|             |             | 101 - 4 | -bit DDR (MN   | IC 4.4) | 11 - Re                              | eserved      | 1 - 1.8V                                              | 1 - 1.8V                                                               |
|             |             | 110 - 8 | -bit DDR (MN   | IC 4.4) |                                      |              |                                                       |                                                                        |
|             |             | E       | Else - reserve | d       |                                      |              |                                                       |                                                                        |

Table 6-39. MMC/eMMC Boot Fusemap

Figure 17 - MMC/eMMC Boot Fusemap for i.MX8 M (Table 6-39)

The *Fuse Description Table* from section 6.2.3 in the i.MX8 M User's Manual gives that BOOT\_CFG is at fuse address **0x470**, see Figure 18. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses.

| 0x470[15:0]  | BOOT_CFG      | 16 | BOOT configuration register,<br>Usage varies, depending on<br>selected boot device.   | See boot fusemap for details.                                                                                                                                                                                                                                                    | SRC SW(ROM) |
|--------------|---------------|----|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0x470[24:16] | Reserved      | 9  | Reserved                                                                              | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[25]    | SEC_CONFIG[1] | 1  | Security Configuration (with<br>SEC_CONFIG[0])                                        | iguration (with<br>G[0]) 00 - FAB (Open)<br>01 - Open - allows any code<br>to be flashed and executed,<br>even if it has no valid<br>signature.<br>1x - Closed (Security On)                                                                                                     |             |
| 0x470[26]    | Reserved      | 1  | Reserved                                                                              | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[28]    | BT_FUSE_SEL   | 1  | Determines, whether using<br>fuses for boot configuration,<br>or GPIO /Serial loader. | If boot_mode="00"<br>(Development)<br>0=Boot mode configuration<br>is taken from GPIOs.<br>1=Boot mode configuration<br>is taken from fuses.<br>If boot_mode="10"<br>(Production)<br>0 - Boot using Serial Loader<br>(USB)<br>1- Boot mode configuration<br>is taken from fuses. | SRC SW(ROM) |

Figure 18 - Fusemap Description Table for i.MX8 M (Table 6-43)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x470 is mapped to. As shown in Figure 19 below this is **Bank1 and Word3**.

| 3035_0460 | Value of OTP Bank1 Word2 (Tester Info.)<br>(OCOTP_HW_OCOTP_TESTER5)               | 32 | R/W | 0000_0000h | 6.3.5.15/<br>901 |
|-----------|-----------------------------------------------------------------------------------|----|-----|------------|------------------|
| 3035_0470 | Value of OTP Bank1 Word3 (Boot Configuration Info.)                               | 32 | R/W | 0000_0000h | 6.3.5.16/<br>902 |
| 3035_0480 | Value of OTP Bank2 Word0 (Boot Configuration Info.)<br>(OCOTP_HW_OCOTP_BOOT_CFG1) | 32 | R/W | 0000_0000h | 6.3.5.17/<br>902 |

Figure 19 - OCOTP memory map for i.MX 8M

With this information we can now determine that bank1 and word3 should be programmed with a value where bit 13 (BOOT\_CFG[13]) and bit 28 (BT\_FUSE\_SEL) are set to 1. The hexadecimal value that corresponds to these two bits being set to 1 is 0x10002000.

### 6.6.1 Instructions

From the **u-boot console** run the following command to program the fuses:

| NOTE: This command cannot be undone. |      |      |   |   |          |  |  |  |  |  |  |
|--------------------------------------|------|------|---|---|----------|--|--|--|--|--|--|
|                                      |      |      |   |   |          |  |  |  |  |  |  |
| =>                                   | fuse | prog | 1 | 3 | 10002000 |  |  |  |  |  |  |

### 6.7 iMX8M Mini uCOM

Section 6.2.1 (Boot Fusemap) in the i.MX8 M Mini User's Manual contains the table shown in Figure 20 below. In this table you can see that for MMC/eMMC boot, BOOT\_CFG[13] must be set to 1 while both BOOT\_CFG[12] and BOOT\_CFG[14] should be 0.

| Boot Device | BOOT_CFG[14] | BOOT_CFG[13] | BOOT_CFG[12] |
|-------------|--------------|--------------|--------------|
| SD/e8D      | 0            | 0            | 1            |
| MMC/eMMC    | 0            | 1            | 0            |
| NAND        | 0            | 1            | 1            |
| FlexSPI     | 1            | 0            | 0            |
| SPI/NOR     | 1            | 1            | 0            |

Table 6-41. Boot Device Select

Figure 20 - Boot Device Select for i.MX8 M Mini (Table 6-41)

There is a more detailed fusemap table specifically for MMC/eMMC booting, see Figure 21. For the iMX8M Mini uCOM board the eMMC is on the SD3 (usdhc3) interface. This means that Port Select must be set to 10, that is, bit 11 must be set to 1.

| Addr        | 7           | 6               | 5                         | 4       | 3                             | 2                            | 1                                                     | 0                                                                                     |
|-------------|-------------|-----------------|---------------------------|---------|-------------------------------|------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------|
| 0x470[15:8] | Reserved    | Bc              | ot Device Sel             | ect     | Port 5<br>00 -<br>01-<br>10 - | Select:<br>SD1<br>SD2<br>SD3 | Power<br>Cycle<br>Enable<br>0 - Disable<br>1 - Enable | SD<br>Loopback<br>Clock<br>Source SEL<br>(SDR50 and<br>SDR104<br>Only)<br>0 - Through |
|             |             |                 |                           |         |                               |                              |                                                       | 1 - Direct                                                                            |
| 0x470[7:0]  | Fast Boot:  |                 | Bus Width:                |         | Sp                            | eed                          | USDHC IO                                              | USDHC IO                                                                              |
|             | 0 - Regular |                 | 000 - 1-bit               |         | 00 - 1                        | lormal                       | VOLTAGE<br>SELECTIO                                   | VOLTAGE<br>SELECTIO                                                                   |
|             | 1 - Fast    |                 | 001 - 4-bit               |         | 01 -                          | High                         | N                                                     | N                                                                                     |
|             | Boot        |                 | 010 - 8-bit               |         | 10 - Reserved for H           |                              | For Normal                                            | For                                                                                   |
|             |             | 101 - 4         | 101 - 4-bit DDR (MMC 4.4) |         | 11 - Reserved                 |                              | Boot Mode                                             | Manufactur                                                                            |
|             |             | 110 - 8         | B-bit DDR (MN             | AC 4.4) |                               |                              | 0 - 3.3V                                              |                                                                                       |
|             |             | Else - Reserved |                           | ,<br>d  |                               |                              | 1 - 1.8V                                              | 0 - 3.3V                                                                              |
|             |             | -               |                           | -       |                               |                              |                                                       | 1 - 1.8V                                                                              |

Table 6-43. MMC/eMMC Boot Fusemap

Figure 21 - MMC/eMMC Boot Fusemap for i.MX8 M Mini (Table 6-43)

The *Fuse Description Table* from section 6.2.3 in the i.MX8 M Mini User's Manual gives that BOOT\_CFG is at fuse address **0x470**, see Figure 22. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses.

| Fuse<br>Address | Fuses Name    | Numbe<br>r of<br>Fuses | Fuses Function                                                                        | Setting                                                                                                                | Used by                       |
|-----------------|---------------|------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| 0x470[15:0]     | BOOT_CFG      | 16                     | BOOT configuration register,<br>Usage varies, depending on<br>selected boot device.   | See boot fusemap for details.                                                                                          | SRC SW(ROM)                   |
| 0x470[24:16]    | Reserved      | 9                      | Reserved                                                                              | Reserved                                                                                                               | Reserved                      |
| 0x470[25]       | SEC_CONFIG[1] | 1                      | Security Configuration (with SEC_CONFIG[0])                                           | 00 - FAB (Open)<br>01 - Open - allows any code<br>to be flashed and executed,<br>even if it has no valid<br>signature. | SW (ROM), SRC,<br>SNVS, TPSMP |
|                 |               |                        |                                                                                       | 1x - Closed (Security On)                                                                                              |                               |
| 0x470[26]       | Reserved      | 1                      | Reserved                                                                              | Reserved                                                                                                               | Reserved                      |
| 0x470[27]       | Reserved      | 1                      | Reserved                                                                              | Reserved                                                                                                               | Reserved                      |
| 0x470[28]       | BT_FUSE_SEL   | SE_SEL 1               | Determines, whether using<br>fuses for boot configuration,<br>or GPIO /Serial loader. | If boot_mode="00"<br>(Development)                                                                                     | SRC SW(ROM)                   |
|                 |               |                        |                                                                                       | 0=Boot mode configuration is taken from GPIOs.                                                                         |                               |
|                 |               |                        |                                                                                       | 1=Boot mode configuration is taken from fuses.                                                                         |                               |
|                 |               |                        |                                                                                       | If boot_mode="10"<br>(Production)                                                                                      |                               |
|                 |               |                        |                                                                                       | 0 - Boot using Serial Loader<br>(USB)                                                                                  |                               |
|                 |               |                        |                                                                                       | 1- Boot mode configuration is taken from fuses.                                                                        |                               |

Figure 22 - Fusemap Description Table for i.MX8 M Mini (Table 6-49)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x470 is mapped to. As shown in Figure 23 below this is **Bank1 Word3**.

| 3035_0460 | Value of OTP Bank1 Word2 (Tester Info.)<br>(OCOTP_HW_OCOTP_TESTER5)               | 32 | R/W | 0000_0000h | 6.3.4.15/<br>866 |
|-----------|-----------------------------------------------------------------------------------|----|-----|------------|------------------|
| 3035_0470 | Value of OTP Bank1 Word3 (Boot Configuration Info.)                               | 32 | R/W | 0000_0000h | 6.3.4.16/<br>867 |
| 3035_0480 | Value of OTP Bank2 Word0 (Boot Configuration Info.)<br>(OCOTP_HW_OCOTP_BOOT_CFG1) |    | R/W | 0000_0000h | 6.3.4.17/<br>867 |

Figure 23 - OCOTP memory map for i.MX 8M Mini

With this information we can now determine that bank1 and word3 should be programmed with a value where bit 11 (BOOT\_CFG[11] - Port Select), bit 13 (BOOT\_CFG[13]) and bit 28 (BT\_FUSE\_SEL) are set to 1. The hexadecimal value that corresponds to these two bits being set to 1 is 0x10002800.

### 6.7.1 Instructions

From the **u-boot console** run the following command to program the fuses:

**NOTE:** This command cannot be undone.

```
=> fuse prog 1 3 10002800
```

### 6.8 iMX8M Nano uCOM

Section 6.2.1 (Boot Fusemap) of the i.MX8 M Nano User's Manual contains the table shown in Figure 24 below. In this table you can see that for USDHC3 (eMMC) boot code should be set to 0x02, that is, BOOT\_MODE[1] should be 1.

| Boot Device Select                     | BOOT<br>CODE | BOOT_M<br>ODE[5]<br>(SAI3_TX<br>D) | BOOT_M<br>ODE[4]<br>(SAI2_TX<br>D0) | BOOT_M<br>ODE[3] | BOOT_M<br>ODE[2] | BOOT_M<br>ODE[1] | BOOT_M<br>ODE[0] |
|----------------------------------------|--------------|------------------------------------|-------------------------------------|------------------|------------------|------------------|------------------|
| Boot from internal fuses               | 0x00         | 0                                  | 0                                   | 0                | 0                | 0                | 0                |
| USB Serial Download                    | 0x01         | 0                                  | 0                                   | 0                | 0                | 0                | 1                |
| USDHC3 (eMMC boot only, SD3 bit)       | 0x02         | 0                                  | 0                                   | 0                | 0                | 1                | 0                |
| USDHC2 (SD boot only, SD2)             | 0x03         | 0                                  | 0                                   | 0                | 0                | 1                | 1                |
| NAND 8-bit single device, 256<br>pages | 0x04         | 0                                  | 0                                   | 0                | 1                | 0                | 0                |
| NAND 8-bit single device, 512<br>pages | 0x05         | 0                                  | 0                                   | 0                | 1                | 0                | 1                |
| FlexSPI 3B Read                        | 0x06         | 0                                  | 0                                   | 0                | 1                | 1                | 0                |
| FlexSPI Hyperflash 3.3V                | 0x07         | 0                                  | 0                                   | 0                | 1                | 1                | 1                |
| eCSPI Boot                             | 0x08         | 0                                  | 0                                   | 1                | 0                | 0                | 0                |

Figure 24 - Boot Device Select for i.MX8 M Nano (Table 6-29)

The Boot fusemap shows that the boot mode fuses are located at bits 12-15 (BOOT\_MODE[0] is on bit 12, BOOT\_MODE[1] on bit 13, and so on), see Figure 25.

|             | (M                                                                                                               | xic)                          |                                                 |                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------------|----------------------------------|
| 0x470[15:8] | BOOT_MODE_FUSES<br>Boot Rom <del>will retrieve</del> boot mode from these fuses<br>instead of BOOT_MODE pins if: | OVERRIDE<br>_USDHC_B<br>T_SEL | OVERRIDE_USDHC_BT<br>_SEL_VAL<br>00 - uSDHC1 SD | OVERRIDE<br>_NAND_PG<br>_PER_BLK |
|             | * BOOT_MODE_PINS=0x0                                                                                             | 0 - Do not<br>override        | 01 - uSDHC1 eMMC                                | 0 - Do not<br>override           |
|             | or<br>* BT_FUSE_SEL blown                                                                                        | 1 - Override                  | 10 - uSDHC2 eMMC<br>11 - uSDHC3 SD              | 1 - Override                     |

Figure 25 - Boot Fusemap for i.MX8 M Nano (Table 6-30)

The *Fuse Description Table* from section 6.2.3 in the i.MX8 M Nano User's Manual gives that BOOT\_CFG is at fuse address **0x470**, see Figure 26. We also need to know the address of the BT\_FUSE\_SEL fuse since this must be set to boot from fuses.

|              | 1           | 1                                                                                                                                                           |                                                                                     |                                                                                                                                                                                                                                                                                  |             |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0x460[31:0]  | Reserved    | 32                                                                                                                                                          | Reserved                                                                            | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[15:0]  | BOOT_CFG    | 16                                                                                                                                                          | BOOT configuration register,<br>Usage varies, depending on<br>selected boot device. | See boot fusemap for details.                                                                                                                                                                                                                                                    | SRC SW(ROM) |
| 0x470[24:16] | Reserved    | 9                                                                                                                                                           | Reserved                                                                            | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[26:16] | Reserved    | 10                                                                                                                                                          | Reserved                                                                            | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[27]    | Reserved    | 1                                                                                                                                                           | Reserved                                                                            | Reserved                                                                                                                                                                                                                                                                         | Reserved    |
| 0x470[28]    | BT_FUSE_SEL | Heserved         1         Heserved           BT_FUSE_SEL         1         Determines, whether using fuses for boot configuration, or GPIO /Serial loader. |                                                                                     | If boot_mode="00"<br>(Development)<br>0=Boot mode configuration<br>is taken from GPIOs.<br>1=Boot mode configuration<br>is taken from fuses.<br>If boot_mode="10"<br>(Production)<br>0 - Boot using Serial Loader<br>(USB)<br>1- Boot mode configuration<br>is taken from fuses. | SRC SW(ROM) |

Figure 26 - Fuse Description table for i.MX8M Nano (Table 6-32)

As described in section 3.2 we can now use the OCOTP Memory Map to find which OTP bank and word the fuse address 0x470 is mapped to. As shown in Figure 23 below this is **Bank1 Word3** 

| L         | · · · · ·                                                           |    | 1   |            |                  |
|-----------|---------------------------------------------------------------------|----|-----|------------|------------------|
| 3035_0460 | Value of OTP Bank1 Word2 (Tester Info.)<br>(OCOTP_HW_OCOTP_TESTER5) | 32 | R/W | 0000_0000h | 6.3.4.15/<br>801 |
| 3035_0470 | Value of OTP Bank1 Word3 (Boot Configuration Info.)                 | 32 | R/W | 0000_0000h | 6.3.4.16/<br>802 |

Figure 27 - OCOTP memory map for i.MX 8M Nano

With this information we can now determine that bank1 and word3 should be programmed with a value where bit 13 (BOOT\_MODE[1]), and bit 28 (BT\_FUSE\_SEL) are set to 1. The hexadecimal value that corresponds to these two bits being set to 1 is 0x10002000.

### 6.8.1 Instructions

From the **u-boot console** run the following command to program the fuses:

**NOTE:** This command cannot be undone.

=> fuse prog 1 3 10002000

### 6.9 iMX7ULP uCOM

For the iMX7ULP the Fusemap is not published in the User's Manual. Instead you need to request this from NXP. Because of this, there are no figures/screenshots included in this section for the fusemap. It is only described which OTP fuses you need to program.

The boot device selection is controlled via BT0\_CFG1 which is located at Bank2 Word 4.

The BT\_FUSE\_SEL must also be set and this fuse is located at Bank2 Word7.

### 6.9.1 Instructions

From the **u-boot console** run the following command to program the fuses:

**NOTE:** This command cannot be undone.

```
=> fuse prog 2 4 00400002
=> fuse prog 2 7 00008000
```

### 7 Program Fuses from UUU

UUU (Universal Update Utility) is used to program the boards with new images / software. You can read more about UUU in the document *Working with Yocto to Build Linux* available on Embedded Artists website. You can download zip files containing the UUU utility and configuration files from <a href="http://imx.embeddedartists.com">http://imx.embeddedartists.com</a>.

In short, UUU is a utility program used in combination with one or more configuration files. The configuration files contain the instructions to run when updating the board. If needed, you can program fuses from such a configuration file.

Below is an example from the configuration file bootloader.uuu belonging to the iMX8M Mini uCOM board. Here we have added the highlighted command (it is not normally included) below which will enable eMMC boot on the iMX8M Mini uCOM board. Please note the "-y" that is added so you don't need to confirm the command.

**NOTE**: Do not just copy the line below to your configuration file. Double-check the fuses you want to program before adding such a command. Once fuses have been programmed it cannot be undone.

```
...

FB: ucmd mmc dev ${emmc_dev}

FB: ucmd mmc info

FB: ucmd fuse prog -y 1 3 10002800

FB: flash bootloader files/imx-boot-imx8mmea-ucom-sd.bin

FB: done
```