



NXP Jun 26, 2025

# **Table of contents**

| 1 | IMX    | 943EVK 3                                             |
|---|--------|------------------------------------------------------|
|   | 1.1    | Overview                                             |
|   | 1.2    | Getting Started with MCUXpresso SDK Package          |
|   |        | 1.2.1 Getting Started with Package 3                 |
|   | 1.3    | Getting Started with MCUXpresso SDK GitHub           |
|   |        | 1.3.1 Getting Started with MCUXpresso SDK Repository |
|   | 1.4    | Release Notes                                        |
|   |        | 1.4.1 MCUXpresso SDK Release Notes                   |
|   | 1.5    | ChangeLog                                            |
|   |        | 1.5.1 MCUXpresso SDK Changelog                       |
|   | 1.6    | Driver API Reference Manual                          |
|   | 1.7    | Middleware Documentation                             |
|   |        | 1.7.1 Multicore                                      |
|   |        | 1.7.2 FreeMASTER                                     |
|   |        | 1.7.3 FreeRTOS                                       |
|   |        | 1.7.4 lwIP                                           |
|   |        |                                                      |
| 2 | Driv   |                                                      |
|   | 2.1    | DSC                                                  |
|   | 2.2    | i.MX                                                 |
|   | 2.3    | i.MX RT                                              |
|   | 2.4    | Kinetis                                              |
|   | 2.5    | LPC                                                  |
|   | 2.6    | MCX                                                  |
|   | 2.7    | Wireless                                             |
| • | 3.61.3 | 107                                                  |
| 3 |        | dleware       127         Motor Control       127    |
|   | 3.1    |                                                      |
|   |        | 3.1.1 FreeMASTER                                     |
| 4 | RTO    | S 165                                                |
| 1 | 4.1    | FreeRTOS                                             |
|   |        | 4.1.1 FreeRTOS kernel                                |
|   |        | 4.1.2 FreeRTOS drivers                               |
|   |        | 4.1.3 backoffalgorithm                               |
|   |        | 4.1.4 corehttp                                       |
|   |        | 4.1.5 corejson                                       |
|   |        | 4.1.6 coremgtt                                       |
|   |        | 4.1.7 coremqtt-agent                                 |
|   |        | 4.1.8 corepkcs11                                     |
|   |        | 4.1.9 freertos-plus-tcp                              |

This documentation contains information specific to the imx943evk board.

# **Chapter 1**

# IMX943EVK

# Note:

IMX943EVK includes IMX943-19X19-LPDDR5-EVK, IMX943-19X19-LPDDR4-EVK, IMX943-15X15-LPDDR4-EVK

IMX943 19x19 LPDDR5 EVK(IMX943LP5EVK-19) = IMX943LP5CPU-19 SOM + X-IMX943BB IMX943 19x19 LPDDR4 EVK(IMX943LP4EVK-19) = IMX943LP4CPU-19 SOM + X-IMX943BB IMX943 15x15 LPDDR4 EVK(IMX943LP4EVK-15) = IMX943LP4CPU-15 SOM + X-IMX943BB

# 1.1 Overview



MCU device and part on board is shown below:

- Device: MIMX94398
- PartNumber: MIMX94398AVKM, MIMX94398AVMM
- Note: IMX943LP5CPU-19 SOM and IMX943LP4CPU-19 SOM boards are using the Part-Number MIMX94398AVKM - IMX943LP4CPU-15 SOM board is using the PartNumber MIMX94398AVMM

# **1.2 Getting Started with MCUXpresso SDK Package**

# 1.2.1 Getting Started with Package

#### **Overview**

The NXP MCUXpresso software and tools offer comprehensive development solutions designed to optimize, ease and help accelerate embedded system development of applications based on general purpose, crossover and Bluetooth-enabled MCUs from NXP. The MCUXpresso SDK includes a flexible set of peripheral drivers designed to speed up and simplify development of embedded applications. Along with the peripheral drivers, the MCUXpresso SDK provides an extensive and rich set of example applications covering everything from basic peripheral use case examples to demo applications. The MCUXpresso SDK also contains optional RTOS integrations such as FreeRTOS and Azure RTOS, and device stack to support rapid development on devices.

For supported toolchain versions, see *MCUXpresso SDK Release Notes for IMX943-EVK (document MCUXSDKIMX943EVKRN)*.

For the latest version of this and other MCUXpresso SDK documents, see the MCUXpresso SDK homepage MCUXpresso-SDK: Software Development Kit for MCUXpresso.



#### **MCUXpresso SDK board support folders**

MCUXpresso SDK board support provides example applications for NXP development and evaluation boards for Arm Cortex-M cores. Board support packages are found inside of the top level boards folder, and each supported board has its own folder (MCUXpresso SDK package can support multiple boards). Within each <board\_name> folder there are various sub-folders to classify the type of examples they contain. These include (but are not limited to):

- cmsis\_driver\_examples: Simple applications intended to concisely illustrate how to use CM-SIS drivers.
- demo\_apps: Full-featured applications intended to highlight key functionality and use cases of the target MCU. These applications typically use multiple MCU peripherals and may leverage stacks and middleware.
- driver\_examples: Simple applications intended to concisely illustrate how to use the MCUXpresso SDK's peripheral drivers for a single use case.
- rtos\_examples: Basic FreeRTOS OS examples showcasing the use of various RTOS objects (semaphores, queues, and so on) and interfacing with the MCUXpresso SDK's RTOS drivers

• multicore\_examples: Simple applications intended to concisely illustrate how to use middle-ware/multicore stack.

**Example application structure** This section describes how the various types of example applications interact with the other components in the MCUXpresso SDK. To get a comprehensive understanding of all MCUXpresso SDK components and folder structure, see *MCUXpresso SDK API Reference Manual*.

Each <code><board\_name></code> folder in the boards directory contains a comprehensive set of examples that are relevant to that specific piece of hardware. Although we use the <code>hello\_world\_sm</code> example (part of the <code>demo\_apps</code> folder), the same general rules apply to any type of example in the <code><board\_name></code> folder.

In the hello\_world\_sm application folder you see the following contents:

| armgcc                                                           |
|------------------------------------------------------------------|
| iar iar                                                          |
| board.c Board macro definitions (LEDs, buttons, etc)             |
| board.h                                                          |
| clock_config.c Application-specific clock configuration          |
|                                                                  |
| demo_name.bin> Pre-compiled application                          |
| demo_name.c                                                      |
| demo_name.xml> Project definition file for MCUXpresso IDE and PG |
| pin_mux.c                                                        |
| pin_mux.h                                                        |
| readme.txt Description and instructions for running              |
|                                                                  |
|                                                                  |

All files in the application folder are specific to that example, so it is easy to copy and paste an existing example to start developing a custom application based on a project provided in the MCUXpresso SDK.

#### **Parent topic:***MCUXpresso SDK board support folders*

**Locating example application source files** When opening an example application in any of the supported IDEs, a variety of source files are referenced. The MCUXpresso SDK devices folder is the central component to all example applications. It means the examples reference the same source files and, if one of these files is modified, it could potentially impact the behavior of other examples.

The main areas of the MCUXpresso SDK tree used in all example applications are:

- devices/<device\_name>: The device's CMSIS header file, MCUXpresso SDK feature file and a few other files
- devices/<device\_name>/cmsis\_drivers: All the CMSIS drivers for your specific MCU
- device\_name>/drivers: All of the peripheral drivers for your specific MCU
- $\rm devices/<device\_name>/<tool\_name>:$  Toolchain-specific startup code, including vector table definitions
- $\rm devices/<device\_name>/utilities:$  Items such as the debug console that are used by many of the example applications
- $\bullet$  devices/<devices\_name>/project\_template: Project template used in CMSIS PACK new project creation

For examples containing an RTOS, there are references to the appropriate source code. RTOSes are in the rtos folder. The core files of each of these are shared, so modifying one could have potential impacts on other projects that depend on that file.

**Parent topic:***MCUXpresso SDK board support folders* 

#### **Toolchain introduction**

The MCUXpresso SDK release for i.MX 943 includes the build system to be used with some toolchains. In this chapter, the toolchain support is presented and detailed.

#### Build a demo application using Arm GCC

This section describes the steps to configure the command-line Arm GCC tools to build, run, and debug demo applications. Additionally, this section lists the necessary driver libraries provided in the MCUXpresso SDK. The hello\_world\_sm demo application targeted for the IMX943 series hardware platform is used as an example, though these steps can be applied to any board, demo, or example application in the MCUXpresso SDK.

**Linux OS host** The following sections provide steps to run a demo compiled with Arm GCC on Linux host.

**Parent topic:***Build a demo application using Arm GCC* 

**Windows OS host** The following sections provide steps to run a demo compiled with Arm GCC on Windows OS host.

**Parent topic:***Build a demo application using Arm GCC* 

#### Build a demo application with IAR

This section describes the steps to run the example applications provided in the MCUXpresso SDK. The demo application targeted for the i.MX 943 hardware platform is used as an example, although these steps can be applied to any example application in the MCUXpresso SDK.

**Build an example application** The following steps guide you through opening the hello\_world example application. These steps may change slightly for other example applications, as some of these applications may have additional layers of folders in their paths.

1. If not already done, open the desired demo application workspace. Most example application workspace files can be located using the following path:

 $<\!\!install\_dir\!>\!/boards/<\!\!board\_name\!>\!/<\!\!example\_type\!>\!/<\!\!application\_name\!>\!/iar$ 

Using the i.MX 943 EVK board as an example, the workspace is located in:

 $<\!\!install\_dir\!>\!/boards/imx943evk/demo\_apps/hello\_world/iar/hello\_world.eww$ 

- 2. Select the desired build target from the drop-down. For this example, select **hello\_world debug**.
- 3. To build the demo application, click **Make**.
- 4. The build completes without errors.

5. Rename the generated hello\_world.bin to m70\_image.bin/m71\_image.bin/m33s\_image.bin, then copy it to the uuu tool directory.

Parent topic:Generate flash.bin

#### Generate a flash.bin

1. Get basic images and the imx-mkimage source repository from corresponding Linux BSP release. These below basic images can to be put into imx-mkimage/iMX94:

- oei-m33-ddr.bin

- m33\_image.bin (m33\_image-mx94alt.bin: the image is generated by the command - make config=mx94alt all;m33\_image-mx94evk.bin: the image is generated by the command - make config=mx94evk all)

- m70\_image.bin (demo binary name for cortex-m7 core0 in M70 MIX)
- m71\_image.bin (demo binary name for cortex-m7 core1 in M71 MIX)
- m33s\_image.bin (demo binary name for cortex-m33 core1 in NETC MIX)
- <lpddr type name>\_dmem\_qb\_v202409.bin(lpddr type name: lpddr5 or lpddr4x)
- <lpddr type name>\_dmem\_v202409.bin
- <lpddr type name>\_imem\_qb\_v202409.bin
- <lpddr type name>\_imem\_v202409.bin
- u-boot.bin
- u-boot-spl.bin
- bl31.bin
- tee.bin
- mx943a0-ahab-container.img

#### Note:

- mx943evk for m33\_image.bin is used for rpmsg str echo, rpmsg ping pong and power\_mode\_switch\_rtos.
- mx943alt for m33\_image.bin is used for almost other examples.
- 2. Copy binary built by ARMGCC/IAR into imx-mkimage/iMX94, and rename them to m70\_image.bin/m71\_image.bin/m33s\_image.bin.
- 3. Generate flash.bin.
  - make SOC=iMX94 OEI=YES flash\_all LPDDR\_TYPE=lpddr5 (Boot up Cortex-A cores and Cortex-M cores[cortex-m33 core1, cortex-m7 core0, cortex-m7 core1])

or

• make SOC=iMX94 OEI=YES flash\_m33s\_m70\_m71 LPDDR\_TYPE=lpddr5 (Boot up Cortex-M cores[cortex-m33 core1, cortex-m7 core0, cortex-m7 core1])

#### Note:

- For LPDDR5, LPDDR\_TYPE=lpddr5;For LPDDR4, LPDDR\_TYPE=lpddr4x.
- Valid combination demos to avoid resource conflict.
  - Any demo on cm33\_core1, hello\_world demo on cm7 core0 and cm7 core1
  - Any demo on cm7\_core0, hello\_world demo on cm33 core1 and cm7 core1
  - Any demo on cm7\_core1, hello\_world demo on cm33 core1 and cm7 core0

4. Burn flash.bin to MicroSD/eMMC at 32 K(0x8000) offset with dd or HxD or UUU and then plug the MicroSD card to the board.

#### For example:

• Burn flash.bin into Micro SD card with dd

dd if=flash.bin of=/dev/sdh bs=1k seek=32 && sync

- Burn flash.bin into SD/eMMC with UUU
  - 1. Connect USB Type-C port to PC through the USB cable. It is used for downloading firmware of the board.
  - 2. Switch to serial downloader mode; boot core is cortex-m33. sd: uuu -b sd imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all new-flash.bin
  - 3. Burn flash.bin with uuu.

emmc: uuu -b emmc imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all flash.bin

sd: uuu -b sd imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all flash.bin

#### Note:

- imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all (imx-boot-imx943-19x19-lpddr4x-evk-sd.bin-flash\_all for IMX943LP4CPU-19 SOM + X-IMX943BB;
   imx-boot-imx943-15x15-lpddr4x-evk-sd.bin-flash\_all for IMX943LP4CPU-15 SOM + X-IMX943BB). Get them from linux bsp.
- flash.bin. The flash.bin is generated by yourself.
- 5. Change the boot mode to SW4[1:4] = x011 for sd boot, SW4[1:4] = x010 for emmc boot.
- 6. Power on the board .

Parent topic:Run a demo application

# Enable MCU UARTs

- 1. Connect usb typec cable from pc to typec port J15 of board.(It will emulate four serial ports[e.g. COM0 LPUART8, COM1, COM2 LPUART1, COM3 LPUART2] in pc)
  - COM0(LPUART8 use as uart of cortex-m33 core1)
  - COM2(LPUART1 use as uart of Cortex-A)
  - COM3(LPUART2 use as uart of Cortex-m33 core0)
- 2. Connect two usb2uart converter from pc to arduino interface of board.(It will emulate two serial ports[e.g. COM4 LPUART11, COM5 LPUART12] in pc)
  - COM4(LPUART11 use as uart of cortex-m7 core0)

J48-2(M2\_UART11\_RXD) – TX of usb2uart converter – pc

J48-4(M2\_UART11\_TXD) – RX of usb2uart converter – pc

GND ———— GND of usb2uart converter – pc

• COM5(LPUART12 - use as uart of cortex-m7 core1)

J44-4(M1\_UART12\_RXD) – TX of usb2uart converter – pc

J44-2(M1\_UART12\_TXD) – RX of usb2uart converter – pc

GND ———— GND of usb2uart converter – pc

Note:

- mx943evk for m33\_image.bin is used for rpmsg str echo, rpmsg ping pong and power\_mode\_switch\_rtos.
- mx943alt for m33\_image.bin is used for almost other examples.
- JTAG cannot be used when LPUART8 is used.
- Pls change uart from LPUART8 to LPUART1 and generate m33\_image.bin with command make config=mx94alt all when debugging with jtag.
  - For MCUXPresso SDK

```
_boards/imx943evk/board.h
#define BOARD_DEBUG_UART_INSTANCE 8 -> #define BOARD_DEBUG_UART_
→INSTANCE 1
```

#### Parent topic:Run a demo application

#### Run a demo application

This section describes the steps to download the flash.bin to sd and emmc, run the example applications provided in the MCUXpresso SDK. The hello\_world\_sm demo application targeted for the i.MX 943 hardware platform is used as an example, although these steps can be applied to any example application in the MCUXpresso SDK.

#### Generate a flash.bin

- 1. Get basic images and the imx-mkimage source repository from corresponding Linux BSP release. These below basic images can to be put into imx-mkimage/iMX94:
  - oei-m33-ddr.bin

- m33\_image.bin (m33\_image-mx94alt.bin: the image is generated by the command - make config=mx94alt all;m33\_image-mx94evk.bin: the image is generated by the command - make config=mx94evk all)

- m70\_image.bin (demo binary name for cortex-m7 core0 in M70 MIX)
- m71\_image.bin (demo binary name for cortex-m7 core1 in M71 MIX)
- m33s\_image.bin (demo binary name for cortex-m33 core1 in NETC MIX)
- <lpddr type name>\_dmem\_qb\_v202409.bin(lpddr type name: lpddr5 or lpddr4x)
- <lpddr type name>\_dmem\_v202409.bin
- <lpddr type name>\_imem\_qb\_v202409.bin
- <lpddr type name>\_imem\_v202409.bin
- u-boot.bin
- u-boot-spl.bin
- bl31.bin
- tee.bin
- mx943a0-ahab-container.img

#### Note:

- mx943evk for m33\_image.bin is used for rpmsg str echo, rpmsg ping pong and power\_mode\_switch\_rtos.
- mx943alt for  $\rm m33\_image.bin$  is used for almost other examples.

- 2. Copy binary built by ARMGCC/IAR into imx-mkimage/iMX94, and rename them to m70\_image.bin/m71\_image.bin/m33s\_image.bin.
- 3. Generate flash.bin.
  - make SOC=iMX94 OEI=YES flash\_all LPDDR\_TYPE=lpddr5 (Boot up Cortex-A cores and Cortex-M cores[cortex-m33 core1, cortex-m7 core0, cortex-m7 core1])

or

• make SOC=iMX94 OEI=YES flash\_m33s\_m70\_m71 LPDDR\_TYPE=lpddr5 (Boot up Cortex-M cores[cortex-m33 core1, cortex-m7 core0, cortex-m7 core1])

#### Note:

- For LPDDR5, LPDDR\_TYPE=lpddr5;For LPDDR4, LPDDR\_TYPE=lpddr4x.
- Valid combination demos to avoid resource conflict.
  - Any demo on cm33\_core1, hello\_world demo on cm7 core0 and cm7 core1
  - Any demo on cm7\_core0, hello\_world demo on cm33 core1 and cm7 core1
  - Any demo on cm7\_core1, hello\_world demo on cm33 core1 and cm7 core0
- 4. Burn flash.bin to MicroSD/eMMC at 32 K(0x8000) offset with dd or HxD or UUU and then plug the MicroSD card to the board.

#### For example:

- Burn flash.bin into Micro SD card with dd
  - dd if=flash.bin of=/dev/sdh bs=1k seek=32 && sync
- Burn flash.bin into SD/eMMC with UUU
  - 1. Connect USB Type-C port to PC through the USB cable. It is used for downloading firmware of the board.
  - 2. Switch to serial downloader mode; boot core is cortex-m33. sd: uuu -b sd imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all new-flash.bin
  - 3. Burn flash.bin with uuu.

emmc: uuu -b emmc imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all flash.bin

sd: uuu -b sd imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all flash.bin

#### Note:

- imx-boot-imx943-19x19-lpddr5-evk-sd.bin-flash\_all (imx-boot-imx943-19x19-lpddr4x-evk-sd.bin-flash\_all for IMX943LP4CPU-19 SOM + X-IMX943BB;
   imx-boot-imx943-15x15-lpddr4x-evk-sd.bin-flash\_all for IMX943LP4CPU-15 SOM + X-IMX943BB). Get them from linux bsp.
- flash.bin. The flash.bin is generated by yourself.
- 5. Change the boot mode to SW4[1:4] = x011 for sd boot, SW4[1:4] = x010 for emmc boot.
- 6. Power on the board .

#### Parent topic:Run a demo application

#### How to determine COM port

This section describes the steps necessary to determine the debug COM port number of your NXP hardware development platform.

1. To determine the COM port, open the Windows operating system Device Manager. This can be achieved by going to the Windows operating system Start menu and typing **Device Manager** in the search bar, as shown in *Figure 1*.



- 2. In the **Device Manager**, expand the **Ports (COM & LPT)** section to view the available ports. Depending on the NXP board you're using, the COM port can be named differently.
  - 1. USB-UART interface



#### Host setup

An MCUXpresso SDK build requires that some packages are installed on the Host. Depending on the used Host operating system, the following tools should be installed.

#### Linux:

• Cmake

```
$ sudo apt-get install cmake
$ # Check the version >= 3.0.x
$ cmake --version
```

#### Windows:

• MinGW

The Minimalist GNU for Windows OS (MinGW) development tools provide a set of tools that are not dependent on third party C-Runtime DLLs (such as Cygwin). The build environment used by the SDK does not utilize the MinGW build tools, but does leverage the base install of both MinGW and MSYS. MSYS provides a basic shell with a Unix-like interface and tools.

- 1. Download the latest MinGW mingw-get-setup installer from sourceforge.net/projects/mingw/files/Installer/.
- 2. Run the installer. The recommended installation path is  $\rm CeAmGW$ , however, you may install to any location.

Note: The installation path cannot contain any spaces.

3. Ensure that mingw32-base and msys-base are selected under Basic Setup.

