# AN13574

# i.MX RT1170 CM4 Primary Core Application

Rev. 0 — 24 February 2022 Application Note

### 1 Introduction

This application note introduces how to set up environment for i.MX RT1170 CM4 primary core case.

It covers the following IDE:

- MCUXpresso
- IAR
- KEIL

By default, CM7 core is primary core on i.MX RT1170. By fusing 960 [12], we can switch to CM4 primary core and then the system boots from CM4 core.

i.MX RT1170 SDK only supports CM7 main core. This document is a supplement to provide basic environment for CM4 primary core case.

AN13574SW is tested by the tool version below:

- MCUXPRESSO 11.4.1
- IAR 9.20.2
- KEIL 5.36.0.0

## 2 Using MCUXpresso

For CM4 primary core in MCUXpresso, see AN13574SW.

NOTE

MCUXPresso IDE needs an initial state of the board to work for CM4 primary core case.

To set the environment, put the board in serial download mode (Set **SW1** to OFF, OFF, OFF, OFF), connect USB cable to SDP port (USB1 port, J20), and execute *AN\_SWlinit\_cm4\_xip\program.bat*.

Switch to XIP boot mode (Set SW1 to OFF, OFF, ON, OFF), and the information appears on the console as below:

This is the init image to setup CM4 primary core environment.

Perform the settings only once before using MCUXpresso for CM4 primary core application on a board.

### 2.1 By DAP LINK

To run CM4 primary core hello world example in MCUXpresso, perform the following steps:

- 1. Install the SDK attached with this application note into MCUXPresso.
- 2. Import the multicore example. It includes a CM7 slave project and a CM4 master project.

| 1   | Introduction     | 1 |  |
|-----|------------------|---|--|
| 2   | Using MCUXpresso |   |  |
| 2.1 | By DAP LINK      | 1 |  |
| 2.2 | By JLink         | 3 |  |
| 3   | Using IAR        |   |  |
| 3.1 | By DAP LINK      | 6 |  |
| 3.2 | By JLink         | 6 |  |
| 4   | Using KEIL       | 7 |  |
| 4.1 | By DAP LINK      | 7 |  |
| 4.2 | By JLink         | 8 |  |
| 5   | Revision history |   |  |
|     |                  |   |  |

Contents





- Build the CM7 slave project.
- 4. Build the CM4 master project.
- 5. To load the project, select CM4 master project and press Both CM4 and CM7 are detected, and CM4 core stops at main, as shown in Figure 2.

```
♦ Debug ☒

    Is evkmimxrt1170_hello_world_cm4_primary LinkServer Debug [C/C++ (NXP Semiconductors) MCU Application]

    Pread #1 1 (Suspended : Breakpoint)

          = main() at hello_world_core0.c:85 0x80028d8
     arm-none-eabi-gdb (10.1.90.20201028)

    Is evkmimxrt1170 hello world cm7 slave LinkServer Debug [C/C++ (NXP Semiconductors) MCU Application]

   & evkmimxrt1170_hello_world_cm7_slave.axf [MIMXRT1176xxxxx (cortex-m7)]
       Thread #1 1 (Running) (Running)
     arm-none-eabi-gdb (10.1.90.20201028)
(gdb[2].proc[42000].threadGroup[i1],gdb[2].proc[42000].OSthread[1]).thread[1].frame[0]
                                                                            I hello_world_core0.c ⋈
  82 int main(void)
  83 {
          /* Initialize MCMGR, install generic event handlers */
  84
  85
          (void)MCMGR_Init();
  86
  87
          /* Init board hardware.*/
          BOARD ConfigMPU();
  88
Figure 2. Starting debug session
```

6. To run CM4 core code, click . CM7 core stops at main, as shown in Figure 3.

Application Note 2/9