| Installation Package Setti | ngs   |                      |       |                   |                    |                                                 |
|----------------------------|-------|----------------------|-------|-------------------|--------------------|-------------------------------------------------|
| Basic Setup                | F F   | Package              | Class | Installed Version | Repository Version | Description                                     |
| All Packages               |       | mingw-developer-tool | bin   |                   | 2013072300         | An MSYS Installation for MinGW Developers (meta |
|                            | 🧐 r   | mingw32-base         | bin   |                   | 2013072200         | A Basic MinGW Installation                      |
|                            |       | mingw32-gcc-ada      | bin   |                   | 4.8.1-4            | The GNU Ada Compiler                            |
|                            |       | mingw32-gcc-fortran  | bin   |                   | 4.8.1-4            | The GNU FORTRAN Compiler                        |
|                            | П г   | mingw32-gcc-g++      | bin   |                   | 4.8.1-4            | The GNU C++ Compiler                            |
|                            |       | mingw32-gcc-objc     | bin   |                   | 4.8.1-4            | The GNU Objective-C Compiler                    |
|                            | (S) 1 | msys-base            | bin   |                   | 2013072300         | A Basic MSYS Installation (meta)                |

4. Click \*\*Apply Changes\*\* in the \*\*Installation\*\* menu and follow the remaining instructions to complete  $\rightarrow$  the installation.

```
|![](../images/complete\_mingw\_and\_msys\_installation.png "Complete MinGW and MSYS installation")
```

5. Add the appropriate item to the Windows operating system path environment variable. It can be found ounder \*\*Control Panel\*\*-\>\*\*System and Security\*\*-\>\*\*System\*\*-\>\*\*Advanced System Settings\*\* in othe \*\*Environment Variables...\*\* section. The path is: `<mingw\_install\_dir>\bin`.

Assuming the default installation path, `C:\MinGW`, an example is as shown in [Figure 3](host\_setup.md  $\rightarrow$ #ADDINGPATH). If the path is not set correctly, the toolchain does not work.

(continues on next page)

(continued from previous page)

\*\*Note: \*\* If you have `C:\MinGW\msys\x.x\bin` in your PATH variable \(as required by KSDK 1.0.0 \), \_  $\rightarrow$  remove it to ensure that the new GCC build system works correctly.

[![](../images/add\_path\_to\_systems\_environment.png "Add Path to systems environment")

- Cmake
  - 1. Download CMake 3.0.x from www.cmake.org/cmake/resources/software.html.
  - 2. Install CMake, ensuring that the option **Add CMake to system PATH** is selected when installing. The user chooses to select whether it is installed into the PATH for all users or just the current user. In this example, it is installed for all users.

| A                    |                             |                         |          |      |
|----------------------|-----------------------------|-------------------------|----------|------|
|                      | Install Opti                |                         |          |      |
|                      | Choose opt                  | ions for installing CMa | ke 3.0.2 |      |
| By default CMa       | ke does not add its directo | ory to the system PAT   | н.       |      |
|                      |                             |                         |          |      |
| Do not add           | CMake to the system PAT     |                         |          |      |
|                      | to the system PATH for al   |                         |          |      |
|                      | to the system PATH for cu   |                         |          |      |
| U national and       |                             |                         |          |      |
|                      |                             |                         |          |      |
| Create CMa           | ke Desktop Icon             |                         |          |      |
|                      |                             |                         |          |      |
|                      |                             |                         |          |      |
|                      |                             |                         |          |      |
|                      |                             |                         |          |      |
|                      |                             |                         |          |      |
| ulleaft Taskall Curr | ham 112 46                  |                         |          |      |
| ullsoft Install Sys  | tem v2.46                   |                         |          |      |
| ullsoft Install Sys  | tem v2.46                   | < Back                  | Next >   | Cano |
| ullsoft Install Sys  | tem v2.46                   | < Back                  | Next >   | Cano |

3. Follow the remaining instructions of the installer.

4. You may need to reboot your system for the PATH changes to take effect.

# 1.3 Getting Started with MCUXpresso SDK GitHub

# 1.3.1 Getting Started with MCUXpresso SDK Repository

# Installation

NOTE

If the installation instruction asks/selects whether to have the tool installation path added to the PATH variable, agree/select the choice. This option ensures that the tool can be used in any terminal in any path. *Verify the installation* after each tool installation.

**Install Prerequisites with MCUXpresso Installer** The MCUXpresso Installer offers a quick and easy way to install the basic tools needed. The MCUXpresso Installer can be obtained from https://github.com/nxp-mcuxpresso/vscode-for-mcux/wiki/Dependency-Installation. The MCUX-presso Installer is an automated installation process, simply select MCUXpresso SDK Developer from the menu and click install. If you prefer to install the basic tools manually, refer to the next section.



# **Alternative: Manual Installation**

#### **Basic tools**

**Git** Git is a free and open source distributed version control system. Git is designed to handle everything from small to large projects with speed and efficiency. To install Git, visit the official Git website. Download the appropriate version(you may use the latest one) for your operating system (Windows, macOS, Linux). Then run the installer and follow the installation instructions.

User git --version to check the version if you have a version installed.

Then configure your username and email using the commands:

```
git config --global user.name "Your Name"
```

```
git config --global user.email "youremail@example.com"
```

#### **Python** Install python 3.10 or latest. Follow the Python Download guide.

Use python --version to check the version if you have a version installed.

#### **West** Please use the west version equal or greater than 1.2.0

# Note: you can add option '--default-timeout=1000' if you meet connection issue. Or you may set a different → source using option '-i'.
# for example, in China you could try: pip install -U west -i https://pypi.tuna.tsinghua.edu.cn/simple

pip install -U west

#### **Build And Configuration System**

**CMake** It is strongly recommended to use CMake version equal or later than 3.30.0. You can get latest CMake distributions from the official CMake download page.

For Windows, you can directly use the .msi installer like cmake-3.31.4-windows-x86\_64.msi to install.

For Linux, CMake can be installed using the system package manager or by getting binaries from the official CMake download page.

After installation, you can use cmake --version to check the version.

**Ninja** Please use the ninja version equal or later than 1.12.1.

By default, Windows comes with the Ninja program. If the default Ninja version is too old, you can directly download the ninja binary and register the ninja executor location path into your system path variable to work.

For Linux, you can use your system package manager or you can directly download the ninja binary to work.

After installation, you can use ninja --version to check the version.

**Kconfig** MCUXpresso SDK uses Kconfig python implementation. We customize it based on our needs and integrate it into our build and configuration system. The Kconfiglib sources are placed under mcuxsdk/scripts/kconfig folder.

Please make sure *python* environment is setup ready then you can use the Kconfig.

**Ruby** Our build system supports IDE project generation for iar, mdk, codewarrior and xtensa to provide OOBE from build to debug. This feature is implemented with ruby. You can follow the guide ruby environment setup to setup the ruby environment. Since we provide a built-in portable ruby, it is just a simple one cmd installation.

If you only work with CLI, you can skip this step.

**Toolchain** MCUXpresso SDK supports all mainstream toolchains for embedded development. You can install your used or interested toolchains following the guides.

| Toolchain                        | Download and Installation Guide                           | Note                |    |         |
|----------------------------------|-----------------------------------------------------------|---------------------|----|---------|
| Armgcc                           | Arm GNU Toolchain Install Guide                           | ARMGCC<br>toolchain | is | default |
| IAR                              | IAR Installation and Licensing quick ref-<br>erence guide |                     |    |         |
| MDK                              | MDK Installation                                          |                     |    |         |
| Armclang                         | Installing Arm Compiler for Embedded                      |                     |    |         |
| Zephyr                           | Zephyr SDK                                                |                     |    |         |
| Codewarrior                      | NXP CodeWarrior                                           |                     |    |         |
| Xtensa                           | Tensilica Tools                                           |                     |    |         |
| NXP S32Compiler RISC-<br>V Zen-V | NXP Website                                               |                     |    |         |

After you have installed the toolchains, register them in the system environment variables. This will allow the west build to recognize them:

| Toolchain                             | Environ-<br>ment<br>Variable | Example                                                                                                                                                        | Cmd<br>Line Ar-<br>gument          |
|---------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Armgcc                                | AR-<br>MGCC_DIR              | C:\armgcc for windows/usr for Linux. Typically<br>arm-none-eabi-* is installed under /usr/bin                                                                  | –<br>toolchain<br>armgcc           |
| IAR                                   | IAR_DIR                      | C:\iar\ewarm-9.60.3 for Windows/opt/iarsystems/<br>bxarm-9.60.3 for Linux                                                                                      | –<br>toolchain<br>iar              |
| MDK                                   | MDK_DIR                      | $\rm C:\Keil\_v5$ for Windows.MDK IDE is not officially supported with Linux.                                                                                  | –<br>toolchain<br>mdk              |
| Armclang                              | ARM-<br>CLANG_DIF            | C:\ArmCompilerforEmbedded6.22 for Windows/opt/<br>ArmCompilerforEmbedded6.21 for Linux                                                                         | –<br>toolchain<br>mdk              |
| Zephyr                                | ZEPHYR_SE                    | c:\NXP\zephyr-sdk- <version> for windows/opt/<br/>zephyr-sdk-<version> for Linux</version></version>                                                           | –<br>toolchain<br>zephyr           |
| CodeWar-<br>rior                      | CW_DIR                       | $\label{eq:CWMCUv11.2} for windows Code Warrior is not supported with Linux$                                                                                   | –<br>toolchain<br>code-<br>warrior |
| Xtensa                                | XCC_DIR                      | C:\xtensa\XtDevTools\install\tools\RI-2023.11-win32\<br>XtensaTools for windows/opt/xtensa/XtDevTools/<br>install/tools/RI-2023.11-Linux/XtensaTools for Linux | –<br>toolchain<br>xtensa           |
|                                       |                              |                                                                                                                                                                |                                    |
| NXP<br>S32Compiler<br>RISC-V<br>Zen-V | RISCVL-<br>LVM_DIR           | C:\riscv-llvm-win32_b298_b298_2024.08.12 for Win-<br>dows/opt/riscv-llvm-Linux-x64_b298_b298_2024.08.12<br>for Linux                                           | –<br>toolchain<br>riscvl-<br>lvm   |

• The <toolchain>\_DIR is the root installation folder, not the binary location folder. For IAR, it is directory containing following installation folders:



- MDK IDE using armclang toolchain only officially supports Windows. In Linux, please directly use armclang toolchain by setting ARMCLANG\_DIR. In Windows, since most Keil users will install MDK IDE instead of standalone armclang toolchain, the MDK\_DIR has higher priority than ARMCLANG\_DIR.
- For Xtensa toolchain, please set the XTENSA\_CORE environment variable. Here's an example list:

| Device Core      | XTENSA_CORE                   |
|------------------|-------------------------------|
| RT500 fusion1    | nxp_rt500_RI23_11_newlib      |
| RT600 hifi4      | $nxp_rt600_RI23_11_newlib$    |
| RT700 hifi1      | $rt700_hifi1_RI23_11_nlib$    |
| RT700 hifi4      | $t700\_hifi4\_RI23\_11\_nlib$ |
| i.MX8ULP fusion1 | $fusion_nxp02_dsp_prod$       |

• In Windows, the short path is used in environment variables. If any toolchain is using the long path, you can open a command window from the toolchain folder and use below command to get the short path: for %i in (.) do echo %~fsi

**Tool installation check** Once installed, open a terminal or command prompt and type the associated command to verify the installation.

If you see the version number, you have successfully installed the tool. Else, check whether the tool's installation path is added into the PATH variable. You can add the installation path to the PATH with the commands below:

• Windows: Open command prompt or powershell, run below command to show the user PATH variable.

reg query HKEY\_CURRENT\_USER\Environment /v PATH

The tool installation path should be C:\Users\xxx\AppData\Local\Programs\Git\cmd. If the path is not seen in the output from above, append the path value to the PATH variable with the command below:

```
reg add HKEY_CURRENT_USER\Environment /v PATH /d "%PATH%;C:\Users\xxx\AppData\
→Local\Programs\Git\cmd"
```

Then close the command prompt or powershell and verify the tool command again.

• Linux:

- 1. Open the \$HOME/.bashrc file using a text editor, such as vim.
- 2. Go to the end of the file.
- 3. Add the line which appends the tool installation path to the PATH variable and export PATH at the end of the file. For example, export PATH="/Directory1:\$PATH".
- 4. Save and exit.
- 5. Execute the script with source .bashrc or reboot the system to make the changes live. To verify the changes, run echo \$PATH.

- macOS:
  - 1. Open the \$HOME/.bash\_profile file using a text editor, such as nano.
  - 2. Go to the end of the file.
  - 3. Add the line which appends the tool installation path to the PATH variable and export PATH at the end of the file. For example, export PATH="/Directory1:\$PATH".
  - 4. Save and exit.
  - 5. Execute the script with **source** .bash\_profile **or reboot** the system to make the changes live. To verify the changes, run echo \$PATH.

#### Get MCUXpresso SDK Repo

**Establish SDK Workspace** To get the MCUXpresso SDK repository, use the west tool to clone the manifest repository and checkout all the west projects.

| # Initialize west with the manifest repository                                   |
|----------------------------------------------------------------------------------|
| west init -m https://github.com/nxp-mcuxpresso/mcuxsdk-manifests/ mcuxpresso-sdk |
|                                                                                  |
| # Update the west projects                                                       |
| cd mcuxpresso-sdk                                                                |
| west update                                                                      |
|                                                                                  |
| # Allow the usage of west extensions provided by MCUXpresso SDK                  |
| west config commands.allow_extensions true                                       |

**Install Python Dependency(If do tool installation manually)** To create a Python virtual environment in the west workspace core repo directory mcuxsdk, follow these steps:

1. Navigate to the core directory:

#### cd mcuxsdk

2. [Optional] Create and activate the virtual environment: If you don't want to use the python virtual environment, skip this step. We strongly suggest you use venv to avoid conflicts with other projects using python.

python -m venv .venv
# For Linux/MacOS
source .venv/bin/activate
# For Windows
.\.venv\Scripts\activate
# If you are using powershell and see the issue that the activate script cannot be run.
# You may fix the issue by opening the powershell as administrator and run below command:
powershell Set-ExecutionPolicy RemoteSigned
# then run above activate command again.

Once activated, your shell will be prefixed with (.venv). The virtual environment can be deactivated at any time by running deactivate command.

**Remember to activate the virtual environment every time you start working in this directory.** If you are using some modern shell like zsh, there are some powerful plugins to help you auto switch venv among workspaces. For example, zsh-autoswitch-virtualenv.

3. Install the required Python packages:

# Note: you can add option '--default-timeout=1000' if you meet connection issue. Or you may set a∟ → different source using option '-i'. # for example, in China you could try: pip3 install -r mcuxsdk/scripts/requirements.txt -i https://pypi. → tuna.tsinghua.edu.cn/simple pip install -r scripts/requirements.txt

# **Explore Contents**

This section helps you build basic understanding of current fundamental project content and guides you how to build and run the provided example project in whole SDK delivery.

**Folder View** The whole MCUXpresso SDK project, after you have done the west init and west update operations follow the guideline at *Getting Started Guide*, have below folder structure:

| Folder         | Description                                                                            |
|----------------|----------------------------------------------------------------------------------------|
| mani-<br>fests | Manifest repo, contains the manifest file to initialize and update the west workspace. |
| mcuxsdk        | The MCUXpresso SDK source code, examples, middleware integration and script files.     |

All the projects record in the Manifest repo are checked out to the folder mcuxsdk/, the layout of mcuxsdk folder is shown as below:

| Folder               | Description                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arch                 | Arch related files such as ARM CMSIS core files, RISC-V files and the build files related to the architecture.                                                                                |
| cmake                | The cmake modules, files which organize the build system.                                                                                                                                     |
| com-<br>po-<br>nents | Software components.                                                                                                                                                                          |
| de-<br>vices         | Device support package which categorized by device series. For each device, header file, feature file, startup file and linker files are provided, also device specific drivers are included. |
| docs                 | Documentation source and build configuration for this sphinx built online documen-<br>tation.                                                                                                 |
| drivers              | Peripheral drivers.                                                                                                                                                                           |
| ex-<br>am-<br>ples   | Various demos and examples, support files on different supported boards. For each board support, there are board configuration files.                                                         |
| mid-<br>dle-<br>ware | Middleware components integrated into SDK.                                                                                                                                                    |
| rtos                 | Rtos components integrated into SDK.                                                                                                                                                          |
| scripts              | Script files for the west extension command and build system support.                                                                                                                         |
| svd                  | Svd files for devices, this is optional because of large size. Customers run west manifest config group.filter +optional and west update mcux-soc-svd to get this folder.                     |

**Examples Project** The examples project is part of the whole SDK delivery, and locates in the folder mcuxsdk/examples of west workspace.

Examples files are placed in folder of  $<\!\!{\rm example\_category}\!>$ , these examples include (but are not limited to)

- demo\_apps: Basic demo set to start using SDK, including hello\_world and led\_blinky.
- driver\_examples: Simple applications that show how to use the peripheral drivers for a single use case. These applications typically only use a single peripheral but there are cases where multiple peripherals are used (for example, SPI transfer using DMA).

Board porting layers are placed in folder of  $\_boards/<board\_name>$  which aims at providing the board specific parts for examples code mentioned above.

#### Run a demo using MCUXpresso for VS Code

This section explains how to configure MCUXpresso for VS Code to build, run, and debug example applications. This guide uses the hello\_world demo application as an example. However, these steps can be applied to any example application in the MCUXpresso SDK.

**Build an example application** This section assumes that the user has already obtained the SDK as outlined in *Get MCUXpresso SDK Repo*.

To build an example application:

1. Import the SDK into your workspace. Click **Import Repository** from the **QUICKSTART PANEL**.



**Note:** You can import the SDK in several ways. Refer to MCUXpresso for VS Code Wiki for details.

Select **Local** if you've already obtained the SDK as seen in *Get MCUXpresso SDK Repo*. Select your location and click **Import**.

| E Import Repositor | ух               |   |               |  |        |
|--------------------|------------------|---|---------------|--|--------|
| Impor              | t Repositor      | у |               |  |        |
| REMOTE             | REMOTE ARCHIVE   |   | LOCAL ARCHIVE |  |        |
| Location:          | c:\Repos\mcuxsdk |   |               |  | Browse |
| Import             |                  |   |               |  |        |

2. Click Import Example from Repository from the QUICKSTART PANEL.



In the dropdown menu, select the MCUXpresso SDK, the Arm GNU Toolchain, your board, template, and application type. Click **Import**.

| ■ Import Example free              | om Repository X                                                                                                                                                                                                                         |             |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Import                             | Example from Repository                                                                                                                                                                                                                 |             |
| Repository:                        | c:\Repos\mcuxsdk (MCUXpresso SDK Repository)                                                                                                                                                                                            | ~           |
| Toolchain:                         | (Arm GNU Toolchain 13.2.rel1 (Build arm-13.7)) 13.2.1 20231009 💿 (C:\NXP\MCUXpressol                                                                                                                                                    | DE_24.'   🗸 |
| Board:                             | FRDM-MCXC444                                                                                                                                                                                                                            | ~           |
|                                    | FRDM-MCXC444                                                                                                                                                                                                                            |             |
| Template:                          | demo_apps/hello_world                                                                                                                                                                                                                   | ~           |
| input. The purp<br>further develop | d demo prints the "Hello World" string to the terminal using the SDK UART drivers and repeat<br>lose of this demo is to show how to use the UART, and to provide a simple project for debugg<br>oment.<br>README file for more details. |             |
| App type:                          | Freestanding application                                                                                                                                                                                                                | ~           |
| Name:                              | frdmmcxc444_hello_world                                                                                                                                                                                                                 |             |
| Location:                          | c:\nxp_examples<br>Note: Path doesn't exist. Folder(s) will be created.                                                                                                                                                                 | Browse      |
| Open read                          | Ime file after project is imported                                                                                                                                                                                                      |             |
| Import                             |                                                                                                                                                                                                                                         |             |

**Note:** The MCUXpresso SDK projects can be imported as **Repository applications** or **Free-standing applications**. The difference between the two is the import location. Projects imported as Repository examples will be located inside the MCUXpresso SDK, whereas Free-standing examples can be imported to a user-defined location. Select between these by designating your selection in the **App type** dropdown menu.

- 3. VS Code will prompt you to confirm if the imported files are trusted. Click Yes.
- 4. Navigate to the **PROJECTS** view. Find your project and click the **Build Project** icon.



The integrated terminal will open at the bottom and will display the build output.

| PROBLEMS OUTPUT                                              | TERMINAL PORTS                         | DEBUG CONSO                        | E SERIAL MONITOR                         | OFFLINE PERIPHERALS                                                                                                                                                                                                  | ∑ CMake: build                        |
|--------------------------------------------------------------|----------------------------------------|------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| [18/21] Building C<br>[19/21] Building C                     | object CMakeFiles<br>object CMakeFiles | 5/hello_world.d<br>5/hello_world.d | ir/C_/Repos/mcuxso<br>ir/C_/Repos/mcuxso | dk/mcuxsdk/components/debug_console_lite/fsl_debug_console.c.obj<br>dk/mcuxsdk/devices/MCX/MCXC/MAC4/drivers/fsl_clock.c.obj<br>dk/mcuxsdk/drivers/lpuart/fsl_lpuart.c.obj<br>dk/mcuxsdk/drivers/uart/fsl_uart.c.obj |                                       |
| [21/21] Linking C @                                          |                                        |                                    |                                          |                                                                                                                                                                                                                      | i i i i i i i i i i i i i i i i i i i |
| Memory region                                                | Used Size Re                           | gion Size %age                     | Used                                     |                                                                                                                                                                                                                      | 1                                     |
| <pre>m_interrupts:</pre>                                     | 192 B                                  | 512 B 3                            | 7.50%                                    |                                                                                                                                                                                                                      |                                       |
| <pre>m_flash_config:</pre>                                   | 16 B                                   | 16 B 10                            | .00%                                     |                                                                                                                                                                                                                      |                                       |
| m text:                                                      | 7892 B                                 | 261104 B                           | 3.02%                                    |                                                                                                                                                                                                                      |                                       |
| m data:                                                      | 2128 B                                 | 32 KB                              | 5.49%                                    |                                                                                                                                                                                                                      |                                       |
| build finished successfully.                                 |                                        |                                    |                                          |                                                                                                                                                                                                                      |                                       |
| Terminal will be reused by tasks, press any key to close it. |                                        |                                    |                                          |                                                                                                                                                                                                                      |                                       |

**Run an example application** Note: for full details on MCUXpresso for VS Code debug probe support, see MCUXpresso for VS Code Wiki.

1. Open the **Serial Monitor** from the VS Code's integrated terminal. Select the VCom Port for your device and set the baud rate to 115200.



2. Navigate to the **PROJECTS** view and click the play button to initiate a debug session.



The debug session will begin. The debug controls are initially at the top.

| C hello_ | world.c ×                                                                               |
|----------|-----------------------------------------------------------------------------------------|
| frdmmcx  | c444_hello_world > examples > demo_apps > hello_world > C hello_v 🗄 IÞ 🗘 🕇 🕇 🖱 🔲   i→ 🕤 |
| 18       |                                                                                         |
| 21       |                                                                                         |
| 22       |                                                                                         |
| 23       | * Variables                                                                             |
| 24       |                                                                                         |
| 25       |                                                                                         |
| 26       |                                                                                         |
| 27       | * Code                                                                                  |
| 28       |                                                                                         |
| 29       |                                                                                         |
| 30       | * @brief Main function                                                                  |
| 31       |                                                                                         |
| 32       | int main(void)                                                                          |
| 33       | {                                                                                       |
| 34       | char ch;                                                                                |
| 35       |                                                                                         |
| 36       | /* Init board hardware. */                                                              |
| D 37     | BOARD_InitHardware();                                                                   |
| 38       |                                                                                         |
| 39       | <pre>PRINTF("hello world.\r\n");</pre>                                                  |
| 40       |                                                                                         |
| 41<br>42 | while (1)                                                                               |
| 42       |                                                                                         |
| 43<br>44 | ch = GETCHAR();<br>PUTCHAR(ch);                                                         |
| 44<br>45 |                                                                                         |
| 45<br>46 | 1                                                                                       |
| 40       |                                                                                         |

3. Click **Continue** on the debug controls to resume execution of the code. Observe the output on the **Serial Monitor**.

| PROBLEMS              | OUTPUT       | TERMINAL   | PERIPHER | ALS RTC          | DS DET | AILS PORTS | DEBUG CONSOLE    | SERIAL MONIT |
|-----------------------|--------------|------------|----------|------------------|--------|------------|------------------|--------------|
| + Open an a           | additional n | nonitor    |          |                  |        |            |                  |              |
| Monitor Mod           | e Serial `   | 🗸 View M   | ode Text |                  | Port   | COM40 - MC | U-Link VCom Port | (COM40) 🗸 i  |
| Stop Mor              | nitoring     | ېي 🔁       | D 0      | <mark>ම</mark> 🕄 |        |            |                  |              |
| Oper<br>hello wor<br> |              | erial port | COM40 -  |                  |        |            |                  |              |

#### Running a demo using ARMGCC CLI/IAR/MDK

**Supported Boards** Use the west extension west list\_project to understand the board support scope for a specified example. All supported build command will be listed in output:

west list\_project -p examples/demo\_apps/hello\_world [-t armgcc]

INFO: [1][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_  $\rightarrow$  evk9mimx8ulp -Dcore\_id=cm33]

INFO: [2][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_  $\rightarrow$  evkbimxrt1050]

 $INFO: [ 3] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/demo_apps/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build -p always examples/hello_world --toolchain armgcc --config release -b_{\Box} ] [west build --toolchain armgcc --config release -b_{\Box} ] [we$ 

<sup>(</sup>continues on next page)

(continued from previous page)

→evkbmimxrt1060] INFO: [ 4][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkbmimxrt1170 -Dcore\_id=cm4] INFO: [ 5][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkbmimxrt1170 -Dcore\_id=cm7] INFO: [ 6][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkcmimxrt1060] INFO: [ 7][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkcmimxrt1060] INFO: [ 7][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkcmimxrt1060] INFO: [ 7][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkcmimxr1060] INFO: [ 7][west build -p always examples/demo\_apps/hello\_world --toolchain armgcc --config release -b\_ →evkcmimxr1060]

The supported toolchains and build targets for an example are decided by the example-self example.yml and board example.yml, please refer Example Toolchains and Targets for more details.

**Build the project** Use west build -h to see help information for west build command. Compared to zephyr's west build, MCUXpresso SDK's west build command provides following additional options for mcux examples:

- --toolchain: specify the toolchain for this build, default armgcc.
- --config: value for CMAKE\_BUILD\_TYPE. If not provided, build system will get all the example supported build targets and use the first debug target as the default one. Please refer Example Toolchains and Targets for more details about example supported build targets.

Here are some typical usages for generating a SDK example:

# Generate example with default settings, default used device is the mainset MK22F51212 west build -b frdmk22f examples/demo\_apps/hello\_world
# Just print cmake commands, do not execute it west build -b frdmk22f examples/demo\_apps/hello\_world --dry-run
# Generate example with other toolchain like iar, default armgcc west build -b frdmk22f examples/demo\_apps/hello\_world --toolchain iar
# Generate example with other config type

west build -b frdmk22f examples/demo\_apps/hello\_world --config release

# Generate example with other devices with --device west build -b frdmk22f examples/demo\_apps/hello\_world --device MK22F12810 --config release

For multicore devices, you shall specify the corresponding core id by passing the command line argument -Dcore\_id. For example

west build -b evkbmimxrt 1170 examples/demo\_apps/hello\_world --toolchain iar -Dcore\_id=cm7 --config \_  $\hookrightarrow flexspi_nor_debug$ 

#### For shield, please use the --shield to specify the shield to run, like

west build -b mimxrt700evk --shield a 8974 examples/issdk\_examples/sensors/fxls8974cf/fxls8974cf\_poll -  $\rightarrow Dcore\_id=cm33\_core0$ 

**Sysbuild(System build)** To support multicore project building, we ported Sysbuild from Zephyr. It supports combine multiple projects for compilation. You can build all projects by adding --sysbuild for main application. For example:

west build -b evkbmimxrt 1170 --sysbuild ./examples/multicore\_examples/hello\_world/primary -D core\_  $\rightarrow$  id=cm7 --config flexspi\_nor\_debug --toolchain=armgcc -p always

For more details, please refer to System build.

**Config a Project** Example in MCUXpresso SDK is configured and tested with pre-defined configuration. You can follow steps blow to change the configuration.

#### 1. Run cmake configuration

west build -b evkbmimxrt1170 examples/demo\_apps/hello\_world -Dcore\_id=cm7 --cmake-only -p

Please note the project will be built without -- cmake-only parameter.

2. Run guiconfig target

west build -t guiconfig

Then you will get the Kconfig GUI launched, like

| 🔀 Hello World                                        | -       | × |
|------------------------------------------------------|---------|---|
| Save Save as Save minimal (advanced) Open            | Jump to |   |
| Show name Show all Single-menu mode                  |         |   |
| (Top)                                                |         |   |
| 🗄 Board Boot Header                                  |         | ~ |
| Project Segments                                     |         |   |
| Device Boot Header                                   |         |   |
| Device MIMXRT1176 Part (Device part MIMXRT1176DVMAA) |         |   |
| Device part MIMXRT1176DVMAA                          |         |   |
| ODevice part MIMXRT1176AVM8A                         |         |   |
| ODevice part MIMXRT1176CVM8A                         |         |   |
| Device specific drivers                              |         |   |
| XUse driver clock                                    |         |   |
| XUse driver iomuxc                                   |         |   |
| Use driver mipi csi2rx                               |         |   |
| Use driver mipi dsi                                  |         |   |
| Suse driver anatop_ai                                |         |   |
| Use driver memory                                    |         |   |
| XUse driver dcdc                                     |         |   |
| Subse driver acac                                    |         |   |
| Security gpc                                         |         |   |
| Subse driver pgric                                   |         |   |
| XUse driver src                                      |         |   |
| est any clare                                        |         | • |

Kconfig definition, with parent deps. propagated to 'depends on'

At D:/sdk\_next/mcuxsdk\devices\../devices/RT/RT1170/MIMXRT1176\drivers/Kconfig:5 Included via D:/sdk\_next/mcuxsdk/examples/demo\_apps/hello\_world/Kconfig:6 -> D:/sdk\_next/mcuxsdk/Kconfig.mcuxpresso:9 -> D:/sdk\_next/mcuxsdk\devices/Kconfig:1 -> D:/sdk\_next/mcuxsdk\devices\../devices/RT/RT1170/MIMXRT1176/Kconfig:8 Menu path: (Top)

menu "Device specific drivers"

You can reconfigure the project by selecting/deselecting Kconfig options.

After saving and closing the Kconfig GUI, you can directly run west build to build with the new configuration.

Flash Note: Please refer Flash and Debug The Example to enable west flash/debug support.

Flash the hello\_world example:

west flash -r linkserver

**Debug** Start a gdb interface by following command:

west debug -r linkserver

**Work with IDE Project** The above build functionalities are all with CLI. If you want to use the toolchain IDE to work to enjoy the better user experience especially for debugging or you are already used to develop with IDEs like IAR, MDK, Xtensa and CodeWarrior in the embedded world, you can play with our IDE project generation functionality.

This is the cmd to generate the evkbmimxrt1170 hello\_world IAR IDE project files.

west build -b evkbmimxrt1170 examples/demo\_apps/hello\_world --toolchain iar -Dcore\_id=cm7 --config\_  $\rightarrow$  flexspi\_nor\_debug -p always -t guiproject

By default, the IDE project files are generated in mcuxsdk/build/<toolchain> folder, you can open the project file with the IDE tool to work:



Note, please follow the *Installation* to setup the environment especially make sure that *ruby* has been installed.

# **1.4 Release Notes**

# 1.4.1 MCUXpresso SDK Release Notes

# **Overview**

The MCUXpresso SDK is a comprehensive software enablement package designed to simplify and accelerate application development with Arm Cortex-M-based devices from NXP, including its general purpose, crossover and Bluetooth-enabled MCUs. MCUXpresso SW and Tools for DSC further extends the SDK support to current 32-bit Digital Signal Controllers. The MCUXpresso SDK includes production-grade software with integrated RTOS (optional), integrated enabling software technologies (stacks and middleware), reference software, and more.

In addition to working seamlessly with the MCUXpresso IDE, the MCUXpresso SDK also supports and provides example projects for various toolchains. The Development tools chapter in the associated Release Notes provides details about toolchain support for your board. Support for the MCUXpresso Config Tools allows easy cloning of existing SDK examples and demos, allowing users to leverage the existing software examples provided by the SDK for their own projects.

Underscoring our commitment to high quality, the MCUXpresso SDK is MISRA compliant and checked with Coverity static analysis tools. For details on MCUXpresso SDK, see MCUXpresso-SDK: Software Development Kit for MCUXpresso.

# **MCUXpresso SDK**

As part of the MCUXpresso software and tools, MCUXpresso SDK is the evolution of Kinetis SDK, includes support for LPC, DSC, PN76, and i.MX System-on-Chip (SoC). The same drivers, APIs, and middleware are still available with support for Kinetis, LPC, DSC, and i.MX silicon. The MCUX-presso SDK adds support for the MCUXpresso IDE, an Eclipse-based toolchain that works with all MCUXpresso SDKs. Easily import your SDK into the new toolchain to access to all of the available components, examples, and demos for your target silicon. In addition to the MCUXpresso IDE, support for the MCUXpresso Config Tools allows easy cloning of existing SDK examples and demos, allowing users to leverage the existing software examples provided by the SDK for their own projects.

In order to maintain compatibility with legacy Freescale code, the filenames and source code in MCUXpresso SDK containing the legacy Freescale prefix FSL has been left as is. The FSL prefix has been redefined as the NXP Foundation Software Library.

# **Development tools**

The MCUXpresso SDK was tested with following development tools. Same versions or above are recommended.

- IAR Embedded Workbench for Arm, version is 9.60.4
- MCUXpresso for VS Code v25.06
- GCC Arm Embedded Toolchain 14.2.x

# Supported development systems

This release supports board and devices listed in following table. The board and devices in bold were tested in this release.

| Devel-<br>opment<br>boards | MCU devices                                                                                                                    |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| IMX943-<br>EVK             | <b>MIMX94398AVKM</b> , MIMX94398AVMM, MIMX94398CVKM, MIMX94398CVMM, MIMX94398DVKM, MIMX94398DVMM, MIMX94398XVKM, MIMX94398XVMM |

#### MCUXpresso SDK release package

The MCUXpresso SDK release package content is aligned with the silicon subfamily it supports. This includes the boards, CMSIS, devices, middleware, and RTOS support.

**Device support** The device folder contains the whole software enablement available for the specific System-on-Chip (SoC) subfamily. This folder includes clock-specific implementation, device register header files, device register feature header files, and the system configuration source files. Included with the standard SoC support are folders containing peripheral drivers, toolchain support, and a standard debug console. The device-specific header files provide a direct access to the microcontroller peripheral registers. The device header file provides an overall SoC memory mapped register definition. The folder also includes the feature header file for each peripheral on the microcontroller. The toolchain folder contains the startup code and linker files for each supported toolchain. The startup code efficiently transfers the code execution to the main() function.

**Board support** The boards folder provides the board-specific demo applications, driver examples, and middleware examples.

**Demo application and other examples** The demo applications demonstrate the usage of the peripheral drivers to achieve a system level solution. Each demo application contains a readme file that describes the operation of the demo and required setup steps. The driver examples demonstrate the capabilities of the peripheral drivers. Each example implements a common use case to help demonstrate the driver functionality.

#### RTOS

**FreeRTOS** Real-time operating system for microcontrollers from Amazon

#### Middleware

**CMSIS DSP Library** The MCUXpresso SDK is shipped with the standard CMSIS development pack, including the prebuilt libraries.

**USB Type-C PD Stack** See the *MCUXpresso SDK USB Type-C PD Stack User's Guide* (document MCUXSDKUSBPDUG) for more information

**USB Host, Device, OTG Stack** See the MCUXpresso SDK USB Stack User's Guide (document MCUXSDKUSBSUG) for more information.

**TinyCBOR** Concise Binary Object Representation (CBOR) Library

**PKCS#11** The PKCS#11 standard specifies an application programming interface (API), called "Cryptoki," for devices that hold cryptographic information and perform cryptographic functions. Cryptoki follows a simple object based approach, addressing the goals of technology independence (any kind of device) and resource sharing (multiple applications accessing multiple devices), presenting to applications a common, logical view of the device called a "cryptographic token".

Multicore Multicore Software Development Kit

**lwIP** The lwIP TCP/IP stack is pre-integrated with MCUXpresso SDK and runs on top of the MCUXpresso SDK Ethernet driver with Ethernet-capable devices/boards.

For details, see the *lwIP TCPIP Stack and MCUXpresso SDK Integration User's Guide* (document MCUXSDKLWIPUG).

lwIP is a small independent implementation of the TCP/IP protocol suite.

**llhttp** HTTP parser llhttp

**FreeMASTER** FreeMASTER communication driver for 32-bit platforms.

#### **Release contents**

Provides an overview of the MCUXpresso SDK release package contents and locations.

| Deliverable                                          | Location                                                                                 |
|------------------------------------------------------|------------------------------------------------------------------------------------------|
| Boards                                               | INSTALL_DIR/boards                                                                       |
| Demo Applications                                    | INSTALL_DIR/boards/ <board_name>/demo_apps</board_name>                                  |
| Driver Examples                                      | INSTALL_DIR/boards/ <board_name>/driver_examples</board_name>                            |
| eIQ examples                                         | INSTALL_DIR/boards/ <board_name>/eiq_examples</board_name>                               |
| Board Project Template for MCUXpresso IDE NPW        | INSTALL_DIR/boards/ <board_name>/project_template</board_name>                           |
| Driver, SoC header files, extension header files and | INSTALL_DIR/devices/ <device_name></device_name>                                         |
| feature header files, utilities                      |                                                                                          |
| CMSIS drivers                                        | INSTALL_DIR/devices/ <device_name>/cmsis_drivers</device_name>                           |
| Peripheral drivers                                   | INSTALL_DIR/devices/ <device_name>/drivers</device_name>                                 |
| Toolchain linker files and startup code              | INSTALL_DIR/devices/ <device_name>/<toolchain_nam< td=""></toolchain_nam<></device_name> |
| Utilities such as debug console                      | INSTALL_DIR/devices/ <device_name>/utilities</device_name>                               |
| Device Project Template for MCUXpresso IDE NPW       | INSTALL_DIR/devices/ <device_name>/project_templat</device_name>                         |
| CMSIS Arm Cortex-M header files, DSP library source  | INSTALL_DIR/CMSIS                                                                        |
| Components and board device drivers                  | INSTALL_DIR/components                                                                   |
| RTOS                                                 | INSTALL_DIR/rtos                                                                         |
| Release Notes, Getting Started Document and other    | INSTALL_DIR/docs                                                                         |
| documents                                            |                                                                                          |
| Tools such as shared cmake files                     | INSTALL_DIR/tools                                                                        |
| Middleware                                           | INSTALL_DIR/middleware                                                                   |

#### Known issues

This section lists the known issues, limitations, and/or workarounds.

#### SEGGER J-Link debugger usage problem

When an M core software is already running, it is possible to get HardFault or data verification issue during loading image into TCM by debugger.

The following steps are recommended to use the J-Link debugger.

1. Configure switch SW1301 to M core boot; low-power boot. Ensure that there is no image on the boot source.

- 2. Power the board and start the debugger for use.
- 3. To restart the debugger, stop the debugger, power off the board, and repeat step 2.

# Failed to get temperature from temp\_ana

**Issue Description** Failed to get data from sensor after selecting temp\_ana (index 0) sensor when the demo temperature\_measurement is running.

#### Reference

| Ticket         | Description                                                                   | Version  |
|----------------|-------------------------------------------------------------------------------|----------|
| MCUX-<br>80597 | Failed to get data from sensor after selecting temp_ana (index 0) sen-<br>sor | 25.06.00 |

#### Sar\_adc trigger not enabled

**Issue Description** Sar\_adc cannot be triggerred due to FSL\_FEATURE\_ADC\_HAS\_EXTERNAL\_TRIGGER not enabled in i.mx943.

#### Reference

| Ticket     | Description                                                  | Version  |
|------------|--------------------------------------------------------------|----------|
| MCUX-80565 | [adc_polling_trigger] the app will block after press any key | 25.06.00 |

# LPUART trigger no output

**Issue Description** There is no output after LPUART being triggered due to wrong pin mux configuration for lpuart12 on i.mx943.

#### Reference

| Ticket     | Ticket Description                              |          |
|------------|-------------------------------------------------|----------|
| MCUX-80622 | [lpuart_polling_trigger] no logs after flashing | 25.06.00 |

# 1.5 ChangeLog

# 1.5.1 MCUXpresso SDK Changelog

# **Board Support Files**

board

# [25.06.00]

• Initial version

# clock\_config

# [25.06.00]

• Initial version

# pin\_mux

# [25.06.00]

• Initial version

# AOI

# [2.0.2]

- Improvements
  - Release peripheral from reset if necessary in init function.

# [2.0.1]

- Bug Fixes
  - MISRA C-2012 issue fixed: rule 10.8, 2.2.

# [2.0.0]

• Initial version.

# **BBNSM**

# [2.0.0]

• Initial version.

# BiSS

# [1.0.2]

- Bug Fixes
  - Fixed freqMADiv and freqAGSDiv setting

# [1.0.1]

- Bug Fixes
  - Fixed coverity issues

# [1.0.0]

• Initial version.

# CACHE XCACHE

#### [2.0.3]

- Bug Fixes
  - Fixed CERT INT30-C violations.

# [2.0.2]

- Bug Fixes
  - Updated XCACHE\_InvalidateCacheByRange(), XCACHE\_CleanCacheByRange(), XCACHE\_CleanInvalidateCacheByRange() in case of startAddr equal to endAddr.

#### [2.0.1]

- Improvements
  - Check input parameter "size\_byte" must be larger than 0.

# [2.0.0]

• Initial version.

# CACHE ARMv7-M7

#### [2.0.4]

- Bug Fixes
  - Fixed doxygen issue.

# [2.0.3]

- Improvements
  - Deleted redundancy code about calculating cache clean/invalidate size and address aligns.

# [2.0.2]

- Bug Fixes
  - Fixed violation of MISRA C-2012 Rule 10.1, 10.3 and 10.4.

# [2.0.1]

- Bug Fixes
  - Fixed cache size issue in L2CACHE\_GetDefaultConfig API.

### [2.0.0]

• Initial version.

#### COMMON

#### [2.6.0]

- Bug Fixes
  - Fix CERT-C violations.

### [2.5.0]

- New Features
  - Added new APIs InitCriticalSectionMeasurementContext, DisableGlobalIRQEx and EnableGlobalIRQEx so that user can measure the execution time of the protected sections.

#### [2.4.3]

- Improvements
  - Enable irqs that mount under irqsteer interrupt extender.

#### [2.4.2]

- Improvements
  - Add the macros to convert peripheral address to secure address or non-secure address.

### [2.4.1]

- Improvements
  - Improve for the macro redefinition error when integrated with zephyr.

#### [2.4.0]

- New Features
  - Added EnableIRQWithPriority, IRQ\_SetPriority, and IRQ\_ClearPendingIRQ for ARM.
  - Added MSDK\_EnableCpuCycleCounter, MSDK\_GetCpuCycleCount for ARM.

#### [2.3.3]

- New Features
  - Added NETC into status group.

### [2.3.2]

- Improvements
  - Make driver aarch64 compatible

# [2.3.1]

- Bug Fixes
  - Fixed MAKE\_VERSION overflow on 16-bit platforms.

# [2.3.0]

- Improvements
  - Split the driver to common part and CPU architecture related part.

# [2.2.10]

- Bug Fixes
  - Fixed the ATOMIC macros build error in cpp files.

# [2.2.9]

- Bug Fixes
  - Fixed MISRA C-2012 issue, 5.6, 5.8, 8.4, 8.5, 8.6, 10.1, 10.4, 17.7, 21.3.
  - Fixed SDK\_Malloc issue that not allocate memory with required size.

# [2.2.8]

- Improvements
  - Included stddef.h header file for MDK tool chain.
- New Features:
  - Added atomic modification macros.

# [2.2.7]

- Other Change
  - Added MECC status group definition.

# [2.2.6]

- Other Change
  - Added more status group definition.
- Bug Fixes
  - Undef \_\_VECTOR\_TABLE to avoid duplicate definition in cmsis\_clang.h

# [2.2.5]

- Bug Fixes
  - Fixed MISRA C-2012 rule-15.5.

## [2.2.4]

- Bug Fixes
  - Fixed MISRA C-2012 rule-10.4.

## [2.2.3]

- New Features
  - Provided better accuracy of SDK\_DelayAtLeastUs with DWT, use macro SDK\_DELAY\_USE\_DWT to enable this feature.
  - Modified the Cortex-M7 delay count divisor based on latest tests on RT series boards, this setting lets result be closer to actual delay time.

### [2.2.2]

- New Features
  - Added include RTE\_Components.h for CMSIS pack RTE.

### [2.2.1]

- Bug Fixes
  - Fixed violation of MISRA C-2012 Rule 3.1, 10.1, 10.3, 10.4, 11.6, 11.9.

### [2.2.0]

- New Features
  - Moved SDK\_DelayAtLeastUs function from clock driver to common driver.

### [2.1.4]

- New Features
  - Added OTFAD into status group.

### [2.1.3]

- Bug Fixes
  - MISRA C-2012 issue fixed.
    - \* Fixed the rule: rule-10.3.

# [2.1.2]

- Improvements
  - Add SUPPRESS\_FALL\_THROUGH\_WARNING() macro for the usage of suppressing fallthrough warning.

## [2.1.1]

- Bug Fixes
  - Deleted and optimized repeated macro.

### [2.1.0]

- New Features
  - Added IRQ operation for XCC toolchain.
  - Added group IDs for newly supported drivers.

## [2.0.2]

- Bug Fixes
  - MISRA C-2012 issue fixed.
    - \* Fixed the rule: rule-10.4.

## [2.0.1]

- Improvements
  - Removed the implementation of LPC8XX Enable/DisableDeepSleepIRQ() function.
  - Added new feature macro switch "FSL\_FEATURE\_HAS\_NO\_NONCACHEABLE\_SECTION" for specific SoCs which have no noncacheable sections, that helps avoid an unnecessary complex in link file and the startup file.
  - Updated the align(x) to **attribute**(aligned(x)) to support MDK v6 armclang compiler.

## [2.0.0]

• Initial version.

# DCIF

## [2.0.0]

• Initial version.

### ECAT

### [2.0.0]

• Initial version.

### EDMA

### [2.10.5]

- Bug Fixes
  - Fixed memory convert would convert NULL as zero address issue.

## [2.10.4]

- Improvements
  - Add new MP register macros to ensure compatibility with different devices.
  - Add macro DMA\_CHANNEL\_ARRAY\_STEPn to adapt to complex addressing of edma tcd registers.

## [2.10.3]

- Bug Fixes
  - Clear interrupt status flags in EDMA\_CreateHandle to avoid triggering interrupt by mistake.

### [2.10.2]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.3.

### [2.10.1]

- Bug Fixes
  - Fixed EDMA\_GetRemainingMajorLoopCount may return wrong value issue.
  - Fixed violations of the MISRA C-2012 rules 13.5, 10.4.

### [2.10.0]

- Improvements
  - Modify the structures edma\_core\_mp\_t, edma\_core\_channel\_t, edma\_core\_tcd\_t to adapt to edma5.
  - Add TCD register macro to facilitate confirmation of tcd type.
  - Modfiy the mask macro to a fixed value.
  - Add EDMA\_TCD\_TYPE macro to determine edma tcd type.
  - Add extension API to the following API to determine edma tcd type.
    - \* EDMA\_ConfigChannelSoftwareTCD -> EDMA\_ConfigChannelSoftwareTCDExt
    - \* EDMA\_TcdReset -> EDMA\_TcdResetExt
    - \* EDMA\_TcdSetTransferConfig -> EDMA\_TcdSetTransferConfigExt
    - \* EDMA\_TcdSetMinorOffsetConfig -> EDMA\_TcdSetMinorOffsetConfigExt
    - \* EDMA\_TcdSetChannelLink -> EDMA\_TcdSetChannelLinkExt
    - \* EDMA\_TcdSetBandWidth -> EDMA\_TcdSetBandWidthExt
    - \* EDMA\_TcdSetModulo -> EDMA\_TcdSetModuloExt
    - \* EDMA\_TcdEnableAutoStopRequest -> EDMA\_TcdEnableAutoStopRequestExt
    - \* EDMA\_TcdEnableInterrupts -> EDMA\_TcdEnableInterruptsExt
    - \* EDMA\_TcdDisableInterrupts -> EDMA\_TcdDisableInterruptsExt
    - \* EDMA\_TcdSetMajorOffsetConfig -> EDMA\_TcdSetMajorOffsetConfigExt

### [2.9.2]

- Improvements
  - Remove tcd alignment check in API that is low level and does not necessarily use scather/gather mode.

### [2.9.1]

- Bug Fixes
  - Deinit channel request source before set channel mux.

#### [2.9.0]

- Improvements
  - Release peripheral from reset if necessary in init function.
- Bug Fixes
  - Fixed the variable type definition error issue.
  - Fixed doxygen warning.
  - Fixed violations of MISRA C-2012 rule 18.1.

### [2.8.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.3

#### [2.8.0]

- Improvements
  - Added feature FSL\_FEATURE\_EDMA\_HAS\_NO\_CH\_SBR\_SEC to separate DMA without SEC bitfield.

### [2.7.1]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.3, 10.4, 11.6, 11.8, 14.3,.

#### [2.7.0]

- Improvements
  - Use more accurate DMA instance based feature macros.
- New Features
  - Add new APIs EDMA\_PrepareTransferTCD and EDMA\_SubmitTransferTCD, which support EDMA transfer using TCD.

#### [2.6.0]

- Improvements
  - Modify the type of parameter channelRequestSource from dma\_request\_source\_t to int32\_t in the EDMA\_SetChannelMux.

### [2.5.3]

• Bug Fixes

- Fixed violations of MISRA C-2012 rule 10.3, 10.4, 11.6, 20.7, 12.2, 20.9, 5.3, 10.8, 8.4, 9.3.

## [2.5.2]

- Improvements
  - Applied ERRATA 51327.

## [2.5.1]

- Bug Fixes
  - Fixed the EDMA\_ResetChannel function cannot reset channel DONE/ERROR status.

### [2.5.0]

- Improvements
  - Added feature FSL\_FEATURE\_EDMA\_HAS\_NO\_SBR\_ATTR\_BIT to separate DMA without ATTR bitfield.
  - Added api EDMA\_GetChannelSystemBusInformation to gets the channel identification and attribute information on the system bus interface.
- Bug Fixes
  - Fixed the ESG bit not set in scatter gather mode issue.
  - Fixed the DREQ bit configuration missed in single transfer issue.
  - Cleared the interrupt status before invoke callback to avoid miss interrupt issue.
  - Removed disableRequestAfterMajorLoopComplete from edma\_transfer\_config\_t structure as driver will handle it.
  - Fixed the channel mux configuration not compatible issue.
  - Fixed the out of bound access in function EDMA\_DriverIRQHandler.

# [2.4.4]

- Bug Fixes
  - Fixed comments by replacing STCD with TCD
  - Fixed the TCD overwrite issue when submit transfer request in the callback if there is a active TCD in hardware.

# [2.4.3]

- Improvements
  - Added FSL\_FEATURE\_MEMORY\_HAS\_ADDRESS\_OFFSET to convert the address between system mapped address and dma quick access address.
- Bug Fixes
  - Fixed the wrong tcd done count calculated in first TCD interrupt for the non scatter gather case.

### [2.4.2]

- Bug Fixes
  - Fixed the wrong tcd done count calculated in first TCD interrupt by correct the initial value of the header.
  - Fixed violations of MISRA C-2012 rule 10.3, 10.4.

## [2.4.1]

- Bug Fixes
  - Added clear CITER and BITER registers in EDMA\_AbortTransfer to make sure the TCD registers in a correct state for next calling of EDMA\_SubmitTransfer.
  - Removed the clear DONE status for ESG not enabled case to aovid DONE bit cleared unexpectedly.

## [2.4.0]

- Improvements
  - Added api EDMA\_EnableContinuousChannelLinkMode to support continuous link mode.
  - Added apis EDMA\_SetMajorOffsetConfig/EDMA\_TcdSetMajorOffsetConfig to support major loop address offset feature.
  - Added api EDMA\_EnableChannelMinorLoopMapping for minor loop offset feature.
  - Removed the reduntant IRQ Handler in edma driver.

### [2.3.2]

- Improvements
  - Fixed HIS ccm issue in function EDMA\_PrepareTransferConfig.
  - Fixed violations of MISRA C-2012 rule 11.6, 10.7, 10.3, 18.1.
- Bug Fixes
  - Added ACTIVE & BITER & CITER bitfields to determine the channel status to fixed the issue of the transfer request cannot submit by function EDMA\_SubmitTransfer when channel is idle.

### [2.3.1]

- Improvements
  - Added source/destination address alignment check.
  - Added driver IRQ handler support for multi DMA instance in one SOC.

### [2.3.0]

- Improvements
  - Added new api EDMA\_PrepareTransferConfig to allow different configurations of width and offset.
- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.4, 10.1.

- Fixed the Coverity issue regarding out-of-bounds write.

### [2.2.0]

- Improvements
  - Added peripheral-to-peripheral support in EDMA driver.

## [2.1.9]

- Bug Fixes
  - Fixed MISRA issue: Rule 10.7 and 10.8 in function EDMA\_DisableChannelInterrupts and EDMA\_SubmitTransfer.
  - Fixed MISRA issue: Rule 10.7 in function EDMA\_EnableAsyncRequest.

## [2.1.8]

- Bug Fixes
  - Fixed incorrect channel preemption base address used in EDMA\_SetChannelPreemptionConfig API which causes incorrect configuration of the channel preemption register.

# [2.1.7]

- Bug Fixes
  - Fixed incorrect transfer size setting.
    - \* Added 8 bytes transfer configuration and feature for RT series;
    - \* Added feature to support 16 bytes transfer for Kinetis.
  - Fixed the issue that EDMA\_HandleIRQ would go to incorrect branch when TCD was not used and callback function not registered.

# [2.1.6]

- Bug Fixes
  - Fixed KW3X MISRA Issue.
    - \* Rule 14.4, 10.8, 10.4, 10.7, 10.1, 10.3, 13.5, and 13.2.
- Improvements
  - Cleared the IRQ handler unavailable for specific platform with macro FSL\_FEATURE\_EDMA\_MODULE\_CHANNEL\_IRQ\_ENTRY\_SHARED\_OFFSET.

# [2.1.5]

- Improvements
  - Improved EDMA IRQ handler to support half interrupt feature.

### [2.1.4]

- Bug Fixes
  - Cleared enabled request, status during EDMA\_Init for the case that EDMA is halted before reinitialization.

## [2.1.3]

- Bug Fixes
  - Added clear DONE bit in IRQ handler to avoid overwrite TCD issue.
  - Optimized above solution for the case that transfer request occurs in callback.

## [2.1.2]

- Improvements
  - Added interface to get next TCD address.
  - Added interface to get the unused TCD number.

### [2.1.1]

- Improvements
  - Added documentation for eDMA data flow when scatter/gather is implemented for the EDMA\_HandleIRQ API.
  - Updated and corrected some related comments in the EDMA\_HandleIRQ API and edma\_handle\_t struct.

# [2.1.0]

- Improvements
  - Changed the EDMA\_GetRemainingBytes API into EDMA\_GetRemainingMajorLoopCount due to eDMA IP limitation (see API comments/note for further details).

# [2.0.5]

- Improvements
  - Added pubweak DriverIRQHandler for K32H844P (16 channels shared).

### [2.0.4]

- Improvements
  - Added support for SoCs with multiple eDMA instances.
  - Added pubweak DriverIRQHandler for KL28T DMA1 and MCIMX7U5\_M4.

### [2.0.3]

- Bug Fixes
  - Fixed the incorrect pubweak IRQHandler name issue, which caused re-definition build errors when client set his/her own IRQHandler, by changing the 32-channel IRQHandler name to DriverIRQHandler.

### [2.0.2]

## • Bug Fixes

 Fixed incorrect minorLoopBytes type definition in \_edma\_transfer\_config struct, and defined minorLoopBytes as uint32\_t instead of uint16\_t.

# [2.0.1]

- Bug Fixes
  - Fixed the eDMA callback issue (which did not check valid status) in EDMA\_HandleIRQ API.

## [2.0.0]

• Initial version.

# EIM

# [2.0.1]

- Improvements
  - Update driver to support fewer channel.
- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.3.

# [2.0.0]

• Initial version.

# EnDat2.2

## [1.0.1]

- Bug Fixes
  - Fixed coverity issues

# [1.0.0]

• Initial version.

### ENDAT3

### [1.0.0]

• Initial version.

# EQDC

# [2.3.1]

- Bug Fix
- Fixed CTRL2[CMODE] field overwritten in API EQDC\_Init.

# [2.3.0]

- Improvements
- Add feature macro to support platforms which do not have compare interrupt.

# [2.2.3]

- Bug Fix
- Clear Revolution Counter Register(REV) in init function to prevent its value not equal to zero after reset.

## [2.2.2]

- Improvements
- Release peripheral from reset if necessary in init function.

# [2.2.1]

- Bug Fix
- Fixed violations of the MISRA C-2012 rules 20.9.

# [2.2.0]

- New features
- Supported the feature that the position counter to be initialized by Index Event Edge Mark.

# [2.1.0]

- Bug Fix
- Fixed typo in interrupt enumeration values.
  - Improvements
- Supported Count Direct Change interrupt.
- Removed unused parameter in user configuration.
- Supported ERRATA\_051383 check, the CTRL[DMAEN] can't be cleared.

# [2.0.1]

- Bug Fix
- Fixed violations of the MISRA C-2012 rules 10.3, 10.6, 10.8, 14.4, 16.4.

## [2.0.0]

• Initial version.

## ERM

### [2.0.1]

- Improvements
  - Update driver to support fewer channel.
- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.3.

## [2.0.0]

• Initial version.

## EWM

# [2.0.4]

- Bug Fixes
  - Fixed CERT INT31-C violations.

## [2.0.3]

- Bug Fixes
  - Fixed violation of MISRA C-2012 rules: 10.1, 10.3.

### [2.0.2]

- Bug Fixes
  - Fixed violation of MISRA C-2012 rules: 10.3, 10.4.

## [2.0.1]

- Bug Fixes
  - Fixed the hard fault in EWM\_Deinit.

### [2.0.0]

• Initial version.

### FLEXCAN

### [2.14.1]

- Bug Fixes
  - Fixed register IMASK2-4 IFLAG2-4 HR\_TIME\_STAMPn access issue on FlexCAN instances with different number of MBs.
  - Fixed bit field MBDSR1-3 access issue on FlexCAN instances with different number of MBs.
- Improvements
  - Unified following API as same parameter and return value type:
    - \* FLEXCAN\_GetMbStatusFlags
    - \* FLEXCAN\_ClearMbStatusFlags
    - \* FLEXCAN\_EnableMbInterrupts
    - $\label{eq:linear} {\tt * FLEXCAN\_DisableMbInterrupts}$

## [2.14.0]

- Improvements
  - Support external time tick feature.
  - Support high resolution timestamp feature.
  - Enter Freeze Mode first when enter Disable Mode on some platform.
  - Add feature macro for Pretended Networking because some FlexCAN instance do not have this feature.
  - Add feature macro for enhanced Rx FIFO because some FlexCAN instance do not have this feature.
  - Add new FlexCAN IRQ Handler FLEXCAN\_DriverDataIRQHandler and FLEX-CAN\_DriverEventIRQHandler. These IRQ Handlers are used on soc which FlexCAN interrupts are grouped by specific function and assigned to different vector.
  - Update macro FLEXCAN\_WAKE\_UP\_FLAG and FLEXCAN\_PNWAKE\_UP\_FLAG to simplify code.
  - Replace macro FSL\_FEATURE\_FLEXCAN\_HAS\_NO\_WAKMSK\_SUPPORT with FSL\_FEATURE\_FLEXCAN\_HAS\_NO\_SLFWAK\_SUPPORT.
  - Replace macro FSL\_FEATURE\_FLEXCAN\_HAS\_NO\_WAKSRC\_SUPPORT with FSL\_FEATURE\_FLEXCAN\_HAS\_GLITCH\_FILTER.
- Bug Fixes
  - Fixed wrong interrupt and status flag helper macro in enumeration \_flexcan\_flags and API FLEXCAN\_DisableInterrupts.
  - Fixed interrupt flag helper macro typo issue.
  - Remove flags which will are unassociated with interrupt in macro FLEX-CAN\_MEMORY\_ERROR\_INT\_FLAG.
  - Remove flags which will are unassociated with interrupt in macro FLEX-CAN\_ERROR\_AND\_STATUS\_INT\_FLAG.
  - Fixed array out-of-bounds access when read enhanced Rx FIFO.

### [2.13.1]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

### [2.13.0]

- Improvements
  - Support payload endianness selection feature.

## [2.12.0]

- Improvements
  - Support automatic Remote Response feature.
  - Add API FLEXCAN\_SetRemoteResponseMbConfig() to configure automatic Remote Response mailbox.

## [2.11.8]

- Improvements
  - Synchronize flexcan driver update on s32z platform.

## [2.11.7]

- Bug Fixes
  - Fixed FLEXCAN\_TransferReceiveEnhancedFifoEDMA() compatibility with edma5.

### [2.11.6]

- Bug Fixes
  - Fixed ERRATA\_9595 FLEXCAN\_EnterFreezeMode() may result to bus fault on some platform.

# [2.11.5]

- Bug Fixes
  - Fixed flexcan\_memset() crash under high optimization compilation.

### [2.11.4]

- Improvements
  - Update CANFD max bitrate to 10Mbps on MCXNx3x and MCXNx4x.
  - Release peripheral from reset if necessary in init function.

## [2.11.3]

- Bug Fixes
  - Fixed FLEXCAN\_TransferReceiveEnhancedFifoEDMA() compile error with DMA3.

### [2.11.2]

- Bug Fixes
  - Fixed bug that timestamp in flexcan\_handle\_t not updated when RX overflow happens.

## [2.11.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.1.

## [2.11.0]

- Bug Fixes
  - Fixed wrong base address argument in FLEXCAN2 IRQ Handler.
- Improvements
  - Add API to determine if the instance supports CAN FD mode at run time.

### [2.10.1]

- Bug Fixes
  - Fixed HIS CCM issue.
  - Fixed RTOS issue by adding protection to read-modify-write operations on interrupt enable/disable API.

### [2.10.0]

- Improvements
  - Update driver to make it able to support devices which has more than 64 8bytes MBs.
  - Update CAN FD transfer APIs to make them set/get edl bit according to frame content, which can make them compatible with classic CAN.

# [2.9.2]

- Bug Fixes
  - Fixed the issue that FLEXCAN\_CheckUnhandleInterruptEvents() can't detecting the exist enhanced RX FIFO interrupt status.
  - Fixed the issue that FLEXCAN\_ReadPNWakeUpMB() does not return fail even no existing valid wake-up frame.
  - Fixed the issue that FLEXCAN\_ReadEnhancedRxFifo() may clear bits other than the data available bit.
  - Fixed violations of the MISRA C-2012 rules 10.4, 10.8.
- Improvements
  - Return kStatus\_FLEXCAN\_RxFifoDisabled instead of kStatus\_Fail when read FIFO fail during IRQ handler.
  - Remove unreachable code from timing calculates APIs.
  - Update Enhanced Rx FIFO handler to make it deal with underflow/overflow status first.

## [2.9.1]

- Bug Fixes
  - Fixed the issue that FLEXCAN\_TransferReceiveEnhancedFifoBlocking() API clearing Fifo data available flag more than once.
  - Fixed the issue that entering FLEXCAN\_SubHandlerForEhancedRxFifo() even if Enhanced Rx fifo interrupts are not enabled.
  - Fixed the issue that FLEXCAN\_TransferReceiveEnhancedFifoEDMA() update handle even if previous Rx FIFO receive not finished.
  - Fixed the issue that FLEXCAN\_SetEnhancedRxFifoConfig() not configure the ER-FCR[NFE] bits to the correct value.
  - Fixed the issue that FLEXCAN\_ReceiveFifoEDMACallback() can't differentiate between Rx fifo and enhanced rx fifo.
  - Fixed the issue that FLEXCAN\_TransferHandleIRQ() can't report Legacy Rx FIFO warning status.

# [2.9.0]

- Improvements
- Add public set bit rate API to make driver easier to use.
- Update Legacy Rx FIFO transfer APIs to make it support received multiple frames during one API call.
- Optimized FLEXCAN\_SubHandlerForDataTransfered() API in interrupt handling to reduce the probability of packet loss.

### [2.8.7]

- Improvements
- Initialized the EDMA configuration structure in the FLEXCAN EDMA driver.

### [2.8.6]

- Bug Fixes
- Fix Coverity overrun issues in fsl\_flexcan\_edma driver.

### [2.8.5]

- Improvements
  - Make driver aarch64 compatible.

# [2.8.4]

- Bug Fixes
  - Fixed FlexCan\_Errata\_6032 to disable all interrupts.

### [2.8.3]

- Bug Fixes
  - Fixed an issue with the FLEXCAN\_EnableInterrupts and FLEXCAN\_DisableInterrupts interrupt enable bits in the CTRL1 register.

## [2.8.2]

- Bug Fixes
  - Fixed errors in timing calculations and simplify the calculation process.
  - Fixed issue of CBT and FDCBT register may write failure.

## [2.8.1]

- Bug Fixes
  - Fixed the issue of CAN FD three sampling points.
  - Added macro to support the devices that no MCR[SUPV] bit.
  - Remove unnecessary clear WMB operations.

### [2.8.0]

- Improvements
  - Update config configuration.
    - \* Added enableSupervisorMode member to support enable/disable Supervisor mode.
  - Simplified the algorithm in CAN FD improved timing APIs.

# [2.7.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.3, 10.7.

### [2.7.0]

- Improvements
  - Update config configuration.
    - \* Added enablePretendedeNetworking member to support enable/disable Pretended Networking feature.
    - \* Added enableTransceiverDelayMeasure member to support enable/disable Transceiver Delay MeasurementPretended feature.
    - \* Added bitRate/bitRateFD member to work as baudRate/baudRateFD member union.
  - Rename all "baud" in code or comments to "bit" to align with the CAN spec.
  - Added Pretended Networking mode related APIs.
    - \* FLEXCAN\_SetPNConfig
    - \* FLEXCAN\_GetPNMatchCount
    - \* FLEXCAN\_ReadPNWakeUpMB

- Added support for Enhanced Rx FIFO.
- Removed independent memory error interrupt/status APIs and put all interrupt/status control operation into FLEXCAN\_EnableInterrupts/FLEXCAN\_DisableInterrupts and FLEXCAN\_GetStatusFlags/FLEXCAN\_ClearStatusFlags APIs.
- Update improved timing APIs to make it calculate improved timing according to CiA doc recommended.
  - \* FLEXCAN\_CalculateImprovedTimingValues.
  - \* FLEXCAN\_FDCalculateImprovedTimingValues.
- Update FLEXCAN\_SetBitRate/FLEXCAN\_SetFDBitRate to added the use of enhanced timing registers.

### [2.6.2]

- Improvements
  - Add CANFD frame data length enumeration.

### [2.6.1]

- Bug Fixes
  - Fixed the issue of not fully initializing memory in FLEXCAN\_Reset() API.

#### [2.6.0]

- Improvements
  - Enable CANFD ISO mode in FLEXCAN\_FDInit API.
  - Enable the transceiver delay compensation feature when enable FD operation and set bitrate switch.
  - Implementation memory error control in FLEXCAN\_Init API.
  - Improve FLEXCAN\_FDCalculateImprovedTimingValues API to get same value for FPRESDIV and PRESDIV.
  - Added memory error configuration for user.
    - \* enableMemoryErrorControl
    - \* enableNonCorrectableErrorEnterFreeze
  - Added memory error related APIs.
    - \* FLEXCAN\_GetMemoryErrorReportStatus
    - \* FLEXCAN\_GetMemoryErrorStatusFlags
    - \* FLEXCAN\_ClearMemoryErrorStatusFlags
    - \* FLEXCAN\_EnableMemoryErrorInterrupts
    - \* FLEXCAN\_DisableMemoryErrorInterrupts
- Bug Fixes
  - Fixed the issue of sent duff CAN frame after call FLEXCAN\_FDInit() API.

## [2.5.2]

- Bug Fixes
  - Fixed the code error issue and simplified the algorithm in improved timing APIs.
    - \* The bit field in CTRL1 register couldn't calculate higher ideal SP, we set it as the lowest one(75%)
      - · FLEXCAN\_CalculateImprovedTimingValues
      - FLEXCAN\_FDCalculateImprovedTimingValues
  - Fixed MISRA-C 2012 Rule 17.7 and 14.4.
- Improvements
  - Pass EsrStatus to callback function when kStatus\_FLEXCAN\_ErrorStatus is comming.

## [2.5.1]

- Bug Fixes
  - Fixed the non-divisible case in improved timing APIs.
    - \* FLEXCAN\_CalculateImprovedTimingValues
    - \* FLEXCAN\_FDCalculateImprovedTimingValues

## [2.5.0]

- Bug Fixes
  - MISRA C-2012 issue check.
    - \* Fixed rules, containing: rule-10.1, rule-10.3, rule-10.4, rule-10.7, rule-10.8, rule-11.8, rule-12.2, rule-13.4, rule-14.4, rule-15.5, rule-15.6, rule-15.7, rule-16.4, rule-17.3, rule-5.8, rule-8.3, rule-8.5.
  - Fixed the issue that API FLEXCAN\_SetFDRxMbConfig lacks inactive message buff.
  - Fixed the issue of Pa082 warning.
  - Fixed the issue of dead lock in the function of interruption handler.
  - Fixed the issue of Legacy Rx Fifo EDMA transfer data fail in evkmimxrt1060 and evkmimxrt1064.
  - Fixed the issue of setting CANFD Bit Rate Switch.
  - Fixed the issue of operating unknown pointer risk.
    - \* when used the pointer "handle->mbFrameBuf[mbIdx]" to update the timestamp in a short-live TX frame, the frame pointer became as unknown, the action of operating it would result in program stack destroyed.
  - Added assert to check current CAN clock source affected by other clock gates in current device.
    - \* In some chips, CAN clock sources could be selected by CCM. But for some clock sources affected by other clock gates, if user insisted on using that clock source, they had to open these gates at the same time. However, they should take into consideration the power consumption issue at system level. In RT10xx chips, CAN clock source 2 was affected by the clock gate of lpuart1. ERRATA ID: (ERR050235 in CCM).
- Improvements
  - Implementation for new FLEXCAN with ECC feature able to exit Freeze mode.

- Optimized the function of interruption handler.
- Added two APIs for FLEXCAN EDMA driver.
  - \* FLEXCAN\_PrepareTransfConfiguration
  - \* FLEXCAN\_StartTransferDatafromRxFIFO
- Added new API for FLEXCAN driver.
  - \* FLEXCAN\_GetTimeStamp
    - For TX non-blocking API, we wrote the frame into mailbox only, so no need to register TX frame address to the pointer, and the timestamp could be updated into the new global variable handle->timestamp[mbIdx], the FLEXCAN driver provided a new API for user to get it by handle and index number after TX DONE Success.
  - \* FLEXCAN\_EnterFreezeMode
  - \* FLEXCAN\_ExitFreezeMode
- Added new configuration for user.
  - \* disableSelfReception
  - \* enableListenOnlyMode
- Renamed the two clock source enum macros based on CLKSRC bit field value directly.
  - \* The CLKSRC bit value had no property about Oscillator or Peripheral type in lots of devices, it acted as two different clock input source only, but the legacy enum macros name contained such property, that misled user to select incorrect CAN clock source.
- Created two new enum macros for the FLEXCAN driver.
  - \* kFLEXCAN\_ClkSrc0
  - \* kFLEXCAN\_ClkSrc1
- Deprecated two legacy enum macros for the FLEXCAN driver.
  - \* kFLEXCAN\_ClkSrcOsc
  - \* kFLEXCAN\_ClkSrcPeri
- Changed the process flow for Remote request frame response..
  - \* Created a new enum macro for the FLEXCAN driver.
    - · kStatus\_FLEXCAN\_RxRemote
- Changed the process flow for kFLEXCAN\_StateRxRemote state in the interrupt handler.
  - \* Should the TX frame not register to the pointer of frame handle, interrupt handler would not be able to read the remote response frame from the mail box to ram, so user should read the frame by manual from mail box after a complete remote frame transfer.

### [2.4.0]

- Bug Fixes
  - MISRA C-2012 issue check.
    - \* Fixed rules, containing: rule-12.1, rule-17.7, rule-16.4, rule-11.9, rule-8.4, rule-14.4, rule-10.8, rule-10.4, rule-10.3, rule-10.7, rule-10.1, rule-11.6, rule-13.5, rule-11.3, rule-8.3, rule-12.2 and rule-16.1.
  - Fixed the issue that CANFD transfer data fail when bus baudrate is 30Khz.

- Fixed the issue that ERR009595 does not folllow the ERRATA document.
- Fixed code error for ERR006032 work around solution.
- Fixed the Coverity issue of BAD\_SHIFT in FLEXCAN.
- Fixed the Repo build warning issue for variable without initial.
- Improvements
  - Fixed the run fail issue of FlexCAN RemoteRequest UT Case.
  - Implementation all TX and RX transfering Timestamp used in FlexCAN demos.
  - Fixed the issue of UT Test Fail for CANFD payload size changed from 64BperMB to 8PerMB.
  - Implementation for improved timing API by baud rate.

## [2.3.2]

- Improvements
  - Implementation for ERR005959.
  - Implementation for ERR005829.
  - Implementation for ERR006032.

## [2.3.1]

- Bug Fixes
  - Added correct handle when kStatus\_FLEXCAN\_TxSwitchToRx is comming.

### [2.3.0]

- Improvements
  - Added self-wakeup support for STOP mode in the interrupt handling.

# [2.2.3]

- Bug Fixes
  - Fixed the issue of CANFD data phase's bit rate not set as expected.

# [2.2.2]

- Improvements
  - Added a time stamp feature and enable it in the interrupt\_transfer example.

# [2.2.1]

- Improvements
  - Separated CANFD initialization API.
  - In the interrupt handling, fix the issue that the user cannot use the normal CAN API when with an FD.

## [2.2.0]

- Improvements
  - Added FSL\_FEATURE\_FLEXCAN\_HAS\_SUPPORT\_ENGINE\_CLK\_SEL\_REMOVE feature to support SoCs without CAN Engine Clock selection in FlexCAN module.
  - Added FlexCAN Serial Clock Operation to support i.MX SoCs.

## [2.1.0]

- Bug Fixes
  - Corrected the spelling error in the function name FLEXCAN\_XXX().
  - Moved Freeze Enable/Disable setting from FLEXCAN\_Enter/ExitFreezeMode() to FLEX-CAN\_Init().
  - Corrected wrong helper macro values.
- Improvements
  - Hid FLEXCAN\_Reset() from user.
  - Used NDEBUG macro to wrap FLEXCAN\_IsMbOccupied() function instead of DEBUG macro.

### [2.0.0]

• Initial version.

### FLEXCAN\_EDMA

### [2.12.0]

- Improvements
  - Support high resolution timestamp feature in enhanced Rx FIFO EDMA.
  - Add feature macro for enhanced Rx FIFO because some FlexCAN instance do not have this feature.
- Bug Fixes
  - Fixed array out-of-bounds access when read enhanced Rx FIFO in EDMA.

### [2.11.7]

• Refer FLEXCAN driver change log 2.7.0 to 2.11.7

### FLEXIO

### [2.3.0]

- Improvements
  - Supported platforms which don't have DOZE mode control.
  - Added more pin control functions.

### [2.2.3]

- Improvements
  - Adapter the FLEXIO driver to platforms which don't have system level interrupt controller, such as NVIC.

### [2.2.2]

- Improvements
  - Release peripheral from reset if necessary in init function.

## [2.2.1]

- Improvements
  - Added doxygen index parameter comment in FLEXIO\_SetClockMode.

## [2.2.0]

- New Features
  - Added new APIs to support FlexIO pin register.

## [2.1.0]

- Improvements
  - Added API FLEXIO\_SetClockMode to set flexio channel counter and source clock.

### [2.0.4]

- Bug Fixes
  - Fixed MISRA 8.4 issues.

# [2.0.3]

- Bug Fixes
  - Fixed MISRA 10.4 issues.

# [2.0.2]

- Improvements
  - Split FLEXIO component which combines all flexio/flexio\_uart/flexio\_i2c/flexio\_i2s drivers into several components: FlexIO component, flexio\_uart component, flexio\_i2c\_master component, and flexio\_i2s component.
- Bug Fixes
  - Fixed MISRA issues
    - \* Fixed rules 10.1, 10.3, 10.4, 10.7, 11.6, 11.9, 14.4, 17.7.

## [2.0.1]

• Bug Fixes

- Fixed the dozen mode configuration error in FLEXIO\_Init API. For enableInDoze = true, the configuration should be 0; for enableInDoze = false, the configuration should be 1.

## FLEXIO\_A-FORMAT

## [1.0.0]

- New Features
  - The polling mode was added to read or configure encoder data
  - The interrupt mode was added to read or configure encoder data

## FLEXIO\_I2C

### [2.6.1]

- Bug Fixes
  - Fixed coverity issues

## [2.6.0]

- Improvements
  - Supported platforms which don't have DOZE mode control.

### [2.5.1]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

### [2.5.0]

- Improvements
  - Split some functions, fixed CCM problem in file fsl\_flexio\_i2c\_master.c.

### [2.4.0]

- Improvements
  - Added delay of 1 clock cycle in FLEXIO\_I2C\_MasterTransferRunStateMachine to ensure that bus would be idle before next transfer if master is nacked.
  - Fixed issue that the restart setup time is less than the time in I2C spec by adding delay of 1 clock cycle before restart signal.

### [2.3.0]

- Improvements
  - Used 3 timers instead of 2 to support transfer which is more than 14 bytes in single transfer.
  - Improved FLEXIO\_I2C\_MasterTransferGetCount so that the API can check whether the transfer is still in progress.
- Bug Fixes
  - Fixed MISRA 10.4 issues.

### [2.2.0]

- New Features
  - Added timeout mechanism when waiting certain state in transfer API.
  - Added an API for checking bus pin status.
- Bug Fixes
  - Fixed COVERITY issue of useless call in FLEXIO\_I2C\_MasterTransferRunStateMachine.
  - Fixed MISRA issues
    - \* Fixed rules 10.1, 10.3, 10.4, 10.7, 11.6, 11.9, 14.4, 17.7.
  - Added codes in FLEXIO\_I2C\_MasterTransferCreateHandle to clear pending NVIC IRQ, disable internal IRQs before enabling NVIC IRQ.
  - Modified code so that during master's nonblocking transfer the start and slave address are sent after interrupts being enabled, in order to avoid potential issue of sending the start and slave address twice.

### [2.1.7]

- Bug Fixes
  - Fixed the issue that FLEXIO\_I2C\_MasterTransferBlocking did not wait for STOP bit sent.
  - Fixed COVERITY issue of useless call in FLEXIO\_I2C\_MasterTransferRunStateMachine.
  - Fixed the issue that I2C master did not check whether bus was busy before transfer.

### [2.1.6]

- Bug Fixes
  - Fixed the issue that I2C Master transfer APIs(blocking/non-blocking) did not support the situation of master transfer with subaddress and transfer data size being zero, which means no data followed the subaddress.

### [2.1.5]

- Improvements
  - Unified component full name to FLEXIO I2C Driver.

## [2.1.4]

- Bug Fixes
  - The following modifications support FlexIO using multiple instances:
    - \* Removed FLEXIO\_Reset API in module Init APIs.
    - \* Updated module Deinit APIs to reset the shifter/timer config instead of disabling module/clock.
    - \* Updated module Enable APIs to only support enable operation.

## [2.1.3]

- Improvements
  - Changed the prototype of FLEXIO\_I2C\_MasterInit to return kStatus\_Success if initialized successfully or to return kStatus\_InvalidArgument if "(srcClock\_Hz / masterConfig->baudRate\_Bps) / 2 - 1" exceeds 0xFFU.

## [2.1.2]

- Bug Fixes
  - Fixed the FLEXIO I2C issue where the master could not receive data from I2C slave in high baudrate.
  - Fixed the FLEXIO I2C issue where the master could not receive NAK when master sent non-existent addr.
  - Fixed the FLEXIO I2C issue where the master could not get transfer count successfully.
  - Fixed the FLEXIO I2C issue where the master could not receive data successfully when sending data first.
  - Fixed the Dozen mode configuration error in FLEXIO\_I2C\_MasterInit API. For enableInDoze = true, the configuration should be 0; for enableInDoze = false, the configuration should be 1.
  - FLEXIO\_I2C\_MasterTransferBlocking – Fixed API the issue that FLEXIO I2C MasterTransferCreateHandle, called which lead to the s flexioHandle/s flexioIsr/s flexioType variable being Then. written. calling FLEXIO I2C MasterTransferBlocking API multiple times. if the s\_flexioHandle/s\_flexioIsr/s\_flexioType variable would not be written any more due to it being out of range. This lead to the following situation: NonBlocking transfer APIs could not work due to the fail of register IRQ.

# [2.1.1]

- Bug Fixes
  - Implemented the FLEXIO\_I2C\_MasterTransferBlocking API which is defined in header file but has no implementation in the C file.

# [2.1.0]

- New Features
  - Added Transfer prefix in transactional APIs.
  - Added transferSize in handle structure to record the transfer size.

## FLEXIO\_I2S

## [2.2.2]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 12.4.

## [2.2.1]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

## [2.2.0]

- New Features
  - Added timeout mechanism when waiting certain state in transfer API.
- Bug Fixes
  - Fixed IAR Pa082 warnings.
  - Fixed violations of the MISRA C-2012 rules 10.4, 14.4, 11.8, 11.9, 10.1, 17.7, 11.6, 10.3, 10.7.

## [2.1.6]

- Bug Fixes
  - Added reset flexio before flexio i2s init to make sure flexio status is normal.

### [2.1.5]

- Bug Fixes
  - Fixed the issue that I2S driver used hard code for bitwidth setting.

# [2.1.4]

- Improvements
  - Unified component's full name to FLEXIO I2S (DMA/EDMA) driver.

### [2.1.3]

- Bug Fixes
  - The following modifications support FLEXIO using multiple instances:
    - \* Removed FLEXIO\_Reset API in module Init APIs.
    - \* Updated module Deinit APIs to reset the shifter/timer config instead of disabling module/clock.
    - \* Updated module Enable APIs to only support enable operation.

# [2.1.2]

- New Features
  - Added configure items for all pin polarity and data valid polarity.
  - Added default configure for pin polarity and data valid polarity.

# [2.1.1]

- Bug Fixes
  - Fixed FlexIO I2S RX data read error and eDMA address error.
  - Fixed FlexIO I2S slave timer compare setting error.

### [2.1.0]

- New Features
  - Added Transfer prefix in transactional APIs.
  - Added transferSize in handle structure to record the transfer size.

### FLEXIO\_I2S\_EDMA

## [2.1.9]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 12.4.

### [2.1.8]

- Improvements
  - Applied EDMA ERRATA 51327.

### FLEXIO\_SPI

### [2.4.2]

- Bug Fixes
  - Fixed FLEXIO\_SPI\_MasterTransferBlocking and FLEXIO\_SPI\_MasterTransferNonBlocking issue in CS continuous mode, the CS might not be continuous.

# [2.4.1]

- Bug Fixes
  - Fixed coverity issues

### [2.4.0]

- Improvements
  - Supported platforms which don't have DOZE mode control.

### [2.3.5]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

## [2.3.4]

- Bug Fixes
  - Fixed the txData from void \* to const void \* in transmit API

## [2.3.3]

- Bugfixes
  - Fixed cs-continuous mode.

## [2.3.2]

- Improvements
  - Changed FLEXIO\_SPI\_DUMMYDATA to 0x00.

## [2.3.1]

- Bugfixes
  - Fixed IRQ SHIFTBUF overrun issue when one FLEXIO instance used as multiple SPIs.

### [2.3.0]

- New Features
  - Supported FLEXIO\_SPI slave transfer with continuous master CS signal and CPHA=0.
  - Supported FLEXIO\_SPI master transfer with continuous CS signal.
  - Support 32 bit transfer width.
- Bug Fixes
  - Fixed wrong timer compare configuration for dma/edma transfer.
  - Fixed wrong byte order of rx data if transfer width is 16 bit, since the we use shifter buffer bit swapped/byte swapped register to read in received data, so the high byte should be read from the high bits of the register when MSB.

# [2.2.1]

- Bug Fixes
  - Fixed bug in FLEXIO\_SPI\_MasterTransferAbortEDMA that when aborting EDMA transfer EDMA\_AbortTransfer should be used rather than EDMA\_StopTransfer.

## [2.2.0]

- Improvements
  - Added timeout mechanism when waiting certain states in transfer driver.
- Bug Fixes
  - Fixed MISRA 10.4 issues.
  - Added codes in FLEXIO\_SPI\_MasterTransferCreateHandle and FLEXIO\_SPI\_SlaveTransferCreateHandle to clear pending NVIC IRQ before enabling NVIC IRQ, to fix issue of pending IRQ interfering the on-going process.

## [2.1.3]

- Improvements
  - Unified component full name to FLEXIO SPI(DMA/EDMA) Driver.
- Bug Fixes
  - Fixed MISRA issues
    - \* Fixed rules 10.1, 10.3, 10.4, 10.7, 11.6, 11.9, 14.4, 17.7.

# [2.1.2]

- Bug Fixes
  - The following modification support FlexIO using multiple instances:
    - \* Removed FLEXIO\_Reset API in module Init APIs.
    - \* Updated module Deinit APIs to reset the shifter/timer config instead of disabling module/clock.
    - \* Updated module Enable APIs to only support enable operation.

# [2.1.1]

- Bug Fixes
  - Fixed bug where FLEXIO SPI transfer data is in 16 bit per frame mode with eDMA.
  - Fixed bug when FLEXIO SPI works in eDMA and interrupt mode with 16-bit per frame and Lsbfirst.
  - Fixed the Dozen mode configuration error in FLEXIO\_SPI\_MasterInit/FLEXIO\_SPI\_SlaveInit API. For enableInDoze = true, the configuration should be 0; for enableInDoze = false, the configuration should be 1.
- Improvements
  - Added #ifndef/#endif to allow users to change the default TX value at compile time.

# [2.1.0]

- New Features
  - Added Transfer prefix in transactional APIs.
  - Added transferSize in handle structure to record the transfer size.
- Bug Fixes

- Fixed the error register address return for 16-bit data write in FLEXIO\_SPI\_GetTxDataRegisterAddress.
- Provided independent IRQHandler/transfer APIs for Master and slave to fix the baudrate limit issue.

#### FLEXIO\_T-FORMAT

#### [1.0.0]

- New Features
  - The polling mode was added to read or configure encoder data
  - The interrupt mode was added to read or configure encoder data

#### FLEXIO\_UART

#### [2.6.2]

- Bug Fixes
  - Fixed coverity issues

#### [2.6.1]

- Improvements
  - Improve baudrate calculation method, to support higher frequency FlexIO clock source.

#### [2.6.0]

- Improvements
  - Supported platforms which don't have DOZE mode control.

### [2.5.1]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

#### [2.5.0]

- Improvements
  - Added API FLEXIO\_UART\_FlushShifters to flush UART fifo.

## [2.4.0]

- Improvements
  - Use separate data for TX and RX in flexio\_uart\_transfer\_t.
- Bug Fixes
  - Fixed bug that when ring buffer is used, if some data is received in ring buffer first before calling FLEXIO\_UART\_TransferReceiveNonBlocking, the received data count returned by FLEXIO\_UART\_TransferGetReceiveCount is wrong.

## [2.3.0]

- Improvements
  - Added check for baud rate's accuracy that returns kStatus\_FLEXIO\_UART\_BaudrateNotSupport when the best achieved baud rate is not within 3% error of configured baud rate.
- Bug Fixes
  - Added codes in FLEXIO\_UART\_TransferCreateHandle to clear pending NVIC IRQ before enabling NVIC IRQ, to fix issue of pending IRQ interfering the on-going process.

## [2.2.0]

- Improvements
  - Added timeout mechanism when waiting for certain states in transfer driver.
- Bug Fixes
  - Fixed MISRA 10.4 issues.

### [2.1.6]

- Bug Fixes
  - Fixed IAR Pa082 warnings.
  - Fixed MISRA issues
    - \* Fixed rules 10.1, 10.3, 10.4, 10.7, 11.6, 11.9, 14.4, 17.7.

### [2.1.5]

- Improvements
  - Triggered user callback after all the data in ringbuffer were received in FLEXIO\_UART\_TransferReceiveNonBlocking.

### [2.1.4]

- Improvements
  - Unified component full name to FLEXIO UART(DMA/EDMA) Driver.

## [2.1.3]

- Bug Fixes
  - The following modifications support FLEXIO using multiple instances:
    - \* Removed FLEXIO\_Reset API in module Init APIs.
    - \* Updated module Deinit APIs to reset the shifter/timer configuration instead of disabling module and clock.
    - \* Updated module Enable APIs to only support enable operation.

# [2.1.2]

- Bug Fixes
  - Fixed the transfer count calculation issue in FLEXIO\_UART\_TransferGetReceiveCount, FLEXIO\_UART\_TransferGetSendCount, FLEXIO\_UART\_TransferGetReceiveCountDMA, FLEXIO\_UART\_TransferGetSendCountDMA, FLEXIO\_UART\_TransferGetReceiveCountEDMA and FLEXIO\_UART\_TransferGetSendCountEDMA.
  - Fixed the Dozen mode configuration error in FLEXIO\_UART\_Init API. For enableInDoze
     true, the configuration should be 0; for enableInDoze = false, the configuration should be 1.
  - Added code to report errors if the user sets a too-low-baudrate which FLEXIO cannot reach.
  - Disabled FLEXIO\_UART receive interrupt instead of all NVICs when reading data from ring buffer. If ring buffer is used, receive nonblocking will disable all NVIC interrupts to protect the ring buffer. This had negative effects on other IPs using interrupt.

# [2.1.1]

- Bug Fixes
  - Changed the API name FLEXIO\_UART\_StopRingBuffer to FLEXIO\_UART\_TransferStopRingBuffer to align with the definition in C file.

### [2.1.0]

- New Features
  - Added Transfer prefix in transactional APIs.
  - Added txSize/rxSize in handle structure to record the transfer size.
- Bug Fixes
  - Added an error handle to handle the situation that data count is zero or data buffer is NULL.

# FLEXIO\_UART\_EDMA

[2.3.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules.

### [2.3.0]

• Refer FLEXIO\_UART driver change log to 2.3.0

#### FRACT\_PLL

#### [2.0.0]

• Initial version.

#### GPT

#### [2.0.5]

- Improvements
  - Support workaround for ERR003777. This workaround helps switching the clock sources.

#### [2.0.4]

- Bug Fixes
  - Fixed compiler warning when built with FSL\_SDK\_DISABLE\_DRIVER\_CLOCK\_CONTROL flag enabled.

### [2.0.3]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 5.3 by customizing function parameter.

### [2.0.2]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 17.7.

#### [2.0.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.1, 10.3, 10.4, 10.6, 10.8, 17.7.

### [2.0.0]

• Initial version.

### HIPERFACE

#### [1.0.0]

• Initial version.

# INTM

### [2.1.0]

• Replace macro FSL\_FEATURE\_INTM\_MONITOR\_COUNT to INTM\_MON\_COUNT.

### [2.0.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.3, 10.4.

#### [2.0.0]

• Initial version.

## IRQSTEER

### [2.0.1]

- Improvement
  - Initialize irqsteer defaultly, so users don't need to call api IRQSTEER\_Init to intialize irqsteer.

## [2.0.0]

• Initial version.

### LPI2C

### [2.6.1]

- Bug Fixes
  - Fixed coverity issues.

## [2.6.0]

- New Feature
  - Added common IRQ handler entry LPI2C\_DriverIRQHandler.

## [2.5.7]

- Improvements
  - Added support for separated IRQ handlers.

# [2.5.6]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

## [2.5.5]

- Bug Fixes
  - Fixed LPI2C\_SlaveInit() allow to disable SDA/SCL glitch filter.

## [2.5.4]

- Bug Fixes
  - Fixed LPI2C\_MasterTransferBlocking() the return value was sometime affected by call of LPI2C\_MasterStop().

## [2.5.3]

- Improvements
  - Added handler for LPI2C7 and LPI2C8.

### [2.5.2]

- Bug Fixes
  - Fixed ERR051119 to ignore the nak flag when IGNACK=1 in LPI2C\_MasterCheckAndClearError.

# [2.5.1]

- Bug Fixes
  - Added bus stop incase of bus stall in LPI2C\_MasterTransferBlocking.
- Improvements
  - Release peripheral from reset if necessary in init function.

### [2.5.0]

- New Features
  - Added new function LPI2C\_SlaveEnableAckStall to enable or disable ACKSTALL.

### [2.4.1]

- Improvements
  - Before master transfer with transactional APIs, enable master function while disable slave function and vise versa for slave transfer to avoid the one affecting the other.

## [2.4.0]

- Improvements
  - Split some functions, fixed CCM problem in file fsl\_lpi2c.c.
- Bug Fixes
  - Fixed bug in LPI2C\_MasterInit that the MCFGR2's value set in LPI2C\_MasterSetBaudRate may be overwritten by mistake.

# [2.3.2]

- Improvements
  - Initialized the EDMA configuration structure in the LPI2C EDMA driver.

## [2.3.1]

- Improvements
  - Updated LPI2C\_GetCyclesForWidth to add the parameter of minimum cycle, because for master SDA/SCL filter, master bus idle/pin low timeout and slave SDA/SCL filter configuration, 0 means disabling the feature and cannot be used.
- Bug Fixes
  - Fixed bug in LPI2C\_SlaveTransferHandleIRQ that when restart detect event happens the transfer structure should not be cleared.
  - Fixed bug in LPI2C\_RunTransferStateMachine, that when only slave address is transferred or there is still data remaining in tx FIFO the last byte's nack cannot be ignored.
  - Fixed bug in slave filter doze enable, that when FILTDZ is set it means disable rather than enable.
  - Fixed bug in the usage of LPI2C\_GetCyclesForWidth. First its return value cannot be used directly to configure the slave FILTSDA, FILTSCL, DATAVD or CLKHOLD, because the real cycle width for them should be FILTSDA+3, FILTSCL+3, FILTSCL+DATAVD+3 and CLKHOLD+3. Second when cycle period is not affected by the prescaler value, prescaler value should be passed as 0 rather than 1.
  - Fixed wrong default setting for LPI2C slave. If enabling the slave tx SCL stall, then the default clock hold time should be set to 250ns according to I2C spec for 100kHz standard mode baudrate.
  - Fixed bug that before pushing command to the tx FIFO the FIFO occupation should be checked first in case FIFO overflow.

### [2.3.0]

- New Features
  - Supported reading more than 256 bytes of data in one transfer as master.
  - Added API LPI2C\_GetInstance.
- Bug Fixes
  - Fixed bug in LPI2C\_MasterTransferAbortEDMA, LPI2C\_MasterTransferAbort and LPI2C\_MasterTransferHandleIRQ that before sending stop signal whether master is active and whether stop signal has been sent should be checked, to make sure no FIFO error or bus error will be caused.

- Fixed bug in LPI2C master EDMA transactional layer that the bus error cannot be caught and returned by user callback, by monitoring bus error events in interrupt handler.
- Fixed bug in LPI2C\_GetCyclesForWidth that the parameter used to calculate clock cycle should be 2^prescaler rather than prescaler.
- Fixed bug in LPI2C\_MasterInit that timeout value should be configured after baudrate, since the timeout calculation needs prescaler as parameter which is changed during baudrate configuration.
- Fixed bug in LPI2C\_MasterTransferHandleIRQ and LPI2C\_RunTransferStateMachine that when master writes with no stop signal, need to first make sure no data remains in the tx FIFO before finishes the transfer.

## [2.2.0]

- Bug Fixes
  - Fixed issue that the SCL high time, start hold time and stop setup time do not meet I2C specification, by changing the configuration of data valid delay, setup hold delay, clock high and low parameters.
  - MISRA C-2012 issue fixed.
    - \* Fixed rule 8.4, 13.5, 17.7, 20.8.

## [2.1.12]

- Bug Fixes
  - Fixed MISRA advisory 15.5 issues.

### [2.1.11]

- Bug Fixes
  - Fixed the bug that, during master non-blocking transfer, after the last byte is sent/received, the kLPI2C\_MasterNackDetectFlag is expected, so master should not check and clear kLPI2C\_MasterNackDetectFlag when remainingBytes is zero, in case FIFO is emptied when stop command has not been sent yet.
  - Fixed the bug that, during non-blocking transfer slave may nack master while master is busy filling tx FIFO, and NDF may not be handled properly.

### [2.1.10]

- Bug Fixes
  - MISRA C-2012 issue fixed.
    - \* Fixed rule 10.3, 14.4, 15.5.
  - Fixed unaligned access issue in LPI2C\_RunTransferStateMachine.
  - Fixed uninitialized variable issue in LPI2C\_MasterTransferHandleIRQ.
  - Used linked TCD to disable tx and enable rx in read operation to fix the issue that for platform sharing the same DMA request with tx and rx, during LPI2C read operation if interrupt with higher priority happened exactly after command was sent and before tx disabled, potentially both tx and rx could trigger dma and cause trouble.
  - Fixed MISRA issues.

- \* Fixed rules 10.1, 10.3, 10.4, 11.6, 11.9, 14.4, 17.7.
- Fixed the waitTimes variable not re-assignment issue for each byte read.
- New Features
  - Added the IRQHandler for LPI2C5 and LPI2C6 instances.
- Improvements
  - Updated the LPI2C\_WAIT\_TIMEOUT macro to unified name I2C\_RETRY\_TIMES.

## [2.1.9]

- Bug Fixes
  - Fixed Coverity issue of unchecked return value in I2C\_RTOS\_Transfer.
  - Fixed Coverity issue of operands did not affect the result in LPI2C\_SlaveReceive and LPI2C\_SlaveSend.
  - Removed STOP signal wait when NAK detected.
  - Cleared before slave repeat start flag transmission started LPI2C SlaveSend/LPI2C SlaveReceive. in The issue was that LPI2C\_SlaveSend/LPI2C\_SlaveReceive did not handle with the reserved repeat start flag. This caused the next slave to send a break, and the master was always in the receive data status, but could not receive data.

## [2.1.8]

- Bug Fixes
  - Fixed the transfer issue with LPI2C\_MasterTransferNonBlocking, kLPI2C\_TransferNoStopFlag, with the wait transfer done through callback in a way of not doing a blocking transfer.
  - Fixed the issue that STOP signal did not appear in the bus when NAK event occurred.

# [2.1.7]

- Bug Fixes
  - Cleared the stopflag before transmission started in LPI2C\_SlaveSend/LPI2C\_SlaveReceive. The issue was that LPI2C\_SlaveSend/LPI2C\_SlaveReceive did not handle with the reserved stop flag and caused the next slave to send a break, and the master always stayed in the receive data status but could not receive data.

# [2.1.6]

- Bug Fixes
  - Fixed driver MISRA build error and C++ build error in LPI2C\_MasterSend and LPI2C\_SlaveSend.
  - Reset FIFO in LPI2C Master Transfer functions to avoid any byte still remaining in FIFO during last transfer.
  - Fixed the issue that LPI2C\_MasterStop did not return the correct NAK status in the bus for second transfer to the non-existing slave address.

# [2.1.5]

- Bug Fixes
  - Extended the Driver IRQ handler to support LPI2C4.
  - Changed to use ARRAY\_SIZE(kLpi2cBases) instead of FEATURE COUNT to decide the array size for handle pointer array.

# [2.1.4]

- Bug Fixes
  - Fixed the LPI2C\_MasterTransferEDMA receive issue when LPI2C shared same request source with TX/RX DMA request. Previously, the API used scatter-gather method, which handled the command transfer first, then the linked TCD which was pre-set with the receive data transfer. The issue was that the TX DMA request and the RX DMA request were both enabled, so when the DMA finished the first command TCD transfer and handled the receive data TCD, the TX DMA request still happened due to empty TX FIFO. The result was that the RX DMA transfer would start without waiting on the expected RX DMA request.
  - Fixed the issue by enabling IntMajor interrupt for the command TCD and checking if there was a linked TCD to disable the TX DMA request in LPI2C\_MasterEDMACallback API.

# [2.1.3]

- Improvements
  - Added LPI2C\_WATI\_TIMEOUT macro to allow the user to specify the timeout times for waiting flags in functional API and blocking transfer API.
  - Added LPI2C\_MasterTransferBlocking API.

# [2.1.2]

- Bug Fixes
  - In LPI2C\_SlaveTransferHandleIRQ, reset the slave status to idle when stop flag was detected.

### [2.1.1]

- Bug Fixes
  - Disabled the auto-stop feature in eDMA driver. Previously, the auto-stop feature was enabled at transfer when transferring with stop flag. Since transfer was without stop flag and the auto-stop feature was enabled, when starting a new transfer with stop flag, the stop flag would be sent before the new transfer started, causing unsuccesful sending of the start flag, so the transfer could not start.
  - Changed default slave configuration with address stall false.

### [2.1.0]

- Improvements
  - API name changed:
    - \* LPI2C\_MasterTransferCreateHandle -> LPI2C\_MasterCreateHandle.

- \* LPI2C\_MasterTransferGetCount -> LPI2C\_MasterGetTransferCount.
- \* LPI2C\_MasterTransferAbort -> LPI2C\_MasterAbortTransfer.
- \* LPI2C\_MasterTransferHandleIRQ -> LPI2C\_MasterHandleInterrupt.
- \* LPI2C\_SlaveTransferCreateHandle -> LPI2C\_SlaveCreateHandle.
- \* LPI2C\_SlaveTransferGetCount -> LPI2C\_SlaveGetTransferCount.
- \* LPI2C\_SlaveTransferAbort -> LPI2C\_SlaveAbortTransfer.
- \* LPI2C\_SlaveTransferHandleIRQ -> LPI2C\_SlaveHandleInterrupt.

## [2.0.0]

• Initial version.

## LPI2C\_EDMA

## [2.4.4]

- Improvements
  - Added support for 2KB data transfer

# [2.4.3]

- Improvements
  - Added support for separated IRQ handlers.

# [2.4.2]

- Improvements
  - Add EDMA ext API to accommodate more types of EDMA.

# [2.4.1]

• Refer LPI2C driver change log 2.0.0 to 2.4.1

## LPIT

# [2.1.1]

- Improvements
  - Release peripheral from reset if necessary in init function.

## [2.1.0]

- Improvements
  - Add new function LPIT\_SetTimerValue to set timeout period.

## [2.0.2]

- Improvements
  - Improved LPIT\_SetTimerPeriod implementation, configure timeout value with LPIT ticks minus 1 generate more correct interval.
  - Added timeout value configuration check for LPIT\_SetTimerPeriod, at least input 3 ticks for calling LPIT\_SetTimerPeriod.
- Bug Fixes
  - Fixed MISRA C-2012 rule 17.7 violations.

## [2.0.1]

- Bug Fixes
  - MISRA C-2012 issue fixed.
    - \* Fixed rules, containing: rule-10.3, rule-14.4, rule-15.5.

## [2.0.0]

• Initial version.

## LPSPI

## [2.7.1]

- Bug Fixes
  - Workaround for errata ERR050607
  - Workaround for errata ERR010655

### [2.7.0]

- New Feature
  - Added common IRQ handler entry LPSPI\_DriverIRQHandler.

### [2.6.10]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

# [2.6.9]

- Bug Fixes
  - Fixed reading of TCR register
  - Workaround for errata ERR050606

## [2.6.8]

- Bug Fixes
  - Fixed build error when SPI\_RETRY\_TIMES is defined to non-zero value.

## [2.6.7]

- Bug Fixes
  - Fixed the txData from void \* to const void \* in transmit API \_lpspi\_master\_handle and \_lpspi\_slave\_handle.

## [2.6.6]

- Bug Fixes
  - Added LPSPI register init in LPSPI\_MasterInit incase of LPSPI register exist.

## [2.6.5]

- Improvements
  - Introduced FSL\_FEATURE\_LPSPI\_HAS\_NO\_PCSCFG and FSL\_FEATURE\_LPSPI\_HAS\_NO\_MULTI\_WIDTH for conditional compile.
  - Release peripheral from reset if necessary in init function.

### [2.6.4]

- Bug Fixes
  - Added LPSPI6\_DriverIRQHandler for LPSPI6 instance.

## [2.6.3]

- Hot Fixes
  - Added macro switch in function LPSPI\_Enable about ERRATA051472.

### [2.6.2]

- Bug Fixes
  - Disabled lpspi before LPSPI\_MasterSetBaudRate incase of LPSPI opened.

### [2.6.1]

- Bug Fixes
  - Fixed return value while calling LPSPI\_WaitTxFifoEmpty in function LP-SPI\_MasterTransferNonBlocking.

### [2.6.0]

- Feature
  - Added the new feature of multi-IO SPI .

## [2.5.3]

- Bug Fixes
  - Fixed 3-wire txmask of handle vaule reentrant issue.

## [2.5.2]

- Bug Fixes
  - Workaround for errata ERR051588 by clearing FIFO after transmit underrun occurs.

## [2.5.1]

- Bug Fixes
  - Workaround for errata ERR050456 by resetting the entire module using LP-SPIn\_CR[RST] bit.

## [2.5.0]

- Bug Fixes
  - Workaround for errata ERR011097 to wait the TX FIFO to go empty when writing TCR register and TCR[TXMSK] value is 1.
  - Added API LPSPI\_WaitTxFifoEmpty for wait the txfifo to go empty.

## [2.4.7]

- Bug Fixes
  - Fixed bug that the SR[REF] would assert if software disabled or enabled the LPSPI module in LPSPI\_Enable.

# [2.4.6]

- Improvements
  - Moved the configuration of registers for the 3-wire lpspi mode to the LPSPI\_MasterInit and LPSPI\_SlaveInit function.

# [2.4.5]

- Improvements
  - Improved LPSPI\_MasterTransferBlocking send performance when frame size is 1-byte.

# [2.4.4]

- Bug Fixes
  - Fixed LPSPI\_MasterGetDefaultConfig incorrect default inter-transfer delay calculation.

## [2.4.3]

- Bug Fixes
  - Fixed bug that the ISR response speed is too slow on some platforms, resulting in the first transmission of overflow, Set proper RX watermarks to reduce the ISR response times.

## [2.4.2]

- Bug Fixes
  - Fixed bug that LPSPI\_MasterTransferBlocking will modify the parameter txbuff and rxbuff pointer.

## [2.4.1]

- Bug Fixes
  - Fixed bug that LPSPI\_SlaveTransferNonBlocking can't detect RX error.

### [2.4.0]

- Improvements
  - Split some functions, fixed CCM problem in file fsl\_lpspi.c.

## [2.3.1]

- Improvements
  - Initialized the EDMA configuration structure in the LPSPI EDMA driver.
- Bug Fixes
  - Fixed bug that function LPSPI\_MasterTransferBlocking should return after the transfer complete flag is set to make sure the PCS is re-asserted.

### [2.3.0]

- New Features
  - Supported the master configuration of sampling the input data using a delayed clock to improve slave setup time.

# [2.2.1]

- Bug Fixes
  - Fixed bug in LPSPI\_SetPCSContinous when disabling PCS continous mode.

### [2.2.0]

- Bug Fixes
  - Fixed bug in 3-wire polling and interrupt transfer that the received data is not correct and the PCS continous mode is not working.

# [2.1.0]

- Improvements
  - Improved LPSPI\_SlaveTransferHandleIRQ to fill up TX FIFO instead of write one data to TX register which improves the slave transmit performance.
  - Added new functional APIs LPSPI\_SelectTransferPCS and LPSPI\_SetPCSContinous to support changing PCS selection and PCS continous mode.
- Bug Fixes

- Fixed bug in non-blocking and EDMA transfer APIs that kStatus\_InvalidArgument is returned if user configures 3-wire mode and full-duplex transfer at the same time, but transfer state is already set to kLPSPI\_Busy by mistake causing following transfer can not start.
- Fixed bug when LPSPI slave using EDMA way to transfer, tx should be masked when tx data is null, otherwise in 3-wire mode which tx/rx use the same pin, the received data will be interfered.

## [2.0.5]

- Improvements
  - Added timeout mechanism when waiting certain states in transfer driver.
- Bug Fixes
  - Fixed the bug that LPSPI can not transfer large data using EDMA.
  - Fixed MISRA 17.7 issues.
  - Fixed variable overflow issue introduced by MISRA fix.
  - Fixed issue that rxFifoMaxBytes should be calculated according to transfer width rather than FIFO width.
  - Fixed issue that completion flag was not cleared after transfer completed.

### [2.0.4]

- Bug Fixes
  - Fixed in LPSPI\_MasterTransferBlocking that master rxfifo may overflow in stall condition.
  - Eliminated IAR Pa082 warnings.
  - Fixed MISRA issues.
    - \* Fixed rules 10.1, 10.3, 10.4, 10.6, 11.9, 14.2, 14.4, 15.7, 17.7.

## [2.0.3]

- Bug Fixes
  - Removed LPSPI\_Reset from LPSPI\_MasterInit and LPSPI\_SlaveInit, because this API may glitch the slave select line. If needed, call this function manually.

### [2.0.2]

- New Features
  - Added dummy data set up API to allow users to configure the dummy data to be transferred.
  - Enabled the 3-wire mode, SIN and SOUT pins can be configured as input/output pin.

### [2.0.1]

- Bug Fixes
  - Fixed the bug that the clock source should be divided by the PRESCALE setting in LP-SPI\_MasterSetDelayTimes function.

- Fixed the bug that LPSPI\_MasterTransferBlocking function would hang in some corner cases.
- Optimization
  - Added #ifndef/#endif to allow user to change the default TX value at compile time.

# [2.0.0]

• Initial version.

### LPSPI\_EDMA

### [2.4.6]

- Improvements
  - Increased transmit FIFO watermark to ensure whole transmit FIFO will be used during data transfer.

## [2.4.5]

- Bug Fixes
  - Fixed reading of TCR register
  - Workaround for errata ERR050606

# [2.4.4]

- Improvements
  - Add EDMA ext API to accommodate more types of EDMA.

# [2.4.3]

- Improvements
  - Supported 32K bytes transmit in DMA, improve the max datasize in LP-SPI\_MasterTransferEDMALite.

# [2.4.2]

- Improvements
  - Added callback status in EDMA\_LpspiMasterCallback and EDMA\_LpspiSlaveCallback to check transferDone.

# [2.4.1]

- Improvements
  - Add the TXMSK wait after TCR setting.

## [2.4.0]

- Improvements
  - Separated LPSPI\_MasterTransferEDMA functions to LP-SPI\_MasterTransferPrepareEDMA and LPSPI\_MasterTransferEDMALite to optimize the process of transfer.

## LPTMR

## [2.2.0]

- Improvements
  - Updated lptmr\_prescaler\_clock\_select\_t, only define the valid options.

## [2.1.1]

• Improvements

 Updated the characters from "PTMR" to "LPTMR" in "FSL\_FEATURE\_PTMR\_HAS\_NO\_PRESCALER\_CLOCK\_SOURCE\_1\_SUPPORT" feature definition.

## [2.1.0]

- Improvements
  - Implement for some special devices' not supporting for all clock sources.
- Bug Fixes
  - Fixed issue when accessing CMR register.

# [2.0.2]

- Bug Fixes
  - Fixed MISRA-2012 issues.
    - \* Rule 10.1.

# [2.0.1]

- Improvements
  - Updated the LPTMR driver to support 32-bit CNR and CMR registers in some devices.

# [2.0.0]

• Initial version.

### LPUART

### [2.9.1]

- Bug Fixes
  - Fixed coverity issues.

## [2.9.0]

- New Feature
  - Added support for swap TXD and RXD pins.
  - Added common IRQ handler entry LPUART\_DriverIRQHandler.

### [2.8.3]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

## [2.8.2]

- Bug Fix
  - Fixed the bug that LPUART\_TransferEnable16Bit controled by wrong feature macro.

## [2.8.1]

- Bug Fixes
  - Fixed issue for MISRA-2012 check.
    - \* Fixed rule-5.3, rule-5.8, rule-10.4, rule-11.3, rule-11.8.

### [2.8.0]

- Improvements
  - Added support of DATA register for 9bit or 10bit data transmit in write and read API. Such as: LPUART\_WriteBlocking16bit, LPUART\_ReadBlocking16bit, LPUART\_TransferEnable16Bit
     LPUART\_WriteNonBlocking16bit, LPUART\_ReadNonBlocking16bit.

# [2.7.7]

- Bug Fixes
  - Fixed the bug that baud rate calculation overflow when srcClock\_Hz is 528MHz.

# [2.7.6]

- Bug Fixes
  - Fixed LPUART\_EnableInterrupts and LPUART\_DisableInterrupts bug that blocks if the LPUART address doesn't support exclusive access.

## [2.7.5]

- Improvements
  - Release peripheral from reset if necessary in init function.

# [2.7.4]

- Improvements
  - Added support for atomic register accessing in LPUART\_EnableInterrupts and LPUART\_DisableInterrupts.

# [2.7.3]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 15.7.

## [2.7.2]

- Bug Fix
  - Fixed the bug that the OSR calculation error when lupart init and lpuart set baud rate.

# [2.7.1]

- Improvements
  - Added support for LPUART\_BASE\_PTRS\_NS in security mode in file fsl\_lpuart.c.

### [2.7.0]

- Improvements
  - Split some functions, fixed CCM problem in file fsl\_lpuart.c.

# [2.6.0]

• Bug Fixes

– Fixed bug that when there are multiple lpuart instance, unable to support different ISR.

# [2.5.3]

- Bug Fixes
  - Fixed comments by replacing unused status flags kLPUART\_NoiseErrorInRxDataRegFlag and kLPUART\_ParityErrorInRxDataRegFlag with kLPUART\_NoiseErrorFlag and kLPUART\_ParityErrorFlag.

### [2.5.2]

- Bug Fixes
  - Fixed bug that when setting watermark for TX or RX FIFO, the value may exceed the maximum limit.
- Improvements
  - Added check in LPUART\_TransferDMAHandleIRQ and LPUART\_TransferEdmaHandleIRQ to ensure if user enables any interrupts other than transfer complete interrupt, the dma transfer is not terminated by mistake.

### [2.5.1]

- Improvements
  - Use separate data for TX and RX in lpuart\_transfer\_t.
- Bug Fixes
  - Fixed bug that when ring buffer is used, if some data is received in ring buffer first before calling LPUART\_TransferReceiveNonBlocking, the received data count returned by LPUART\_TransferGetReceiveCount is wrong.

### [2.5.0]

- Bug Fixes
  - Added missing interrupt enable masks kLPUART\_Match1InterruptEnable and kLPUART\_Match2InterruptEnable.
  - Fixed bug in LPUART\_EnableInterrupts, LPUART\_DisableInterrupts and LPUART\_GetEnabledInterrupts that the BAUD[LBKDIE] bit field should be soc specific.
  - Fixed bug in LPUART\_TransferHandleIRQ that idle line interrupt should be disabled when rx data size is zero.
  - Deleted unused status flags kLPUART\_NoiseErrorInRxDataRegFlag and kLPUART\_ParityErrorInRxDataRegFlag, since firstly their function are the same as kLPUART\_NoiseErrorFlag and kLPUART\_ParityErrorFlag, secondly to obtain them one data word must be read out thus interfering with the receiving process.
  - Fixed bug in LPUART\_GetStatusFlags that the STAT[LBKDIF], STAT[MA1F] and STAT[MA2F] should be soc specific.
  - Fixed bug in LPUART\_ClearStatusFlags that tx/rx FIFO is reset by mistake when clearing flags.
  - Fixed bug in LPUART\_TransferHandleIRQ that while clearing idle line flag the other bits should be masked in case other status bits be cleared by accident.
  - Fixed bug of race condition during LPUART transfer using transactional APIs, by disabling and re-enabling the global interrupt before and after critical operations on interrupt enable register.
  - Fixed DMA/eDMA transfer blocking issue by enabling tx idle interrupt after DMA/eDMA transmission finishes.
- New Features
  - Added APIs LPUART\_GetRxFifoCount/LPUART\_GetTxFifoCount to get rx/tx FIFO data count.
  - Added APIs LPUART\_SetRxFifoWatermark/LPUART\_SetTxFifoWatermark to set rx/tx FIFO water mark.

## [2.4.1]

- Bug Fixes
  - Fixed MISRA advisory 17.7 issues.

# [2.4.0]

- New Features
  - Added APIs to configure 9-bit data mode, set slave address and send address.

## [2.3.1]

- Bug Fixes
  - Fixed MISRA advisory 15.5 issues.

### [2.3.0]

- Improvements
  - Modified LPUART\_TransferHandleIRQ so that txState will be set to idle only when all data has been sent out to bus.
  - Modified LPUART\_TransferGetSendCount so that this API returns the real byte count that LPUART has sent out rather than the software buffer status.
  - Added timeout mechanism when waiting for certain states in transfer driver.

# [2.2.8]

- Bug Fixes
  - Fixed issue for MISRA-2012 check.
    - \* Fixed rule-10.3, rule-14.4, rule-15.5.
  - Eliminated Pa082 warnings by assigning volatile variables to local variables and using local variables instead.
  - Fixed MISRA issues.
    - \* Fixed rules 10.1, 10.3, 10.4, 10.8, 14.4, 11.6, 17.7.
- Improvements
  - Added check for kLPUART\_TransmissionCompleteFlag in LPUART\_WriteBlocking, LPUART\_TransferHandleIRQ, LPUART\_TransferSendDMACallback and LPUART\_SendEDMACallback to ensure all the data would be sent out to bus.
  - Rounded up the calculated sbr value in LPUART\_SetBaudRate and LPUART\_Init to achieve more acurate baudrate setting. Changed osr from uint32\_t to uint8\_t since osr's bigest value is 31.
  - Modified LPUART\_ReadBlocking so that if more than one receiver errors occur, all status flags will be cleared and the most severe error status will be returned.

## [2.2.7]

- Bug Fixes
  - Fixed issue for MISRA-2012 check.
    - \* Fixed rule-12.1, rule-17.7, rule-14.4, rule-13.3, rule-14.4, rule-10.4, rule-10.8, rule-10.3, rule-10.7, rule-10.1, rule-11.6, rule-13.5, rule-11.3, rule-13.2, rule-8.3.

# [2.2.6]

- Bug Fixes
  - Fixed the issue of register's being in repeated reading status while dealing with the IRQ routine.

### [2.2.5]

- Bug Fixes
  - Do not set or clear the TIE/RIE bits when using LPUART\_EnableTxDMA and LPUART\_EnableRxDMA.

### [2.2.4]

- Improvements
  - Added hardware flow control function support.
  - Added idle-line-detecting feature in LPUART\_TransferNonBlocking function. If an idle line is detected, a callback is triggered with status kStatus\_LPUART\_IdleLineDetected returned. This feature may be useful when the received Bytes is less than the expected received data size. Before triggering the callback, data in the FIFO (if has FIFO) is read out, and no interrupt will be disabled, except for that the receive data size reaches 0.
  - Enabled the RX FIFO watermark function. With the idle-line-detecting feature enabled, users can set the watermark value to whatever you want (should be less than the RX FIFO size). Data is received and a callback will be triggered when data receive ends.

### [2.2.3]

- Improvements
  - Changed parameter type in LPUART\_RTOS\_Init struct from rtos\_lpuart\_config to lpuart\_rtos\_config\_t.
- Bug Fixes
  - Disabled LPUART receive interrupt instead of all NVICs when reading data from ring buffer. Otherwise when the ring buffer is used, receive nonblocking method will disable all NVICs to protect the ring buffer. This may has a negative effect on other IPs that are using the interrupt.

### [2.2.2]

- Improvements
  - Added software reset feature support.
  - Added software reset API in LPUART\_Init.

# [2.2.1]

- Improvements
  - Added separate RX/TX IRQ number support.

# [2.2.0]

- Improvements
  - Added support of 7 data bits and MSB.

# [2.1.1]

- Improvements
  - Removed unnecessary check of event flags and assert in LPUART\_RTOS\_Receive.
  - Added code to always wait for RX event flag in LPUART\_RTOS\_Receive.

# [2.1.0]

- Improvements
  - Update transactional APIs.

# LPUART\_EDMA

# [2.4.0]

• Refer LPUART driver change log 2.1.0 to 2.4.0

# MCM

# [2.2.0]

- Improvements
  - Support platforms with less features.

# [2.1.0]

- Others
  - Remove byteID from mcm\_lmem\_fault\_attribute\_t for document update.

# [2.0.0]

• Initial version.

### **MSGINTR**

### [2.0.2]

- Improvements
  - Conditional compile IRQ handlers.

## [2.0.1]

- Bug Fixes
  - Fixed MISRA issue rule 8.4, 11.9, 17.7.

### [2.0.0]

• Initial version.

### MU

## [2.7.0]

- New Features
  - Added API MU\_GetRxStatusFlags.

### [2.6.0]

- New Features
  - Added API MU\_GetInterruptsPending.

### [2.5.1]

- Bug Fixes
  - Fixed the bug that MU\_TriggerGeneralPurposeInterrupts and MU\_TriggerInterrupts may trigger previous triggered general purpose interrupts again by mistake.

#### [2.5.0]

- New Features
  - Supported more than 4 general purpose interrupts.
  - Added seperate APIs for general purpose interrupts.

### [2.4.0]

- Improvements
  - Supported the case that some features only avaiable with specific instances. These features include Hardware Reset, Boot Peer Core, Hold Reset. When using the features with instances which don't support them, driver will report error.

## [2.3.3]

- Improvements
  - Release peripheral from reset if necessary in init function.

## [2.3.2]

- Improvements
  - Supported platforms which don't have CCR0[RSTH], CCR0[CLKE], CCR0[HR], CCR0[HRM].

## [2.3.1]

- Bug Fixes
  - Fixed build error for platforms which have CCR0[RSTH], but no CCR0[NMI].

## [2.3.0]

- New features
  - Added support for i.MX RT7xx.

# [2.2.1]

- Bug Fixes
  - Fixed issue that MU\_GetInstance() is defined but never used.

### [2.2.0]

- New features
  - Added support for i.MX RT118x.
- Bug Fixes
  - Fixed general purpose interrupt bug.
- Other Changes
  - Change \_mu\_interrupt\_trigger item value.

### [2.1.2]

- Bug Fixes
  - Fixed bug that general purpose interrupt can't be configured.

# [2.1.1]

- Bug Fixes
  - Fixed MISRA C-2012 issues.

### [2.1.0]

- Improvements
  - Added new enum mu\_msg\_reg\_index\_t.

### [2.0.0]

• Initial version.

### NETC

### [2.9.1]

- Improvements
  - NETC\_TimerInit() will always ignore user config->atomicMode and set it to 1 internally. This guarantees that period updates, that change both the integer and fractional part are always done atomically.

### [2.9.0]

- Bug Fixes
  - Fixed padding in netc\_tb\_sgi\_rsp\_data\_t union structure for query operations on OEXEN and IRXEN parameters.
  - Fixed structure use for rate policer and stream gate request commands memset.
  - Updated ERRATA 052134 to 052206.
  - Fixed MII mode setting.
  - Fixed i.MX943 getting function instance.
- New Features
  - Added API to Reset IRX and OEX flags in stream gate instance entry.
  - Added API to configure the priority to traffic class map.
  - Added APIs to query table entry and get maximum entry number for Frame Modification Table.
  - Added APIs to configure Frame preemption.
  - Added APIs to configure PSRCR and PGCR registers to implement HSR feature.
  - Moved PHY WRAPPER init sequence (NETC\_PHYInit) implementation to SoC. And Added i.MX943 support.
- Improvements
  - keep netc\_tb\_sgi\_rsp\_data\_t local to the low level driver functions for SGI table entry query.
  - Converted to use preinitVsi callback for VSI pre-init.
  - Added note for ERRATA 052167 to remind that actual MAC Tx IPG is longer than configured when transmitting back-to-back packets in MII half duplex. When using MII protocol, using full-duplex mode is recommended instead of half-duplex. If using MII half-duplex mode, additional bandwidth loss should be expected and accounted for due to extended IPG.

#### [2.8.2]

- Bug Fixes
  - Fixed ingress port filter table frame attribute flags mask field issue.

# [2.8.1]

- Bug Fixes
  - Fixed MAC/VLAN filter operations through VSI-PSI message.
  - Fixed NETC\_PortConfigTxIpgPreamble compile.
- Improvements
  - Enabled standard VLAN EtherTypes for i.MX95 VSIs for VLAN support.
  - Added netc\_timer\_exttrig\_index\_t definition for i.MX95.
  - Updated default BPCR[STAMVD] value setting to align the register reset value.

## [2.8.0]

- Bug Fixes
  - Fixed ERRATA 052024.
  - Fixed ERRATA 052129.
  - Fixed ERRATA 052134.
  - Fixed ERRATA 052031.
  - Fixed ERRATA 051994.
  - Fixed ERRATA 051936.
- New Features
  - Added interface to reset the mark frame red parameter.
  - Added support for FRER sequence generation reset.
  - Added NETC Switch Tag support.
  - Added the Tx offload feature support.
- Improvements
  - Simplify NETC\_TimerGetFreeRunningTime. Hardware synchronizes reads from high/low registers for the free running time. No need to do it in software.

# [2.7.2]

- Bug Fixes
  - Fixed MISRA issue rule 4.10, 10.1, 10.3, 10.4, 10.7, 10.8, 11.3, 16.1, 16.4, 17.7.

# [2.7.1]

- Bug Fixes
  - Fixed Coverity issue with array out of bounds access.

# [2.7.0]

- New Features
  - Added VSI-PSI messaging driver.
- Bug Fixes
  - Fixed the issue that EP/SWT\_ReceiveFrame don't return error status when some errors occur.

## [2.6.1]

- Bug Fixes
  - Updated the MAC loopback configuration as Reference Manual.

## [2.6.0]

- New Features
  - Added API to get transmit max SDU for specified port Traffic Class.
  - Added API to query entry from the Rate Policing table.
  - Added API to retrieve maximum rate policer entries.
  - Added API to set switch port default VID separately.
  - Added API to set max frame size separately.
  - Added API to query FRER resource.
- Bug Fixes
  - Fixed the issue that stream gate query functions don't check return status.
  - Fixed the ISF table query function operation issue.
  - Fixed the wrong configuration of Tx max SDU check.
  - Fixed ERRATA 051524.
  - Fixed ERRATA 051649.
  - Fixed ERRATA 051707.
  - Fixed ERRATA 051710.
  - Fixed ERRATA 051711.
- Improvements
  - Factorized qbv basetime workaround code, and stop using synchronized time for the workaround code. Synchronized time functionality should be reserved for gPTP operation.

# [2.5.1]

- Improvements
  - Conditional compile NETC\_ETH\_LINK\_PM0\_COMMAND\_CONFIG\_HD\_FCEN register.

### [2.5.0]

- New Features
  - Added PHY WRAPPER driver.
  - Added C45 support for internal MDIO.
  - Added 10G support.
- Bug Fixes
  - Fixed ERRATA 051130.
  - Fixed master bus and memory access.
- Improvements
  - Moved platform specific code to soc driver.

– Split switch code.

## [2.4.0]

- New Features
  - Added the interrupt control functions for port MAC module.
  - Added setting parameters including half-duplex back pressure, port timestamp capture point, RGMII Tx clock stop state during low power idle, ports default traffic class gating states and timer atomic writing setting.
  - Added NETC\_TimerInitHandle() to initialize a timer handle without modifying hardware state. Required to be able to read timer from another CPU.
  - Added NETC\_TimerGetFreeRunningTime() to be able to read free running timer.
  - Added support for ingress stream gate query.
- Improvements
  - Added necessary default settings in the GetDefaultConfig functions in case some features can't work after initialization.
  - Updated loopback function according to new bit field in CRR.
  - Deleted the useless error check for ERRATA051243.
  - Updated NETC\_TimerGetCurrentTime() to avoid using synchronized time and be able to read the time from different threads/cpus without locking.
  - Deleted the useless priority check in NETC\_PortConfigTcCBS().
- Bug Fixes
  - Fixed typo in NETC\_PortConfig.

### [2.3.2]

- Bug Fixes
  - Added workaround for ERRATA051587.

### [2.3.1]

- Bug Fixes
  - Fixed MISRA issue rule 10.3, 10.4, 10.8, 11.6, 11.7.

#### [2.3.0]

- Bug Fixes
  - Added SWT\_PortStop() API for ERRATA051398.
  - Fixed the build error by add feature macro for port FCS Error Action feature.
  - Removed duplicate code from NETC\_PortEthMacGracefulStop() API.
  - Fixed MISRA issue rule 8.6, 10.4, 11.9, 14.4.

#### [2.2.2]

- Bug Fixes
  - Fixed the issue that NETC\_PortSetSpeed() would overwrite the full PCR register.

## [2.2.1]

- Improvements
  - Fixed cpp build warning.

# [2.2.0]

- Bug Fixes
  - Fixed the issue that NETC\_ConfigTGSAdminList() doesn't clear the previous command response data status filed.
  - Fixed the issue that EP\_ReceiveFrameCopy(&handle, 0, NULL, 0, NULL) can't drop error frame.
  - Fixed the issue that SWT\_GetTimestampRefResp can't get Switch Tx TS Resp with no MgmtRxBdRing.
  - Fixed the issue that RGMII Half Duplex mode misconfigured.
  - Fixed the issue that missing workaround for ERR050679, ERR051246 and ERR051254.
  - Fixed the issue that missing feature macro for ERR051130, ERR051202, ERR051260.
  - Fixed the issue that ep/swt\_tx\_opt struct use wrong vlan tag tpid value.
  - Fixed MISRA issue rule 5.8, 8.3, 8.12, 10.1, 10.3, 10.4, 10.6, 10.7, 10.8, 11.6, 11.8, 12.2, 14.4, 15.5, 15.6, 16.1, 16.3, 16.4, 17.7.
  - Fixed the issue that internal MDIO read function uses wrong register.
  - Fixed the issue that SWT\_TxPortTGSEnable()/EP\_TxPortTGSEnable() still uses the default timer after enabling the 1588 timer.
  - Remove the resetCount parameter from get port discard statistic APIs because the registers required by this function have been removed from hardware design.
  - Fixed the issue that SWT/EP\_ReclaimTxDesc() can't call reclaim callback for each full frame.
  - Fixed the issue in NETC\_TimerAdjustFreq().
- New Features
  - Added the support for 1588 One-Step timestamp when chip doesn't have ERR051255.
  - Added APIs to get dynamic table remaining available entry numbers.
  - Added APIs to get static table number of entries.
- Improvements
  - Return detail error status instead of kStatus\_Fail in NTMP APIs.
  - Rename feature macros and move them into the feature file.
  - Optimize the implementation of the NETC\_TimerAddOffset() function to avoid change the TMR\_CNT\_L/H registers, and add required procedure for call NETC\_TimerAddOffset() API in the comments.
  - Update the SWT\_FMDUpdateTableEntry()/SWT\_FMDQueryTableEntry() APIs to make them use internel table buffer.
  - Update SWT\_TxPortTGSEnable()/EP\_TxPortTGSEnable() to make it can config the default administration gate control list gates' state.
  - Use TMR\_SRT\_L/H instead of TMR\_CUR\_TIMER when want to get current 1588 timer value.

## [2.1.0]

- Bug Fixes
  - Fixed the issue that EP\_RxL2MFInit doesn't set the multicast promiscuous correctly.
  - Fixed the timer add offset issue.
  - Fixed the issue that all ENETC/Switch PCIe functions must be enabled firstly before triggering EP/SWT NTMP access and MSIX messages.
  - Fixed RT1180 NETC errata 051202: Configure Tx MAC to wait until 32 bytes of data are built up in the transmit FIFO before beginning transmission on the link.
  - Added workaround for RT1180 NETC errata 051130: C Egress time gate scheduling can get corrupted when functional level reset is applied or when time gating is disabled.
  - Fixed bugs in statistic APIs.
- New Features
  - Added the support for EP VSI transmission and PSI-VSI message exchanging.
  - Added EP receive regular frame zero-copy support.
  - Integrated EMDIO support in NETC MDIO driver for accessing PHY when EP/Switch function isn't enabled.
  - Added Timer and Switch MSIX table configuration support.
  - Added update entry APIs for IPF/VF/FDB/L2MCF/IS/ISF/SGI/RP/FM/ET/ISEQG tables, and search entry APIs for FDB/L2MCF table.
  - Added Ingress buffer pool table config APIs.
  - Added MAC Tx padding and Rx min/max frame size configuration to support Tx/Rx frames smaller than 64 bytes.
  - Added API to do graceful Stop for ETH MAC.
- Improvements
  - Used Rx buffer address array provided by application instead of buffer start address with contiguous memory to make the Rx buffer setup more flexible.
  - Added ring and userData parameter in the Tx reclaim callback.
  - Updated NETC hardware layer folder name from 'hw' to 'netc\_hw'.
  - Stored necessary EP and SWT configurations constant in handle structure instead of storing pointer which forces appliction to keep static configuration structure data.
  - Updated NETC\_MsixXxx to EP\_MsixXxx to differentiate with corresponding SWT/Timer MSIX configuration APIs.
  - Aligned TGSL/SGCL API with enet\_qos high-level driver.
  - Updated EP/Switch config structure to include all port related config.
  - Updated Switch transfer API only send management frame (Direct enqueue and Switch Port Masquerading) and only receive Host Reason no-zero frames.
  - Updated EP transfer API only send/receive regular frames.
  - Updated Switch/EP handle to make them use independent cache maintain, alloc/free memory and reclaimCallback functions.

### [2.0.0]

• Initial version.

## PDM

## [2.9.2]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.1, 10.3, 10.4, 10.5, 10.6, 10.7, 10.8, 12.4.

## [2.9.1]

- Bug Fixes
  - Fixed the issue that the driver still enters the interrupt after disabling clock.

## [2.9.0]

- Improvements
- Added feature FSL\_FEATURE\_PDM\_HAS\_DECIMATION\_FILTER\_BYPASS to config CTRL\_2[DEC\_BYPASS] field.
- Modify code to make the OSR value is not limited to 16.

# [2.8.1]

- Improvements
- Added feature FSL\_FEATURE\_PDM\_HAS\_NO\_DOZEN to handle nonexistent CTRL\_1[DOZEN] field.

### [2.8.0]

- Improvements
- Added feature FSL\_FEATURE\_PDM\_HAS\_NO\_HWVAD to remove the support of hadware voice activity detector.
- Added feature FSL\_FEATURE\_PDM\_HAS\_NO\_FILTER\_BUFFER to remove the support of FIR\_RDY bitfield in STAT register.

### [2.7.4]

- Bug Fixes
  - Fixed driver can not determine the specific float number of clock divider.
  - Fixed PDM\_ValidateSrcClockRate calculates PDM channel in wrong method issue.

### [2.7.3]

- Improvements
- Added feature FSL\_FEATURE\_PDM\_HAS\_NO\_VADEF to remove the support of VADEF bit-field in VAD0\_STAT register.

### [2.7.2]

- Improvements
- Added feature FSL\_FEATURE\_PDM\_HAS\_NO\_MINIMUM\_CLKDIV to decide whether the minimum clock frequency division is required.

# [2.7.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 8.4, 10.3, 10.1, 10.4, 14.4

# [2.7.0]

- Improvements
  - Added api PDM\_EnableHwvadInterruptCallback to support handle hwvad IRQ in PDM driver.
  - Corrected the sample rate configuration for non high quality mode.
  - Added api PDM\_SetChannelGain to support adjust the channel gain.

## [2.6.0]

- Improvements
  - Added new features FSL\_FEATURE\_PDM\_HAS\_STATUS\_LOW\_FREQ/FSL\_FEATURE\_PDM\_HAS\_DC\_OUT

## [2.5.0]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 8.4, 16.5, 10.4, 10.3, 10.1, 11.9, 17.7, 10.6, 14.4, 11.8, 11.6.

## [2.4.1]

- Bug Fixes
  - Fixed MDK 66-D warning in pdm driver.

### [2.4.0]

- Improvements
  - Added api PDM\_TransferSetChannelConfig/PDM\_ReadFifo to support read different width data.
  - Added feature FSL\_FEATURE\_PDM\_HAS\_RANGE\_CTRL and api PDM\_ClearRangeStatus/PDM\_GetRangeStatus for range register.
- Bug Fixes
  - Fixed violation of MISRA C-2012 Rule 14.4, 10.3, 10.4.

### [2.3.0]

- Improvements
  - Enabled envelope/energy voice detect mode by adding apis PDM\_SetHwvadInEnvelopeBasedMode/PDM\_SetHwvadInEnergyBasedMode.
  - Added feature FSL\_FEATURE\_PDM\_CHANNEL\_NUM for different SOC.

## [2.2.1]

- Bug Fixes
  - Fixed violation of MISRA C-2012 Rule 10.1, 10.3, 10.4, 10.6, 10.7, 11.3, 11.8, 14.4, 17.7, 18.4.
  - Added medium quality mode support in function PDM\_SetSampleRateConfig.

## [2.2.0]

- Improvements
  - Added api PDM\_SetSampleRateConfig to improve user experience and marked api PDM\_SetSampleRate as deprecated.

## [2.1.1]

- Improvements
- Used new SDMA API SDMA\_SetDoneConfig instead of SDMA\_EnableSwDone for PDM SDMA driver.

## [2.1.0]

- Improvements
  - Added software buffer queue for transactional API.

### [2.0.1]

- Improvements
  - Improved HWVAD feature.

### [2.0.0]

• Initial version.

### PDM\_EDMA

### [2.6.5]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.1, 10.3, 10.4, 10.5, 10.6, 10.7, 10.8.

### [2.6.4]

- Improvements
  - Add handling for runtime change of number of linked transfers

## [2.6.3]

- Improvements
  - Add EDMA ext API to accommodate more types of EDMA.

## [2.6.2]

- Improvements
  - Add macro MCUX\_SDK\_PDM\_EDMA\_PDM\_ENABLE\_INTERNAL to let the user decide whether to enable it when calling PDM\_TransferReceiveEDMA.

# [2.6.1]

- Bug Fixes
  - Fixed violation of MISRA C-2012 Rule 10.3, 10.4.

## [2.6.0]

- Improvements
  - Updated api PDM\_TransferReceiveEDMA to support channel block interleave transfer.
  - Added new api PDM\_TransferSetMultiChannelInterleaveType to support channel interleave type configurations.

### [2.5.0]

• Refer PDM driver change log 2.1.0 to 2.5.0

### PWM

### [2.9.0]

- Improvements
  - Support PWMX channel output for edge aligned PWM.
  - Forbid submodule 0 counter initialize with master sync and master reload mode.

### [2.8.4]

- Improvements
  - Support workaround for ERR051989. This function helps realize no phase delay between submodule 0 and other submodule.

## [2.8.3]

- Bug Fixes
  - Fixed MISRA C-2012 Rule 15.7

## [2.8.2]

- Bug Fixes
  - Fixed warning conversion from 'int' to 'uint16\_t' on API PWM\_Init.
  - Fixed warning unused variable 'reg' on API PWM\_SetPwmForceOutputToZero.

## [2.8.1]

- Improvements
  - Release peripheral from reset if necessary in init function.

# [2.8.0]

- Improvements
  - Added API PWM\_UpdatePwmPeriodAndDutycycle to update the PWM signal's period and dutycycle for a PWM submodule.
  - Added API PWM\_SetPeriodRegister and PWM\_SetDutycycleRegister to merge duplicate code in API PWM\_SetupPwm, PWM\_UpdatePwmDutycycleHighAccuracy and PWM\_UpdatePwmPeriodAndDutycycle

## [2.7.1]

- Improvements
  - Supported UPDATE\_MASK bit in MASK register.

## [2.7.0]

- Improvements
  - Supported platforms which don't have Capture feature with channel A and B.
  - Supported platforms which don't have Submodule 3.
  - Added assert function in API PWM\_SetPhaseDelay to prevent wrong argument.

# [2.6.1]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rules: 10.3.

### [2.6.0]

- Improvements
  - Added API PWM\_SetPhaseDelay to set the phase delay from the master sync signal of submodule 0.
  - Added API PWM\_SetFilterSampleCountthe to set number of consecutive samples that must agree prior to the input filter.
  - Added API PWM\_SetFilterSamplePeriod to set set the sampling period of the fault pin input filter.

### [2.5.1]

- Bug Fixes
  - Fixed MISRA C-2012 rules: 10.1, 10.3, 10.4, 10.6 and 10.8.
  - Fixed the issue that PWM\_UpdatePwmDutycycle() can't update duty cycle status value correct.

# [2.5.0]

- Improvements
  - Added API PWM\_SetOouputToIdle to set pwm channel output to idle.
  - Added API PWM\_GetPwmChannelState to get the pwm channel output duty cycle value.
  - Added API PWM\_SetPwmForceOutputToZero to set the pwm channel output to zero logic.
  - Added API PWM\_SetChannelOutput to set the pwm channel output state.
  - Added API PWM\_SetClockMode to set the value of the clock prescaler.
  - Added API PWM\_SetupPwmPhaseShift to set PWM which a special phase shift and 50% duty cycle.
  - Added API PWM\_SetVALxValue/PWM\_GetVALxValue to set/get PWM VALs registers values directly.

## [2.4.0]

- Improvements
  - Supported the PWM which can't work in wait mode.

## [2.3.0]

- Improvements
  - Add PWM output enable&disbale API for SDK.
- Bug Fixes
  - Fixed changing channel B configuration when parameter is kPWM\_PWMX and PWMX configuration is not supported yet.

# [2.2.1]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rules: 10.3, 10.4.
- Bug Fixes
  - Fixed the issue that PWM drivers computed VAL1 improperly.
- Improvements
  - Updated calculation accuracy of reloadValue in dutyCycleToReloadValue function.

# [2.2.0]

- Improvements
  - Added new enumeration and two APIs to support enabling and disabling one or more PWM output triggers.
  - Added a new function to make the most of 16-bit resolution PWM.
  - Added one API to support updating fault status of PWM output.
  - Added one API to support PWM DMA write request.
  - Added three APIs to support PWM DMA capture read request.

- Added one API to support get default fault config of PWM.
- Added one API to support setting PWM fault disable mapping.

## [2.1.0]

- Improvements
  - Moved the configuration of fault input filter into a new API to avoid be initialized multiple times.
- Bug Fixes
  - MISRA C-2012 issue fixed.
    - \* Fix rules, containing: rule-10.2, rule-10.3, rule-10.4, rule-10.7, rule-10.8, rule-14.4, rule-16.4.

# [2.0.1]

- Bug Fixes
  - Fixed the issue that PWM submodule may be initialized twice in function PWM\_SetupPwm().

## [2.0.0]

• Initial version.

### PXP

# [2.7.0]

- New Features
  - Added the PS\_LRC setting for V4.
  - Added the PXP\_SetPath setting for V4.
  - Fixed the code logic, V4 do not support DATA\_PATH\_CTRL1.

### [2.6.1]

- Improvements
  - Release peripheral from reset if necessary in init function.

### [2.6.0]

- Bug Fixes
  - Added missing configuration option for fetch engine background value.
  - Fixed bug in PXP\_SetStoreEngineConfig that the address increment for store mask is not linear.
  - Added channel aribitration configuration for fetch engine, channel combine for store engine.
  - Fixed wrong method of obtaining the store mask address.

- Fixed wrong method of configuring flag shift mask/width which can only be written in word boundary.
- Fixed wrong configurations of block store and pitch in PXP\_SetStoreEngineConfig.
- Fixed wrong method of obtaining cfaValue address and calculating word count.
- Fixed the channel word order cannot be updated when configuring the second channel.
- Fixed bugs in PXP\_SetHistogramConfig of wrong method to obtain the store mask address and wrong access of 32-bit registers.

## [2.5.0]

- New Features
  - Added new API PXP\_GetPorterDuffConfigExt for flexible Porter-Duff configuration.
  - Added enumerations for new AS/PS pixel formats for certain SoCs.

## [2.4.1]

- New Features
  - Added API PXP\_ResetControl to reset the PXP and the control register to initialized state.

## [2.4.0]

- New Features
  - Added the API PXP\_BuildRect of building a solid rectangle of given pixel value.
  - Added the interrupt enable/disable and status mask for V3.
  - Added API PXP\_EnableProcessEngine to enable/disable process engines for V3.
  - Added API PXP\_SetHistogramSize to re-configure the histogram size for each update.
  - Updated PXP\_WfeaInit and PXP\_SetWfeaConfig according to header file's update of WFE related registers.
  - Updated PXP\_WfeaInit to support handshake with upstream dither store engine and added API PXP\_WfeaEnableDitherHandshake to enable/disable the feature.
  - Added API PXP\_GetLutUsage to get the occupied LUT list.
  - Updated APIs to support alpha blending engine1.
  - Added the API PXP\_MemCopy to support all memory size copy.
- Bug Fixes
  - Fixed wrong naming for mux16.
  - Fixed wrong naming for enumerations in pxp\_scanline\_burst\_t.
  - Fixed bug in PXP\_GetHistogramMatchResult since there are 2 histograms engines rather than 1.
  - Fixed bug in PXP\_SetFetchEngineConfig that the fetch size should not be minus one coding.

### [2.3.0]

- New Features
  - Added the configuration of fetch engine, store engine, pre-dither engine and histogram block.

## [2.2.2]

- Improvements
  - Disable alpha surface (AS) in PXP\_Init.

# [2.2.1]

- Improvements
  - Added memory address conversion to support buffers which could only be accessed using alias address by non-core masters.

## [2.2.0]

- Bug Fixes
  - Fixed Porter Duff configuration error.

## [2.1.0]

- New Features
  - Added Porter Duff support.
  - Added APIs PXP\_StartMemCopy and PXP\_StartPictureCopy.
  - Added API PXP\_SetProcessSurfaceYUVFormat.

# [2.0.2]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 3.1, 10.8, 11.6, 12.2.

# [2.0.1]

- Bug Fixes
  - Fixed the rotate function issue for i.MX 6ULL.

# [2.0.0]

• Initial version.

# RGPIO

# [2.1.0]

- New feature:
  - Added API RGPIO\_EnablePortInput()
  - Added API RGPIO\_SetPinInterruptConfig()
  - Added API RGPIO\_GetPinsInterruptFlags()
  - Added API RGPIO\_ClearPinsInterruptFlags()

#### [2.0.3]

- Improvements:
  - Enhanced FGPIO\_PinInit to enable clock internally.

#### [2.0.2]

- Bug fix
  - MISRA C-2012 issue fixed.
    - \* Fix rules, containing: rule-10.3, rule-14.4, rule-15.5.

# [2.0.1]

- API Interface Change:
  - Refined naming of API while keep all original APIs with marking them as deprecated. The original API will be removed in the next release. The main change is to update API with prefix of \_PinXXX() and \_PortXXX().

#### [2.0.0]

• Initial version.

#### S3MU

- 2.0.2 Fix macro BIT redefined warning when compiling with Zephyr.
- 2.0.1 Update kStatusGroup\_SNT to kStatusGroup\_ELEMU.
- 2.0.0 Initial version of S3MU driver.

#### SAI

#### [2.4.7]

- Added conditional support for bit clock swap feature
- Added common IRQ handler entry SAI\_DriverIRQHandler.

# [2.4.6]

- Bug Fixes
  - Fixed the IAR build warning.

# [2.4.5]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.1, 10.3, 10.4, 10.5, 10.6, 10.7, 10.8, 12.4.

# [2.4.4]

- Bug Fixes
  - Fixed enumeration sai\_fifo\_combine\_t add RX configuration.

# [2.4.3]

- Bug Fixes
  - Fixed enumeration sai\_fifo\_combine\_t value configuration issue.

# [2.4.2]

- Improvements
  - Release peripheral from reset if necessary in init function.

# [2.4.1]

- Bug Fixes
  - Fixed bitWidth incorrectly assigned issue.

# [2.4.0]

- Improvements
  - Removed deprecated APIs.

# [2.3.8]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.4.

# [2.3.7]

- Improvements
  - Change feature "FSL\_FEATURE\_SAI\_FIFO\_COUNT" to "FSL\_FEATURE\_SAI\_HAS\_FIFO".
  - Added feature "FSL\_FEATURE\_SAI\_FIFO\_COUNTn(x)" to align SAI fifo count function with IP in function

# [2.3.6]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 5.6.

# [2.3.5]

- Improvements
  - Make driver to be aarch64 compatible.

# [2.3.4]

- Bug Fixes
  - Corrected the fifo combine feature macro used in driver.

# [2.3.3]

- Bug Fixes
  - Added bit clock polarity configuration when sai act as slave.
  - Fixed out of bound access coverity issue.
  - Fixed violations of MISRA C-2012 rule 10.3, 10.4.

# [2.3.2]

- Bug Fixes
  - Corrected the frame sync configuration when sai act as slave.

# [2.3.1]

- Bug Fixes
  - Corrected the peripheral name in function SAI0\_DriverIRQHandler.
  - Fixed violations of MISRA C-2012 rule 17.7.

# [2.3.0]

- Bug Fixes
  - Fixed the build error caused by the SOC has no fifo feature.

# [2.2.3]

- Bug Fixes
  - Corrected the peripheral name in function SAI0\_DriverIRQHandler.

#### [2.2.2]

- Bug Fixes
  - Fixed the issue of MISRA 2004 rule 9.3.
  - Fixed sign-compare warning.
  - Fixed the PA082 build warning.
  - Fixed sign-compare warning.
  - Fixed violations of MISRA C-2012 rule 10.3,17.7,10.4,8.4,10.7,10.8,14.4,17.7,11.6,10.1,10.6,8.4,14.3,16.4,18
  - Allow to reset Rx or Tx FIFO pointers only when Rx or Tx is disabled.
- Improvements
  - Added 24bit raw audio data width support in sai sdma driver.
  - Disabled the interrupt/DMA request in the SAI\_Init to avoid generates unexpected sai FIFO requests.

# [2.2.1]

- Improvements
  - Added mclk post divider support in function SAI\_SetMasterClockDivider.
  - Removed useless configuration code in SAI\_RxSetSerialDataConfig.
- Bug Fixes
  - Fixed the SAI SDMA driver build issue caused by the wrong structure member name used in the function SAI\_TransferRxSetConfigSDMA/SAI\_TransferTxSetConfigSDMA.
  - Fixed BAD BIT SHIFT OPERATION issue caused by the FSL\_FEATURE\_SAI\_CHANNEL\_COUNTn.
  - Applied ERR05144: not set FCONT = 1 when TMR > 0, otherwise the TX may not work.

# [2.2.0]

- Improvements
  - Added new APIs for parameters collection and simplified user interfaces:
    - \* SAI\_Init
    - \* SAI\_SetMasterClockConfig
    - \* SAI\_TxSetBitClockRate
    - \* SAI\_TxSetSerialDataConfig
    - \* SAI\_TxSetFrameSyncConfig
    - \* SAI\_TxSetFifoConfig
    - \* SAI\_TxSetBitclockConfig
    - \* SAI\_TxSetConfig
    - \* SAI\_TxSetTransferConfig
    - \* SAI\_RxSetBitClockRate
    - \* SAI\_RxSetSerialDataConfig
    - \* SAI\_RxSetFrameSyncConfig
    - \* SAI\_RxSetFifoConfig

- \* SAI\_RxSetBitclockConfig
- \* SAI\_RXSetConfig
- \* SAI\_RxSetTransferConfig
- \* SAI\_GetClassicI2SConfig
- \* SAI\_GetLeftJustifiedConfig
- \* SAI\_GetRightJustifiedConfig
- \* SAI\_GetTDMConfig

# [2.1.9]

- Improvements
  - Improved SAI driver comment for clock polarity.
  - Added enumeration for SAI for sample inputs on different edges.
  - Changed FSL\_FEATURE\_SAI\_CHANNEL\_COUNT to FSL\_FEATURE\_SAI\_CHANNEL\_COUNTn(base) for the difference between the different SAI instances.
- Added new APIs:
  - SAI\_TxSetBitClockDirection
  - SAI\_RxSetBitClockDirection
  - SAI\_RxSetFrameSyncDirection
  - SAI\_TxSetFrameSyncDirection

#### [2.1.8]

- Improvements
  - Added feature macro test for the sync mode2 and mode 3.
  - Added feature macro test for masterClockHz in sai\_transfer\_format\_t.

# [2.1.7]

- Improvements
  - Added feature macro test for the mclkSource member in sai\_config\_t.
  - Changed "FSL\_FEATURE\_SAI5\_SAI6\_SHARE\_IRQ" to "FSL\_FEATURE\_SAI\_SAI5\_SAI6\_SHARE\_IRQ".
  - Added #ifndef #endif check for SAI\_XFER\_QUEUE\_SIZE to allow redefinition.
- Bug Fixes
  - Fixed build error caused by feature macro test for mclkSource.

# [2.1.6]

- Improvements
  - Added feature macro test for mclkSourceClockHz check.
  - Added bit clock source name for general devices.
- Bug Fixes
  - Fixed incorrect channel numbers setting while calling RX/TX set format together.

# [2.1.5]

- Bug Fixes
  - Corrected SAI3 driver IRQ handler name.
  - Added I2S4/5/6 IRQ handler.
  - Added base in handler structure to support different instances sharing one IRQ number.
- New Features
  - Updated SAI driver for MCR bit MICS.
  - Added 192 KHZ/384 KHZ in the sample rate enumeration.
  - Added multi FIFO interrupt/SDMA transfer support for TX/RX.
  - Added an API to read/write multi FIFO data in a blocking method.
  - Added bclk bypass support when bclk is same with mclk.

# [2.1.4]

- New Features
  - Added an API to enable/disable auto FIFO error recovery in platforms that support this feature.
  - Added an API to set data packing feature in platforms which support this feature.

# [2.1.3]

- New Features
  - Added feature to make I2S frame sync length configurable according to bitWidth.

# [2.1.2]

- Bug Fixes
  - Added 24-bit support for SAI eDMA transfer. All data shall be 32 bits for send/receive, as eDMA cannot directly handle 3-Byte transfer.

#### [2.1.1]

- Improvements
  - Reduced code size while not using transactional API.

#### [2.1.0]

- Improvements
  - API name changes:
    - \* SAI\_GetSendRemainingBytes -> SAI\_GetSentCount.
    - \* SAI\_GetReceiveRemainingBytes -> SAI\_GetReceivedCount.
    - \* All names of transactional APIs were added with "Transfer" prefix.
    - \* All transactional APIs use base and handle as input parameter.
    - \* Unified the parameter names.

- Bug Fixes
  - Fixed WLC bug while reading TCSR/RCSR registers.
  - Fixed MOE enable flow issue. Moved MOE enable after MICS settings in SAI\_TxInit/SAI\_RxInit.

#### [2.0.0]

• Initial version.

#### SAI\_EDMA

#### [2.7.3]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.1, 10.3, 10.4, 10.5, 10.6, 10.7, 10.8, 12.4.

#### [2.7.2]

- Improvements
  - Add macros MCUX\_SDK\_SAI\_EDMA\_TX\_ENABLE\_INTERNAL and MCUX\_SDK\_SAI\_EDMA\_RX\_ENABLE\_INTERNAL to let the user decide whether to enable SAI when calling SAI\_TransferSendEDMA/SAI\_TransferReceiveEDMA.

#### [2.7.1]

- Improvements
  - Add EDMA ext API to accommodate more types of EDMA.

#### [2.7.0]

- Improvements
  - Updated api SAI\_TransferReceiveEDMA to support voice channel block interleave transfer.
  - Updated api SAI\_TransferSendEDMA to support voice channel block interleave transfer.
  - Added new api SAI\_TransferSetInterleaveType to support channel interleave type configurations.

#### [2.6.0]

- Improvements
  - Removed deprecated APIs.

#### [2.5.1]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 20.7.

#### [2.5.0]

- Improvements
  - Added new api SAI\_TransferSendLoopEDMA/SAI\_TransferReceiveLoopEDMA to support loop transfer.
  - Added multi sai channel transfer support.

#### [2.4.0]

- Improvements
  - Added new api SAI\_TransferGetValidTransferSlotsEDMA which can be used to get valid transfer slot count in the sai edma transfer queue.
  - Deprecated the api SAI\_TransferRxSetFormatEDMA and SAI\_TransferTxSetFormatEDMA.
- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.3,10.4.

#### [2.3.2]

• Refer SAI driver change log 2.1.0 to 2.3.2

#### SAR\_ADC

#### [2.3.0]

- New Feature
  - Added new feature macro a for compatibility with ADCs on some platforms where some instances do not support group3.

#### [2.2.0]

- New Feature
  - Added new features to compatible with new platforms.

#### [2.1.1]

- Improvement
  - Change ADC sample rate phase duration default value from 0x08 to 0x14.

#### [2.1.0]

- New Feature
  - Added ADC\_StopConvChain function to support stop scan in normal conversion scan operation mode.

#### [2.0.3]

- Bug Fixes
  - Fixed the array name usage error in function ADC\_GetInstance.

#### [2.0.2]

- Bug Fixes
  - Fixed MISRA issues.

## [2.0.1]

- Bug Fixes
  - Fixed the bug that when calling function ADC\_EnableWdgThresholdInt() in function ADC\_SetAnalogWdgConfig(), the parameter was passed incorrectly.

#### [2.0.0]

• Initial version.

#### SEMA42

#### [2.1.0]

- New Features
  - Added SEMA42\_BUSY\_POLL\_COUNT parameter to prevent infinite polling loops in SEMA42 operations.
  - Added timeout mechanism to all polling loops in SEMA42 driver code.
- Improvements
  - Updated SEMA42\_Lock function to return status\_t instead of void for better error handling.
  - Enhanced documentation to clarify timeout behavior and return values.

## [2.0.4]

- Improvements
  - Release peripheral from reset if necessary in init function.

#### [2.0.3]

- Improvements
  - Changed to implement SEMA42\_Lock base on SEMA42\_TryLock.

#### [2.0.2]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 17.7.

#### [2.0.1]

- Bug Fixes
  - Fixed violations of the MISRA C-2012 rules 10.3, 10.4, 14.4, 18.1.

#### [2.0.0]

• Initial version.

## SFA

# [2.1.3]

- Improvements
  - Add timeout for APIs with dfmea issues.

# [2.1.2]

- Improvements
  - Updated SFA\_ClearStatusFlag() function to support clearing all status flags.

# [2.1.1]

- Improvements
  - Updated SFA driver code to reduce code redundancy.
  - Updated the use of macros in the driver code to enable the CUT pin function.

### [2.1.0]

- Improvements
  - Updated how the clock frequency under test is calculated.
  - Supported configuration reference clock source.
  - Added clock count limit APIs.
  - Added macros to support fields that are configurable in different instances.

#### [2.0.1]

- Bug Fixes
  - Fixed the issue in SFA\_Mode0Calculate function.
- Improvements
  - For the devices that support RF SFA, cast the peripheral structure to SFA\_Type.

#### [2.0.0]

• Initial version.

# SINC

# [2.1.5]

- Bug Fixes
  - Fixed building warning.

# [2.1.4]

- Bug Fixes
  - Fixed building issue.

# [2.1.3]

- Bug Fixes
  - Fixed function 'SINC\_SetChannelProtectionOption' logic operation error.

# [2.1.2]

- Bug Fixes
  - Fixed the typo issue of missing character 'U' in the feature macro 'FSL\_FEATRE\_SINC\_CACFR\_HAS\_NO\_PTMUX'.

# [2.1.1]

- Bug Fixes
  - Fixed MISRA C-2012 rule 10.4 and 10.8 issues.

# [2.1.0]

- Improvements
  - Added support for chips that each instance equipped with 5 channels.

# [2.0.2]

- Improvements
  - Added comments for over sample ratio.

# [2.0.1]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 15.6, 10.4, 10.1, 10.3 and 10.7.

# [2.0.0]

• Initial version.

#### SRAMCTL

# [3.0.0]

• Initial version.

#### TPM

#### [2.3.5]

- New Feature
  - Added IRQ handler entry for TPM2.

#### [2.3.4]

- New Feature
  - Added common IRQ handler entry TPM\_DriverIRQHandler.

#### [2.3.3]

- Improvements
  - Conditionally compile interrupt handling code to solve the problem of using this driver on CPU cores that do not support interrupts.

#### [2.3.2]

- Bug Fixes
  - Fixed ERR008085 TPM writing the TPMx\_MOD or TPMx\_CnV registers more than once may fail when the timer is disabled.

#### [2.3.1]

- Bug Fixes
  - Fixed compilation error when macro FSL\_SDK\_DISABLE\_DRIVER\_CLOCK\_CONTROL is 1.

#### [2.3.0]

- Improvements
  - Create callback feature for TPM match and timer overflow interrupts.

#### [2.2.4]

- Improvements
  - Add feature macros(FSL\_FEATURE\_TPM\_HAS\_GLOBAL\_TIME\_BASE\_EN, FSL\_FEATURE\_TPM\_HAS\_GLOBAL\_TIME\_BASE\_SYNC).

#### [2.2.3]

- Improvements
  - Release peripheral from reset if necessary in init function.

#### [2.2.2]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.4.

# [2.2.1]

- Bug Fixes
  - Fixed CCM issue by splitting function from TPM\_SetupPwm() function to reduce function complexity.
  - Fixed violations of MISRA C-2012 rule 17.7.

# [2.2.0]

- Improvements
  - Added TPM\_SetChannelPolarity to support select channel input/output polarity.
  - Added TPM\_EnableChannelExtTrigger to support enable external trigger input to be used by channel.
  - Added TPM\_CalculateCounterClkDiv to help calculates the counter clock prescaler.
  - Added TPM\_GetChannelValue to support get TPM channel value.
  - Added new TPM configuration.
    - \* syncGlobalTimeBase
    - \* extTriggerPolarity
    - \* chnlPolarity
  - Added new PWM signal configuration.
    - \* secPauseLevel
- Bug Fixes
  - Fixed TPM\_SetupPwm can't configure 0% combined PWM issues.

# [2.1.1]

- Improvements
  - Add feature macro for PWM pause level select feature.

# [2.1.0]

- Improvements
  - Added TPM\_EnableChannel and TPM\_DisableChannel APIs.
  - Added new PWM signal configuration.
    - \* pauseLevel Support select output level when counter first enabled or paused.
    - \* enableComplementary Support enable/disable generate complementary PWM signal.
    - \* deadTimeValue Support deadtime insertion for each pair of channels in combined PWM mode.
- Bug Fixes
  - Fixed issues about channel MSnB:MSnA and ELSnB:ELSnA bit fields and CnV register change request acknowledgement. Writes to these bits are ignored when the interval between successive writes is less than the TPM clock period.

#### [2.0.8]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.1, 10.4, 10.7 and 14.4.

# [2.0.7]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rule 10.4 and 17.7.

# [2.0.6]

- Bug Fixes
  - Fixed Out-of-bounds issue.

# [2.0.5]

- Bug Fixes
  - Fixed MISRA-2012 rules.
    - \* Rule 10.6, 10.7

# [2.0.4]

- Bug Fixes
  - Fixed ERR050050 in functions TPM\_SetupPwm/TPM\_UpdatePwmDutycycle. When TPM was configured in EPWM mode as PS = 0, the compare event was missed on the first reload/overflow after writing 1 to the CnV register.

# [2.0.3]

- Bug Fixes
  - MISRA-2012 issue fixed.
    - \* Fixed rules: rule-12.1, rule-17.7, rule-16.3, rule-14.4, rule-1.3, rule-10.4, rule-10.3, rule-10.7, rule-10.1, rule-10.6, and rule-18.1.

#### [2.0.2]

- Bug Fixes
  - Fixed issues in functions TPM\_SetupPwm/TPM\_UpdateChnlEdgeLevelSelect /TPM\_SetupInputCapture/TPM\_SetupOutputCompare/TPM\_SetupDualEdgeCapture, wait acknowledgement when the channel is disabled.

# [2.0.1]

- Bug Fixes
  - Fixed TPM\_UpdateChnIEdgeLevelSelect ACK wait issue.
  - Fixed the issue that TPM\_SetupdualEdgeCapture could not set FILTER register.
  - Fixed TPM\_UpdateChnEdgeLevelSelect ACK wait issue.

#### [2.0.0]

• Initial version.

# TRDC

# [2.3.0]

- New Features
  - Added API TRDC\_EnableProcessorDomainAssignment to disable/enable DAC.
- Bug Fixes
  - Fixed MISRA violation of missing function declaration.
  - Fixed wrong operation of domain mask in TRDC\_MbcNseClearAll and TRDC\_MrcDomainNseClear.

# [2.2.1]

- Bug Fixes
  - Fixed MISRA violations of rule 10.3.

# [2.2.0]

- New Features
  - Added new APIs to support SoC with more than one processor core.

#### [2.1.1]

- Bug Fixes
  - Fixed MISRA violations of rule 10.3, 10.6, 10.7 and 18.1.

#### [2.1.0]

- Improvements
  - Modified some of the addressing method according to the device header file's update.
  - Modified flash address configuration structure and default setting.
- New Features
  - Added API to set flash logic window array address.
- Bug Fixes
  - Fixed wrong return value of TRDC\_GetFlashLogicalWindowPbase.
  - Fixed bug in TRDC\_GetAndClearFirstSpecificDomainError that the error status is cleared by mistake before obtained by software.
  - Fixed MISRA violations of rule 10.3, 10.4, 10.6 and 10.8.

# [2.0.0]

• Initial version.

#### TSTMR

#### [2.0.2]

- Improvements
  - Support 24MHz clock source.
- Bugfix
  - Fix MISRA C-2012 Rule 10.4 issue.
  - Read of TSTMR HIGH must follow TSTMR LOW atomically: require masking interrupt around 2 LSB / MSB accesses.

#### [2.0.1]

- Bugfix
  - Restrict to read with 32-bit accesses only.
  - Restrict that TSTMR LOW read occurs first, followed by the TSTMR HIGH read.

#### [2.0.0]

• Initial version.

## XBAR

#### [2.1.2]

• Correct bits of SEL registers

# [2.1.1]

• Fix wrong offset of ctrl registers

# [2.1.0]

• unify bit fields width for xbar instance index and xbar input/output signal index.

#### [2.0.4]

- Improvements
  - Rename feature macro name.

#### [2.0.3]

- Improvements
  - Improved to support 32-bit width peripheral.

### [2.0.2]

- Bug Fixes
  - Fixed MISRA C-2012 violations.

#### [2.0.1]

- Bug Fixes
  - Fixed the xbar instance base offset error.

# [2.0.0]

• Initial version.

# XSPI

# [2.5.1]

- Improvements
  - Updated default value of sfpArbitrationLockTimeoutValue and ipAccessTimeoutValue to 0xFFFFFFFUL.
  - Added #if defined(CACHE64\_CTRL0\_BASE) ... #endif section to support some devices that do not support CACHE64.

# [2.5.0]

- Improvements
  - Updated XSPI\_TransferBlocking() to support use case the transfersize bigger than page size.
  - Updated xspi\_device\_interface\_type\_t to support changes of page size for hyperram interface.
  - Updated XSPI\_ReadBlocking() to fix an potential issue which cause TIMEOUT error.

# [2.4.0]

- New Features
  - Added functions of control cache64.

#### [2.3.0]

- Improvements
  - Added new interface: XSPI\_StartIpAccessNonBlocking();
  - Provied driver Irq handler for xspi driver;
  - Use ERRSTAT[ARB\_WIN] to replace FSMSTAT[VLD].

#### [2.2.1]

- Improvements
  - Moved some frequently used variables(s\_tgSfarsRegOffset, s\_tgIpcrsRegOffset, s\_sfpTgIpcrRegOffset, s\_sfpTgIpSfarRegOffset, s\_tgMdadRegOffset) to common code to offload of stack.
  - Added return status in case of timeout flag asserted during IP read access.
- Bug Fixes

- Fixed violations of MISRA C-2012 rules.

#### [2.2.0]

- Improvements
  - Improved xspi\_device\_config\_t structure, removed some not-device related members.
  - Improved xspi\_config\_t structure, removed some device related settings.
  - Renamed XSPI\_SetFlashConfig() to XSPI\_SetDeviceConfig().
  - Decoupled settings of IP access, AHB access.
  - Added low-level interfaces to support IP access(including SFP), and AHB access(including performance monitor).

# [2.1.0]

- Bug Fixes
  - Fixed issue of XSPI\_Init() function, set MCR[MDIS] to disable clocks before settings of MCR register.
  - Unused deviceConfig in XSPI\_GetDefaultConfig() function.
- Improvements
  - Updated structure for dllconfig, added method to allow user custom dll parameters.
  - Updated XSPI\_UpdateDllValue() function to align with changes of dllconfig.
  - Move device specific value to device feature file.

#### [2.0.1]

- Bug Fixes
  - Fixed the XSPI DLL function.
  - Added ALIGN and X16Mode macro definition in driver.
  - updated XSPI PSRAM example.

#### [2.0.0]

• Initial version.

#### **XSPI EDMA Driver**

#### [2.0.2]

- Bug Fixes
  - Fixed violations of MISRA C-2012 rules.

#### [2.0.1]

- Improvements
  - Invoked new defined interface of xspi driver.
  - In callback function, disable RX/TX DMA.

#### [2.0.0]

• Initial version.

# 1.6 Driver API Reference Manual

This section provides a link to the Driver API RM, detailing available drivers and their usage to help you integrate hardware efficiently.

MIMX94398\_drivers

# **1.7 Middleware Documentation**

Find links to detailed middleware documentation for key components. While not all onboard middleware is covered, this serves as a useful reference for configuration and development.

# 1.7.1 Multicore

multicore

# 1.7.2 FreeMASTER

freemaster

# 1.7.3 FreeRTOS

**FreeRTOS** 

1.7.4 lwIP

lwip

# **Chapter 2**

# Drivers

The following is a list of the Driver API Reference Manuals categorized by device series.

- 2.1 DSC
- 2.2 i.MX
- 2.3 i.MX RT
- 2.4 Kinetis
- 2.5 LPC
- 2.6 MCX
- 2.7 Wireless

# **Chapter 3**

# **Middleware**

# 3.1 Motor Control

# 3.1.1 FreeMASTER

Communication Driver User Guide

#### Introduction

**What is FreeMASTER?** FreeMASTER is a PC-based application developed by NXP for NXP customers. It is a versatile tool usable as a real-time monitor, visualization tool, and a graphical control panel of embedded applications based on the NXP processing units.

This document describes the embedded-side software driver which implements an interface between the application and the host PC. The interface covers the following communication:

- **Serial** UART communication either over plain RS232 interface or more typically over a USB-to-Serial either external or built in a debugger probe.
- USB direct connection to target microcontroller
- CAN bus
- TCP/IP network wired or WiFi
- Segger J-Link RTT
- JTAG debug port communication
- ...and all of the above also using a **Zephyr** generic drivers.

The driver also supports so-called "packet-driven BDM" interface which enables a protocol-based communication over a debugging port. The BDM stands for Background Debugging Module and its physical implementation is different on each platform. Some platforms leverage a semi-standard JTAG interface, other platforms provide a custom implementation called BDM. Regardless of the name, this debugging interface enables non-intrusive access to the memory space while the target CPU is running. For basic memory read and write operations, there is no communication driver required on the target when communicating with the host PC. Use this driver to get more advanced FreeMASTER protocol features over the BDM interface. The driver must be configured for the packet-driven BDM mode, in which the host PC uses the debugging interface to write serial command frames directly to the target memory buffer. The same method is then used to read response frames from that memory buffer.

Similar to "packet-driven BDM", the FreeMASTER also supports a communication over [J-Link RTT]((https://www.segger.com/products/debug-probes/j-link/technology/about-real-time-transfer/) interface defined by SEGGER Microcontroller GmbH for ARM CortexM-based micro-controllers. This method also uses JTAG physical interface and enables high-speed real time communication to run over the same channel as used for application debugging.

**Driver version 3** This document describes version 3 of the FreeMASTER Communication Driver. This version features the implementation of the new Serial Protocol, which significantly extends the features and security of its predecessor. The new protocol internal number is v4 and its specification is available in the documentation accompanying the driver code.

Driver V3 is deployed to modern 32-bit MCU platforms first, so the portfolio of supported platforms is smaller than for the previous V2 versions. It is recommended to keep using the V2 driver for legacy platforms, such as S08, S12, ColdFire, or Power Architecture. Reach out to FreeMAS-TER community or to the local NXP representative with requests for more information or to port the V3 driver to legacy MCU devices.

Thanks to a layered approach, the new driver simplifies the porting of the driver to new UART, CAN or networking communication interfaces significantly. Users are encouraged to port the driver to more NXP MCU platforms and contribute the code back to NXP for integration into future releases. Existing code and low-level driver layers may be used as an example when porting to new targets.

**Note:** Using the FreeMASTER tool and FreeMASTER Communication Driver is only allowed in systems based on NXP microcontroller or microprocessor unit. Use with non-NXP MCU platforms is **not permitted** by the license terms.

**Target platforms** The driver implementation uses the following abstraction mechanisms which simplify driver porting and supporting new communication modules:

- **General CPU Platform** (see source code in the src/platforms directory). The code in this layer is only specific to native data type sizes and CPU architectures (for example; alignment-aware memory copy routines). This driver version brings two generic implementations of 32-bit platforms supporting both little-endian and big-endian architectures. There are also implementations customized for the 56F800E family of digital signal controllers and S12Z MCUs. **Zephyr** is treated as a specific CPU platform as it brings unified user configuration (Kconfig) and generic hardware device drivers. With Zephyr, the transport layer and low-level communication layers described below are configured automatically using Kconfig and Device Tree technologies.
- **Transport Communication Layer** The Serial, CAN, Networking, PD-BDM, and other methods of transport logic are implemented as a driver layer called FMSTR\_TRANSPORT with a uniform API. A support of the Network transport also extends single-client modes of operation which are native for Serial, USB and CAN by a concept of multiple client sessions.
- Low-level Communication Driver Each type of transport further defines a low-level API used to access the physical communication module. For example, the Serial transport defines a character-oriented API implemented by different serial communication modules like UART, LPUART, USART, and also USB-CDC. Similarly, the CAN transport defines a message-oriented API implemented by the FlexCAN or MCAN modules. Moreover, there are multiple different implementations for the same kind of communication peripherals. The difference between the implementation is in the way the low-level hardware registers are accessed. The *mcuxsdk* folder contains implementations which use MCUXpresso SDK drivers. These drivers should be used in applications based on the NXP MCUXpresso SDK. The "ampsdk" drivers target automotive-specific MCUs and their respective SDKs. The "dreg" implementations use a plain C-language access to hardware register addresses which makes it a universal and the most portable solution. In this case, users are encouraged to add more drivers for other communication modules or other respective SDKs and contribute the code back to NXP for integration.

The low-level drivers defined for the Networking transport enable datagram-oriented UDP and stream TCP communication. This implementation is demonstrated using the lwIP software stack but shall be portable to other TCP/IP stacks. It may sound surprisingly, but also the Segger J-Link RTT communication driver is linked to the Networking transport (RTT is stream oriented communication handled similarly to TCP).

**Replacing existing drivers** For all supported platforms, the driver described in this document replaces the V2 implementation and also older driver implementations that were available separately for individual platforms (PC Master SCI drivers).

**Clocks, pins, and peripheral initialization** The FreeMASTER communication driver is only responsible for runtime processing of the communication and must be integrated with an user application code to function properly. The user application code is responsible for general initialization of clock sources, pin multiplexers, and peripheral registers related to the communication speed. Such initialization should be done before calling the FMSTR\_Init function.

It is recommended to develop the user application using one of the Software Development Kits (SDKs) available from third parties or directly from NXP, such as MCUXpresso SDK, MCUXpresso IDE, and related tools. This approach simplifies the general configuration process significantly.

**MCUX presso SDK** The MCUX presso SDK is a software package provided by NXP which contains the device initialization code, linker files, and software drivers with example applications for the NXP family of MCUs. The MCUX presso Config Tools may be used to generate the clock-setup and pin-multiplexer setup code suitable for the selected processor.

The MCUXpresso SDK also contains this FreeMASTER communication driver as a "middleware" component which may be downloaded along with the example applications from https: //mcuxpresso.nxp.com/en/welcome.

**MCUXpresso SDK on GitHub** The FreeMASTER communication driver is also released as one of the middleware components of the MCUXpresso SDK on the GitHub. This release enables direct integration of the FreeMASTER source code Git repository into a target applications including Zephyr applications.

Related links:

- The official FreeMASTER middleware repository.
- Online version of this document

**FreeMASTER in Zephyr** The FreeMASTER middleware repository can be used with MCUXpresso SDK as well as a Zephyr module. Zephyr-specific samples which include examples of Kconfig and Device Tree configurations for Serial, USB and Network communications are available in separate repository. West manifest in this sample repository fetches the full Zephyr package including the FreeMASTER middleware repository used as a Zephyr module.

#### **Example applications**

**MCUX SDK Example applications** There are several example applications available for each supported MCU platform.

• **fmstr\_uart** demonstrates a plain serial transmission, typically connecting to a computer's physical or virtual COM port. The typical transmission speed is 115200 bps.

- **fmstr\_can** demonstrates CAN bus communication. This requires a suitable CAN interface connected to the computer and interconnected with the target MCU using a properly terminated CAN bus. The typical transmission speed is 500 kbps. A FreeMASTER-over-CAN communication plug-in must be used.
- **fmstr\_usb\_cdc** uses an on-chip USB controller to implement a CDC communication class. It is connected directly to a computer's USB port and creates a virtual COM port device. The typical transmission speed is above 1 Mbps.
- **fmstr\_net** demonstrates the Network communication over UDP or TCP protocol. Existing examples use lwIP stack to implement the communication, but in general, it shall be possible to use any other TCP/IP stack to achieve the same functionality.
- **fmstr\_wifi** is the fmstr\_net application modified to use a WiFi network interface instead of a wired Ethernet connection.
- **fmstr\_rtt** demonstrates the communication over SEGGER J-Link RTT interface. Both fmstr\_net and fmstr\_rtt examples require the FreeMASTER TCP/UDP communication plug-in to be used on the PC host side.
- **fmstr\_eonce** uses the real-time data unit on the JTAG EOnCE module of the 56F800E family to implement pseudo-serial communication over the JTAG port. The typical transmission speed is around 10 kbps. This communication requires FreeMASTER JTAG/EOnCE communication plug-in.
- **fmstr\_pdbdm** uses JTAG or BDM debugging interface to access the target RAM directly while the CPU is running. Note that such approach can be used with any MCU application, even without any special driver code. The computer reads from and writes into the RAM directly without CPU intervention. The Packet-Driven BDM (PD-BDM) communication uses the same memory access to exchange command and response frames. With PD-BDM, the FreeMASTER tool is able to go beyond basic memory read/write operations and accesses also advanced features like Recorder, TSA, or Pipes. The typical transmission speed is around 10 kbps. A PD-BDM communication plug-in must be used in FreeMASTER and configured properly for the selected debugging interface. Note that this communication cannot be used while a debugging interface is used by a debugger session.
- **fmstr\_any** is a special example application which demonstrates how the NXP MCUXpresso Config Tools can be used to configure pins, clocks, peripherals, interrupts, and even the FreeMASTER "middleware" driver features in a graphical and user friendly way. The user can switch between the Serial, CAN, and other ways of communication and generate the required initialization code automatically.

**Zephyr sample spplications** Zephyr sample applications demonstrate Kconfig and Device Tree configuration which configure the FreeMASTER middleware module for a selected communication option (Serial, CAN, Network or RTT).

Refer to *readme.md* files in each sample directory for description of configuration options required to implement FreeMASTER connectivity.

#### Description

This section shows how to add the FreeMASTER Communication Driver into application and how to configure the connection to the FreeMASTER visualization tool.

**Features** The FreeMASTER driver implements the FreeMASTER protocol V4 and provides the following features which may be accessed using the FreeMASTER visualization tool:

- Read/write access to any memory location on the target.
- Optional password protection of the read, read/write, and read/write/flash access levels.

- Atomic bit manipulation on the target memory (bit-wise write access).
- Optimal size-aligned access to memory which is also suitable to access the peripheral register space.
- Oscilloscope access—real-time access to target variables. The sample rate may be limited by the communication speed.
- Recorder— access to the fast transient recorder running on the board as a part of the FreeMASTER driver. The sample rate is only limited by the MCU CPU speed. The length of the data recorded depends on the amount of available memory.
- Multiple instances of Oscilloscopes and Recorders without the limitation of maximum number of variables.
- Application commands—high-level message delivery from the PC to the application.
- TSA tables—describing the data types, variables, files, or hyperlinks exported by the target application. The TSA newly supports also non-memory mapped resources like external EEPROM or SD Card files.
- Pipes—enabling the buffered stream-oriented data exchange for a general-purpose terminal-like communication, diagnostic data streaming, or other data exchange.

The FreeMASTER driver features:

- Full FreeMASTER protocol V4 implementation with a new V4 style of CRC used.
- Layered approach supporting Serial, CAN, Network, PD-BDM, and other transports.
- Layered low-level Serial transport driver architecture enabling to select UART, LPUART, USART, and other physical implementations of serial interfaces, including USB-CDC.
- Layered low-level CAN transport driver architecture enabling to select FlexCAN, msCAN, MCAN, and other physical implementations of the CAN interface.
- Layered low-level Networking transport enabling to select TCP, UDP or J-Link RTT communication.
- TSA support to write-protect memory regions or individual variables and to deny the access to the unsafe memory.
- The pipe callback handlers are invoked whenever new data is available for reading from the pipe.
- Two Serial Single-Wire modes of operation are enabled. The "external" mode has the RX and TX shorted on-board. The "true" single-wire mode interconnects internally when the MCU or UART modules support it.

The following sections briefly describe all FreeMASTER features implemented by the driver. See the PC-based FreeMASTER User Manual for more details on how to use the features to monitor, tune, or control an embedded application.

**Board Detection** The FreeMASTER protocol V4 defines the standard set of configuration values which the host PC tool reads to identify the target and to access other target resources properly. The configuration includes the following parameters:

- Version of the driver and the version of the protocol implemented.
- MTU as the Maximum size of the Transmission Unit (for example; communication buffer size).
- Application name, description, and version strings.
- Application build date and time as a string.
- Target processor byte ordering (little/big endian).
- Protection level that requires password authentication.

- Number of the Recorder and Oscilloscope instances.
- RAM Base Address for optimized memory access commands.

**Memory Read** This basic feature enables the host PC to read any data memory location by specifying the address and size of the required memory area. The device response frame must be shorter than the MTU to fit into the outgoing communication buffer. To read a device memory of any size, the host uses the information retrieved during the Board Detection and splits the large-block request to multiple partial requests.

The driver uses size-aligned operations to read the target memory (for example; uses proper read-word instruction when an address is aligned to 4 bytes).

**Memory Write** Similarly to the Memory Read operation, the Memory Write feature enables to write to any RAM memory location on the target device. A single write command frame must be shorter than the MTU to fit into the target communication buffer. Larger requests must be split into smaller ones.

The driver uses size-aligned operations to write to the target memory (for example; uses proper write-word instruction when an address is aligned to 4 bytes).

**Masked Memory Write** To implement the write access to a single bit or a group of bits of target variables, the Masked Memory Write feature is available in the FreeMASTER protocol and it is supported by the driver using the Read-Modify-Write approach.

Be careful when writing to bit fields of volatile variables that are also modified in an application interrupt. The interrupt may be serviced in the middle of a read-modify-write operation and it may cause data corruption.

**Oscilloscope** The protocol and driver enables any number of variables to be read at once with a single request from the host. This feature is called Oscilloscope and the FreeMASTER tool uses it to display a real-time graph of variable values.

The driver can be configured to support any number of Oscilloscope instances and enable simultaneously running graphs to be displayed on the host computer screen.

**Recorder** The protocol enables the host to select target variables whose values are then periodically recorded into a dedicated on-board memory buffer. After such data sampling stops (either on a host request or by evaluating a threshold-crossing condition), the data buffer is downloaded to the host and displayed as a graph. The data sampling rate is not limited by the speed of the communication line, so it enables displaying the variable transitions in a very high resolution.

The driver can be configured to support multiple Recorder instances and enable multiple recorder graphs to be displayed on the host screen. Having multiple recorders also enables setting the recording point differently for each instance. For example; one instance may be recording data in a general timer interrupt while another instance may record at a specific control algorithm time in the PWM interrupt.

**TSA** With the TSA feature, data types and variables can be described directly in the application source code. Such information is later provided to the FreeMASTER tool which may use it instead of reading symbol data from the application ELF executable file.

The information is encoded as so-called TSA tables which become direct part of the application code. The TSA tables contain descriptors of variables that shall be visible to the host tool. The descriptors can describe the memory areas by specifying the address and size of the memory

block or more conveniently using the C variable names directly. Different set of TSA descriptors can be used to encode information about the structure types, unions, enumerations, or arrays.

The driver also supports special types of TSA table entries to describe user resources like external EEPROM and SD Card files, memory-mapped files, virtual directories, web URL hyperlinks, and constant enumerations.

**TSA Safety** When the TSA is enabled in the application, the TSA Safety can be enabled and validate the memory accesses directly by the embedded-side driver. When the TSA Safety is turned on, any memory request received from the host is validated and accepted only if it belongs to a TSA-described object. The TSA entries can be declared as Read-Write or Read-Only so that the driver can actively deny the write access to the Read-Only objects.

**Application commands** The Application Commands are high-level messages that can be delivered from the PC Host to the embedded application for further processing. The embedded application can either poll the status, or be called back when a new Application Command arrives to be processed. After the embedded application acknowledges that the command is handled, the host receives the Result Code and reads the other return data from memory. Both the Application Commands and the Result Codes are specific to a given application and it is user's responsibility to define them. The FreeMASTER protocol and the FreeMASTER driver only implement the delivery channel and a set of API calls to enable the Application Command processing in general.

**Pipes** The Pipes enable buffered and stream-oriented data exchange between the PC Host and the target application. Any pipe can be written to and read from at both ends (either on the PC or the MCU). The data transmission is acknowledged using the special FreeMASTER protocol commands. It is guaranteed that the data bytes are delivered from the writer to the reader in a proper order and without losses.

**Serial single-wire operation** The MCU Serial Communication Driver natively supports normal dual-wire operation. Because the protocol is half-duplex only, the driver can also operate in two single-wire modes:

- "External" single-wire operation where the Receiver and Transmitter pins are shorted on the board. This mode is supported by default in the MCU driver because the Receiver and Transmitter units are enabled or disabled whenever needed. It is also easy to extend this operation for the RS485 communication.
- "True" single-wire mode which uses only a single pin and the direction switching is made by the UART module. This mode of operation must be enabled by defining the FM-STR\_SERIAL\_SINGLEWIRE configuration option.

**Multi-session support** With networking interface it is possible for multiple clients to access the target MCU simultaneously. Reading and writing of target memory is processed atomically so there is no risk of data corruption. The state-full resources such as Recorders or Oscilloscopes are locked to a client session upon first use and access is denied to other clients until lock is released..

Zephyr-specific

**Dedicated communication task** FreeMASTER communication may run isolated in a dedicated task. The task automates the FMSTR\_Init and FMSTR\_Poll calls together with periodic activities enabling the FreeMASTER UI to fetch information about tasks and CPU utilization. The task can be started automatically or manually, and it must be assigned a priority to be able to react on interrupts and other communication events. Refer to Zephyr FreeMASTER sample applications which all use this communication task.

**Zephyr shell and logging over FreeMASTER pipe** FreeMASTER implements a shell backend which may use FreeMASTER pipe as a I/O terminal and logging output. Refer to Zephyr FreeMASTER sample applications which all use this feature.

**Automatic TSA tables** TSA tables can be declared as "automatic" in Zephyr which make them automatically registered in the table list. This may be very useful when there are many TSA tables or when the tables are defined in different (often unrelated) libraries linked together. In this case user does not need to build a list of all tables manually.

**Driver files** The driver source files can be found in a top-level src folder, further divided into the sub-folders:

- *src/platforms* platform-specific folder—one folder exists for each supported processor platform (for example; 32-bit Little Endian platform). Each such folder contains a platform header file with data types and a code which implements the potentially platform-specific operations, such as aligned memory access.
- *src/common* folder—contains the common driver source files shared by the driver for all supported platforms. All the *.c* files must be added to the project, compiled, and linked together with the application.
  - *freemaster.h -* master driver header file, which declares the common data types, macros, and prototypes of the FreeMASTER driver API functions.
  - freemaster\_cfg.h.example this file can serve as an example of the FreeMASTER driver configuration file. Save this file into a project source code folder and rename it to freemaster\_cfg.h. The FreeMASTER driver code includes this file to get the projectspecific configuration options and to optimize the compilation of the driver.
  - *freemaster\_defcfg.h* defines the default values for each FreeMASTER configuration option if the option is not set in the *freemaster\_cfg.h* file.
  - *freemaster\_protocol.h* defines the FreeMASTER protocol constants used internally by the driver.
  - *freemaster\_protocol.c* implements the FreeMASTER protocol decoder and handles the basic Get Configuration Value, Memory Read, and Memory Write commands.
  - *freemaster\_rec.c* handles the Recorder-specific commands and implements the Recorder sampling and triggering routines. When the Recorder is disabled by the FreeMASTER driver configuration file, this file only compiles to empty API functions.
  - *freemaster\_scope.c* handles the Oscilloscope-specific commands. If the Oscilloscope is disabled by the FreeMASTER driver configuration file, this file compiles as void.
  - *freemaster\_pipes.c* implements the Pipes functionality when the Pipes feature is enabled.
  - *freemaster\_appcmd.c* handles the communication commands used to deliver and execute the Application Commands within the context of the embedded application. When the Application Commands are disabled by the FreeMASTER driver configuration file, this file only compiles to empty API functions.

- *freemaster\_tsa.c* handles the commands specific to the TSA feature. This feature enables the FreeMASTER host tool to obtain the TSA memory descriptors declared in the embedded application. If the TSA is disabled by the FreeMASTER driver configuration file, this file compiles as void.
- *freemaster\_tsa.h* contains the declaration of the macros used to define the TSA memory descriptors. This file is indirectly included into the user application code (via *freemaster.h*).
- *freemaster\_sha.c* implements the SHA-1 hash code used in the password authentication algorithm.
- *freemaster\_private.h* contains the declarations of functions and data types used internally in the driver. It also contains the C pre-processor statements to perform the compile-time verification of the user configuration provided in the *freemaster\_cfg.h* file.
- *freemaster\_serial.c* implements the serial protocol logic including the CRC, FIFO queuing, and other communication-related operations. This code calls the functions of the low-level communication driver indirectly via a character-oriented API exported by the specific low-level driver.
- *freemaster\_serial.h* defines the low-level character-oriented Serial API.
- *freemaster\_can.c* implements the CAN protocol logic including the CAN message preparation, signalling using the first data byte in the CAN frame, and other communication-related operations. This code calls the functions of the low-level communication driver indirectly via a message-oriented API exported by the specific low-level driver.
- freemaster\_can.h defines the low-level message-oriented CAN API.
- *freemaster\_net.c* implements the Network protocol transport logic including multiple session management code.
- *freemaster\_net.h* definitions related to the Network transport.
- *freemaster\_pdbdm.c* implements the packet-driven BDM communication buffer and other communication-related operations.
- *freemaster\_utils.c* aligned memory copy routines, circular buffer management and other utility functions
- *freemaster\_utils.h* definitions related to utility code.
- *src/drivers/[sdk]/serial* contains the code related to the serial communication implemented using one of the supported SDK frameworks.
  - *freemaster\_serial\_XXX.c* and *.h* implement low-level access to the communication peripheral registers. Different files exist for the UART, LPUART, USART, and other kinds of Serial communication modules.
- *src/drivers/[sdk]/can* contains the code related to the serial communication implemented using one of the supported SDK frameworks.
  - *freemaster\_XXX.c* and *.h* implement low-level access to the communication peripheral registers. Different files exist for the FlexCAN, msCAN, MCAN, and other kinds of CAN communication modules.
- *src/drivers/[sdk]/network* contains low-level code adapting the FreeMASTER Network transport to an underlying TCP/IP or RTT stack.
  - *freemaster\_net\_lwip\_tcp.c* and *\_udp.c* default networking implementation of TCP and UDP transports using lwIP stack.
  - freemaster\_net\_segger\_rtt.c implementation of network transport using Segger J-Link RTT interface

**Driver configuration** The driver is configured using a single header file (*freemaster\_cfg.h*). Create this file and save it together with other project source files before compiling the driver code. All FreeMASTER driver source files include the *freemaster\_cfg.h* file and use the macros defined here for the conditional and parameterized compilation. The C compiler must locate the configuration file when compiling the driver files. Typically, it can be achieved by putting this file into a folder where the other project-specific included files are stored.

As a starting point to create the configuration file, get the *freemaster\_cfg.h.example* file, rename it to *freemaster\_cfg.h*, and save it into the project area.

**Note:** It is NOT recommended to leave the *freemaster\_cfg.h* file in the FreeMASTER driver source code folder. The configuration file must be placed at a project-specific location, so that it does not affect the other applications that use the same driver.

**Configurable items** This section describes the configuration options which can be defined in *freemaster\_cfg.h.* 

#### Interrupt modes

#define FMSTR\_LONG\_INTR [0|1] #define FMSTR\_SHORT\_INTR [0|1] #define FMSTR\_POLL\_DRIVEN [0|1]

Value Type boolean (0 or 1)

**Description** Exactly one of the three macros must be defined to non-zero. The others must be defined to zero or left undefined. The non-zero-defined constant selects the interrupt mode of the driver. See *Driver interrupt modes*.

- FMSTR\_LONG\_INTR long interrupt mode
- FMSTR\_SHORT\_INTR short interrupt mode
- FMSTR POLL DRIVEN poll-driven mode

**Note:** Some options may not be supported by all communication interfaces. For example, the FMSTR\_SHORT\_INTR option is not supported by the USB\_CDC interface.

#### **Protocol transport**

#define FMSTR\_TRANSPORT [identifier]

**Value Type** Driver identifiers are structure instance names defined in FreeMASTER source code. Specify one of existing instances to make use of the protocol transport.

**Description** Use one of the pre-defined constants, as implemented by the FreeMASTER code. The current driver supports the following transports:

- FMSTR\_SERIAL serial communication protocol
- FMSTR\_CAN using CAN communication
- FMSTR\_PDBDM using packet-driven BDM communication
- FMSTR\_NET network communication using TCP or UDP protocol

**Serial transport** This section describes configuration parameters used when serial transport is used:

#define FMSTR\_TRANSPORT FMSTR\_SERIAL

**FMSTR\_SERIAL\_DRV** Select what low-level driver interface will be used when implementing the Serial communication.

#define FMSTR\_SERIAL\_DRV [identifier]

**Value Type** Driver identifiers are structure instance names defined in FreeMASTER drivers code. Specify one of existing serial driver instances.

**Description** When using MCUXpresso SDK, use one of the following constants (see /*drivers/mcuxsdk/serial* implementation):

- **FMSTR\_SERIAL\_MCUX\_UART** UART driver
- FMSTR\_SERIAL\_MCUX\_LPUART LPUART driver
- FMSTR\_SERIAL\_MCUX\_USART USART driver
- FMSTR\_SERIAL\_MCUX\_MINIUSART miniUSART driver
- FMSTR\_SERIAL\_MCUX\_QSCI DSC QSCI driver
- **FMSTR\_SERIAL\_MCUX\_USB** USB/CDC class driver (also see code in the */sup-port/mcuxsdk\_usb* folder)
- FMSTR\_SERIAL\_56F800E\_EONCE DSC JTAG EOnCE driver

Other SDKs or BSPs may define custom low-level driver interface structure which may be used as FMSTR\_SERIAL\_DRV. For example:

• **FMSTR\_SERIAL\_DREG\_UART** - demonstrates the low-level interface implemented without the MCUXpresso SDK and using direct access to peripheral registers.

#### FMSTR\_SERIAL\_BASE

#define FMSTR\_SERIAL\_BASE [address|symbol]

Value Type Optional address value (numeric or symbolic)

**Description** Specify the base address of the UART, LPUART, USART, or other serial peripheral module to be used for the communication. This value is not defined by default. User application should call FMSTR\_SetSerialBaseAddress() to select the peripheral module.

#### FMSTR\_COMM\_BUFFER\_SIZE

#define FMSTR\_COMM\_BUFFER\_SIZE [number]

Value Type 0 or a value in range 32...255

**Description** Specify the size of the communication buffer to be allocated by the driver. Default value, which suits all driver features, is used when this option is defined as 0.

#### FMSTR\_COMM\_RQUEUE\_SIZE

#define FMSTR\_COMM\_RQUEUE\_SIZE [number]

Value Type Value in range 0...255

**Description** Specify the size of the FIFO receiver queue used to quickly receive and store characters in the FMSTR\_SHORT\_INTR interrupt mode. The default value is 32 B.

#### FMSTR\_SERIAL\_SINGLEWIRE

#define FMSTR\_SERIAL\_SINGLEWIRE [0|1]

Value Type Boolean 0 or 1.

**Description** Set to non-zero to enable the "True" single-wire mode which uses a single MCU pin to communicate. The low-level driver enables the pin direction switching when the MCU peripheral supports it.

**CAN Bus transport** This section describes configuration parameters used when CAN transport is used:

#define FMSTR\_TRANSPORT FMSTR\_CAN

**FMSTR\_CAN\_DRV** Select what low-level driver interface will be used when implementing the CAN communication.

#define FMSTR\_CAN\_DRV [identifier]

**Value Type** Driver identifiers are structure instance names defined in FreeMASTER drivers code. Specify one of existing CAN driver instances.

**Description** When using MCUXpresso SDK, use one of the following constants (see /*drivers/mcuxsdk/can implementation*):

- FMSTR\_CAN\_MCUX\_FLEXCAN FlexCAN driver
- FMSTR\_CAN\_MCUX\_MCAN MCAN driver
- FMSTR\_CAN\_MCUX\_MSCAN msCAN driver
- FMSTR\_CAN\_MCUX\_DSCFLEXCAN DSC FlexCAN driver
- FMSTR\_CAN\_MCUX\_DSCMSCAN DSC msCAN driver

Other SDKs or BSPs may define the custom low-level driver interface structure which may be used as FMSTR\_CAN\_DRV.

#### FMSTR\_CAN\_BASE

#define FMSTR\_CAN\_BASE [address|symbol]

Value Type Optional address value (numeric or symbolic)

**Description** Specify the base address of the FlexCAN, msCAN, or other CAN peripheral module to be used for the communication. This value is not defined by default. User application should call FMSTR\_SetCanBaseAddress() to select the peripheral module.

#### FMSTR\_CAN\_CMDID

#define FMSTR\_CAN\_CMDID [number]

Value Type CAN identifier (11-bit or 29-bit number)

**Description** CAN message identifier used for FreeMASTER commands (direction from PC Host tool to target application). When declaring 29-bit identifier, combine the numeric value with FMSTR\_CAN\_EXTID bit. Default value is 0x7AA.

#### FMSTR\_CAN\_RSPID

#define FMSTR\_CAN\_RSPID [number]

Value Type CAN identifier (11-bit or 29-bit number)

**Description** CAN message identifier used for responding messages (direction from target application to PC Host tool). When declaring 29-bit identifier, combine the numeric value with FMSTR\_CAN\_EXTID bit. Note that both *CMDID* and *RSPID* values may be the same. Default value is 0x7AA.

#### FMSTR\_FLEXCAN\_TXMB

#define FMSTR\_FLEXCAN\_TXMB [number]

**Value Type** Number in range of 0..N where N is number of CAN message-buffers supported by HW module.

**Description** Only used when the FlexCAN low-level driver is used. Define the FlexCAN message buffer for CAN frame transmission. Default value is 0.

#### FMSTR\_FLEXCAN\_RXMB

#define FMSTR\_FLEXCAN\_RXMB [number]

**Value Type** Number in range of 0..N where N is number of CAN message-buffers supported by HW module.

**Description** Only used when the FlexCAN low-level driver is used. Define the FlexCAN message buffer for CAN frame reception. Note that the FreeMASTER driver may also operate with a common message buffer used by both TX and RX directions. Default value is 1.

**Network transport** This section describes configuration parameters used when Network transport is used:

#define FMSTR\_TRANSPORT FMSTR\_NET

FMSTR\_NET\_DRV Select network interface implementation.

#define FMSTR\_NET\_DRV [identifier]

**Value Type** Identifiers are structure instance names defined in FreeMASTER drivers code. Specify one of existing NET driver instances.

**Description** When using MCUXpresso SDK, use one of the following constants (see /drivers/mcuxsdk/network implementation):

- FMSTR\_NET\_LWIP\_TCP TCP communication using lwIP stack
- FMSTR\_NET\_LWIP\_UDP UDP communication using lwIP stack
- FMSTR\_NET\_SEGGER\_RTT Communication using SEGGER J-Link RTT interface

Other SDKs or BSPs may define the custom networking interface which may be used as FM-STR\_CAN\_DRV.

Add another row below:

#### FMSTR\_NET\_PORT

#define FMSTR\_NET\_PORT [number]

**Value Type** TCP or UDP port number (short integer)

**Description** Specifies the server port number used by TCP or UDP protocols.

#### FMSTR\_NET\_BLOCKING\_TIMEOUT

#define FMSTR\_NET\_BLOCKING\_TIMEOUT [number]

Value Type Timeout as number of milliseconds

**Description** This value specifies a timeout in milliseconds for which the network socket operations may block the execution inside *FMSTR\_Poll*. This may be set high (e.g. 250) when a dedicated RTOS task is used to handle FreeMASTER protocol polling. Set to a lower value when the polling task is also responsible for other operations. Set to 0 to attempt to use non-blocking socket operations.

#### FMSTR\_NET\_AUTODISCOVERY

#define FMSTR\_NET\_AUTODISCOVERY [0|1]

Value Type Boolean 0 or 1.

**Description** This option enables the FreeMASTER driver to use a separate UDP socket to broadcast auto-discovery messages to network. This helps the FreeMASTER tool to discover the target device address, port and protocol options.

**Debugging options** 

FMSTR\_DISABLE

#define FMSTR\_DISABLE [0|1]

**Value Type** boolean (0 or 1)

**Description** Define as non-zero to disable all FreeMASTER features, exclude the driver code from build, and compile all its API functions empty. This may be useful to remove FreeMASTER without modifying any application source code. Default value is 0 (false).

#### FMSTR\_DEBUG\_TX

#define FMSTR\_DEBUG\_TX [0|1]

Value Type Boolean 0 or 1.

**Description** Define as non-zero to enable the driver to periodically transmit test frames out on the selected communication interface (SCI or CAN). With the debug transmission enabled, it is simpler to detect problems in the baudrate or other communication configuration settings.

The test frames are transmitted until the first valid command frame is received from the PC Host tool. The test frame is a valid error status frame, as defined by the protocol format. On the serial line, the test frame consists of three printable characters (+©W) which are easy to capture using the serial terminal tools.

This feature requires the FMSTR\_Poll() function to be called periodically. Default value is 0 (false).

#### FMSTR\_APPLICATION\_STR

#define FMSTR\_APPLICATION\_STR

Value Type String.

**Description** Name of the application visible in FreeMASTER host application.

**Memory access** 

## FMSTR\_USE\_READMEM

#define FMSTR\_USE\_READMEM [0|1]

Value Type Boolean 0 or 1.

**Description** Define as non-zero to implement the Memory Read command and enable FreeMASTER to have read access to memory and variables. The access can be further restricted by using a TSA feature. Default value is 1 (true).

#### FMSTR\_USE\_WRITEMEM

#define FMSTR\_USE\_WRITEMEM [0|1]

Value Type Boolean 0 or 1.

**Description** Define as non-zero to implement the Memory Write command. The default value is 1 (true).

Oscilloscope options

#### FMSTR\_USE\_SCOPE

#define FMSTR\_USE\_SCOPE [number]

Value Type Integer number.

**Description** Number of Oscilloscope instances to be supported. Set to 0 to disable the Oscilloscope feature. Default value is 0.

#### FMSTR\_MAX\_SCOPE\_VARS

#define FMSTR\_MAX\_SCOPE\_VARS [number]

Value Type Integer number larger than 2.

**Description** Number of variables to be supported by each Oscilloscope instance. Default value is 8.

#### **Recorder options**

#### FMSTR\_USE\_RECORDER

 $\# define \ FMSTR\_USE\_RECORDER \ [number]$ 

#### Value Type Integer number.

**Description** Number of Recorder instances to be supported. Set to 0 to disable the Recorder feature. Default value is 0.

#### FMSTR\_REC\_BUFF\_SIZE

#define FMSTR\_REC\_BUFF\_SIZE [number]

**Value Type** Integer number larger than 2.

**Description** Defines the size of the memory buffer used by the Recorder instance #0. Default: not defined, user shall call 'FMSTR\_RecorderCreate()" API function to specify this parameter in run time.

#### FMSTR\_REC\_TIMEBASE

 $\# define \ FMSTR\_REC\_TIMEBASE \ [time \ specification]$ 

Value Type Number (nanoseconds time).

**Description** Defines the base sampling rate in nanoseconds (sampling speed) Recorder instance #0.

Use one of the following macros:

- FMSTR\_REC\_BASE\_SECONDS(x)
- FMSTR\_REC\_BASE\_MILLISEC(x)
- FMSTR\_REC\_BASE\_MICROSEC(x)
- FMSTR\_REC\_BASE\_NANOSEC(x)

Default: not defined, user shall call 'FMSTR\_RecorderCreate()" API function to specify this parameter in run time.

#### FMSTR\_REC\_FLOAT\_TRIG

 $\# define \ FMSTR\_REC\_FLOAT\_TRIG \ [0|1]$ 

Value Type Boolean 0 or 1.

**Description** Define as non-zero to implement the floating-point triggering. Be aware that floating-point triggering may grow the code size by linking the floating-point standard library. Default value is 0 (false).

#### **Application Commands options**

## FMSTR\_USE\_APPCMD

#define FMSTR\_USE\_APPCMD [0|1]

Value Type Boolean 0 or 1.

**Description** Define as non-zero to implement the Application Commands feature. Default value is 0 (false).

## FMSTR\_APPCMD\_BUFF\_SIZE

#define FMSTR\_APPCMD\_BUFF\_SIZE [size]

Value Type Numeric buffer size in range 1..255

**Description** The size of the Application Command data buffer allocated by the driver. The buffer stores the (optional) parameters of the Application Command which waits to be processed.

## FMSTR\_MAX\_APPCMD\_CALLS

#define FMSTR\_MAX\_APPCMD\_CALLS [number]

Value Type Number in range 0..255

 $\label{eq:Description} \begin{array}{ll} \mbox{The number of different Application Commands that can be assigned a callback handler function using $FMSTR_RegisterAppCmdCall()$. Default value is 0$. \\ \end{array}$ 

## **TSA options**

## FMSTR\_USE\_TSA

#define FMSTR\_USE\_TSA [0|1]

Value Type Boolean 0 or 1.

**Description** Enable the FreeMASTER TSA feature to be used. With this option enabled, the TSA tables defined in the applications are made available to the FreeMASTER host tool. Default value is 0 (false).

## FMSTR\_USE\_TSA\_SAFETY

#define FMSTR\_USE\_TSA\_SAFETY [0|1]

Value Type Boolean 0 or 1.

**Description** Enable the memory access validation in the FreeMASTER driver. With this option, the host tool is not able to access the memory which is not described by at least one TSA descriptor. Also a write access is denied for objects defined as read-only in TSA tables. Default value is 0 (false).

#### FMSTR\_USE\_TSA\_INROM

#define FMSTR\_USE\_TSA\_INROM [0|1]

Value Type Boolean 0 or 1.

**Description** Declare all TSA descriptors as *const*, which enables the linker to put the data into the flash memory. The actual result depends on linker settings or the linker commands used in the project. Default value is 0 (false).

#### FMSTR\_USE\_TSA\_DYNAMIC

#define FMSTR\_USE\_TSA\_DYNAMIC [0|1]

Value Type Boolean 0 or 1.

**Description** Enable runtime-defined TSA entries to be added to the TSA table by the FM-STR\_SetUpTsaBuff() and FMSTR\_TsaAddVar() functions. Default value is 0 (false).

**Pipes options** 

#### FMSTR\_USE\_PIPES

#define FMSTR\_USE\_PIPES [0|1]

Value Type Boolean 0 or 1.

**Description** Enable the FreeMASTER Pipes feature to be used. Default value is 0 (false).

#### FMSTR\_MAX\_PIPES\_COUNT

#define FMSTR\_MAX\_PIPES\_COUNT [number]

**Value Type** Number in range 1..63.

**Description** The number of simultaneous pipe connections to support. The default value is 1.

**Driver interrupt modes** To implement the communication, the FreeMASTER driver handles the Serial or CAN module's receive and transmit requests. Use the *freemaster\_cfg.h* configuration file to select whether the driver processes the communication automatically in the interrupt service routine handler or if it only polls the status of the module (typically during the application idle time).

This section describes each of the interrupt mode in more details.

## **Completely Interrupt-Driven operation** Activated using:

#define FMSTR\_LONG\_INTR 1

In this mode, both the communication and the FreeMASTER protocol decoding is done in the *FMSTR\_SerialIsr*, *FMSTR\_CanIsr*, or other interrupt service routine. Because the protocol execution may be a lengthy task (especially with the TSA-Safety enabled) it is recommended to use this mode only if the interrupt prioritization scheme is possible in the application and the FreeMAS-TER interrupt is assigned to a lower (the lowest) priority.

In this mode, the application code must register its own interrupt handler for all interrupt vectors related to the selected communication interface and call the FMSTR\_SerialIsr or FM-STR\_CanIsr functions from that handler.

#### Mixed Interrupt and Polling Modes Activated using:

#### #define FMSTR\_SHORT\_INTR 1

In this mode, the communication processing time is split between the interrupt routine and the main application loop or task. The raw communication is handled by the *FMSTR\_SerialIsr, FM-STR\_CanIsr*, or other interrupt service routine, while the protocol decoding and execution is handled by the *FMSTR\_Poll* routine. Call *FMSTR\_Poll* during the idle time in the application main loop.

The interrupt processing in this mode is relatively fast and deterministic. Upon a serial-receive event, the received character is only placed into a FIFO-like queue and it is not further processed. Upon a CAN receive event, the received frame is stored into a receive buffer. When transmitting, the characters are fetched from the prepared transmit buffer.

In this mode, the application code must register its own interrupt handler for all interrupt vectors related to the selected communication interface and call the *FMSTR\_SerialIsr* or *FM-STR\_CanIsr* functions from that handler.

When the serial interface is used as the serial communication interface, ensure that the *FM*-*STR\_Poll* function is called at least once per *N* character time periods. *N* is the length of the FreeMASTER FIFO queue (*FMSTR\_COMM\_RQUEUE\_SIZE*) and the character time is the time needed to transmit or receive a single byte over the SCI line.

#### **Completely Poll-driven**

#define FMSTR\_POLL\_DRIVEN 1

In this mode, both the communication and the FreeMASTER protocol decoding are done in the *FMSTR\_Poll* routine. No interrupts are needed and the *FMSTR\_SerialIsr*, *FMSTR\_CanIsr*, and similar handlers compile to an empty code.

When using this mode, ensure that the *FMSTR\_Poll* function is called by the application at least once per the serial "character time" which is the time needed to transmit or receive a single character.

In the latter two modes (*FMSTR\_SHORT\_INTR* and *FMSTR\_POLL\_DRIVEN*), the protocol handling takes place in the FMSTR\_Poll routine. An application interrupt can occur in the middle of the

Read Memory or Write Memory commands' execution and corrupt the variable being accessed by the FreeMASTER driver. In these two modes, some issues or glitches may occur when using FreeMASTER to visualize or monitor volatile variables modified in interrupt servicing code.

The same issue may appear even in the full interrupt mode (FMSTR\_LONG\_INTR), if volatile variables are modified in the interrupt code with a priority higher than the priority of the communication interrupt.

**Data types** Simple portability was one of the main requirements when writing the FreeMAS-TER driver. This is why the driver code uses the privately-declared data types and the vast majority of the platform-dependent code is separated in the platform-dependent source files. The data types used in the driver API are all defined in the platform-specific header file.

To prevent name conflicts with the symbols used in the application, all data types, macros, and functions have the FMSTR\_prefix. The only global variables used in the driver are the transport and low-level API structures exported from the driver-implementation layer to upper layers. Other than that, all private variables are declared as static and named using the fmstr\_prefix.

**Communication interface initialization** The FreeMASTER driver does not perform neither the initialization nor the configuration of the peripheral module that it uses to communicate. It is the application startup code responsibility to configure the communication module before the FreeMASTER driver is initialized by the FMSTR\_Init call.

When the Serial communication module is used as the FreeMASTER communication interface, configure the UART receive and transmit pins, the serial communication baud rate, parity (no-parity), the character length (eight bits), and the number of stop bits (one) before initializing the FreeMASTER driver. For either the long or the short interrupt modes of the driver (see *Driver interrupt modes*), configure the interrupt controller and register an application-specific interrupt handler for all interrupt sources related to the selected serial peripheral module. Call the FMSTR\_SerialIsr function from the application handler.

When a CAN module is used as the FreeMASTER communication interface, configure the CAN receive and transmit pins and the CAN module bit rate before initializing the FreeMASTER driver. For either the long or the short interrupt modes of the driver (see *Driver interrupt modes*), configure the interrupt controller and register an application-specific interrupt handler for all interrupt sources related to the selected CAN peripheral module. Call the FMSTR\_CanIsr function from the application handler.

**Note:** It is not necessary to enable or unmask the serial nor the CAN interrupts before initializing the FreeMASTER driver. The driver enables or disables the interrupts and communication lines, as required during runtime.

**FreeMASTER Recorder calls** When using the FreeMASTER Recorder in the application (FM-STR\_USE\_RECORDER > 0), call the FMSTR\_RecorderCreate function early after FMSTR\_Init to set up each recorder instance to be used in the application. Then call the FMSTR\_Recorder function periodically in the code where the data recording should occur. A typical place to call the Recorder routine is at the timer or PWM interrupts, but it can be anywhere else. The example applications provided together with the driver code call the FMSTR\_Recorder in the main application loop.

In applications where FMSTR\_Recorder is called periodically with a constant period, specify the period in the Recorder configuration structure before calling FMSTR\_RecorderCreate. This setting enables the PC Host FreeMASTER tool to display the X-axis of the Recorder graph properly scaled for the time domain.

**Driver usage** Start using or evaluating FreeMASTER by opening some of the example applications available in the driver setup package.

Follow these steps to enable the basic FreeMASTER connectivity in the application:

- Make sure that all \**c* files of the FreeMASTER driver from the *src/common/platforms/[your\_platform]* folder are a part of the project. See *Driver files* for more details.
- Configure the FreeMASTER driver by creating or editing the *freemaster\_cfg.h* file and by saving it into the application project directory. See *Driver configuration* for more details.
- Include the *freemaster.h* file into any application source file that makes the FreeMASTER API calls.
- Initialize the Serial or CAN modules. Set the baud rate, parity, and other parameters of the communication. Do not enable the communication interrupts in the interrupt mask registers.
- For the FMSTR\_LONG\_INTR and FMSTR\_SHORT\_INTR modes, install the applicationspecific interrupt routine and call the FMSTR\_SerialIsr or FMSTR\_CanIsr functions from this handler.
- Call the FMSTR\_Init function early on in the application initialization code.
- Call the FMSTR\_RecorderCreate functions for each Recorder instance to enable the Recorder feature.
- In the main application loop, call the FMSTR\_Poll API function periodically when the application is idle.
- For the FMSTR\_SHORT\_INTR and FMSTR\_LONG\_INTR modes, enable the interrupts globally so that the interrupts can be handled by the CPU.

**Communication troubleshooting** The most common problem that causes communication issues is a wrong baud rate setting or a wrong pin multiplexer setting of the target MCU. When a communication between the PC Host running FreeMASTER and the target MCU cannot be established, try enabling the FMSTR\_DEBUG\_TX option in the *freemaster\_cfg.h* file and call the FM-STR\_Poll function periodically in the main application task loop.

With this feature enabled, the FreeMASTER driver periodically transmits a test frame through the Serial or CAN lines. Use a logic analyzer or an oscilloscope to monitor the signals at the communication pins of the CPU device to examine whether the bit rate and signal polarity are configured properly.

## **Driver API**

This section describes the driver Application Programmers' Interface (API) needed to initialize and use the FreeMASTER serial communication driver.

**Control API** There are three key functions to initialize and use the driver.

## FMSTR\_Init

## Prototype

FMSTR\_BOOL FMSTR\_Init(void);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_protocol.c*

**Description** This function initializes the internal variables of the FreeMASTER driver and enables the communication interface. This function does not change the configuration of the selected communication module. The hardware module must be initialized before the *FMSTR\_Init* function is called.

A call to this function must occur before calling any other FreeMASTER driver API functions.

## FMSTR\_Poll

#### Prototype

void FMSTR\_Poll(void);

- Declaration: freemaster.h
- Implementation: *freemaster\_protocol.c*

**Description** In the poll-driven or short interrupt modes, this function handles the protocol decoding and execution (see *Driver interrupt modes*). In the poll-driven mode, this function also handles the communication interface with the PC. Typically, the *FMSTR\_Poll* function is called during the "idle" time in the main application task loop.

To prevent the receive data overflow (loss) on a serial interface, make sure that the FMSTR\_Poll function is called at least once per the time calculated as:

N \* Tchar

where:

- *N* is equal to the length of the receive FIFO queue (configured by the FM-STR\_COMM\_RQUEUE\_SIZE macro). *N* is 1 for the poll-driven mode.
- *Tchar* is the character time, which is the time needed to transmit or receive a single byte over the SCI line.

**Note:** In the long interrupt mode, this function typically compiles as an empty function and can still be called. It is worthwhile to call this function regardless of the interrupt mode used in the application. This approach enables a convenient switching between the different interrupt modes only by changing the configuration macros in the *freemaster\_cfg.h* file.

## FMSTR\_SerialIsr / FMSTR\_CanIsr

#### **Prototype**

void FMSTR\_SerialIsr(void); void FMSTR\_CanIsr(void);

- Declaration: freemaster.h
- Implementation: *hw-specific low-level driver C file*

**Description** This function contains the interrupt-processing code of the FreeMASTER driver. In long or short interrupt modes (see *Driver interrupt modes*), this function must be called from the application interrupt service routine registered for the communication interrupt vector. On platforms where the communication module uses multiple interrupt vectors, the application should register a handler for all vectors and call this function at each interrupt.

**Note:** In a poll-driven mode, this function is compiled as an empty function and does not have to be used.

## **Recorder API**

## FMSTR\_RecorderCreate

## Prototype

FMSTR\_BOOL FMSTR\_RecorderCreate(FMSTR\_INDEX recIndex, FMSTR\_REC\_BUFF\* buffCfg);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_rec.c*

**Description** This function registers a recorder instance and enables it to be used by the PC Host tool. Call this function for all recorder instances from 0 to the maximum number defined by the FMSTR\_USE\_RECORDER configuration option (minus one). An exception to this requirement is the recorder of instance 0 which may be automatically configured by FM-STR\_Init when the *freemaster\_cfg.h* configuration file defines the *FMSTR\_REC\_BUFF\_SIZE* and *FMSTR\_REC\_TIMEBASE* options.

For more information, see *Configurable items*.

#### FMSTR\_Recorder

#### Prototype

void FMSTR\_Recorder(FMSTR\_INDEX recIndex);

- Declaration: freemaster.h
- Implementation: *freemaster\_rec.c*

**Description** This function takes a sample of the variables being recorded using the FreeMAS-TER Recorder instance *recIndex*. If the selected Recorder is not active when the *FMSTR\_Recorder* function is being called, the function returns immediately. When the Recorder is active, the values of the variables being recorded are copied into the recorder buffer and the trigger conditions are evaluated.

If a trigger condition is satisfied, the Recorder enters the post-trigger mode, where it counts down the follow-up samples (number of *FMSTR\_Recorder* function calls) and de-activates the Recorder when the required post-trigger samples are finished.

The *FMSTR\_Recorder* function is typically called in the timer or PWM interrupt service routines. This function can also be called in the application main loop (for testing purposes).

## FMSTR\_RecorderTrigger

## Prototype

void FMSTR\_RecorderTrigger(FMSTR\_INDEX recIndex);

- Declaration: freemaster.h
- Implementation: *freemaster\_rec.c*

**Description** This function forces the Recorder trigger condition to happen, which causes the Recorder to be automatically deactivated after the post-trigger samples are sampled. Use this function in the application code for programmatic control over the Recorder triggering. This can be useful when a more complex triggering conditions need to be used.

**Fast Recorder API** The Fast Recorder feature is not available in the FreeMASTER driver version 3. This feature was heavily dependent on the target platform and it was only available for the 56F8xxxx DSCs.

**TSA Tables** When the TSA is enabled in the FreeMASTER driver configuration file (by setting the FMSTR\_USE\_TSA macro to a non-zero value), it defines the so-called TSA tables in the application. This section describes the macros that must to be used to define the TSA tables.

There can be any number of TSA tables spread across the application source files. There must be always exactly one TSA Table List defined, which informs the FreeMASTER driver about the active TSA tables.

When there is at least one TSA table and one TSA Table List defined in the application, the TSA information automatically appears in the FreeMASTER symbols list. The symbols can then be used to create FreeMASTER variables for visualization or control.

**TSA table definition** The TSA table describes the static or global variables together with their address, size, type, and access-protection information. If the TSA-described variables are of a structure type, the TSA table may also describe this type and provide an access to the individual structure members of the variable.

The TSA table definition begins with the FMSTR\_TSA\_TABLE\_BEGIN macro with a *table\_id* identifying the table. The *table\_id* shall be a valid C-langiage symbol.

 $FMSTR\_TSA\_TABLE\_BEGIN(table\_id)$ 

After this opening macro, the TSA descriptors are placed using these macros:

```
/* Adding variable descriptors */
FMSTR_TSA_RW_VAR(name, type) /* read/write variable entry */
FMSTR_TSA_RO_VAR(name, type) /* read-only variable entry */
/* Description of complex data types */
FMSTR_TSA_STRUCT(struct_name) /* structure or union type entry */
FMSTR_TSA_MEMBER(struct_name, member_name, type) /* structure member entry */
/* Memory blocks */
FMSTR_TSA_RW_MEM(name, type, address, size) /* read/write memory block */
FMSTR_TSA_RO_MEM(name, type, address, size) /* read-only memory block */
```

The table is closed using the FMSTR\_TSA\_TABLE\_END macro:

FMSTR\_TSA\_TABLE\_END()

**TSA descriptor parameters** The TSA descriptor macros accept these parameters:

- *name* variable name. The variable must be defined before the TSA descriptor references it.
- *type* variable or member type. Only one of the pre-defined type constants may be used (see below).
- *struct\_name* structure type name. The type must be defined (typedef) before the TSA descriptor references it.

• *member\_name* — structure member name.

**Note:** The structure member descriptors (FMSTR\_TSA\_MEMBER) must immediately follow the parent structure descriptor (FMSTR\_TSA\_STRUCT) in the table.

**Note:** To write-protect the variables in the FreeMASTER driver (FMSTR\_TSA\_RO\_VAR), enable the TSA-Safety feature in the configuration file.

**TSA variable types** The table lists *type* identifiers which can be used in TSA descriptors:

| Constant                                 | Description                                                    |
|------------------------------------------|----------------------------------------------------------------|
| FMSTR_TSA_UINTn                          | Unsigned integer type of size <i>n</i> bits (n=8,16,32,64)     |
| FMSTR_TSA_SINTn                          | Signed integer type of size <i>n</i> bits (n=8,16,32,64)       |
| FMSTR_TSA_FRACn                          | Fractional number of size <i>n</i> bits (n=16,32,64).          |
| FMSTR_TSA_FRAC_Q( <i>m</i> , <i>n</i> )  | Signed fractional number in general Q form (m+n+1 total bits)  |
| FMSTR_TSA_FRAC_UQ( <i>m</i> , <i>n</i> ) | Unsigned fractional number in general UQ form (m+n total bits) |
| FMSTR_TSA_FLOAT                          | 4-byte standard IEEE floating-point type                       |
| FMSTR_TSA_DOUBLE                         | 8-byte standard IEEE floating-point type                       |
| FMSTR_TSA_POINTER                        | Generic pointer type defined (platform-specific 16 or 32 bit)  |
| FM-<br>STR_TSA_USERTYPE(name)            | Structure or union type declared with FMSTR_TSA_STRUCT record  |

**TSA table list** There shall be exactly one TSA Table List in the application. The list contains one entry for each TSA table defined anywhere in the application.

The TSA Table List begins with the FMSTR\_TSA\_TABLE\_LIST\_BEGIN macro and continues with the TSA table entries for each table.

FMSTR\_TSA\_TABLE\_LIST\_BEGIN()

FMSTR\_TSA\_TABLE(table\_id) FMSTR\_TSA\_TABLE(table\_id2) FMSTR\_TSA\_TABLE(table\_id3)

The list is closed with the FMSTR\_TSA\_TABLE\_LIST\_END macro:

FMSTR\_TSA\_TABLE\_LIST\_END()

**TSA Active Content entries** FreeMASTER v2.0 and higher supports TSA Active Content, enabling the TSA tables to describe the memory-mapped files, virtual directories, and URL hyperlinks. FreeMASTER can access such objects similarly to accessing the files and folders on the local hard drive.

With this set of TSA entries, the FreeMASTER pages can be embedded directly into the target MCU flash and accessed by FreeMASTER directly over the communication line. The HTML-coded pages rendered inside the FreeMASTER window can access the TSA Active Content resources using a special URL referencing the *fmstr:* protocol.

This example provides an overview of the supported TSA Active Content entries:

```
FMSTR_TSA_TABLE_BEGIN(files_and_links)
```

```
/* Directory entry applies to all subsequent MEMFILE entries */
FMSTR_TSA_DIRECTORY("/text_files") /* entering a new virtual directory */
```

(continues on next page)

(continued from previous page)

/\* The readme.txt file will be accessible at the fmstr://text\_files/readme.txt URL \*/ FMSTR\_TSA\_MEMFILE("readme.txt", readme\_txt, sizeof(readme\_txt)) /\* memory-mapped file \*/

/\* Files can also be specified with a full path so the DIRECTORY entry does not apply \*/ FMSTR\_TSA\_MEMFILE("/index.htm", index, sizeof(index)) /\* memory-mapped file \*/ FMSTR\_TSA\_MEMFILE("/prj/demo.pmp", demo\_pmp, sizeof(demo\_pmp)) /\* memory-mapped file \*/

/\* Hyperlinks can point to a local MEMFILE object or to the Internet \*/ FMSTR\_TSA\_HREF("Board's Built-in Welcome Page", "/index.htm") FMSTR\_TSA\_HREF("FreeMASTER Home Page", "http://www.nxp.com/freemaster")

/\* Project file links simplify opening the projects from any URLs \*/ FMSTR\_TSA\_PROJECT("Demonstration Project (embedded)", "/prj/demo.pmp") FMSTR\_TSA\_PROJECT("Full Project (online)", "http://mycompany.com/prj/demo.pmp")

FMSTR\_TSA\_TABLE\_END()

## TSA API

## FMSTR\_SetUpTsaBuff

## Prototype

FMSTR\_BOOL FMSTR\_SetUpTsaBuff(FMSTR\_ADDR buffAddr, FMSTR\_SIZE buffSize);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_tsa.c*

## Arguments

- *buffAddr* [in] address of the memory buffer for the dynamic TSA table
- *buffSize* [in] size of the memory buffer which determines the maximum number of TSA entries to be added in the runtime

**Description** This function must be used to assign the RAM memory buffer to the TSA subsystem when FMSTR\_USE\_TSA\_DYNAMIC is enabled. The memory buffer is then used to store the TSA entries added dynamically to the runtime TSA table using the FMSTR\_TsaAddVar function call. The runtime TSA table is processed by the FreeMASTER PC Host tool along with all static tables as soon as the communication port is open.

The size of the memory buffer determines the number of TSA entries that can be added dynamically. Depending on the MCU platform, one TSA entry takes either 8 or 16 bytes.

## FMSTR\_TsaAddVar

## Prototype

```
FMSTR_BOOL FMSTR_TsaAddVar(FMSTR_TSATBL_STRPTR tsaName, FMSTR_TSATBL_STRPTR

→ tsaType,

FMSTR_TSATBL_VOIDPTR varAddr, FMSTR_SIZE32 varSize,

FMSTR_SIZE flags);
```

• Declaration: *freemaster.h* 

• Implementation: *freemaster\_tsa.c* 

## Arguments

- *tsaName* [in] name of the object
- *tsaType* [in] name of the object type
- varAddr [in] address of the object
- varSize [in] size of the object
- *flags* [in] access flags; a combination of these values:
  - *FMSTR\_TSA\_INFO\_RO\_VAR* read-only memory-mapped object (typically a variable)
  - FMSTR\_TSA\_INFO\_RW\_VAR read/write memory-mapped object
  - *FMSTR\_TSA\_INFO\_NON\_VAR —* other entry, describing structure types, structure members, enumerations, and other types

**Description** This function can be called only when the dynamic TSA table is enabled by the FMSTR\_USE\_TSA\_DYNAMIC configuration option and when the FMSTR\_SetUpTsaBuff function call is made to assign the dynamic TSA table memory. This function adds an entry into the dynamic TSA table. It can be used to register a read-only or read/write memory object or describe an item of the user-defined type.

See *TSA table definition* for more details about the TSA table entries.

## **Application Commands API**

## FMSTR\_GetAppCmd

## Prototype

FMSTR\_APPCMD\_CODE FMSTR\_GetAppCmd(void);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_appcmd.c*

**Description** This function can be used to detect if there is an Application Command waiting to be processed by the application. If no command is pending, this function returns the FM-STR\_APPCMDRESULT\_NOCMD constant. Otherwise, this function returns the code of the Application Command that must be processed. Use the FMSTR\_AppCmdAck call to acknowledge the Application Command after it is processed and to return the appropriate result code to the host.

The FMSTR\_GetAppCmd function does not report the commands for which a callback handler function exists. If the FMSTR\_GetAppCmd function is called when a callback-registered command is pending (and before it is actually processed by the callback function), this function returns FMSTR\_APPCMDRESULT\_NOCMD.

## FMSTR\_GetAppCmdData

## Prototype

FMSTR\_APPCMD\_PDATA FMSTR\_GetAppCmdData(FMSTR\_SIZE\* dataLen);

- Declaration: freemaster.h
- Implementation: *freemaster\_appcmd.c*

## Arguments

• *dataLen* [out] - pointer to the variable that receives the length of the data available in the buffer. It can be NULL when this information is not needed.

**Description** This function can be used to retrieve the Application Command data when the application determines that an Application Command is pending (see *FMSTR\_GetAppCmd*).

There is just a single buffer to hold the Application Command data (the buffer length is FM-STR\_APPCMD\_BUFF\_SIZE bytes). If the data are to be used in the application after the command is processed by the FMSTR\_AppCmdAck call, copy the data out to a private buffer.

## FMSTR\_AppCmdAck

## Prototype

void FMSTR\_AppCmdAck(FMSTR\_APPCMD\_RESULT resultCode);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_appcmd.c*

## Arguments

• *resultCode* [in] - the result code which is to be returned to FreeMASTER

**Description** This function is used when the Application Command processing finishes in the application. The resultCode passed to this function is returned back to the host and the driver is re-initialized to expect the next Application Command.

After this function is called and before the next Application Command arrives, the return value of the FMSTR\_GetAppCmd function is FMSTR\_APPCMDRESULT\_NOCMD.

## FMSTR\_AppCmdSetResponseData

## Prototype

 $void\ FMSTR\_AppCmdSetResponseData(FMSTR\_ADDR\ resultDataAddr,\ FMSTR\_SIZE\ resultDataLen);$ 

- Declaration: *freemaster.h*
- Implementation: *freemaster\_appcmd.c*

## Arguments

- *resultDataAddr* [in] pointer to the data buffer that is to be copied to the Application Command data buffer
- *resultDataLen* [in] length of the data to be copied. It must not exceed the FM-STR\_APPCMD\_BUFF\_SIZE value.

**Description** This function can be used before the Application Command processing finishes, when there are data to be returned back to the PC.

The response data buffer is copied into the Application Command data buffer, from where it is accessed when the host requires it. Do not use FMSTR\_GetAppCmdData and the data buffer after FMSTR\_AppCmdSetResponseData is called.

**Note:** The current version of FreeMASTER does not support the Application Command response data.

## FMSTR\_RegisterAppCmdCall

## Prototype

 $\label{eq:str_bound} FMSTR\_BOOL\ FMSTR\_RegisterAppCmdCall(FMSTR\_APPCMD\_CODE\ appCmdCode,\ FMSTR\_opPCMDFUNC\ callbackFunc);$ 

- Declaration: *freemaster.h*
- Implementation: *freemaster\_appcmd.c*

## Arguments

- appCmdCode [in] the Application Command code for which the callback is to be registered
- *callbackFunc* [in] pointer to the callback function that is to be registered. Use NULL to unregister a callback registered previously with this Application Command.

**Return value** This function returns a non-zero value when the callback function was successfully registered or unregistered. It can return zero when trying to register a callback function for more than FMSTR\_MAX\_APPCMD\_CALLS different Application Commands.

**Description** This function can be used to register the given function as a callback handler for the Application Command. The Application Command is identified using single-byte code. The callback function is invoked automatically by the FreeMASTER driver when the protocol decoder obtains a request to get the application command result code.

The prototype of the callback function is

FMSTR\_APPCMD\_RESULT HandlerFunction(FMSTR\_APPCMD\_CODE nAppcmd, FMSTR\_APPCMD\_PDATA pData, FMSTR\_SIZE nDataLen);

Where:

- nAppcmd -Application Command code
- *pData*—points to the Application Command data received (if any)
- *nDataLen*—information about the Application Command data length

The return value of the callback function is used as the Application Command Result Code and returned to FreeMASTER.

**Note:** The FMSTR\_MAX\_APPCMD\_CALLS configuration macro defines how many different Application Commands may be handled by a callback function. When FMSTR\_MAX\_APPCMD\_CALLS is undefined or defined as zero, the FMSTR\_RegisterAppCmdCall function always fails.

## **Pipes API**

## FMSTR\_PipeOpen

## Prototype

```
{\rm FMSTR\_HPIPE\ FMSTR\_PipeOpen(FMSTR\_PIPE\_PORT\ pipePort,\ FMSTR\_PPIPEFUNC\ pipeCallback,}
```

FMSTR\_ADDR pipeRxBuff, FMSTR\_PIPE\_SIZE pipeRxSize, FMSTR\_ADDR pipeTxBuff, FMSTR\_PIPE\_SIZE pipeTxSize, FMSTR\_U8 type, const FMSTR\_CHAR \*name);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_pipes.c*

## Arguments

- pipePort [in] port number that identifies the pipe for the client
- *pipeCallback* [in] pointer to the callback function that is called whenever a pipe data status changes
- pipeRxBuff [in] address of the receive memory buffer
- pipeRxSize [in] size of the receive memory buffer
- *pipeTxBuff* [in] address of the transmit memory buffer
- *pipeTxSize* [in] size of the transmit memory buffer
- *type* [in] a combination of FMSTR\_PIPE\_MODE\_xxx and FMSTR\_PIPE\_SIZE\_xxx constants describing primary pipe data format and usage. This type helps FreeMASTER decide how to access the pipe by default. Optional, use 0 when undetermined.
- *name* [in] user name of the pipe port. This name is visible to the FreeMASTER user when creating the graphical pipe interface.

**Description** This function initializes a new pipe and makes it ready to accept or send the data to the PC Host client. The receive memory buffer is used to store the received data before they are read out by the FMSTR\_PipeRead call. When this buffer gets full, the PC Host client denies the data transmission into this pipe until there is enough free space again. The transmit memory buffer is used to store the data transmitted by the application to the PC Host client using the FMSTR\_PipeWrite call. The transmit buffer can get full when the PC Host is disconnected or when it is slow in receiving and reading out the pipe data.

The function returns the pipe handle which must be stored and used in the subsequent calls to manage the pipe object.

The callback function (if specified) is called whenever new data are received through the pipe and available for reading. This callback is also called when the data waiting in the transmit buffer are successfully pushed to the PC Host and the transmit buffer free space increases. The prototype of the callback function provided by the user application must be as follows. The *PipeHandler* name is only a placeholder and must be defined by the application. void PipeHandler(FMSTR\_HPIPE pipeHandle);

## FMSTR\_PipeClose

## Prototype

void FMSTR\_PipeClose(FMSTR\_HPIPE pipeHandle);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_pipes.c*

## Arguments

• pipeHandle [in] - pipe handle returned from the FMSTR\_PipeOpen function call

**Description** This function de-initializes the pipe object. No data can be received or sent on the pipe after this call.

## FMSTR\_PipeWrite

#### Prototype

FMSTR\_PIPE\_SIZE FMSTR\_PipeWrite(FMSTR\_HPIPE pipeHandle, FMSTR\_ADDR pipeData, FMSTR\_PIPE\_SIZE pipeDataLen, FMSTR\_PIPE\_SIZE writeGranularity);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_pipes.c*

## Arguments

- *pipeHandle* [in] pipe handle returned from the FMSTR\_PipeOpen function call
- pipeData [in] address of the data to be written
- *pipeDataLen* [in] length of the data to be written
- writeGranularity [in] size of the minimum unit of data which is to be written

**Description** This function puts the user-specified data into the pipe's transmit memory buffer and schedules it for transmission. This function returns the number of bytes that were successfully written into the buffer. This number may be smaller than the number of the requested bytes if there is not enough free space in the transmit buffer.

The *writeGranularity* argument can be used to split the data into smaller chunks, each of the size given by the *writeGranularity* value. The FMSTR\_PipeWrite function writes as many data chunks as possible into the transmit buffer and does not attempt to write an incomplete chunk. This feature can prove to be useful to avoid the intermediate caching when writing an array of integer values or other multi-byte data items. When making the nGranularity value equal to the nLength value, all data are considered as one chunk which is either written successfully as a whole or not at all. The nGranularity value of 0 or 1 disables the data-chunk approach.

## FMSTR\_PipeRead

## Prototype

FMSTR\_PIPE\_SIZE FMSTR\_PipeRead(FMSTR\_HPIPE pipeHandle, FMSTR\_ADDR pipeData, FMSTR\_PIPE\_SIZE pipeDataLen, FMSTR\_PIPE\_SIZE readGranularity);

- Declaration: *freemaster.h*
- Implementation: *freemaster\_pipes.c*

## Arguments

- *pipeHandle* [in] pipe handle returned from the FMSTR\_PipeOpen function call
- pipeData [in] address of the data buffer to be filled with the received data
- *pipeDataLen* [in] length of the data to be read
- *readGranularity* [in] size of the minimum unit of data which is to be read

**Description** This function copies the data received from the pipe from its receive buffer to the user buffer for further processing. The function returns the number of bytes that were successfully copied to the buffer. This number may be smaller than the number of the requested bytes if there is not enough data bytes available in the receive buffer.

The readGranularity argument can be used to copy the data in larger chunks in the same way as described in the FMSTR\_PipeWrite function.

**API data types** This section describes the data types used in the FreeMASTER driver. The information provided here can be useful when modifying or porting the FreeMASTER Communication Driver to new NXP platforms.

**Note:** The licensing conditions prohibit use of FreeMASTER and the FreeMASTER Communication Driver with non-NXP MPU or MCU products.

**Public common types** The table below describes the public data types used in the FreeMASTER driver API calls. The data types are declared in the *freemaster.h* header file.

| Type name                   | Description                                                                    |
|-----------------------------|--------------------------------------------------------------------------------|
| FM-                         | Data type used to hold the memory address. On most platforms, this is normally |
| STR_ADDR                    | a C-pointer, but it may also be a pure integer type.                           |
| For exam-                   |                                                                                |
| ple, this                   |                                                                                |
| type is<br>defined as       |                                                                                |
| long inte-                  |                                                                                |
| ger on the                  |                                                                                |
| 56F8xxx                     |                                                                                |
| platform                    |                                                                                |
| where<br>the 24-bit         |                                                                                |
| addresses                   |                                                                                |
| must be                     |                                                                                |
| supported,                  |                                                                                |
| but the                     |                                                                                |
| C-pointer<br>may be         |                                                                                |
| only 16                     |                                                                                |
| bits wide                   |                                                                                |
| in some                     |                                                                                |
| compiler                    |                                                                                |
| configura-<br>tions.        |                                                                                |
| FM-                         | Data type used to hold the memory block size.                                  |
| STR_SIZE                    |                                                                                |
| It is re-                   |                                                                                |
| quired<br>that this         |                                                                                |
| type is un-                 |                                                                                |
| signed and                  |                                                                                |
| at least 16                 |                                                                                |
| bits wide                   |                                                                                |
| integer.<br><i>FM-</i>      | Data type used as a general boolean type.                                      |
| STR_BOOL                    | Data type used as a general boolean type.                                      |
| This type                   |                                                                                |
| is used                     |                                                                                |
| only in                     |                                                                                |
| zero/non-<br>zero con-      |                                                                                |
| ditions in                  |                                                                                |
| the driver                  |                                                                                |
| code.                       | Data type used to hold the Application Command code                            |
| FM-<br>STR_APPCM.           | Data type used to hold the Application Command code.                           |
| Generally,                  |                                                                                |
| this is an                  |                                                                                |
| unsigned                    |                                                                                |
| 8-bit value.<br><i>FM</i> - | Data type used to create the Application Command data buffer.                  |
| STR_APPCM.                  | Data Gro used to create the reprication communic data bunch                    |
| Generally,                  |                                                                                |
| this is an                  |                                                                                |
| unsigned<br>8-bit value.    |                                                                                |
| <i>FM-</i>                  | Data type used to hold the Application Command result code.                    |
| STR APPCM                   |                                                                                |
| 160 –<br>Generally,         | Chapter 3. Middleware                                                          |
| this is an                  |                                                                                |
| unsigned<br>8-bit value.    |                                                                                |
| o bit vulue.                |                                                                                |

**Public TSA types** The table describes the TSA-specific public data types. These types are declared in the *freemaster\_tsa.h* header file, which is included in the user application indirectly by the *freemaster.h* file.

| FM-           | Data type used to hold a descriptor index in the TSA table or a table index in the |
|---------------|------------------------------------------------------------------------------------|
| STR_TSA_TII   | list of TSA tables.                                                                |
| By default,   |                                                                                    |
| this is       |                                                                                    |
| defined       |                                                                                    |
| as FM-        |                                                                                    |
| STR_SIZE.     |                                                                                    |
| FM-           | Data type used to hold a memory block size, as used in the TSA descriptors.        |
| $STR_TSA_TSL$ |                                                                                    |
| By default,   |                                                                                    |
| this is       |                                                                                    |
| defined       |                                                                                    |
| as FM-        |                                                                                    |
| STR_SIZE.     |                                                                                    |

**Public Pipes types** The table describes the data types used by the FreeMASTER Pipes API:

| FM-<br>STR_HPIPE                                                 | Pipe handle that identifies the open-pipe object.       |
|------------------------------------------------------------------|---------------------------------------------------------|
| Generally,<br>this is a<br>pointer<br>to a void                  |                                                         |
| type.                                                            |                                                         |
| FM-<br>STR_PIPE_P(                                               | Integer type required to hold at least 7 bits of data.  |
| Generally,<br>this is an<br>unsigned<br>8-bit or<br>16-bit type. |                                                         |
| FM-<br>STR_PIPE_SI                                               | Integer type required to hold at least 16 bits of data. |
| This is<br>used to<br>store the<br>data buffer<br>sizes.         |                                                         |
| FM-<br>STR PPIPEF                                                | Pointer to the pipe handler function.                   |
| See FM-<br>STR_PipeOpe<br>for more                               |                                                         |
| details.                                                         |                                                         |

**Internal types** The table describes the data types used internally by the FreeMASTER driver. The data types are declared in the platform-specific header file and they are not available in the application code.

| FMSTR_U8                | The smallest memory entity.                                      |
|-------------------------|------------------------------------------------------------------|
| On the vast             | The sindlest memory entry.                                       |
| majority of             |                                                                  |
| platforms,              |                                                                  |
| this is an              |                                                                  |
| unsigned                |                                                                  |
| 8-bit inte-             |                                                                  |
| ger.<br>On the          |                                                                  |
| 56F8xx                  |                                                                  |
| DSP plat-               |                                                                  |
| form, this              |                                                                  |
| is defined              |                                                                  |
| as an un-               |                                                                  |
| signed                  |                                                                  |
| 16-bit inte-            |                                                                  |
| ger.<br><i>FM</i> -     | Unsigned 16-bit integer.                                         |
| STR_U16                 | onsighted to bit integet.                                        |
| FM-                     | Unsigned 32-bit integer.                                         |
| <i>STR_U32</i>          |                                                                  |
| FMSTR_S8                | Signed 8-bit integer.                                            |
| FM-                     | Signed 16-bit integer.                                           |
| STR_S16<br>FM-          | Signed 32-bit integer.                                           |
| STR_S32                 | Signed 52-bit integer.                                           |
| FM-                     | 4-byte standard IEEE floating-point type.                        |
| STR_FLOAT               |                                                                  |
| FM-                     | Data type forming a union with a structure of flag bit-fields.   |
| STR_FLAGS               | Dete true holding a general size value, et leget 9 bite wide     |
| FM-<br>STR_SIZE8        | Data type holding a general size value, at least 8 bits wide.    |
| FM-                     | General for-loop index. Must be signed, at least 16 bits wide.   |
| STR_INDEX               |                                                                  |
| FM-                     | A single character in the communication buffer.                  |
| STR_BCHR                |                                                                  |
| Typically,              |                                                                  |
| this is<br>an 8-bit     |                                                                  |
| unsigned                |                                                                  |
| integer,                |                                                                  |
| except for              |                                                                  |
| the DSP                 |                                                                  |
| platforms               |                                                                  |
| where it                |                                                                  |
| is a 16-bit             |                                                                  |
| integer.<br><i>FM</i> - | A pointer to the communication buffer (an array of FMSTR_BCHR).  |
| STR_BPTR                | r pointer to the communication bunch (an array of r mork_berry). |
|                         |                                                                  |

## **Document references**

## Links

• This document online: https://mcuxpresso.nxp.com/mcuxsdk/latest/html/middleware/ freemaster/doc/index.html

- FreeMASTER tool home: www.nxp.com/freemaster
- FreeMASTER community area: community.nxp.com/community/freemaster
- FreeMASTER GitHub code repo: https://github.com/nxp-mcuxpresso/mcux-freemaster
- MCUXpresso SDK home: www.nxp.com/mcuxpresso
- MCUXpresso SDK builder: mcuxpresso.nxp.com/en

## Documents

- FreeMASTER Usage Serial Driver Implementation (document AN4752)
- Integrating FreeMASTER Time Debugging Tool With CodeWarrior For Microcontrollers v10.X Project (document AN4771)
- Flash Driver Library For MC56F847xx And MC56F827xx DSC Family (document AN4860)

**Revision history** This Table summarizes the changes done to this document since the initial release.

| Revi- | Date    | Description                                                                                                                                                                                                                                                                                                                           |
|-------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sion  |         |                                                                                                                                                                                                                                                                                                                                       |
| 1.0   | 03/2006 | Limited initial release                                                                                                                                                                                                                                                                                                               |
| 2.0   | 09/2007 | Updated for FreeMASTER version. New Freescale doc-<br>ument template used.                                                                                                                                                                                                                                                            |
| 2.1   | 12/2007 | Added description of the new Fast Recorder feature and its API.                                                                                                                                                                                                                                                                       |
| 2.2   | 04/2010 | Added support for MPC56xx platform, Added new API for use CAN interface.                                                                                                                                                                                                                                                              |
| 2.3   | 04/2011 | Added support for Kxx Kinetis platform and MQX oper-<br>ating system.                                                                                                                                                                                                                                                                 |
| 2.4   | 06/2011 | Serial driver update, adds support for USB CDC inter-<br>face.                                                                                                                                                                                                                                                                        |
| 2.5   | 08/2011 | Added Packet Driven BDM interface.                                                                                                                                                                                                                                                                                                    |
| 2.7   | 12/2013 | Added FLEXCAN32 interface, byte access and isr call-<br>back configuration option.                                                                                                                                                                                                                                                    |
| 2.8   | 06/2014 | Removed obsolete license text, see the software pack-<br>age content for up-to-date license.                                                                                                                                                                                                                                          |
| 2.9   | 03/2015 | Update for driver version 1.8.2 and 1.9: FreeMAS-<br>TER Pipes, TSA Active Content, LIN Transport Layer<br>support, DEBUG-TX communication troubleshooting,<br>Kinetis SDK support.                                                                                                                                                   |
| 3.0   | 08/2016 | Update for driver version 2.0: Added support for<br>MPC56xx, MPC57xx, KEAxx and S32Kxx platforms.<br>New NXP document template as well as new license<br>agreement used. added MCAN interface. Folders struc-<br>ture at the installation destination was rearranged.                                                                 |
| 4.0   | 04/2019 | Update for driver released as part of FreeMASTER v3.0<br>and MCUXpresso SDK 2.6. Updated to match new V4<br>serial communication protocol and new configuration<br>options. This version of the document removes sub-<br>stantial portion of outdated information related to S08,<br>S12, ColdFire, Power and other legacy platforms. |
| 4.1   | 04/2020 | Minor update for FreeMASTER driver included in MCUXpresso SDK 2.8.                                                                                                                                                                                                                                                                    |
| 4.2   | 09/2020 | Added example applications description and informa-<br>tion about the MCUXpresso Config Tools. Fixed the<br>pipe-related API description.                                                                                                                                                                                             |
| 4.3   | 10/2024 | Added description of Network and Segger J-Link RTT in-<br>terface configuration. Accompanying the MCUXpresso<br>SDK version 24.12.00.                                                                                                                                                                                                 |
| 4.4   | 04/2025 | Added Zephyr-specific information. Accompanying the MCUXpresso SDK version 25.06.00.                                                                                                                                                                                                                                                  |

# **Chapter 4**

# RTOS

# 4.1 FreeRTOS

# 4.1.1 FreeRTOS kernel

Open source RTOS kernel for small devices.

FreeRTOS kernel for MCUXpresso SDK Readme

FreeRTOS kernel for MCUXpresso SDK ChangeLog

FreeRTOS kernel Readme

## 4.1.2 FreeRTOS drivers

This is set of NXP provided FreeRTOS reentrant bus drivers.

# 4.1.3 backoffalgorithm

Algorithm for calculating exponential backoff with jitter for network retry attempts.

## Readme

## 4.1.4 corehttp

C language HTTP client library designed for embedded platforms.

## 4.1.5 corejson

JSON parser.

Readme

# 4.1.6 coremqtt

MQTT publish/subscribe messaging library.

# 4.1.7 coremqtt-agent

The coreMQTT Agent library is a high level API that adds thread safety to the coreMQTT library.

## Readme

# 4.1.8 corepkcs11

PKCS #11 key management library.

## Readme

# 4.1.9 freertos-plus-tcp

Open source RTOS FreeRTOS Plus TCP.

## Readme