```
♦ Debug ☒

    Is evkmimxrt1170 hello world cm4 primary LinkServer Debug [C/C++ (NXP Semiconductors) MCU Application]

  & evkmimxrt1170_hello_world_cm4_primary.axf [MIMXRT1176xxxxx (cortex-m4)]
        Thread #1 1 (Running)
     arm-none-eabi-gdb (10.1.90.20201028)

    Is evkmimxrt1170_hello_world_cm7_slave LinkServer Debug [C/C++ (NXP Semiconductors) MCU Application]

  B evkmimxrt1170_hello_world_cm7_slave.axf [MIMXRT1176xxxxx (cortex-m7)]

    P Thread #1 1 (Suspended : Breakpoint)

          main() at hello world core1.c:60 0x20340842
     arm-none-eabi-gdb (10.1.90.20201028)
[0] [gdb[2].proc[42000].threadGroup[i1],gdb[2].proc[42000].OSthread[1]).thread[1].frame[0]
                                                                                   le hello world core0.c
540int main(void)
55 {
56
         uint32_t startupData, i;
57
         mcmgr_status_t status;
58
59
         /* Define the init structure for the output LED pin*/
         gpio_pin_config_t led_config = {
60
61
              kGPIO_DigitalOutput,
62
              0,
63
         };
64
Figure 3. CM7 run to main()
```

7. Select CM7 project and run. The log is shown in console as below:

```
Hello World from the Primary Core!
Starting Secondary core.
The secondary core application has been started.
```

### 2.2 By JLink

To use JLink, first remove the jumper **J6** and **J7** on board.

The SEGGER version tested in this application note is v7.54b. To set flashloader in SEGGER for i.MX RT1170 CM4 primary core, perform the following steps:

- 1. Go to <segger installation directory> |JLink|Devices|NXP.
- 2. Create a folder called iMXRT117x.
- 3. Copy AN\_SW\example\_mcuxpresso\MIMXRT117x\_QuadSPI\_4KB\_SEC\_Alias.FLM\text{ in AN13574SW to <segger installation directory>\JL\text{ink\Devices\NXP\imxRT117x}.}
- 4. Add text below to <segger installation directory>\JLink\JLinkDevices.xml. AN\_SW\example\_mcuxpresso\ JLinkDevices.xml\ in AN13574SW.

```
<Device>
<ChipInfo Vendor="NXP"

Name="MIMXRT1176xxxA_M4"

Core="JLINK_CORE_CORTEX_M4"

WorkRAMAddr="0x20000000"

WorkRAMSize="0x00008000" />
```

i.MX RT1170 CM4 Primary Core Application, Rev. 0, 24 February 2022

Application Note 3 / 9

```
<FlashBankInfo Name="QSPI Flash"
    BaseAddr="0x08000000"
    MaxSize="0x01000000"
    Loader="Devices/NXP/iMXRT117x/MIMXRT117x_QuadSPI_4KB_SEC_Alias.FLM"
    LoaderType="FLASH_ALGO_TYPE_OPEN" />
</Device>
```

#### For debugging, perform the following steps:

- Perform Step 1- 5 in By DAP LINK.
- To exit debugging mode, click
- · Deselect Reset before running.



• To start debugging again, press . As shown in Figure 5, CM4 project is loaded and stops at main ().

Application Note 4/9

5/9

```
🏶 Debug 🏻
    W Language Property of the 

▼ ② evkmimxrt1170_hello_world_cm4_primary.axf

    P Thread #1 57005 (Suspended : Breakpoint)

                                                   main() at hello world core0.c:85 0x80028d8
                          arm-none-eabi-gdb (10.1.90.20201028)
                                                                                                                                                                                      le hello_world_... □ hello_world_...
                                                                                                                                                                                                                                                                                                                                                                     mcmgr.
   startup_mimxr...
                                                                                            startup_mimxr...
             82⊖int main(void)
             83 {
                                                   /* Initialize MCMGR, install generic event handlers */
             84
            85
                                                   (void)MCMGR_Init();
             86
                                                    /* Init board hardware.*/
             87
                                                   BOARD_ConfigMPU();
Figure 5. Starting CM4 debug session
```

- To run the code, press
- To start debugging, select CM7 project and press
   BY default, it works in attach mode. Both the two cores are in debugging.

```
Debug 

v evkmimxrt1170_hello_world_cm4_primary JLink Debug [GDB SEGGER Interface Debugging]

v evkmimxrt1170_hello_world_cm4_primary.axf

p Thread #1 57005 (Running : User Request)

arm-none-eabi-gdb (10.1.90.20201028)

v evkmimxrt1170_hello_world_cm7_slave JLink Debug [GDB SEGGER Interface Debugging]

evkmimxrt1170_hello_world_cm7_slave.axf

arm-none-eabi-gdb (10.1.90.20201028)

Figure 6. Start CM7 debug session
```

• To suspend debug session if necessary, press

## 3 Using IAR

There is an example in AN13574SW for CM4 primary core in IAR. Use this example for the operation below.

i.MX RT1170 CM4 Primary Core Application, Rev. 0, 24 February 2022

### 3.1 By DAP LINK

To run CM4 primary core hello world example in IAR, perform the following steps:

- 1. Open and build CM7 slave project.
- 2. Open and build CM4 master project.
- 3. In CM4 primary project, launch the project. Both cores are detected and stop at main().





4. Run CM4 project, and both cores start running.

### 3.2 By JLink

To use JLink, perform the following steps:

- Back up iMXRT\_1170.dmac in <IAR installation path>larm|config|debugger|NXP.
- Back up FlashIMXRT1170\_FlexSPI.mac in <IAR installation path>| arm|config|flashloader|NXP.
- Copy AN\_SWlexample\_iarliMXRT\_1170.dmac in AN13574SW to <IAR installation path>larmlconfigldebuggerINXP.
- Copy AN\_SWIexample\_iar\FlashIMXRT1170\_FlexSPI.mac in AN13573SW to <IAR installation path>\ arm\config\flashloader\NXP.

Perform the following steps:

1. Remove the jumper J6 and J7 on board.

7/9

- 2. Switch the debugger to be JLink in the example projects.
- 3. Build, download, and run CM4 project.
- 4. Build and attach CM7 project (from IAR -> Project).



5. If necessary, press and the code stop where it is running.

### 4 Using KEIL

There is an example in AN13574SW for CM4 primary core in KEIL. Use this example for the operation below.

Keil also needs an initial board state for first image download. For details, see Note in Using MCUXpresso.

### 4.1 By DAP LINK

- 1. Open and build CM7 slave project.
- 2. Open and build CM4 primary project.
- 3. Launch CM4 primary debug session and run the code. It stops at main().



4. To attach CM7 slave debug session, click

**Application Note** 



### 4.2 By JLink

To use JLink, remove the jumpers **J6** and **J7** on board.

Switch the debugger setting in the example to be JLink.

For debugging, follow Steps 1 - 4 in By DAP LINK.

# 5 Revision history

| Rev. | Date             | Description     |
|------|------------------|-----------------|
| 0    | 24 February 2022 | Initial release |

How To Reach Us

Home Page:

Web Support:

nxp.com/support

**Limited warranty and liability**— Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions.

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

Security — Customer understands that all NXP products may be subject to unidentified or documented vulnerabilities. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately. Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP. NXP has a Product Security Incident Response Team (PSIRT) (reachable at PSIRT@nxp.com) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX,EMBRACE, GREENCHIP, HITAG, ICODE, JCOP, LIFE, VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, CodeWarrior, ColdFire, ColdFire+, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, Tower, TurboLink, EdgeScale, EdgeLock, elQ, and Immersive3D are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org. M, M Mobileye and other Mobileye trademarks or logos appearing herein are trademarks of Mobileye Vision Technologies Ltd. in the United States, the EU and/or other jurisdictions.



© NXP B.V. 2022.

All rights reserved.