

## MOTIX<sup>™</sup> TLE986x MOTIX<sup>™</sup> TLE987x BF, A, UH, and UI step

## **BootROM User manual**

Rev. 1.9, 2023-10-23



| <b>1</b><br>1.1<br>1.2<br>1.3                                                                                                                                                                                | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | .5<br>.5                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| <b>2</b><br>2.1<br>2.2                                                                                                                                                                                       | Overview .<br>Firmware architecture<br>Program structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 7                                                                                                      |
| <b>3</b><br>3.1<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.3.1<br>3.1.3.1<br>3.1.3.2<br>3.1.4<br>3.1.5<br>3.1.6<br>3.1.7<br>3.1.8<br>3.1.8.1<br>3.1.9                                                                 | Startup procedure         Program structure         Test and initialization of RAM         NVM initialisation routine         NVM MapRAM initialisation         NVM MapRAM initialization at high prio reset         NVM MapRAM initialization at low prio reset         Oscillator trimming and system clock selection         Analog module trimming         User configuration data initialization         Debug Support mode entry         User mode and BSL mode entry         NAC definition         Node Address for Diagnostic (NAD)                                                                                                                                                                  | . 9<br>. 9<br>10<br>10<br>10<br>11<br>11<br>12<br>12<br>13<br>13                                         |
| <b>4</b><br>4.1<br>4.2<br>4.2.1<br>4.2.2<br>4.3<br>4.4<br>4.4.1<br>4.4.1.1<br>4.4.1.2<br>4.4.1.3<br>4.4.1.3<br>4.4.1.4<br>4.4.2<br>4.4.2.1<br>4.4.2.2<br>4.4.2.3<br>4.4.2.2<br>4.4.2.3<br>4.4.2.5<br>4.4.2.6 | FastLIN and UART BSL mode         FastLIN and UART BSL protocol         Phase I for UART BSL: Automatic serial synchronization to the host         General description         Calculation of BR_VALUE and PRE values         Phase I for FastLIN BSL: FastLIN BSL entry sequence         Phase II: Serial communication protocol and the working modes         Serial communication protocol         Transfer block structure         Transfer block type         Response codes to the host         Block response delay         UART BSL modes         Header block         Mode 0 - Code/Data download to RAM/100TP         Mode 2 - Code/Data download to NVM         Mode 3 - Code execution inside RAM | 18<br>19<br>19<br>21<br>22<br>22<br>23<br>23<br>24<br>27<br>29<br>29<br>29<br>29<br>32<br>32<br>32<br>37 |
| 4.4.2.6<br>4.4.2.7                                                                                                                                                                                           | Mode 4 - NVM erase          Mode 6 - NVM protection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                          |



| 4.4.2.8 | Mode A - NVM readout, Chip ID, checksum, FastLIN BSL entry com-<br>mand 40 |
|---------|----------------------------------------------------------------------------|
| 4.4.3   | 16 bits inverted XOR checksum 46                                           |
| 4.5     | WDT1 refreshing 46                                                         |
| 5       | NVM                                                                        |
| 5.1     | NVM overview                                                               |
| 5.1.1   | NVM organisation                                                           |
| 5.2     | NVM configuration sectors organisation 50                                  |
| 5.2.1   | Chip ID definition                                                         |
| 5.2.2   | 100 Time Programmable data 53                                              |
| 5.3     | NVM user routines organisation 61                                          |
| 5.3.1   | Opening assembly buffer routine 63                                         |
| 5.3.2   | NVM programming routine 66                                                 |
| 5.3.3   | Page verify routine                                                        |
| 5.3.4   | NVM page erasing routine 72                                                |
| 5.3.5   | Erase page verify routine 74                                               |
| 5.3.6   | Sector erasing routine                                                     |
| 5.3.7   | Erase sector verify routine 76                                             |
| 5.3.8   | Abort NVM programming routine 78                                           |
| 5.3.9   | MapRAM initialization                                                      |
| 5.3.10  | Read NVM status routine 80                                                 |
| 5.3.11  | Read 100 Time Programmable parameter data routine                          |
| 5.3.12  | Program 100 Time Programmable routine                                      |
| 5.3.13  | NVM ECC check routines 84                                                  |
| 5.3.14  | Read NVM ECC2 address routine 86                                           |
| 5.3.15  | RAM MBIST starting routine                                                 |
| 5.3.16  | NVM protection status change routines                                      |
| 5.3.17  | Read NVM config status routine                                             |
| 5.3.18  | Read user calibration data                                                 |
| 5.3.19  | NVMCLKFAC setting routine                                                  |
| 5.4     | NVM user applications                                                      |
| 5.4.1   | NVM Data sector handling                                                   |
| 5.4.2   | Supporting background NVM operation                                        |
| 5.4.3   | Emergency operation handling 104                                           |
| 5.4.3.1 | Emergency operation handling - Type 1 routines                             |
| 5.4.3.2 | Emergency operation handling - Type 2 routines                             |
| 5.4.3.3 | Emergency operation handling timing                                        |
| 5.4.4   | NVM user routines operation                                                |
| 5.4.4.1 | NVM user programming operation                                             |
| 5.4.4.2 | Tearing-safe programming 109                                               |
| 5.4.4.3 | NVM user erase operation                                                   |
| 5.4.4.4 | NVM user programming abort operation                                       |



| 5.4.5 | NVM protection mechanism | 111 |
|-------|--------------------------|-----|
| 6     | Revision history         | 112 |



#### Introduction

## 1 Introduction

This document specifies the BootROM firmware behavior for the TLE986x/TLE987x family. The specification contains the following major sections:

- BootROM overview
- Startup procedure
- BSL features
- NVM structure and user routines description

## 1.1 Purpose

The document describes the functionality of the BootROM firmware.

## 1.2 Scope

The BootROM firmware for the TLE986x/TLE987x family provides the following features:

- Startup procedure for stable operation of TLE986x/TLE987x chip
- Debugger connection for code debug
- · BSL mode for users to download and run code from NVM and RAM
- NVM operation handling, e.g. program and erase

## 1.3 Abbreviations and special terms

#### Table 1-1 Abbreviations and terms

| BSL  | BootStrap Loader            |
|------|-----------------------------|
| CS   | Configuration Sector        |
| EOT  | End of Transmission         |
| EVR  | Embedded Voltage Regulator  |
| NAC  | No Activity Count           |
| NAD  | Node address for diagnostic |
| NEA  | NVM End Address             |
| NLS  | NVM Linear Size             |
| NSA  | NVM Starting Address        |
| NVM  | Non Volatile Memory         |
| OCDS | On-Chip Debug Support       |
| OSC  | Oscillator                  |
| PEM  | Program Execution Mode      |



#### Introduction

| PLL  | Phase-Locked Loop            |
|------|------------------------------|
| SA   | Service Algorithm            |
| SCU  | System Control Unit          |
| SWD  | Serial Wire Debug            |
| VTOR | Vector Table Offset Register |
| WDT  | WatchDog Timer               |

## Table 1-1 Abbreviations and terms (cont'd)



#### Overview

## 2 Overview

This specification describes all firmware features including the operations and tasks defined to support the general startup behaviour and various boot options.

## 2.1 Firmware architecture

TLE986x/TLE987x on-chip BootROM consists of:

- Startup procedure, see Chapter 3
- Bootstrap loader via UART, see Chapter 4
- NVM user routines and NVM integrity handling routines, see Chapter 5

The BootROM in TLE986x/TLE987x is located at  $00000000_{\rm H}$  and so represents the standard reset handler routine.

The startup procedure includes:

- EVR calibration
- MapRAM initialisation
- On-chip oscillator configurations
- NVM protection enabling
- · Branching to different modes

The latched values of TMS, P0.0 and P0.2 at the rising edge of RESET determine the mode of operation to be entered.

BootROM operation modes:

- User / BSL mode
- Debug Support mode

In User mode BootROM performs the following steps: execute the startup procedure, set the vector table position at the beginning of the NVM in user accessible space (by proper setting of the VTOR register) and jump to the user defined reset handler routine (jump to the location pointed by the address  $11000004_{\rm H} - 11000007_{\rm H}$ ) to execute the user program.

Note: The firmware will only set the VTOR to point at the beginning of the user accessible NVM region, but it will not write any vector table. It is a task of the user to download a correct vector table.

 Table 2-1 lists the boot options available in the TLE986x/TLE987x.



#### Overview

| TMS/SWD | P0.0 | P0.2 | Mode                                          |
|---------|------|------|-----------------------------------------------|
| 0       | x    | х    | User mode / BSL mode <sup>1)2)</sup>          |
| 1       | 1    | 0    | Debug Support mode with Serial Wire (SW) port |

## Table 2-1 TLE986x/TLE987x boot options

<sup>1)</sup> On-chip OSC is selected as PLL input. System is running on LP\_CLK until firmware switches to PLL output before jumping to user code. Exception is with hardware reset where user settings are retained.

2) Boot in User mode or BSL mode depends on the NAC word in user memory (NVM).

### 2.2 Program structure

The different sections of the BootROM provide the following basic functionality.

#### Startup procedure

The startup procedure is the main control program in the BootROM. It is the first software controlled operation that is executed after any reset.

The startup procedure will perform configuration sector verification, EVR calibration, onchip oscillator trimming, MapRAM initialisation, BootROM protection, NVM protection and decode the pin-latched values of the TMS, P0.0 and P0.2 to determine which mode it will jump to.

#### User mode

User mode supports user code execution in the NVM address space. However, if NVM is not protected and the bytes at address  $11000004_{H} - 11000007_{H}$  are erased (FF<sub>H</sub>), then device enters Sleep mode. If a valid user reset vector is found at  $11000004_{H}$  (values at  $11000004_{H} - 11000007_{H}$  not equal to FFFFFFF<sub>H</sub>) and a proper NAC value is found, then the BootROM proceeds into User mode. In case an invalid NAC value is found, the device waits forever for a FastLIN BSL communication.

#### FastLIN and UART BSL mode

It is used to support BSL via UART protocol. Downloading of code/data to RAM and NVM related programming is supported in this mode.





## 3 Startup procedure

This chapter describes the BootROM startup procedure in TLE986x/TLE987x.

The startup procedure is the first software-controlled operation in the BootROM that is automatically started after every reset. Certain operations are skipped depending on the type of reset. Refer to next section for further details.

## 3.1 Program structure

The first task executed by the startup firmware is the check of the reset source.

For power-on, brown-out reset or wake-up from Sleep mode reset, RAM test and initialization are executed according to user settings, while they are skipped for other reset types.

Firmware code uses part of the RAM for variable storage, literal pools and stack pointer. The startup code only uses a specific RAM region (the first 1 Kbyte mapped from address  $18000000_H$  to  $180003FF_H$ ), subset of the total available RAM address range. In the remaining region, which is not used by the firmware, the user can store values to be valid across reset for all reset sources different from power-on reset, brown-out reset and wake-up reset. For these three reset sources, either a RAM test or a RAM clear might be executed thus destroying the previously stored values.

After that, depending on the reset source, the firmware will do NVM protection, NVM MapRAM initialisation, on-chip oscillator trimming, PLL setting and analog module trimming. It will decode the pin-latched values of the TMS, P0.0 and P0.2 to determine which mode it will jump to.

If bootup mode is Debug Support mode, the WDT1 is disabled. For entry to User mode, the WDT1 remains active. Next, the firmware will wait for NVM module to be ready.

For software, or internal watchdog reset (triggered by the WDT in the SCU), the following steps are skipped:

- · RAM test and initialisation
- NVM MapRAM initialisation and service algorithm
- Setting of oscillator and PLL and switching system clock input to PLL output
- · Loading of analog modules trimming parameters from first 100TP page
- · Loading of user configuration data from 100TP page into the RAM
- Clearing of NMI status before exit to User mode or Debug Support mode

## 3.1.1 Test and initialization of RAM

A functional test sequence is executed on the entire RAM after power-on reset and brown-out reset. This can be executed optionally after a wake-up reset. The test consists of a linear write/read algorithm using alternating data. Once it is started, the firmware waits until the test is completed, before checking the result and continuing accordingly the startup sequence.



The execution of the RAM test after a wake-up reset is controlled by the MBIST\_EN bit in the PMU->SystemStartConfig register. The user can freely set the value of this bit and its value is kept over wake-up reset. If the bit is set to 0, the RAM test is not performed on wake-up. If the bit is set to 1 then the RAM test is performed even for wake-up resets.

If an error is detected the device is set to loop endlessly with WDT1 enabled.

In case of power-on reset, brown-out reset or wake-up reset from Sleep mode the startup procedure will continue with a complete RAM initialization by writing all the RAM to zero with proper ECC status. This is needed to prevent an ECC error during user code execution due to a write operation to an un-initialised location (with invalid ECC code). Afterwards the Firmware proceeds checking the NVM status.

#### Notes

- 1. Via MBIST EN bit user can only disable the RAM test sequence while the RAM initialization to  $00_H$  is still executed.
- 2. The test sequence on the entire RAM takes 500  $\mu$ s while the initialization of the complete RAM takes 150  $\mu$ s.

## 3.1.2 NVM initialisation routine

This routine will set the NVM protection according to the password in the configuration sector (refer to the **Section 5.4.5** for further details on NVM protection and protection password).

## 3.1.3 NVM MapRAM initialisation

The MapRAM is being used for the EEPROM emulation which is described in the **Section 5.4.1**. After every reset the system performs the MapRAM initialisation. This operation is triggered to restore the MapRAM content.

The operation is executed with different flows depending on the type of reset. These two flows are described in the following chapters.

## 3.1.3.1 NVM MapRAM initialization at high prio reset

During power-on reset, brown-out reset, pin reset or wake-up reset, the MapRAM content is cleared. For this reason, during the following startup sequence the system performs a complete MapRAM initialization. In case during the initialisation at least one error is detected, the service algorithm routine is called to do the repair.

In case of mapping errors, the repair mechanism consists of erasing the wrong pages (either faulty or double mapped pages). The repair step then requires the right of modifying the NVM Data sector content, which can be in contrast to the NVM protection



settings user has provided. To avoid any risk of data loss, the user can control via dedicated 100TP page parameter whether the SA is allowed to proceed to the repair step in case NVM password protection for NVM Data sector is installed.

Detailed description of the MapRAM initialization and repair step can be found in the **Section 5.4.1**.

## 3.1.3.2 NVM MapRAM initialization at low prio reset

During low prio reset (soft reset, internal WDT reset and lockup reset) the content of the MapRAM is not cleared and so a MapRAM initialization is not mandatory. Any of these reset types might occur during an NVM operation on a non-linearly mapped data sector and might result in an inconsistent state of the MapRAM. In order to check MapRAM for consistency, MapRAM initialization is performed for these reset types too. In case of mapping errors no repair step is triggered, so that worst case startup time is not increased.

The result of the NVM Data sector initialization executed during the startup flow is reported to the user via the bit 1 of the SYS\_STRTUP\_STS register (MRMINITSTS). If this bit is set to 1 then the last initialization failed and the mapping info might be corrupted. In this case, a reset (power-on reset, brown-out reset, pin reset, WDT1 reset or wake-up reset) can be issued in order to start the Service Algorithm to try to fix the integrity issue inside the Data NVM. If the MRAMINITSTS is still flagged afterwards, the Data NVM sector has to be re-initialized by performing a sector erase.

## 3.1.4 Oscillator trimming and system clock selection

After every power-on reset, brown-out reset, pin reset or wake-up from sleep reset the system runs with an internal low precision clock (nominally 18 MHz). During the startup procedure, the internal oscillator is trimmed and the PLL is programmed to  $f_{\rm SYS}$  max of the specific device. In order to reduce the boot time, the startup procedure continues to run with the low precision clock while the PLL is locking. System clock will be switched to PLL output before jumping to user or BSL mode in case of successful lock. In case the PLL does not lock the startup sequence proceeds further using the low precision clock as system clock.

Once User mode is entered, the user is allowed to set the final desired frequency by proper register setting.

# Note: After every power-on reset, brown-out reset, pin reset or wake-up reset, the user shall check whether the system is running on the low precision clock or on the PLL output reading the SYSCON0 register.



## 3.1.5 Analog module trimming

In this routine, the trimming values of voltage regulators, LIN module, temperature sensor, bridge driver and other analog modules are read from the configuration sector and written into the respective SFR. For User mode or Debug Support mode, checksum on 100TP page is evaluated. In case of error, default values are used. Refer to **Table 5-11** for a list of user parameters in 100TP page.

## 3.1.6 User configuration data initialization

The firmware provides a routine to download data stored in user accessible configuration sector pages (100TP) during the startup flow. In particular, the routine copies a specified number of bytes from a selected 100TP page (starting always from first byte in the page) into the RAM (starting at a given address). The routine is by default disabled and can be enabled and controlled by proper programming of the bytes stored in first 100TP page as described in the **Table 5-11**. This routine is not performed after a software or watchdog reset.

Relevant routine control parameters stored in the first 100TP page are:

- CS\_USER\_CAL\_STARTUP\_EN (offset=79<sub>H</sub>): When set to C3<sub>H</sub> it enables the user data download from a 100TP page into the RAM during startup flow. All other values will be ignored and the routine will not be executed at startup.
- CS\_USER\_CAL\_XADDH: (offset=7A<sub>H</sub>): It defines the high byte of the RAM starting address where to copy data downloaded from 100TP page. This byte is ignored if the routine is not enabled.
- CS\_USER\_CAL\_XADDL: (offset=7B<sub>H</sub>): It defines the low byte of the RAM starting address where to copy data downloaded from 100TP page. This byte is ignored if the routine is not enabled.
- CS\_USER\_CAL\_100TP\_PAGE: (offset=7C<sub>H</sub>): It defines the 100TP page where data has to be downloaded from (refer to Figure 5-8). This byte is ignored if the routine is not enabled.
- CS\_USER\_CAL\_NUM: (offset=7D<sub>H</sub>): It defines the number of bytes to be downloaded starting from the first byte of the selected 100TP page. This byte is ignored if the routine is not enabled.

The RAM address where the user configuration data has to be copied to is stored as a 16-bit offset to the RAM start address ( $18000000_{H}$ ). This offset is defined by the CS\_USER\_CAL\_XADDL and CS\_USER\_CAL\_XADDH parameters.

The routine has been developed to support downloading of the Customer\_ID and the ADC calibration parameters stored at the beginning of the first 100TP page (see **Table 5-11**) into the RAM for an easy access but can be more generally used for all other CS user parameters. If the routine is enabled, firmware will copy the data from the selected 100TP page into the RAM. Moreover, independent of startup setting, a similar routine is provided as NVM user routine (refer to the **Section 5.3.18**).



## 3.1.7 Debug Support mode entry

Entry to Debug Support mode is determined by pin setting at power-up (see Table 2-1).

In case NVM address  $11000004_{H} - 11000007_{H}$  is not FFFFFFF<sub>H</sub>, the firmware code clears the RAM, waits for debugger to be connected, moves the VTOR to  $11000000_{H}$  and jumps to user code.

## 3.1.8 User mode and BSL mode entry

Entry to User mode is determined by the No Activity Count (NAC) value which is defined in the user code (refer to the Section 3.1.8.1). After waiting the time defined by the current NAC value, the startup procedure sets the VTOR register to point to the beginning of the NVM ( $11000000_H$ ) and jumps to the reset handler.

If NVM double bit error occurs when reading the NAC value, the system goes into endless loop.

Before entering User mode, the system clock frequency is switched to PLL output previously set to the max  $f_{SYS}$  of the device. In case the PLL has not locked within 1 ms, the CPU clock source LP\_CLK (low precision clock running nominally at 18 MHz) will be used.

Note: User mode is entered jumping to the reset handler. This can happen directly from startup routine, after a waiting time for possible BSL communication, or as a result of BSL commands. In all these cases, jump to User mode will only occur either (1) when NVM is not protected and NVM content at  $11000004_{\rm H} - 11000007_{\rm H}$  is not FFFFFFF<sub>H</sub> or (2) when NVM is protected. In all other cases, firmware will put the device in Sleep mode.

## 3.1.8.1 NAC definition

The NAC value defines the time window after reset release in which the firmware is able to receive BSL connection messages. The bits 5 to 0 define the duration of the time window while bit 7 of the NAC defines, which BSL interface is selected. Bit 6 is reserved and not used. If no BSL messages are received on the selected BSL interface during the NAC window and NAC time has expired, the firmware code proceeds to User mode.

There are 2 different BSL interfaces supported, FastLIN and UART.

The FastLIN BSL is an enhanced feature in TLE986x/TLE987x device, supporting a fixed baud-rate of 115.2 kBaud. In order to support the faster baud-rate, the protocol is the same of UART BSL, implemented in the integrated LIN transceiver (refer to **Chapter 4** for protocol description).



After ending the startup procedure, the program will detect any activities on the LIN/ UART for a period of time, determined by (((NAC &  $3F_H$ ) -1<sub>H</sub>) \* 5) ms reduced by the time already spent to perform the startup procedure. When nothing is detected on the LIN/ UART and (((NAC &  $3F_H$ ) -1<sub>H</sub>) \* 5) ms is passed from reset going high, the microcontroller will jump to User mode. If NAC(5:0) is 1<sub>H</sub>, the BSL window is closed, no BSL connection is possible and User mode is entered without delay.

The maximum NAC value is restricted to  $C_H$  as the first open WDT1 window is worst case 65 ms. In case a valid BSL command is detected during the BSL window the firmware suspends the counting of the WDT1 in order to avoid that requested BSL communication is broken by a WDT1 reset. The firmware will then re-enable the WDT1 before jumping to user code. If NAC is not valid, BootROM code will switch off the WDT1 and wait for a FastLIN entry sequence infinitely.

**Table 3-1** gives an overview of the action of the microcontroller with respect to No Activity Count (NAC) values and the **Table 3-2** shows the selection of the BSL interface depending on the NAC bit 7.



| Table 3-1         Type of action w.r.t. No Activity Count (NAC) values |                                                       |  |
|------------------------------------------------------------------------|-------------------------------------------------------|--|
| NAC value (5:0)                                                        | Action                                                |  |
| 01 <sub>H</sub>                                                        | 0 ms delay. Jump to User mode immediately             |  |
| 02 <sub>H</sub>                                                        | 5 ms delay before jumping to User mode <sup>1)</sup>  |  |
| 03 <sub>H</sub>                                                        | 10 ms delay before jumping to User mode <sup>1)</sup> |  |
| 04 <sub>H</sub>                                                        | 15 ms delay before jumping to User mode <sup>1)</sup> |  |
| 05 <sub>H</sub>                                                        | 20 ms delay before jumping to User mode <sup>1)</sup> |  |
| 06 <sub>H</sub>                                                        | 25 ms delay before jumping to User mode <sup>1)</sup> |  |
| 07 <sub>H</sub>                                                        | 30 ms delay before jumping to User mode <sup>1)</sup> |  |
| 08 <sub>H</sub>                                                        | 35 ms delay before jumping to User mode <sup>1)</sup> |  |
| 09 <sub>H</sub>                                                        | 40 ms delay before jumping to User mode <sup>1)</sup> |  |
| 0A <sub>H</sub>                                                        | 45 ms delay before jumping to User mode <sup>1)</sup> |  |
| 0B <sub>H</sub>                                                        | 50 ms delay before jumping to User mode <sup>1)</sup> |  |
| 0C <sub>H</sub>                                                        | 55 ms delay before jumping to User mode <sup>1)</sup> |  |
| 0D <sub>H</sub> - 3F <sub>H</sub> , 00 <sub>H</sub> , Invalid          | Wait forever for the first frame                      |  |

<sup>1)</sup> If a FastLIN frame/UART frame is received within the delay period, the following actions occur; (1) the remaining delay is ignored, (2) it will not enter User mode anymore (3) it will process the FastLIN / UART frame accordingly.



| Table 3-2 | BSL Interface selection via NAC |             |  |
|-----------|---------------------------------|-------------|--|
| NAC(7)    |                                 | Action      |  |
| 0         |                                 | FastLIN BSL |  |
| 1         |                                 | UART BSL    |  |

For each variant, the NAC value is stored, together with the NAD value, in the last 4 bytes of the linearly mapped NVM region. To ensure the parameter validity, the actual and inverted values of the 2 parameters are checked. In case the stored value and inverted value are not consistent (value + inverted value + 1 not equal to 0) the parameter is considered to be invalid and the default value is used. The BSL window will be open indefinitely and FastLIN is selected as BSL interface.

The **Table 3-3** shows the addresses for all the available family devices. In the table NSA stands for NVM Starting Address (the value is equal to  $11000000_{\text{H}}$  for all variants) and NLS stands for NVM Linear Size, in bytes, whose value is variant dependent.

| Address                  | User defined value            | Criteria / Range                                                                                    | Default         |
|--------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------|-----------------|
| NSA+(NLS-4) <sub>H</sub> | NAC                           | 01 <sub>H</sub> - 0C <sub>H</sub> for FastLIN BSL<br>81 <sub>H</sub> - 8C <sub>H</sub> for UART BSL | 7F <sub>H</sub> |
| NSA+(NLS-3) <sub>H</sub> | NAC                           | 1's complement                                                                                      | -               |
| NSA+(NLS-2) <sub>H</sub> | NAD (for FastLIN<br>BSL only) | 01 <sub>H</sub> - FF <sub>H</sub> (00 <sub>H</sub> is reserved)                                     | 7F <sub>H</sub> |
| NSA+(NLS-1) <sub>H</sub> | NAD (for FastLIN<br>BSL only) | 1's complement                                                                                      | -               |

Table 3-3 NAC and NAD parameters details

For NSA and NLS values refer to Table 5-2.

## 3.1.9 Node Address for Diagnostic (NAD)

The NAD value is stored similarly to the NAC value in NVM. This field specifies the address of the active slave node. Only slave nodes have an address. The NAD address range supported in TLE986x/TLE987x is listed in Table 3-4.

| Table 3-4 | NAD address range |
|-----------|-------------------|
|-----------|-------------------|

| NAD Value                          | Description           |
|------------------------------------|-----------------------|
| 00 <sub>H</sub>                    | Invalid Slave Address |
| $01_{\rm H}$ to ${\rm FE}_{\rm H}$ | Valid Slave Address   |



| Table 3-4       | NAD address range (cont'd)                                                                          |  |
|-----------------|-----------------------------------------------------------------------------------------------------|--|
| NAD Value       | Description                                                                                         |  |
| 7F <sub>H</sub> | Default Address (NAD value is invalid or it is not programmed in NVM linear area)                   |  |
| FF <sub>H</sub> | Broadcast Address (The actual NAD value stored in the NVM is not checked. Communication is granted) |  |

If the NAD value is not programmed in the NVM linear region or in case its value is invalid (value and inverted value not consistent), the NAD is assumed to be 7F<sub>H</sub>.





## 4 FastLIN and UART BSL mode

This chapter describes the protocol used for the FastLIN and UART BSL.

Both FastLIN and UART BSL share the same protocol. FastLIN BSL communication is performed via the integrated LIN transceiver while UART BSL is performed via the full duplex UART interface (UART1, UART send P0.1, UART receive P1.4).

## Note: UART BSL expects a full duplex communication. A connection of an external LIN transceiver to P0.1/P1.4 is not supported by UART BSL.

Although FastLIN BSL uses the same protocol as UART BSL, the connection sequence is different. To protect the FastLIN BSL from unwanted entries, a special entry sequence must be executed before FastLIN BSL is fully enabled. In addition, the FastLIN BSL is always executed at a fixed baud-rate of 115.2 kBaud.

## 4.1 FastLIN and UART BSL protocol

The FastLIN and UART BSL protocol is based on the following two phases:

- Phase I: Establish a serial connection
  - For FastLIN BSL the device automatically sets a baud-rate of 115.2 kBaud and waits for a specific command entry sequence before enabling all FastLIN BSL supported features (refer to the Section 4.3).
  - For UART BSL the device automatically synchronizes transfer speed (baudrate) with the serial communication partner (host) for UART. (refer to the Section 4.2).
- **Phase II**: Perform the serial communication with the host. The host controls communication by sending header information which selects one of the working modes (refer to the Section 4.4) These modes are:
  - Mode 0 (00H): Transfer a user program from the host to RAM or write 100TP pages<sup>1)</sup>
  - Mode 1 (01H): Execute a user program in the RAM<sup>2)</sup>
  - Mode 2 (02H): Transfer a user program from the host to NVM<sup>1)</sup>
  - Mode 3 (03H): Execute a user program in the NVM<sup>2)</sup>
  - Mode 4 (04H): Erase NVM<sup>1)</sup>
  - Mode 6 (06H): Permanent NVM protection mode enabling/disabling scheme<sup>2)</sup>
  - Mode A (0AH): Get Info (based on option byte)<sup>1)</sup>

<sup>1)</sup> The microcontroller returns to the beginning of phase II and waits for the next command from the host.

<sup>2)</sup> UART BSL and serial communication are terminated.



Except **Mode 1**, **Mode 3** and **Mode 6**, the microcontroller returns to the beginning of Phase II and waits for the next command from the host after executing all other modes.

All serial communication is performed via the integrated LIN transceiver for FastLIN and via the full duplex serial interface (UART1) of the TLE986x/TLE987x for UART BSL.

The serial transfer works in asynchronous mode with the serial parameters 8N1 (eight data bits, no parity and one stop bit).

The following section provides detailed information on these two phases.

## 4.2 Phase I for UART BSL: Automatic serial synchronization to the host

Upon entering UART BSL mode, a serial connection is established and the transfer speed (baud-rate) of the serial communication partner (host) is automatically synchronized in the following steps, a simplified entry flow is depicted in Figure 4-1:

- STEP 1: Initialize serial interface for reception and timer for baud-rate measurement
- STEP 2: Wait for test byte (80<sub>H</sub>) from host
- · STEP 3: Synchronize the baud-rate to the host
- STEP 4: Send acknowledge byte (55<sub>H</sub>) to the host
- STEP 5: Enter Phase II

## 4.2.1 General description

The microcontroller will set the serial port of the UART1 to mode 1 (8-bit UART, variable baud-rate) for communication. Timer 2 will be set in Auto-Reload mode (16-bit timer) for baud-rate measurement. In the process of waiting for the test byte ( $80_H$ ), microcontroller will start the timer on reception of the start bit (0) and stop it on reception of the last bit of the test byte (1). Then the UART BSL routine calculates the actual baud-rate, sets the PRE and BR\_VALUE values and activates baud-rate generator. When the synchronization is done, the microcontroller sends back the acknowledge byte ( $55_H$ ) to the host. If the synchronization fails, the baud-rates for the microcontroller cannot be received properly by the host. In this case, on the host side, the host software may give a message to the user, e.g. asking the user to repeat the synchronization procedure. On the microcontroller side, the UART BSL routine cannot judge whether the synchronization is correct or not. It always enters phase II after sending the acknowledge byte. Therefore, if synchronization fails, a reset of the microcontroller has to be invoked, in order to start a new synchronization attempt.



## MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

#### FastLIN and UART BSL mode



Figure 4-1 BSL entry flow (simplified)



## 4.2.2 Calculation of BR\_VALUE and PRE values

For the baud-rate synchronization of the microcontroller to the fixed baud-rate of the host, the UART BSL routine waits for a test byte  $(80_H)$ , which has to be sent by the host. By polling the receive port of the serial interface (P1\_DATA.4/RxD Pin), the Timer2 (T2) is started on the reception of the start bit (0) and stopped on the reception of the last bit of the test byte (1). Hence the time recorded is the receiving time of 8 bits (1 start bit plus 7 least significant bits of the test byte). The resulting timer value is 16-bit (T2). This value is used to calculate the 11-bit auto-reload value (BR\_VALUE stored in the BGH and BGL SFRs), the fractional divider FDSEL and PRE, with T2PRE predefined as 011. This calculation needs two formulas.

First, the correlation between the baud-rate (baud) and the reload value (BG) depends on the internal peripheral frequency ( $f_{PCLK}$ )

$$baud = \frac{f_{PCLK}}{16 \times PRE \times \left(BR_VALUE + \frac{FDSEL}{32}\right)}$$
[4.1]

Second, the relation between the baud-rate (baud) and the recording value of Timer2 (T2) depends on the T2 peripheral frequency ( $f_{T2}$ ) and the number of received bits ( $f_{T2}N_b$ )

baud = 
$$\frac{f_{T2} \times N_b}{T2}$$
 [4.2]

Combining Equation [4.1] and Equation [4.2] with N<sub>b</sub>=8, f<sub>T2</sub>=f<sub>PCLK</sub>/8 (T2PRE=011),

$$\frac{f_{PCLK}}{16 \times PRE \times \left(BR_VALUE + \frac{FDSEL}{32}\right)} = \frac{\frac{f_{PCLK}}{8} \times 8}{T2}$$
[4.3]

Simplifying Equation [4.3], we get

$$PRE \times \left(BR_VALUE + \frac{FDSEL}{32}\right) = \frac{T2}{16}$$
[4.4]

After setting BR\_VALUE, FDSEL and PRE, the baud-rate generator will then be enabled, and the UART BSL routine sends an acknowledge byte ( $55_H$ ) to the host. If this byte is received correctly, it will be guaranteed that both serial interfaces are working with the same baud-rate.

MOTIX<sup>™</sup> TLE986x, MOTIX<sup>™</sup> TLE987x, BootROM



#### FastLIN and UART BSL mode

### 4.3 Phase I for FastLIN BSL: FastLIN BSL entry sequence

Upon entering FastLIN BSL mode, there is no automatic synchronization to the host transfer speed. The device sets the baud-rate to 115.2 kBaud. Please also refer to the simplified entry flow in Figure 4-1.

In addition, the FastLIN mode is protected against unwanted entries, i.e. because of noise on the communication line. In order to establish a FastLIN connection, the following sequence must be sent to the device during the active BSL connection window (NAC).

- STEP 1: Host to send the "Get Chip ID for FastLIN BSL entry" command
- STEP 2: Device to answer with acknowledge (55<sub>H</sub>)
- STEP 3: Device to answer with the Chip ID

Get Chip ID for FastLIN BSL entry is described in the Section 4.4.2.8.

If the sequence has been passed to the device during the BSL active window and the device has acknowledged the commands and answered with the Chip ID then the FastLIN BSL connection is established, the NAC and the WDT1 will be disabled and the device will wait for further FastLIN BSL commands.

### 4.4 Phase II: Serial communication protocol and the working modes

Once the BSL communication is established, the FastLIN or UART BSL enters Phase II, during which it communicates with the host to select the desired working modes. The detailed communication protocol is explained as follows: from now on, both FastLIN and UART BSL modes share the same UART BSL protocol.

#### 4.4.1 Serial communication protocol

The communication between the host and the UART BSL routine is done by a simple transfer protocol. The information is sent from the host to the microcontroller in blocks. All the blocks follow the specified block structure. The host is sending several transfer blocks and the UART BSL routine is just confirming them by sending back single acknowledge or error bytes. The microcontroller itself does not send any transfer blocks.

However, the above rule does not apply to some modes where the microcontroller might need to send the required data to the host besides the acknowledge or error byte (e.g. Mode A).



## 4.4.1.1 Transfer block structure

A transfer block consists of three parts:

| Block Type<br>(1 byte) | <b>Data Area</b><br>(X bytes) | <b>Checksum</b><br>(1 byte) |  |
|------------------------|-------------------------------|-----------------------------|--|
|                        | ()                            | (1 = 500)                   |  |

- **Block Type**: The type of block, which determines how the bytes in the data area are interpreted. Implemented block types are:
  - 00<sub>H</sub> type "Header"
  - 01<sub>H</sub> type "Data"
  - 02<sub>H</sub> type "End of Transmission" (EOT)
- Data area: A list of bytes, which represents the data of the block. The length of data area cannot exceed 128 bytes for Mode 0 and 2. For Mode 2, the length of data area must always be 128 bytes. This is due to the fact that NVM is written page-wise.
- Checksum: The XOR checksum of the block type and data area.

The host will decide the number of transfer blocks and their respective lengths during one serial communication process. For safety purpose, the last byte of each transfer block is a simple checksum of the block type and data area. The host generates the checksum by XOR-ing all the bytes of the block type and data area. Every time the UART BSL routine receives a transfer block, it recalculates the checksum of the received bytes (block type and data area) and compares it with the attached checksum.

Note: If there is less than one page to be programmed to NVM, the PC host will have to fill up the vacancies with  $00_{H}$ , and transfer data in the length of 128 bytes.

## 4.4.1.2 Transfer block type

There are three types of transfer blocks depending on the value of the block type. **Table 4-1** provides the general information on these block types. More details will be described in the corresponding sections later.



| Table 4-1    | Type of trans   | fer block                                                                                                                                                                                                                                                 |  |  |  |
|--------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Block name   | Block type      | Description                                                                                                                                                                                                                                               |  |  |  |
| Header block | 00 <sub>H</sub> | This block has a fixed length of 8 bytes. Special information is contained in the data area of the block, which is used to select different working modes.                                                                                                |  |  |  |
| Data block   | 01 <sub>H</sub> | This block length depends on the special information<br>given in the previous header block. This block is used in<br>working Mode 0 and 2 to transfer a portion of program<br>code. The program code is contained in the data area of<br>the block.       |  |  |  |
| EOT block    | 02 <sub>H</sub> | This block length depends on the special information<br>given in the previous header block. This block is the last<br>block in data transmission in working Mode 0 and 2. The<br>last program code to be transferred is in the data area of<br>the block. |  |  |  |

## 

#### 4.4.1.3 Response codes to the host

The microcontroller communicates to the host whether a block has been successfully received by sending out a response code. If a block is received correctly, an acknowledge code (55<sub>H</sub>) is sent. In case of failure, an error code is returned. There are two possible error codes,  $FF_{H}$  or  $FE_{H}$ , reflecting the two possible types of fail, block type or Checksum Error. A Block Type Error occurs when either a not implemented block type or transfer blocks in wrong sequence are received. For example, if in working mode 0 two consecutive header blocks are received a Block Type Error is detected and a Block Type Error  $(FF_H)$  indication is returned. A Checksum Error occurs when the checksum comparison on a received block fails. In such a case, the transfer is rejected and a Checksum Error (FE<sub>H</sub>) indication is returned. In both error cases the UART BSL routine awaits the actual block from the host again.

When program and erase operation of NVM is restricted due to enabled NVM protection, only Mode 1 and 3 and some options of Mode A are allowed. All other modes are blocked and a Protection Error code (FD<sub>H</sub>) will be sent to host. This will indicate that NVM is protected and no programming and erasing are allowed. In this error case, the UART BSL routine will wait for the next header block from the host again.

Table 4-2 gives a summary of the response codes to be sent back to the host by the microcontroller after it receives a transfer block.



| able 4-2 Type of response codes                               |  |  |  |  |  |  |
|---------------------------------------------------------------|--|--|--|--|--|--|
| Response code to the host                                     |  |  |  |  |  |  |
| 55 <sub>H</sub>                                               |  |  |  |  |  |  |
| FF <sub>H</sub>                                               |  |  |  |  |  |  |
| FE <sub>H</sub>                                               |  |  |  |  |  |  |
| FD <sub>H</sub>                                               |  |  |  |  |  |  |
| 0FB <sub>H</sub> only valid for Mode 0 option F0 <sub>H</sub> |  |  |  |  |  |  |
| 0FA <sub>H</sub> only valid for Mode 0 option F0 <sub>H</sub> |  |  |  |  |  |  |
| 0F9 <sub>H</sub> only valid for Mode 0 option F0 <sub>H</sub> |  |  |  |  |  |  |
|                                                               |  |  |  |  |  |  |

### Table 4-2 Type of response codes

**Table 4-3** shows a tabulated summary of the possible responses the device may transmit following the reception of a header, data or EOT block.

| Mode | Header block                                                             | Data block                                          | EOT block                                                                                  |
|------|--------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------|
| 0    | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Protection Error | Acknowledge,<br>Block Type Error,<br>Checksum Error | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Combined/ID/InPage<br>offset error |
| 1    | Acknowledge,<br>Block Type Error,<br>Checksum Error                      |                                                     |                                                                                            |
| 2    | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Protection Error | Acknowledge,<br>Block Type Error,<br>Checksum Error | Acknowledge,<br>Block Type Error,<br>Checksum Error                                        |
| 3    | Acknowledge,<br>Block Type Error,<br>Checksum Error                      |                                                     |                                                                                            |
| 4    | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Protection Error |                                                     |                                                                                            |

 Table 4-3
 Possible responses for various block types



| Table 4-3 | Possible responses for various block types (cont'd) |
|-----------|-----------------------------------------------------|
|-----------|-----------------------------------------------------|

| Mode | Header block                                                             | Data block | EOT block |
|------|--------------------------------------------------------------------------|------------|-----------|
| 6    | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Protection Error |            |           |
| A    | Acknowledge,<br>Block Type Error,<br>Checksum Error,<br>Protection Error |            |           |

The responses are defined in **Table 4-4**, which lists the possible reasons and/or implications for error and suggests the possible corrective actions that the host can take upon notification of the error.

| Response            | Value           | Description            |         |                                                                                                              |                                    |  |  |
|---------------------|-----------------|------------------------|---------|--------------------------------------------------------------------------------------------------------------|------------------------------------|--|--|
|                     |                 | Block BSL<br>type mode |         | Reasons / Implications                                                                                       | Corrective action                  |  |  |
| Acknow-<br>ledge    | 55 <sub>H</sub> | Head<br>er             | 1, 3    | The requested operation will<br>be performed once the<br>response is sent.                                   |                                    |  |  |
|                     |                 |                        |         | The requested operation has<br>been performed and was<br>successful. Requested data<br>transmission follows. |                                    |  |  |
|                     |                 |                        | 6       | The requested operation has                                                                                  |                                    |  |  |
|                     |                 | EOT                    | 0, 2, 4 | been performed and was<br>successful.                                                                        |                                    |  |  |
|                     |                 | All other combinations |         | Reception of the block was successful. Ready to receive the next block.                                      |                                    |  |  |
| Block Type<br>Error | FF <sub>H</sub> | Head<br>er             | 2, 4, A | Start address in mode data is<br>not within NVM address<br>range or invalid 100TP page.                      | Retransmit a valid<br>header block |  |  |
|                     |                 | All o<br>combir        |         | Either the block type is<br>undefined or option is invalid<br>or the flow is invalid.                        | Retransmit a valid<br>block        |  |  |

 Table 4-4
 Definitions of responses



| Response                         | Value                                                                                                                     | Description                                                                                                                  |                          |                                                                                                  |                             |  |  |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------|-----------------------------|--|--|
|                                  |                                                                                                                           | Block BSL<br>type mode                                                                                                       |                          | Reasons / Implications                                                                           | Corrective action           |  |  |
| Checksum<br>Error                | FE <sub>H</sub>                                                                                                           |                                                                                                                              | ll<br>nations            | There is a mismatch between<br>the calculated and the<br>received checksum.                      | Retransmit a valid<br>block |  |  |
| Protection<br>Error              | FD <sub>H</sub> Head<br>er0, 2,<br>4, 6, AProtection against external<br>access enabled, i.e. user-<br>password is valid. |                                                                                                                              | Disable protection       |                                                                                                  |                             |  |  |
| Combined<br>Offset<br>Error Code | FB <sub>H</sub>                                                                                                           | 100TP page 1 and there is at<br>least 1 byte with a not in page<br>offset and 1 byte pointing to<br>the Customer_ID reserved |                          | 100TP page 1 and there is at<br>least 1 byte with a not in page<br>offset and 1 byte pointing to | Check the byte<br>offset    |  |  |
| ID Offset<br>Error Code          |                                                                                                                           |                                                                                                                              | Check the byte<br>offset |                                                                                                  |                             |  |  |
| Combined<br>Offset<br>Error Code | F9 <sub>H</sub>                                                                                                           | EOT                                                                                                                          | 0                        | There is at least 1 byte with a not in page offset.                                              | Check the byte<br>offset    |  |  |

#### Table 4-4 Definitions of responses (cont'd)

## 4.4.1.4 Block response delay

As described in the **Section 4.4.1.3**, after receiving any block the microcontroller communicates to the host whether the block was successfully received by sending out a response code. If a block is received correctly, an acknowledge code (55H) is sent. In case of failure, an error code is returned.

The response is transmitted with a delay that depends on the selected mode and on the type of the block received.

The following **Table 4-5** reports the maximum response delay for each mode and block type.



| Mode   | Option | Description                   |                               | Block type          |                     |
|--------|--------|-------------------------------|-------------------------------|---------------------|---------------------|
|        |        |                               | Header                        | Data                | EoT                 |
| Mode 0 | 0x00   | Download Code/<br>Data to RAM | 250 us                        | 1 µs per byte       | 1 µs per byte       |
|        | 0xF0   | Download data to 100TP pages  | 250 µs                        | 1 µs per byte       | 10 ms <sup>1)</sup> |
| Mode 1 |        | RAM code<br>execution         | 250 µs                        |                     |                     |
| Mode 2 |        | Download Code/<br>Data to NVM | 250 µs                        | 10 ms <sup>1)</sup> | 10 ms <sup>1)</sup> |
| Mode 3 |        | NVM code<br>execution         | 250 µs                        |                     |                     |
| Mode 4 | 0x00   | NVM page erase                | 4.5 ms                        |                     |                     |
|        | 0x40   | NVM sector erase              | 4.5 ms                        |                     |                     |
|        | 0xC0   | NVM mass erase                | 4.5 ms per sector             |                     |                     |
| Mode 6 |        | NVM protection set            | 10 ms <sup>1)</sup>           |                     |                     |
|        |        | NVM protection reset          | 4.5 ms + 4.5<br>ms per sector |                     |                     |
| Mode A | 0x00   | Get Chip ID                   | 250 µs                        |                     |                     |
|        | 0x10   | NVM page<br>checksum check    | 250 µs                        |                     |                     |
|        | 0x18   | NVM mass<br>checksum check    | 100 ms                        |                     |                     |
|        | 0x50   | 100TP page<br>checksum check  | 250 µs                        |                     |                     |
|        | 0xC0   | NVM page                      | 250 µs                        |                     |                     |
|        | 0xF0   | 100TP page                    | 250 µs                        |                     |                     |

## Table 4-5 Maximum response delay

<sup>1)</sup> Time needed for data collection, OpenAB, erasing old data (if required) and programming the data given.



## 4.4.2 UART BSL modes

When the UART BSL routine enters Phase II, it first waits for an 8-byte long header block from the host. The header block contains the information for the selection of the working modes. Depending on this information, the UART BSL routine selects and activates the desired working mode. If the microcontroller receives an incorrect header block, the UART BSL routine sends, instead of an acknowledge code, a checksum or block type Error code to the host and awaits the header block again. In this case the host may react by re-sending the header block or by releasing a message to the user.

## 4.4.2.1 Header block

The header block is always the first transfer block to be sent by the host during one data communication process. It contains the working mode number and special information on the related mode (referred to as "Mode Data"). The general structure of a header block is shown below.

| Block Type      | pe Data Area |           |                       |  |
|-----------------|--------------|-----------|-----------------------|--|
| 00 <sub>H</sub> | Mode         | Mode Data | Checksum     (1 byte) |  |
| (Header Block)  | (1 byte)     | (5 bytes) |                       |  |

Description:

- Block Type 00<sub>H</sub>: The block type, which marks the block as a header block.
- Mode: The mode to be selected. The implemented modes are covered in Chapter 4.
- **Mode Data**: Five bytes of special information, which are necessary to activate corresponding working mode.
- Checksum: The checksum of the header block.

## 4.4.2.2 Mode 0 - Code/Data download to RAM/100TP

Mode 0 is used to transfer a user program or data from the host to the RAM of the microcontroller via serial interface. Selecting the proper mode option, this mode can be used to transfer data into the user configuration sector pages. In this case, user has to transfer data to the RAM in accordance with the format reported in the **Table 5-12** and after EOT block has been received, data is automatically copied with proper offset in the target page.

Different options supported are:

- Option 00<sub>H</sub>: RAM download
- Option F0<sub>H</sub>: RAM download and configuration sector page programming

The header block for this working mode has the following structure:



#### The header block for RAM download (option = 00<sub>H</sub>)

|                                  |                                    |                               | Mod                          | le Data ( 5 by              | tes)                 |                                                       |                      |
|----------------------------------|------------------------------------|-------------------------------|------------------------------|-----------------------------|----------------------|-------------------------------------------------------|----------------------|
| <b>00</b> н<br>(Header<br>Block) | <b>00<sub>н</sub></b><br>(Mode 0 ) | StartAddr<br>High<br>(1 byte) | StartAddr<br>Low<br>(1 byte) | Block<br>Length<br>(1 byte) | Not Used<br>(1 byte) | <b>Option</b><br>= <b>00</b> <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |

Mode Data Description:

**Start Addr High, Low**: 16-bit start address, which determines where to copy the received program codes into the RAM.

Block Length: The length (number of bytes) of the following data blocks or EOT block.

Not Used: This byte is not used and will be ignored.

**Option**: Set to 00<sub>H</sub> for RAM download.

Note: RAM address provided as input in Mode 0 has to be considered as an offset to be added to the standard RAM starting address of the TLE986x/TLE987x.

In option 00H start address can be each valid RAM offset address. Data sent in the following data/ EOT blocks will be copied into the RAM at the specified address (18000000<sub>H</sub> + StartAddr).

#### The header block for RAM download and 100TP page programming (option = F0<sub>H</sub>)

| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>00<sub>H</sub></b><br>(Mode 0 ) | StartAddr<br>High<br>(1 byte) | StartAddr<br>Low<br>(1 byte) | Block<br>Length<br>(1 byte) | <b>100TP</b><br><b>Page</b><br>( 1 byte) | <b>Option</b><br>(1 Byte) | Checksum<br>(1 byte) |
|--------------------------------------------|------------------------------------|-------------------------------|------------------------------|-----------------------------|------------------------------------------|---------------------------|----------------------|

Mode Data Description:

**Start Addr High, Low**: 16-bit start address, which determines where to copy the received data in the RAM.

Block Length: The length of the following data blocks or EOT block.

**100TP Page**: This byte is used to select the desired 100TP page to be programmed. This byte is relevant only in case option  $F0_H$  is used. The 100TP page is selected according to the addressing scheme reported in Figure 5-8.

**Option**: Set to F0<sub>H</sub> for RAM download and 100TP page programming.



Using this option, user can write data into the 100TP pages. In this case, data has to be sent to the RAM according to the **Table 5-12** and therefore start address has to be equal to  $18000400_{\text{H}}$ . In case a different starting address is provided, the operation will result in a Block Type Error indication. When this option is selected a proper 100TP page has to be provided.

Note: RAM address provided as input in Mode 0 has to be considered as an offset to be added to the standard RAM starting address of the TLE986x/TLE987x. So, for option  $FO_H$ , the Start Addr parameter has to be set to  $0400_H$ .

All other options will be treated as option  $00_{H}$ .

Note: The **Block Length** refers to the whole length (block type, data area and checksum) of the following transfer block (data block or EOT block).

After successfully receiving the header block, the microcontroller enters Mode 0, during which the program codes are transmitted from the host to the microcontroller by data block and EOT block, which are described as below.

#### The data block



Description:

**Program Code**: The program code has a length of ((**Block Length**) - 2) byte, where the **Block Length** is provided in the previous header block.

#### The EOT block

| 02 <sub>н</sub><br>(EOT<br>Block) | Last<br>Codelength<br>(1 byte) | Program Code<br>(Last Codelength<br>bytes) | Not Used<br>(((Block Length) – 3 – (Last<br>Codelength)) bytes) | Checksum<br>(1 byte) |  |
|-----------------------------------|--------------------------------|--------------------------------------------|-----------------------------------------------------------------|----------------------|--|
|-----------------------------------|--------------------------------|--------------------------------------------|-----------------------------------------------------------------|----------------------|--|

Description:

Last Codelength: This byte indicates the length of the program code in this EOT block.

**Program Code**: The last program code to be sent to the microcontroller.

Not used: The length is ((Block Length) - 3 - (Last Codelength)) bytes.



When trying to program 100TP page, some special error handling is provided.

In particular, in addition to the generic error code, the UART BSL Mode 0 option  $\mathrm{F0}_{\mathrm{H}}$  may return:

- BLOCKFAULT indication (FF<sub>H</sub>) in case of wrong config sector page selection.
- INPAGEOFFSETFAULT indication (F9<sub>H</sub>) in case at least one byte has an offset > 7E<sub>H</sub>, i.e. has a not in page offset or is targeting the page counter (refer to Table 5-12). In this case, the program for the valid bytes is still performed.
- IDOFFSETFAULT indication (FA<sub>H</sub>) in case at least one byte is targeting the Customer\_ID reserved region when programming 100TP page 1. In this case, the program for the valid bytes is still performed.
- COMBOFFSETFAULT indication (FB<sub>H</sub>) in case at least one byte is targeting the Customer\_ID reserved region when programming 100TP page 1 and at least 1 byte has a not in page offset or is targeting the page counter. In this case, the program for the valid bytes is still performed.

## 4.4.2.3 Mode 1 - Code execution inside RAM

Mode 1 is used to execute a user program in the RAM of the microcontroller at the address pointed by the RAM location  $18000404_{\text{H}}$ . The header block for this working mode has the following structure:

#### The header block

|                                  |                                   | Mode Data ( 5 bytes) |                      |
|----------------------------------|-----------------------------------|----------------------|----------------------|
| <b>00</b> н<br>(Header<br>Block) | <b>01<sub>H</sub></b><br>(Mode 1) | Not Used             | Checksum<br>(1 byte) |

Mode Data Description:

Not used: The five bytes are not used and will be ignored in Mode 1.

In working mode 1, the header block is the only transfer block to be sent by the host, no further serial communication is necessary. The microcontroller will exit the UART BSL mode, set the vector table in RAM at address  $18000400_{\text{H}}$  and branch to the address pointed by the standard reset handler ( $18000404_{\text{H}}$ ).

## 4.4.2.4 Mode 2 - Code/Data download to NVM

Mode 2 is used to transfer a user program from the host to the NVM of the microcontroller via serial interface. This mode is not accessible if NVM protection is installed.

The header block for this working mode has the following structure:



#### The header block

| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>02<sub>H</sub></b><br>(Mode 2) | StartAddr<br>4<br>(MSB) | StartAddr<br>3 | StartAddr<br>2 | StartAddr<br>1<br>(LSB) | Block<br>Length<br>(1 byte) | Checksum<br>(1 byte) |
|--------------------------------------------|-----------------------------------|-------------------------|----------------|----------------|-------------------------|-----------------------------|----------------------|

#### Mode Data Description:

**Start Addr 4, 3, 2, and 1**: 32-bit start address, which determines where to copy the received program codes in the NVM. This address must be aligned to the page address (bit[6:0] = 0).

**Block Length**: The length of the following data blocks or EOT block. If data blocks are to be sent, the block length has to be 130 (128+2) bytes. If only EOT block is sent, the block length has to be 131 (128+3) bytes. Other block length values than 130 (data block) or 131 (EOT block) are not allowed.

Note: If the data starts in a non-page address, PC host must fill up the beginning vacancies with  $00_H$  and provide the start address of that page. For e.g., if data starts in  $11000F82_H$ , the PC host will fill up the addresses  $11000F80_H$  and  $11000F81_H$  with  $00_H$  and provide the **Start Address**  $11000F80_H$  to microcontroller. Moreover, if data is only 8 bytes, the PC host will also fill up the remaining addresses with  $00_H$  and transfer 128 data bytes. The **Block Length** refers to the whole length (block type, data area and checksum) of the following transfer block (data block or EOT block).

After successfully receiving the header block, the microcontroller enters Mode 2, during which the program codes are transmitted from the host to the microcontroller by data block and EOT block, which are described as below.

#### The data block

#### Description:

**Program Codes**: The program codes have a length of ((**Block Length**) - 2) bytes, where **Block Length** is provided in the previous header block.



### The EOT block

| <b>02<sub>н</sub></b><br>(EOT<br>Block) | Last<br>Codelength<br>(1 byte) | Program Code<br>(Last Codelength<br>bytes) | <b>Not Used</b><br>(((Block Length) – 3 – (Last<br>Codelength)) bytes) | Checksum<br>(1 byte) |  |
|-----------------------------------------|--------------------------------|--------------------------------------------|------------------------------------------------------------------------|----------------------|--|
|                                         |                                |                                            |                                                                        |                      |  |

Description:

Last Codelength: This byte indicates the number of program code bytes in this EOT block.

Program Code: The last program code bytes to be sent to the microcontroller.

Not used: The length is ((Block Length) - 3 - (Last Codelength)) bytes.

The following Figures show examples of how to program one or several NVM pages using working mode 2.





Figure 4-2 Single NVM page program via working mode 2



## MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

#### FastLIN and UART BSL mode

| Programmir<br>Host                  | g second, third a           | ind fourth pag                   | e of the first Li                 | near sector : f                                   | NVM address                      | es 11000080,                       |                          | TLE98×× |
|-------------------------------------|-----------------------------|----------------------------------|-----------------------------------|---------------------------------------------------|----------------------------------|------------------------------------|--------------------------|---------|
| 00 <sub>H</sub><br>(Heade<br>Block) | 02 <sub>H</sub><br>(Mode 2) | 11 <sub>H</sub><br>(StartAddr 4) | 00 <sub>H</sub><br>(StartAddr 3)  | Data ( 5 byte<br>00 <sub>H</sub><br>(StartAddr 2) | 80 <sub>H</sub><br>(StartAddr 1) | 82 <sub>H</sub><br>(Block Length ) | Checksum<br>(1 byte)     |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    |                          |         |
|                                     |                             | Waitf                            | for Ack: Max v                    | vaiting time 25                                   | 50 µs                            |                                    | 55 <sub>H</sub><br>(Ack) |         |
| -                                   |                             |                                  |                                   |                                                   |                                  |                                    | (Ack)                    |         |
| 01,                                 |                             | Program C                        | odes for sec                      | ond page of f                                     | irst sector                      |                                    | Checksum                 |         |
| 01 <sub>H</sub><br>(Data<br>Block)  |                             | (((Bloo                          | odes for sec<br>ck Length) - 2)   | bytes) = 128                                      | Bytes                            |                                    | (1 byte)                 |         |
|                                     |                             | Wait                             | for Ack : Max v                   | vaiting time 10                                   | ) ms                             |                                    |                          |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    | <b>55</b> н<br>(Ack)     |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    |                          |         |
| 01 <sub>H</sub><br>(Data<br>Block)  |                             | Program<br>(((Bloo               | Codes for thi<br>ck Length) - 2)  | rd page of fir<br>bytes) = 128                    | st sector<br>Bytes               |                                    | Checksum<br>(1 byte)     |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    | <b>&gt;</b>              |         |
|                                     |                             | Wait                             | for Ack : Max v                   | vaiting time 10                                   | ) ms                             |                                    |                          |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    | <b>55</b> н<br>(Ack)     |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    |                          |         |
| 01 <sub>H</sub><br>(Data<br>Block)  |                             | Program Co<br>(((Block           | odes for four<br>( Length) - 2) I | th page of first<br>oytes) = 128 E                | at sector<br>Sytes               |                                    | Checksum<br>(1 byte)     |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    |                          |         |
|                                     |                             | Wait for                         | Ack: Max wai                      | ting time 10 n                                    | าร                               |                                    | 55.                      |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    | Ack)                     |         |
| 02 <sub>н</sub><br>(ЕОТ             | 00 <sub>н</sub><br>(Last    |                                  |                                   | ot Used Byte                                      |                                  |                                    | Checksum                 |         |
| (EOT<br>Block)                      | (Last<br>CodelEngth)        |                                  | No. (                             | 127 bytes)                                        |                                  |                                    | (1 byte)                 |         |
|                                     |                             | Wait for a                       | Ack: Max wait                     | ing time 250 u                                    | a                                |                                    |                          |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    | 55 <sub>H</sub><br>(Ack) |         |
|                                     |                             |                                  |                                   |                                                   |                                  |                                    |                          | 1       |

Figure 4-3 Multiple NVM page program via working mode 2



#### 4.4.2.5 Mode 3 - Code execution inside NVM

Mode 3 is used to execute a user program in the NVM of the microcontroller at the address pointed by the NVM location  $11000004_{\text{H}}$ . The header block for this working mode has the following structure:

#### The header block

|                                            |                                    | Mode Data ( 5 bytes) |                      |
|--------------------------------------------|------------------------------------|----------------------|----------------------|
| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>03<sub>н</sub></b><br>(Mode 3 ) | Not Used             | Checksum<br>(1 byte) |

#### Mode Data Description:

Not used: The five bytes are not used and will be ignored in Mode 3.

In working mode 3, the header block is the only transfer block to be sent by the host, no further serial communication is necessary. The microcontroller will exit the UART BSL mode, set the vector table in NVM at the address  $11000000_{\rm H}$  and jump to the address pointed by the NVM location  $11000004_{\rm H}$ .

Note: Jump to NVM will only occur when either (1) NVM is not protected and NVM content at  $11000004_H$  is not  $FF_H$  or (2) when NVM is protected. In all other cases, firmware will put the device in Sleep mode.

#### 4.4.2.6 Mode 4 - NVM erase

Mode 4 is used to erase different areas of the NVM. It supports mass erase of all the NVM sectors, individual erase of the sectors for linear area or for non-linear area and single page erase. This is determined by the option byte. This mode is not accessible if the NVM protection is enabled.

Different options supported are:

- Option 00<sub>H</sub> : NVM page erase
- Option 40<sub>H</sub> : NVM sector erase
- Option C0<sub>H</sub> : NVM Mass erase



#### The header block for NVM page erase (with option = $00_{H}$ )

|                                            |                                   |                         | Mode Data ( 5 bytes) |                |                        |                                               |                      |  |
|--------------------------------------------|-----------------------------------|-------------------------|----------------------|----------------|------------------------|-----------------------------------------------|----------------------|--|
| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>04<sub>H</sub></b><br>(Mode 4) | StartAddr<br>4<br>(MSB) | StartAddr<br>3       | StartAddr<br>2 | StartAddr<br>1<br>(LSB | <b>Option</b><br>=00 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |  |

Mode Data Description:

**Start Addr High, Low**: 32-bit start address, which determines which NVM page to be erased. Address should be page aligned (bit[6:0]=0).

**Option**: Set to 00<sub>H</sub> for page erase.

When the option byte =  $00_{H}$ , this mode performs an erase of the NVM page specified by the provided address.

#### The header block for NVM sector erase: (with option = $40_{H}$ )

| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>04<sub>H</sub></b><br>(Mode 4 ) | StartAddr<br>4<br>(MSB) | StartAddr<br>3 | StartAddr<br>2 | StartAddr<br>1<br>(LSB | <b>Option</b><br>= <b>40</b> <sub>H</sub><br>(1 byte) | Checksum<br>(1 byte) |
|--------------------------------------------|------------------------------------|-------------------------|----------------|----------------|------------------------|-------------------------------------------------------|----------------------|

#### Mode Data Description:

**Start Addr High, Low**: 32-bit start address, which determines which NVM sector to be erased. Address should be sector aligned (bit[11:0]=0).

**Option**: Set to 40<sub>H</sub> for sector erase.

When the option byte =  $40_{\text{H}}$ , this mode performs an erase of the NVM sector specified by the provided address. The time taken to erase a sector is max 4.5 ms.

#### The header block for NVM mass erase: (with option = C0<sub>H</sub>)

|                        |                                    | Mode Data ( 5 bytes) |                            |                      |
|------------------------|------------------------------------|----------------------|----------------------------|----------------------|
| <b>00</b> н<br>(Header | <b>04<sub>H</sub></b><br>(Mode 4 ) | Not Used             | Option<br>=C0 <sub>H</sub> | Checksum<br>(1 byte) |
| Block)                 |                                    | (4 bytes)            | (1 byte)                   | ( ) /                |

#### Mode Data Description:

Not used: The four bytes are not used and will be ignored in option C0<sub>H</sub>.



**Option**: Set to C0<sub>H</sub> for mass erase.

When the option byte =  $C0_H$ , this mode performs a mass erase of all the NVM sectors. The time taken will be max. 4.5 ms \* number of sectors, as the erase operation is done sequentially.

#### Notes

- 1. In Mode 4, a Block Type Error will be sent, if an invalid option byte is received. Once password is set, no access to Mode 4 is allowed and Protection Error will be sent.
- 2. NAC and NAD values will also be erased and the device will no longer be accessible in UART BSL, because NAC is invalid and default NAC will be used.

# 4.4.2.7 Mode 6 - NVM protection

Mode 6 is used to enable or disable the NVM protection mode by the given userpassword. The header block for this working mode has the following structure:

#### The header block

|                                  |                                    |                   | Mode Data ( 5 bytes) |                      |  |  |  |
|----------------------------------|------------------------------------|-------------------|----------------------|----------------------|--|--|--|
| <b>00<sub>н</sub></b><br>(Header | <b>06<sub>н</sub></b><br>(Mode 6 ) | User-<br>password | Not Used             | Checksum<br>(1 byte) |  |  |  |
| Block)                           |                                    | (1 byte)          | (4 bytes)            | (12)(0)              |  |  |  |

#### Mode Data Description

**User-password**: This byte is given by user to enable or disable NVM protection mode.

Not used: The four bytes are not used and will be ignored in Mode 6.

In Mode 6, the header block is the only transfer block to be sent by the host. If the device is unprotected, the provided user-password will be set as NVM\_PASSWORD and internally stored. If MSB of the NVM\_PASSWORD is 0, only Code Flash mapped sectors are protected. If the bit is 1, both Code Flash and Data Flash are protected. No further commands will be accepted until a power-up or hardware reset. Afterwards, protection mode will be enabled.

However, if the NVM is already protected, the microcontroller will deactivate the protection and erase the NVM if the user-password byte matches the stored NVM\_PASSWORD byte. The time between the command and the device response will be max. 4.5 ms + 4.5 ms \* number of NVM sectors, as shown in **Table 4-5**. During this time the device should remain powered and should not be reset to prevent interruption of the erase process.



If MSB of the NVM\_PASSWORD is 0, only Code Flash mapped sectors are erased. If the bit is 1, both Code Flash and Data Flash are erased. No further commands will be accepted until a power-up or hardware reset. Afterwards, protection mode will be disabled.

In case NVM is protected and the given user-password does not match the stored NVM\_PASSWORD, no actions will be triggered and a Protection Error (FD<sub>H</sub>) will be returned instead of acknowledge.

#### Notes

- Password value has to be different from 00<sub>H</sub> and FF<sub>H</sub>. If NVM\_PASSWORD is set to either 00<sub>H</sub> or FF<sub>H</sub> on an unprotected device, the protection will not be set and a Protection Error (FD<sub>H</sub>) will be returned.
- 2. When disabling NVM protection, together with NVM, the NAC and NAD values are erased too. As a result, after next reset, invalid NAC and default NAD will be used and chip waits forever for the first FastLIN BSL frame. The device will no longer be accessible in UART BSL mode, because the NAC is invalid and default NAC will be used.

#### Table 4-6 Erase NVM during unprotection

| NVM_PASSWORD bit 7 | Description                                          |
|--------------------|------------------------------------------------------|
| 0                  | Only linearly mapped NVM is erased                   |
| 1                  | Both linearly and non-linearly mapped NVM are erased |

# 4.4.2.8 Mode A - NVM readout, Chip ID, checksum, FastLIN BSL entry command

Mode A is used to get 4 bytes Chip ID data, NVM or 100TP page read, NVM or 100TP page or NVM mass checksum check depending on the option byte value in the header block.

In addition, the get Chip ID command is used as entry command for the FastLIN BSL mode.

Different options are supported:

- Option 00<sub>H</sub>: Get 4 bytes Chip ID
- Option 10<sub>H</sub>: NVM page checksum check
- Option 18<sub>H</sub>: Mass NVM checksum check
- Option 50<sub>H</sub>: 100TP page checksum check
- Option C0<sub>H</sub>: NVM page read
- Option F0<sub>H</sub>: 100TP page read



# The header block for Get 4 byte Chip ID (option = $00_{H}$ )

|                        |                         | Mode Data ( 5 bytes) |                            |                      |
|------------------------|-------------------------|----------------------|----------------------------|----------------------|
| <b>00</b> н<br>(Header | <b>0А</b> н<br>(Mode A) | Not Used             | Option<br>=00 <sub>∺</sub> | Checksum<br>(1 byte) |
| Block)                 |                         | (4 bytes)            | (1 byte)                   |                      |

Mode Data Description:

**Not Used**: These bytes are not used and will be ignored for option 00<sub>H</sub>.

**Option**: Set to 00<sub>H</sub> for Get 4 byte Chip ID.

If this command is successfully received, microcontroller will return an acknowledge followed by 4 data bytes and a single byte checksum. The order of the 4 bytes of data are SFR ID, CHIP\_ID2, CHIP\_ID1 and CHIP\_ID0. Refer to the **Section 5.2.1** for CHIP\_ID definition.

Note: The checksum is calculated on the acknowledge and the 4 data bytes.

#### The header block for Get 4 byte Chip ID as FastLIN entry (option = 00<sub>H</sub>)

In order to avoid unwanted entries, the FastLIN connection is established only if this command is successfully received during the active BSL connection window defined by the NAC. This command must then be the first FastLIN BSL command to be sent by the Host.

| 00 <sub>H</sub>   | 0A <sub>H</sub> | BSL Entry Key   |                                     |                                    |                                              |                                               | Charlesum            |
|-------------------|-----------------|-----------------|-------------------------------------|------------------------------------|----------------------------------------------|-----------------------------------------------|----------------------|
| (Header<br>Block) | (Mode A)        | NAD<br>(1 byte) | ́В`<br>=42 <sub>н</sub><br>(1 byte) | `Ś<br>=53 <sub>н</sub><br>(1 byte) | ` <b>L</b> ´<br>=4С <sub>н</sub><br>(1 byte) | <b>Option</b><br>=00 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |

Mode Data Description:

**NAD**: Node address for diagnostic, specifies the address of the active slave node. See the **Section 3.1.9**.

BSL Entry Key: "BSL" in ASCII.

**Option**: Set to 00<sub>H</sub> for Get 4 byte Chip ID.

If this command is successfully received, the microcontroller returns an acknowledge followed by 4 data bytes and a single byte checksum. The order of the 4 bytes of data are SFR ID, CHIP\_ID2, CHIP\_ID1 and CHIP\_ID0. Refer to the **Section 5.2.1** for CHIP\_ID definition.

On successful completion of the sequence, FastLIN BSL is fully entered and all other commands can be executed.

Note: The checksum is calculated on the acknowledge and the 4 data bytes.



#### The header block for NVM page checksum check (option = $10_{H}$ )

|                                            |                                    |                               | Data Area                    |                                        |                                       |                                        |                      |  |
|--------------------------------------------|------------------------------------|-------------------------------|------------------------------|----------------------------------------|---------------------------------------|----------------------------------------|----------------------|--|
| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>0А<sub>н</sub></b><br>(Mode A ) | StartAddr<br>High<br>(1 byte) | StartAddr<br>Low<br>(1 byte) | Expected<br>CHKSum<br>High<br>(1 byte) | Expected<br>CHKSum<br>Low<br>(1 byte) | Option<br>=10 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |  |

#### Mode Data Description:

**Start Addr High, Low**: Address of the NVM page for checksum check. (Address should be page aligned, bit[6:0]=0.)

Expected CHKSum High, Low: Expected checksum High/Low byte.

**Option**: Set to 10<sub>H</sub> to enable NVM page checksum check.

Note: The start address provided with the header block must be shifted by 7 bits to the left and then added to the NVM start address to build the actual address, i.e. it is calculated as follows in Mode A option  $CO_H$ : Actual address = 11000000<sub>H</sub> + (StartAddrHigh << 15) + (StartAddrLow << 7).

This option will trigger a checksum calculation (16 bits inverted XOR, refer to the **Section 4.4.3**) over the whole page pointed by the address given in the header block and the result will then be compared with the expected checksum (provided as well by the user in the header frame). If the given address is a valid NVM address, the microcontroller will return an acknowledge followed by four data bytes and a single byte checksum. The bytes are, in sequential order, pass/fail indication ( $00_{H}$  if the calculated and expected checksum match,  $80_{H}$  if they differ), calculated checksum High byte, calculated checksum Low byte, and a final byte equal to  $00_{H}$ .

Note: The checksum is calculated on the acknowledge and the 4 data bytes.

The input address should always be page aligned. In case it is not aligned, the address will be internally changed to point to the beginning of the addressed page so that checksum is always evaluated on a complete page.

In case the provided address is not a valid NVM address, the microcontroller will return a Block Type Error ( $FF_H$ ) instead of an acknowledge (55<sub>H</sub>) followed by no further bytes.

```
Note: In case the address is pointing to an erased non linearly mapped page, the address is considered invalid and a Block Type Error (FF<sub>H</sub>) is returned.
```



#### The header block for Mass checksum check (option = 18<sub>H</sub>)

|                                            |                          |                      | Mode Data ( 5 bytes) |                                        |                                       |                                        |                      |  |
|--------------------------------------------|--------------------------|----------------------|----------------------|----------------------------------------|---------------------------------------|----------------------------------------|----------------------|--|
| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>0А</b> н<br>(Mode A ) | Not Used<br>(1 byte) | Not Used<br>(1 byte) | Expected<br>CHKSum<br>High<br>(1 byte) | Expected<br>CHKSum<br>Low<br>(1 byte) | Option<br>=18 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |  |

Mode Data Description:

Not Used: These bytes are not used and will be ignored for option 18<sub>H</sub>.

Expected CHKSum High, Low: Expected checksum High/Low byte.

**Option**: Set to 18<sub>H</sub> to enable mass checksum check.

This option will trigger a checksum calculation (16 bits inverted XOR, refer to the **Section 4.4.3**) over all the linearly mapped sectors (including erased pages and sectors). The not linearly mapped sectors and 100TP pages are not included. The result will then be compared with the expected checksum (provided by the user in the header frame). The microcontroller will return an acknowledge followed by four data bytes and a single byte checksum. The bytes are, in sequential order, pass/fail indication (00<sub>H</sub> if the calculated and expected checksum match, 80<sub>H</sub> if they differ), calculated checksum High byte, calculated checksum Low byte, and a final byte equal to  $00_{\rm H}$ .

Note: The checksum is calculated on the acknowledge and the 4 data bytes.

#### The header block for 100TP page checksum check (option = 50<sub>H</sub>)

|                                            |                                    |                           |                      | Data Area                              |                                       |                                        |                      |
|--------------------------------------------|------------------------------------|---------------------------|----------------------|----------------------------------------|---------------------------------------|----------------------------------------|----------------------|
| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>0А<sub>Н</sub></b><br>(Mode A ) | 100TP<br>Page<br>(1 byte) | Not Used<br>(1 byte) | Expected<br>CHKSum<br>High<br>(1 byte) | Expected<br>CHKSum<br>Low<br>(1 byte) | Option<br>=50 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |

Mode Data Description:

100TP Page: Selection of the 100TP page to be checked (refer to Figure 5-8).

Not Used: This byte is not used and will be ignored for option 50<sub>H</sub>.

Expected CHKSum High, Low: Expected checksum High/Low byte.

**Option**: Set to 50<sub>H</sub> to enable 100TP page checksum check.

This option will trigger a checksum calculation (16 bits inverted XOR, refer to the **Section 4.4.3**) over the whole 100TP page pointed by the address given in the header block and the result will then be compared with the expected checksum (provided as well by the user in the header frame). The 100TP page address has to be in accordance with the configuration sector address scheme described in the **Figure 5-8**. If the given address is valid, the microcontroller will return an acknowledge followed by four data bytes and a single byte checksum. The bytes are, in sequential order, pass/fail indication  $(00_{\rm H}$  if the calculated and expected checksum match,  $80_{\rm H}$  if they differ), calculated checksum High byte, calculated checksum Low byte, and a final byte equal to  $00_{\rm H}$ .

In case the provided address is not valid, the microcontroller will return a Block Type Error ( $FF_H$ ) instead of an acknowledge (55<sub>H</sub>) followed by no further bytes.

Note: The checksum is calculated on the acknowledge and the 4 data bytes.

#### The header block for NVM page read (option C0<sub>H</sub>)

| <b>00</b> н<br>(Header<br>Block) | <b>0А<sub>н</sub></b><br>(Mode A ) | StartAddr<br>High<br>(1 byte) | StartAddr<br>Low<br>(1 byte) | Not Used<br>(1 byte) | Not Used<br>(1 byte) | <b>Option</b><br>= <b>C0</b> <sub>H</sub><br>(1 byte) | Checksum<br>(1 byte) |
|----------------------------------|------------------------------------|-------------------------------|------------------------------|----------------------|----------------------|-------------------------------------------------------|----------------------|

Mode Data Description:

**Start Addr High, Low**: Address of the NVM page to be read (Address should be page aligned, bit[6:0]=0.)

Not Used: These bytes are not used and will be ignored for option C0<sub>H</sub>.

**Option**: Set to C0<sub>H</sub> to enable NVM page read.

Note: The start address provided with the header block has to be shifted by 7 bits to the left and then added to the NVM start address to build the actual address, i.e. it is calculated as follows in Mode A option  $C0_H$ :

Actual address =  $11000000_{H}$  + (StartAddrHigh << 15) + (StartAddrLow << 7).

This option will trigger a read of the addressed NVM page. Microcontroller will return an acknowledge ( $55_H$ ) followed by the 128 NVM page data bytes (starting from the least significant byte of the page).

The input address should always be aligned with a page. In case it is not aligned, the address will be internally changed to point to the beginning of the addressed page so that the page bytes are always returned ordered from the least to the most significant byte.

In case the provided address is not a valid NVM address, the microcontroller will return a Block Type Error ( $FF_H$ ) instead of an acknowledge (55<sub>H</sub>) followed by no further bytes.

To prevent user code to be read, this option is disabled if NVM is protected and only a Protection Error byte  $(FD_H)$  will be returned.

Note: In case the address is pointing to an erased non linearly mapped page, the address is considered invalid and a Block Type Error (FF<sub>H</sub>) is returned.

# The header block for 100TP page read (option = $F0_H$ )

| <b>00<sub>н</sub></b><br>(Header<br>Block) | <b>0А<sub>Н</sub></b><br>(Mode A ) | Not Used<br>(1 byte) | Not Used<br>(1 byte) | Not Used<br>(1 byte) | 100TP<br>Page<br>(1 byte) | <b>Option</b><br>=F0 <sub>н</sub><br>(1 byte) | Checksum<br>(1 byte) |
|--------------------------------------------|------------------------------------|----------------------|----------------------|----------------------|---------------------------|-----------------------------------------------|----------------------|

Mode Data Description:

Not Used: These bytes are not used and will be ignored for option F0<sub>H</sub>.

100TP Page: Selection of the 100TP page to be checked (refer to Figure 5-8).

**Option**: Set to F0<sub>H</sub> to enable 100TP page read.

This option will trigger a read of the addressed 100TP page. Microcontroller will return an acknowledge ( $55_H$ ) followed by the 128 100TP page data bytes (starting from the least significant byte of the page).

The 100TP page is selected by the CS page byte according to the scheme shown in **Figure 5-8**.

In case an invalid 100TP page is selected the microcontroller will return a Block Type Error ( $FF_H$ ) instead of an acknowledge (55<sub>H</sub>) followed by no further bytes.

To prevent user code to be read, this option is disabled if NVM is protected (NVM password installed) and only a Protection Error byte  $(FD_H)$  will be returned.

# All other values for option byte

Block Type Error indication (FF<sub>H</sub>) is sent back.

In Mode A, the header block is the only transfer block to be sent by the host. The microcontroller will return an acknowledge followed by data bytes if the header block is received successfully. If an invalid option is received, the microcontroller will return a Block Type Error indication ( $FF_H$ ) and no further bytes.



# 4.4.3 16 bits inverted XOR checksum

This checksum structure is used in BSL Mode A options  $10_H$ ,  $18_H$ ,  $50_H$  as a fast data integrity check. These modes will read the specified NVM range, calculate the checksum and compare it against the expected one provided as command parameter.

To calculate this checksum, all Half-Words (16 bits) of the selected NVM region are xored. The resulting value is then logically complemented (1's complement).

The following figure shows the calculation algorithm.

| Byte(0)                                                                       | rte(0) Byte(1) Byte(2) Byte(3) Byte(4) Byte(5) |  | Byte(n-2) | Byte(n-1) |  |  |  |
|-------------------------------------------------------------------------------|------------------------------------------------|--|-----------|-----------|--|--|--|
|                                                                               |                                                |  |           |           |  |  |  |
| HalfWord(0)         HalfWord(1)         HalfWord(2)         HalfWord((n-2)/2) |                                                |  |           |           |  |  |  |
|                                                                               |                                                |  |           |           |  |  |  |
| ~( HW(0) xor HW(1) xor HW(2) xor xor HW((n-2)/2) )                            |                                                |  |           |           |  |  |  |
| For a NVM page, n= 128 =>                                                     |                                                |  |           |           |  |  |  |
| ~( HW(0) xor HW(1) xor HW(2) xor xor HW(63) )                                 |                                                |  |           |           |  |  |  |

Figure 4-4 16 bits inverted XOR checksum calculation

# 4.5 WDT1 refreshing

After a reset the WDT1 is starting with a long open window. WDT1 keeps on running while waiting for first UART frame. In case during the UART BSL waiting time, defined by NAC, a UART communication is detected, WTD1 is disabled and its status frozen.

Subsequently, before exiting to RAM or NVM in UART BSL modes 1 and 3 the watchdog is re-enabled and starts from the previously frozen state. The WDT1 is then still in long open window and the remaining valid time is equal to long open window minus the time between reset release and first UART communication. User program needs to trigger the WDT1 refresh accordingly.



# 5 NVM

Non Volatile Memory (NVM) is the flash module of the TLE986x/TLE987x which partly supports EEPROM emulation.

# 5.1 NVM overview

The NVM is a single block of NVM memory of up to 256 Kbytes separated into Code and Data space. The following table shows the NVM address range.

#### Table 5-1 NVM address range

| Address    | Address range |
|------------|---------------|
| NSA to NEA | NVM memory    |

NSA and NEA values are shown in Table 5-2:

| NVM size<br>(Kbyte) | NVM starting<br>address<br>(NSA) | NVM linear<br>size, NVM<br>CFLASH<br>size (NLS) | NVM<br>DFLASH<br>starting<br>address | NVM<br>DFLASH<br>size | NVM DFLASH<br>end address,<br>NVM FLASH<br>end address (NEA) |
|---------------------|----------------------------------|-------------------------------------------------|--------------------------------------|-----------------------|--------------------------------------------------------------|
| 36                  | 11000000 <sub>H</sub>            | 8000 <sub>H</sub>                               | 11008000 <sub>H</sub>                | 1000 <sub>H</sub>     | 11008FFF <sub>H</sub>                                        |
| 64                  | 11000000 <sub>H</sub>            | F000 <sub>H</sub>                               | 1100F000 <sub>H</sub>                | 1000 <sub>H</sub>     | 1100FFFF <sub>H</sub>                                        |
| 128                 | 11000000 <sub>H</sub>            | 1F000 <sub>H</sub>                              | 1101F000 <sub>H</sub>                | 1000 <sub>H</sub>     | 1101FFFF <sub>H</sub>                                        |
| 256                 | 11000000 <sub>H</sub>            | 3F000 <sub>H</sub>                              | 1103F000 <sub>H</sub>                | 1000 <sub>H</sub>     | 1103FFFF <sub>H</sub>                                        |

#### Table 5-2 NVM size and address range

#### Notes

- 1. An erased page is ECC-Clean and will not generate an ECC error.
- 2. Reading an erased page in the Code space will return FF<sub>H</sub> and will not trigger any error.
- Reading an erased page in the Data space will return 00<sub>H</sub> and will also create an NVM Map Error NMI, if enabled in NMICON. As a consequence, an erased page in the Data space has to be written before it can be read without triggering an error.

# 5.1.1 NVM organisation

The NVM has 2 types of memory configuration, Code and Data. It is organised in sectors. Each NVM Sector is a block of 4 Kbytes organised into blocks of 128 bytes called page. The page is the minimum data granularity for NVM (Code and Data) write and erase so, with this NVM structure, any NVM update, even when targeting only one byte, actually



involves 128 bytes. **Table 5-3** shows the sector address organisation of the first and last 4 sectors of the 256 Kbytes NVM. The other sector organization can be simply derived per extension of the reported scheme. **Table 5-4** shows the page address organisation of NVM Sector 1 and it can be used as a reference for page organization of any NVM Sector.

| Address                   | NVM Sector number |
|---------------------------|-------------------|
| 11000000H to<br>11000FFFH | 1                 |
| 11001000H to<br>11001FFFH | 2                 |
| 11002000H to<br>11002FFFH | 3                 |
| 11003000H to<br>11003FFFH | 4                 |
| 1103C000H to<br>1103CFFFH | 61                |
| 1103D000H to<br>1103DFFFH | 62                |
| 1103E000H to<br>1103EFFFH | 63                |
| 1103F000H to<br>1103FFFFH | 64                |

| Table 5-3 NVM memory sector organisation |
|------------------------------------------|
|------------------------------------------|

| Table 5-4 | NVM memory sector 1 page organisation |
|-----------|---------------------------------------|
|-----------|---------------------------------------|

| Address                   | Page number of NVM Sector |  |
|---------------------------|---------------------------|--|
| 11000000H to<br>1100007FH | 0                         |  |
| 11000080H to<br>110000FFH | 1                         |  |
| 11000100H to<br>1100017FH | 2                         |  |
| 11000180H to<br>110001FFH | 3                         |  |
| 11000200H to<br>1100027FH | 4                         |  |



| Address                   | Page number of NVM Sector |
|---------------------------|---------------------------|
| 11000280H to<br>110002FFH | 5                         |
| 11000300H to<br>1100037FH | 6                         |
| 11000380H to<br>110003FFH | 7                         |
| 11000400H to<br>1100047FH | 8                         |
| 11000480H to<br>110004FFH | 9                         |
| 11000500H to<br>1100057FH | 10                        |
| 11000580H to<br>110005FFH | 11                        |
| 11000600H to<br>1100067FH | 12                        |
| 11000680H to<br>110006FFH | 13                        |
| 11000700H to<br>1100077FH | 14                        |
| 11000780H to<br>110007FFH | 15                        |
| 11000800H to<br>1100087FH | 16                        |
| 11000880H to<br>110008FFH | 17                        |
| 11000900H to<br>1100097FH | 18                        |
| 11000980H to<br>110009FFH | 19                        |
| 11000A00H to<br>11000A7FH | 20                        |
| 11000A80H to<br>11000AFFH | 21                        |

# Table 5-4 NVM memory sector 1 page organisation (cont'd)



| Page number of NVM Sector |
|---------------------------|
| 22                        |
| 23                        |
| 24                        |
| 25                        |
| 26                        |
| 27                        |
| 28                        |
| 29                        |
| 30                        |
| 31                        |
|                           |

#### Table 5-4 NVM memory sector 1 page organisation (cont'd)

# 5.2 NVM configuration sectors organisation

The configuration sector contains important user data needed for proper system initialization.

# 5.2.1 Chip ID definition

The specific characteristics of the different variants of the product family are captured in the definition of the CHIP\_ID bytes.

The Chip\_ID bytes can be read via BSL mode A. When triggered, this mode replies providing the 3 CHIP\_ID bytes plus the content of the Identification register (ID).

Please refer to the following tables for CHIP\_ID details. This is a variant specific identification number. The unique device specific identification number is described in **Table 5-11**.



| Table 5-5 | Chip ID byte 0 |        |        |     |          |
|-----------|----------------|--------|--------|-----|----------|
| Res       | MAX FREQ       | OP AMP | Phases | DMA | PKG Type |

Table 5-6 Chip ID byte 0 bits description

| Field    | Bits  | Description                                                             |
|----------|-------|-------------------------------------------------------------------------|
| PKG_Type | [1:0] | Package type<br>00 VQFN-48<br>01 TQFP-48<br>10 Reserved<br>11 Reserved  |
| DMA      | 2     | DMA<br>0 With DMA<br>1 Without DMA                                      |
| Phases   | 3     | Bridge driver number of phases<br>0 2 phases<br>1 3 phases              |
| OP_AMP   | 4     | Op Amp<br>0 With Op Amp<br>1 Without Op Amp                             |
| Max Freq | [6:5] | Maximum frequency<br>00 Reserved<br>01 20 MHz<br>10 24 MHz<br>11 40 MHz |
| Res      | 7     | Reserved                                                                |



# Table 5-7 Chip ID byte 1

| NVM SIZE | EEPROM SIZE |
|----------|-------------|
|          |             |

# Table 5-8 Chip ID byte 1 bits description

| Field       | Bits  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EEPROM_SIZE | [3:0] | EEPROM (non-linearly mapped NVM) size<br>0000 0 Kbyte<br>0001 4 Kbyte<br>0010 8 Kbyte<br>0011 12 Kbyte<br>0100 16 Kbyte<br>0101 20 Kbyte<br>0110 24 Kbyte<br>0111 28 Kbyte<br>1010 32 Kbyte<br>1000 32 Kbyte<br>1001 36 Kbyte<br>1011 44 Kbyte<br>1100 48 Kbyte<br>1100 48 Kbyte<br>1110 56 Kbyte                                                                                                                                                |
| NVM_SIZE    | [7:4] | 1111 60 Kbyte         Total NVM size         0000 Res         0001 256 Kbyte         0010 Res         0011 36 Kbyte         0100 Res         0101 Res         0110 Res         0111 64 Kbyte         1000 Res         1011 Res         1010 Res         1011 Res         1010 Res         1011 Res         1010 Res         1011 Res         1100 Res         1101 Res         1101 Res         1110 Res         1110 Res         1111 128 Kbyte |



#### Table 5-9 Chip ID byte 2

| Res | VARIANT_ID |
|-----|------------|

#### Table 5-10 Chip ID byte 2 bits Description

| Field      | Bits  | Description |
|------------|-------|-------------|
| VARIANT_ID | [3:0] | Variant ID  |
| Res        | [7:4] | Reserved    |

#### 5.2.2 100 Time Programmable data

User has eight 100 time programmable pages (100TP). The first one is used to store user configuration parameters for measurement interface and sense amplifier as well as ADC1 calibration parameters. These parameters are usually determined in the user application and might require several iterations before the best fit is found.

The values of the first page, from offset  $10_{\rm H}$  to  $63_{\rm H}$ , are automatically copied into the dedicated SFR registers after every power-on reset, brown-out reset or wake-up reset from Sleep mode thus replacing the registers default reset values. The user can check them by reading the dedicated SFRs or by reading directly the content of the page.

The first 4 bytes of the first 100TP page are used to store a device ID that can be read by the user. The content of these 4 bytes are preloaded prior to shipment and cannot be modified by the user. In case the user tries to write these values via the 100TP page writing features offered in BSL or via NVM user routine, an error is reported and the original content of the bytes is preserved. The Customer\_ID definition is described in **Figure 5-1**.

The data stored in this first 100TP page can be found in Table 5-11.

To read data stored in the 100TP pages, refer to the Section 5.3.11.

To perform the programming of these pages, the user is required to preload the contents to be programmed into the RAM as listed in **Table 5-12**. The offset entered for the programming does not need to be in sequential order. Once a page has been programmed 100 times, no further programming on that page is allowed. In the last byte of each 100TP page a program counter is stored (not changeable by user).

Since part of the data stored in the first 100TP page are used as trim or configuration data at reset, the content is protected by an in-page checksum (XOR of the first 126 bytes of the page) stored at one before last byte of the page (in-page offset  $7E_{H}$ , refer to **Table 5-11**). User is required to properly calculate and update the checksum when re-programming the 100TP page 1.



Note: At power-on reset, brown-out reset or wake-up reset from Sleep mode, the firmware checks the checksum of the first 100TP page. In case the checksum is not correct, The data stored from offset  $10_H$  to  $63_H$  are not downloaded into the SFRs and backup values are used instead.

For further information regarding 100TP page program, refer to the Section 5.3.12.

| Data<br>offset                        | SFR /<br>Variable name    | Description                                                                  | Default<br>value       | Back-up<br>value <sup>1)</sup> |
|---------------------------------------|---------------------------|------------------------------------------------------------------------------|------------------------|--------------------------------|
| 00 <sub>H</sub> to<br>03 <sub>H</sub> | CUSTOMER_ID               | Device ID for user                                                           | Device ID<br>dependent | N.A.                           |
| 04 <sub>H</sub>                       | GAIN_VS_10B               | Calibration gain for<br>supply voltage<br>measurement                        | Chip<br>Individual     | N.A.                           |
| 05 <sub>H</sub>                       | OFFSET_VS_10B             | Calibration offset for<br>supply voltage<br>measurement                      | Chip<br>Individual     | N.A.                           |
| 06 <sub>H</sub>                       | GAIN_VBAT_<br>SENSE_10B   | Calibration gain for<br>battery voltage<br>measurement                       | Chip<br>Individual     | N.A.                           |
| 07 <sub>H</sub>                       | OFFSET_VBAT_<br>SENSE_10B | Calibration offset for<br>battery voltage<br>measurement                     | Chip<br>Individual     | N.A.                           |
| 08 <sub>H</sub>                       | GAIN_VMON_<br>ATT_1_5     | Calibration gain for high<br>voltage monitoring input<br>voltage measurement | Chip<br>Individual     | N.A.                           |
| 09 <sub>H</sub>                       | OFFSET_VMON_<br>ATT_1_5   | Calibration offset for high voltage monitoring input voltage measurement     | Chip<br>Individual     | N.A.                           |
| 0A <sub>H</sub>                       | CONFIG_VERS               | Configuration Sector version                                                 | 02 <sub>H</sub>        | N.A.                           |
| 0B <sub>H</sub>                       | Reserved                  | Reserved                                                                     | 00 <sub>H</sub>        | N.A.                           |
| 0C <sub>H</sub> to<br>0D <sub>H</sub> | CFLASH_PW                 | Code Flash protection<br>removal password                                    | 0000 <sub>H</sub>      | N.A.                           |
| 0E <sub>H</sub> to<br>0F <sub>H</sub> | DFLASH_PW                 | Data Flash protection<br>removal password                                    | 0000 <sub>H</sub>      | N.A.                           |
| 10 <sub>H</sub> to<br>13 <sub>H</sub> | MEAS_ADC2_<br>CTRL1       | Measurement unit:<br>Control register 1                                      | 00000000 <sub>H</sub>  | 00000000 <sub>H</sub>          |

Table 5-11 100TP page 1



| Data<br>offset                        | SFR /<br>Variable name | Description                                                                   | Default<br>value      | Back-up<br>value <sup>1)</sup> |
|---------------------------------------|------------------------|-------------------------------------------------------------------------------|-----------------------|--------------------------------|
| 14 <sub>H</sub> to<br>17 <sub>H</sub> | MEAS_ADC2_<br>CTRL2    | Measurement unit:<br>Control register 2                                       | 00000703 <sub>H</sub> | 00000703 <sub>H</sub>          |
| 18 <sub>H</sub> to<br>1B <sub>H</sub> | MEAS_ADC2_<br>SQ1_4    | Channel controller:<br>Measurement channel<br>enable bits of cycle 1 to 4     | 29362837 <sub>H</sub> | 29362837 <sub>H</sub>          |
| 1C <sub>H</sub> to<br>1F <sub>H</sub> | MEAS_ADC2_<br>SQ5_8    | Channel controller:<br>Measurement channel<br>enable bits of cycle 5 to 8     | 28372836 <sub>H</sub> | 28372836 <sub>H</sub>          |
| 20 <sub>H</sub> to<br>23 <sub>H</sub> | MEAS_ADC2_<br>SQ9_10   | Channel controller:<br>Measurement channel<br>enable bits of cycle 9<br>to 10 | 00002936 <sub>H</sub> | 00002936 <sub>H</sub>          |
| 24 <sub>H</sub> to<br>27 <sub>H</sub> | ADC2_CAL_CH0_1         | Calibration unit:<br>Calibration of channel 0<br>and 1                        | Chip<br>Individual    | Chip<br>Individual             |
| 28 <sub>H</sub> to<br>2B <sub>H</sub> | ADC2_CAL_CH2_3         | Calibration unit:<br>Calibration of channel 2<br>and 3                        | Chip<br>Individual    | Chip<br>Individual             |
| 2C <sub>H</sub> to<br>2F <sub>H</sub> | ADC2_CAL_CH4_5         | Calibration unit:<br>Calibration of channel 4<br>and 5                        | Chip<br>Individual    | Chip<br>Individual             |
| 30 <sub>H</sub> to<br>33 <sub>H</sub> | ADC2_<br>FILTCOEFF0_5  | IIR filter:<br>Filter coefficients of ADC<br>channels 0 to 5                  | 00000AAA <sub>H</sub> | 00000AAA <sub>H</sub>          |
| 34 <sub>H</sub> to<br>37 <sub>H</sub> | ADC2_FILT_UP_<br>CTRL  | Postprocessing:<br>Upper threshold filter<br>enable                           | 00000F3F <sub>H</sub> | 00000F3F <sub>H</sub>          |
| 38 <sub>H</sub> to<br>3B <sub>H</sub> | ADC2_FILT_LOW_<br>CTRL | Postprocessing:<br>Lower threshold filter<br>enable                           | 00000F3F <sub>H</sub> | 00000F3F <sub>H</sub>          |
| 3C <sub>H</sub> to<br>3F <sub>H</sub> | ADC2_TH0_3_<br>LOWER   | Postprocessing:<br>Lower comparator trigger<br>level of channels 0 to 3       | 182F423A <sub>H</sub> | 182F423A <sub>H</sub>          |

Table 5-11100TP page 1 (cont'd)



| Data<br>offset                        | SFR /<br>Variable name | Description                                                              | Default<br>value      | Back-up<br>value <sup>1)</sup> |
|---------------------------------------|------------------------|--------------------------------------------------------------------------|-----------------------|--------------------------------|
| 40 <sub>H</sub> to<br>43 <sub>H</sub> | ADC2_TH4_5_<br>LOWER   | Postprocessing:<br>Lower comparator trigger<br>level of channels 4 to 5  | 00009A00 <sub>H</sub> | 00009A00 <sub>H</sub>          |
| 44 <sub>H</sub> to<br>47 <sub>H</sub> | ADC2_TH6_9_<br>LOWER   | Postprocessing:<br>Lower comparator trigger<br>level of channels 6 to 9  | C6D39ECD <sub>H</sub> | C6D39ECD <sub>H</sub>          |
| 48 <sub>H</sub> to<br>4B <sub>H</sub> | ADC2_TH0_3_<br>UPPER   | Postprocessing:<br>Upper comparator trigger<br>level of channels 0 to 3  | ABBDC5C0 <sub>H</sub> | ABBDC5C0 <sub>H</sub>          |
| 4C <sub>H</sub> to<br>4F <sub>H</sub> | ADC2_TH4_5_<br>UPPER   | Postprocessing:<br>Upper comparator trigger<br>level of channels 4 to 5  | 0000BC00 <sub>H</sub> | 0000BC00 <sub>H</sub>          |
| 50 <sub>H</sub> to<br>53 <sub>H</sub> | ADC2_CNT0_3_<br>LOWER  | Postprocessing:<br>Lower counter trigger<br>level of channels 0 to 3     | 12131312 <sub>H</sub> | 12131312 <sub>H</sub>          |
| 54 <sub>H</sub> to<br>57 <sub>H</sub> | ADC2_CNT4_5_<br>LOWER  | Postprocessing:<br>Lower counter trigger<br>level of channels 4 to 5     | 00000A0A <sub>H</sub> | 00000A0A <sub>H</sub>          |
| 58 <sub>H</sub> to<br>5B <sub>H</sub> | ADC2_CNT0_3_<br>UPPER  | Postprocessing:<br>Upper counter trigger<br>level of channels 0 to 3     | 12131B1A <sub>H</sub> | 12131B1A <sub>H</sub>          |
| 5C <sub>H</sub> to<br>5F <sub>H</sub> | ADC2_CNT4_5_<br>UPPER  | Postprocessing:<br>Upper counter trigger<br>level of channels 4 to 5     | 00001212 <sub>H</sub> | 00001212 <sub>H</sub>          |
| 60 <sub>H</sub> to<br>63 <sub>H</sub> | ADC2_MMODE0_5          | Postprocessing:<br>Overvoltage<br>measurement mode of<br>channels 0 to 5 | 00000000 <sub>H</sub> | 00000000 <sub>H</sub>          |
| 64 <sub>H</sub> to<br>6B <sub>H</sub> | Reserved               | Reserved                                                                 | 00 <sub>H</sub>       | N.A.                           |
| 6C <sub>H</sub>                       | CHIP_ID_BYTE_00        | Chip ID byte 00 <sup>2)</sup>                                            | Chip<br>Individual    | N.A.                           |
| 6D <sub>H</sub>                       | CHIP_ID_BYTE_01        | Chip ID byte 01 <sup>2)</sup>                                            | Chip<br>Individual    | N.A.                           |

Table 5-11100TP page 1 (cont'd)



| Data<br>offset  | SFR /<br>Variable name     | Description                                                                                                             | Default<br>value   | Back-up<br>value <sup>1)</sup> |
|-----------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------|
| 6E <sub>H</sub> | CHIP_ID_BYTE_02            | Chip ID byte 02 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 6F <sub>H</sub> | CHIP_ID_BYTE_03            | Chip ID byte 03 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 70 <sub>H</sub> | CHIP_ID_BYTE_04            | Chip ID byte 04 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 71 <sub>H</sub> | CHIP_ID_BYTE_05            | Chip ID byte 05 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 72 <sub>H</sub> | CHIP_ID_BYTE_06            | Chip ID byte 06 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 73 <sub>H</sub> | CHIP_ID_BYTE_07            | Chip ID byte 07 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 74 <sub>H</sub> | CHIP_ID_BYTE_08            | Chip ID byte 08 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 75 <sub>H</sub> | CHIP_ID_BYTE_09            | Chip ID byte 09 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 76 <sub>H</sub> | CHIP_ID_BYTE_10            | Chip ID byte 10 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 77 <sub>H</sub> | CHIP_ID_BYTE_11            | Chip ID byte 11 <sup>2)</sup>                                                                                           | Chip<br>Individual | N.A.                           |
| 78 <sub>H</sub> | CS_SA_WITH_PRO<br>T_EN     | When set to A5 <sub>H</sub> , enables<br>Service Algorithm even<br>on protected NVM Data<br>Sector                      | 00 <sub>H</sub>    | N.A.                           |
| 79 <sub>H</sub> | CS_USER_CAL_ST<br>ARTUP_EN | Enable byte for user<br>calibration data download<br>during startup. If<br>value=0xC3 then the<br>download is enabled   | 00 <sub>H</sub>    | N.A.                           |
| 7A <sub>H</sub> | CS_USER_CAL_XA<br>DDH      | High byte of the RAM<br>starting address where<br>downloaded data has to<br>be stored (0xF0 for RAM<br>initial address) | 00 <sub>H</sub>    | N.A.                           |

Table 5-11100TP page 1 (cont'd)



| IN V IVI | N | 1V | M |
|----------|---|----|---|
|----------|---|----|---|

| Data<br>offset  | SFR /<br>Variable name     | Description                                                                                                                    | Default<br>value   | Back-up<br>value <sup>1)</sup> |
|-----------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------|
| 7B <sub>H</sub> | CS_USER_CAL_XA<br>DDL      | LOW byte of the RAM<br>starting address where<br>downloaded data has to<br>be stored (0x00 for RAM<br>initial address)         | 00 <sub>H</sub>    | N.A.                           |
| 7C <sub>H</sub> | CS_USER_CAL_10<br>0TP_PAGE | 100TP page where<br>calibration data has to be<br>downloaded from. By<br>default 100TP page1<br>should be used<br>(Value=0x11) | 00 <sub>H</sub>    | N.A.                           |
| 7D <sub>H</sub> | CS_USER_CAL_NU<br>M        | Number of bytes to be<br>downloaded starting from<br>the first byte of the<br>selected 100TP page                              | 00 <sub>H</sub>    | N.A.                           |
| 7E <sub>H</sub> | CHECKSUM_100TP<br>_P1      | XOR of the first 126 bytes of 100TP page 1                                                                                     | Chip<br>Individual | N.A.                           |
| 7F <sub>H</sub> | PROG_TIMES_100<br>TP_P1    | This reflects the number<br>of times that this page<br>has been programmed<br>(up to a maximum of 100<br>times)                | 00 <sub>H</sub>    | N.A.                           |

Table 5-11 100TP page 1 (cont'd)

<sup>1)</sup> Values used during startup for analog module trimming in case a checksum error on 100TP page 1 is detected. Refer to the Section 3.1.5.

<sup>2)</sup> This is a unique device specific identification number. The variant specific identification number is described in the Section 5.2.1.



| RAM address                         | Function                                                                                       |  |
|-------------------------------------|------------------------------------------------------------------------------------------------|--|
| 18000400 <sub>H</sub>               | Number of bytes to be programmed (i.e. <b>N</b> , up to a maximum of 127 bytes <sup>1)</sup> ) |  |
| 18000401 <sub>H</sub>               | 100TP offset 1                                                                                 |  |
| 18000402 <sub>H</sub>               | 100TP data 1 to be programmed                                                                  |  |
| 18000403 <sub>H</sub>               | 100TP offset 2                                                                                 |  |
| 18000404 <sub>H</sub>               | 100TP data 2 to be programmed                                                                  |  |
|                                     |                                                                                                |  |
| 18000401 <sub>H</sub> + ((N-1) x 2) | 100TP offset N                                                                                 |  |
| 18000402 <sub>H</sub> + ((N-1) x 2) | 100TP data N to be programmed                                                                  |  |

#### Table 5-12 RAM preloading for 100TP page programming

<sup>1)</sup> The maximum number of bytes that the user can load into the 100TP pages is limited to 127 since last byte is used as a program operation counter. To ensure that the page are not programmed more than 100 times, even not by accident, the counter byte (last byte in the page) can be read but not overwritten by the user.



# MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

#### NVM



#### Figure 5-1 Customer\_ID definition



# 5.3 NVM user routines organisation

The NVM user routines are BootROM routines called by user and placed from the address  $0000383D_H$  to  $00003925_H$ . The complete list of NVM user routines can be found in Table 5-13.

| Address               | Routine                 | Description                                                        |
|-----------------------|-------------------------|--------------------------------------------------------------------|
| 00003925 <sub>H</sub> | USER_CFLASH_WR_PROT_EN  | To enable write protection on the linearly mapped NVM sectors      |
| 0000391D <sub>H</sub> | USER_CFLASH_WR_PROT_DIS | To disable write protection on the linearly mapped NVM sectors     |
| 00003915 <sub>H</sub> | USER_CFLASH_RD_PROT_EN  | To enable read protection on the linearly mapped NVM sectors       |
| 0000390D <sub>H</sub> | USER_CFLASH_RD_PROT_DIS | To disable read protection on the linearly mapped NVM sectors      |
| 00003905 <sub>H</sub> | USER_DFLASH_WR_PROT_EN  | To enable write protection on the non linearly mapped NVM sectors  |
| 000038FD <sub>H</sub> | USER_DFLASH_WR_PROT_DIS | To disable write protection on the non linearly mapped NVM sectors |
| 000038F5 <sub>H</sub> | USER_DFLASH_RD_PROT_EN  | To enable read protection on the non linearly mapped NVM sectors   |
| 000038ED <sub>H</sub> | USER_DFLASH_RD_PROT_DIS | To disable read protection on the non linearly mapped NVM sectors  |
| 000038E5 <sub>H</sub> | USER_OPENAB             | To open the assembly buffer for writing                            |
| 000038DD <sub>H</sub> | USER_PROG               | To program the NVM                                                 |
| 000038D5 <sub>H</sub> | USER_ERASEPG            | To erase an NVM page                                               |
| 000038CD <sub>H</sub> | USER_ABORTPROG          | To abort the NVM programming by closing the assembly buffer        |
| 000038C5 <sub>H</sub> | USER_NVMRDY             | To access if the NVM is in ready to read status                    |
| 000038BD <sub>H</sub> | USER_READ_CAL           | To read the NVM calibration data                                   |
| 000038B5 <sub>H</sub> | USER_NVM_CONFIG         | To read the NVM configuration status                               |
| 000038AD <sub>H</sub> | USER_NVM_ECC2ADDR       | To read the NVM ECC2 address                                       |
| 0000389D <sub>H</sub> | USER_MAPRAM_INIT        | To initialize MapRAM                                               |
|                       |                         |                                                                    |

# Table 5-13NVM user routines list



| Address               | Routine                  | Description                                                                                     |  |
|-----------------------|--------------------------|-------------------------------------------------------------------------------------------------|--|
| 00003895 <sub>H</sub> | USER_VERIFY_PAGE         | To perform a page verify                                                                        |  |
| 0000388D <sub>H</sub> | USER_ERASE_SECTOR_VERIFY | To perform a sector erase verify                                                                |  |
| 00003885 <sub>H</sub> | USER_ERASEPG_VERIFY      | To perform a page erase verify                                                                  |  |
| 00003875 <sub>H</sub> | USER_READ_100TP          | To read the NVM 100TP parameter data                                                            |  |
| 0000386D <sub>H</sub> | USER_100TP_PROG          | To perform the 100TP program<br>(this can be used 100 times per<br>100TP page)                  |  |
| 00003865 <sub>H</sub> | USER_ERASE_SECTOR        | To erase an NVM sector                                                                          |  |
| 00003855 <sub>H</sub> | USER_NVMCLKFAC_SET       | To set NVMCLKFAC bit in SYSCON0                                                                 |  |
| 0000384D <sub>H</sub> | USER_RAM_MBIST_START     | BIST_START To perform a sequential<br>checkerboard and inverted<br>checkerboard test on the RAM |  |
| 00003845 <sub>H</sub> | USER_NVM_ECC_CHECK       | To trigger a complete NVM read<br>and provide cumulated ECC single<br>bit error indication      |  |
| 0000383D <sub>H</sub> | USER_ECC_CHECK           | To provide cumulated ECC single<br>bit error indication since last call of<br>the function      |  |

<sup>1)</sup> This function is not available for variants with 256 Kbyte flash.

| Table 5-14 | NVM user routines maximum stack usage |
|------------|---------------------------------------|
|------------|---------------------------------------|

| Routine                 | Maximum<br>stack usage<br>BF, and A<br>step [bytes] | Maximum<br>stack usage<br>UH step<br>[bytes] | Maximum<br>stack usage<br>UI step<br>[bytes] |
|-------------------------|-----------------------------------------------------|----------------------------------------------|----------------------------------------------|
| USER_CFLASH_WR_PROT_EN  | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_CFLASH_WR_PROT_DIS | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_CFLASH_RD_PROT_EN  | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_CFLASH_RD_PROT_DIS | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |



| Routine                                | Maximum<br>stack usage<br>BF, and A<br>step [bytes] | Maximum<br>stack usage<br>UH step<br>[bytes] | Maximum<br>stack usage<br>UI step<br>[bytes] |
|----------------------------------------|-----------------------------------------------------|----------------------------------------------|----------------------------------------------|
| USER_DFLASH_WR_PROT_EN                 | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_DFLASH_WR_PROT_DIS                | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_DFLASH_RD_PROT_EN                 | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_DFLASH_RD_PROT_DIS                | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_OPENAB                            | 003C <sub>H</sub>                                   | 003C <sub>H</sub>                            | 003C <sub>H</sub>                            |
| USER_PROG                              | 00BC <sub>H</sub>                                   | 0100 <sub>H</sub>                            | 00FC <sub>H</sub>                            |
| USER_ERASEPG                           | 005C <sub>H</sub>                                   | 00C0 <sub>H</sub>                            | 00BC <sub>H</sub>                            |
| USER_ABORTPROG                         | 0014 <sub>H</sub>                                   | 0014 <sub>H</sub>                            | 0014 <sub>H</sub>                            |
| USER_NVMRDY                            | 0004 <sub>H</sub>                                   | 0004 <sub>H</sub>                            | 0004 <sub>H</sub>                            |
| USER_READ_CAL                          | 0034 <sub>H</sub>                                   | 0034 <sub>H</sub>                            | 0034 <sub>H</sub>                            |
| USER_NVM_CONFIG                        | 0010 <sub>H</sub>                                   | 0010 <sub>H</sub>                            | 0010 <sub>H</sub>                            |
| USER_NVM_ECC2ADDR                      | 0010 <sub>H</sub>                                   | 0010 <sub>H</sub>                            | 0010 <sub>H</sub>                            |
| USER_MAPRAM_INIT                       | 0024 <sub>H</sub>                                   | 0024 <sub>H</sub>                            | 0024 <sub>H</sub>                            |
| USER_VERIFY_PAGE <sup>1)</sup>         | 003C <sub>H</sub>                                   | 003C <sub>H</sub>                            | 003C <sub>H</sub>                            |
| USER_ERASE_SECTOR_VERIFY <sup>1)</sup> | 005C <sub>H</sub>                                   | 005C <sub>H</sub>                            | 005C <sub>H</sub>                            |
| USER_ERASEPG_VERIFY <sup>1)</sup>      | 0034 <sub>H</sub>                                   | 0034 <sub>H</sub>                            | 0034 <sub>H</sub>                            |
| USER_READ_100TP                        | 0034 <sub>H</sub>                                   | 0034 <sub>H</sub>                            | 0034 <sub>H</sub>                            |
| USER_100TP_PROG                        | 0088 <sub>H</sub>                                   | 00C0 <sub>H</sub>                            | 00BC <sub>H</sub>                            |
| USER_ERASE_SECTOR                      | 0038 <sub>H</sub>                                   | 00A0 <sub>H</sub>                            | 009C <sub>H</sub>                            |
| USER_NVMCLKFAC_SET                     | 000C <sub>H</sub>                                   | 000C <sub>H</sub>                            | 000C <sub>H</sub>                            |
| USER_RAM_MBIST_START                   | 01E4 <sub>H</sub>                                   | 01E4 <sub>H</sub>                            | 01E4 <sub>H</sub>                            |
| USER_NVM_ECC_CHECK                     | 0024 <sub>H</sub>                                   | 0024 <sub>H</sub>                            | 0024 <sub>H</sub>                            |
| USER_ECC_CHECK                         | 0024 <sub>H</sub>                                   | 0024 <sub>H</sub>                            | 0024 <sub>H</sub>                            |

#### Table 5-14 NVM user routines maximum stack usage (cont'd)

<sup>1)</sup> This function is not available for variants with 256 Kbyte flash.

# 5.3.1 Opening assembly buffer routine

The NVM programming routine consists of two parts: the assembly buffer opening routine, and the programming and verification routine.

MOTIX<sup>™</sup> TLE986x, MOTIX<sup>™</sup> TLE987x, BootROM



#### NVM

The Open Assembly buffer routine reads the content of the physical page into a NVM internal RAM memory block (Assembly Buffer). The address of the page to be read is provided with the OpenAB function call. Once the OpenAB call has been executed successfully the user can update the content of the Assembly Buffer (128 bytes) by (over)writing the data starting from the address handed over to the OpenAB function.

In case the provided address targets the NVM non-linearly mapped Data region , before copying the data, the OpenAB routine will check to which physical page the provided address is linked and make the data of this physical page available in the Assembly Buffer.

In order to prepare the data for the next program operation, the open assembly buffer routine then accesses the data stored in the MapRAM and NVM array (data block and MapBlock) related to the address provided as input. While accessing this data, the routine performs a consistency check of the read information and reports a proper warning or fail to the user by means of the bit 0, 1, 2 and 3 of the return values (**Table 5-16**). The performed check and related warnings/errors depend on the region to which the addressed page belongs, as described in **Table 5-15**:

| NVM region  | ECC fail in       | ECC fail in     | ECC fail in                                 |
|-------------|-------------------|-----------------|---------------------------------------------|
|             | MapRAM            | MapBlock        | data block                                  |
| Code region | Not applicable    | Not applicable  | Bit 1 set, only<br>warning, AB is<br>opened |
| Data region | Bits 0 and 3 set. | Bit 2 set, only | Bit 1 set, only                             |
|             | Error, AB not     | warning, AB is  | warning, AB is                              |
|             | opened            | opened          | opened                                      |

 Table 5-15
 Open Assembly Buffer subroutine return value for ECC check

Note: The assembly buffer opening routine needs to be executed successfully before the NVM programming routine can be called.

#### Table 5-16 Opening assembly buffer subroutine

| Subroutine | 000038E5 <sub>H</sub> : USER_OPENAB                   |
|------------|-------------------------------------------------------|
|            | Prototype:<br>unsigned char USER_OPENAB(int *Address) |
|            |                                                       |



| Input  | *Address(int pointer):<br>Pointer to the NVM address to be programmed             |
|--------|-----------------------------------------------------------------------------------|
| Output | Return value (unsigned char):                                                     |
|        | Bit 0: Pass or fail                                                               |
|        | 0 = Assembly Buffer is successfully opened                                        |
|        | 1 = Assembly Buffer cannot be opened                                              |
|        | Bit 1: Data Block ECC Pass or fail                                                |
|        | 0 = Data Block has no ECC2 fail                                                   |
|        | 1 = Data Block has at least one ECC2 fail                                         |
|        | Bit 2: Map Block ECC Pass or fail                                                 |
|        | 0 = Map Block has no ECC2 fail                                                    |
|        | 1 = Map Block has at least one ECC2 fail                                          |
|        | Bit 2 is used only for pages in Data sector.                                      |
|        | Bit 3: MapRAM ECC Pass or fail                                                    |
|        | 0 = MapRAM has no ECC2 fail                                                       |
|        | 1 = MapRAM has at least one ECC2 fail                                             |
|        | Bit 3 is used only for pages in Data sector.                                      |
|        | Bit 7: Execution Pass/Fail status                                                 |
|        | 0 = Pass: Routine was correctly executed                                          |
|        | 1 = Fail: Routine was not executed                                                |
|        | Possible reasons of failure:                                                      |
|        | <ul> <li>Corrupted NVM data sector</li> </ul>                                     |
|        | <ul> <li>The range of the address is protected</li> </ul>                         |
|        | The range of the address is incorrect                                             |
|        | Possible reason for execution fail:                                               |
|        | <ul> <li>Routine called as nested call during the execution of another</li> </ul> |
|        | NVM routine (e.g. via RAM branching)                                              |
|        | <ul> <li>Assembly Buffer is already opened</li> </ul>                             |

#### Table 5-16 Opening assembly buffer subroutine (cont'd)

The input address will be page aligned internally, bit[6:0] = don't care. Once assembly buffer is opened, user must either proceed with the standard program flow (refer to **Figure 0-4**) or close the assembly buffer using the dedicated abort programming user routine (refer to the **Section 5.3.8**). All other sequences are not allowed and might lead to loss of data. Please check the flow diagram in **Figure 5-15**, it depicts the usage of the USER\_OPENAB function.



# 5.3.2 NVM programming routine

There are 2 types of programming available, Type 1 or Type 2 (Type 1 without or Type 2 with RAM background activity during NVM operation).

For Type 1 programming, the flow control is always kept by the BootROM NVM programming routine. Consequently, no other operations can be run in parallel thus avoiding making use of the NVM operation waiting time. In Type 2 programming, the BootROM routine starts the write operation and then gives back control to the user software by branching to the RAM address  $18000400_{\text{H}}$ . In this scenario, the user software needs to reside in RAM because no access to the NVM is possible while internal program sequence is on-going. The user software needs to hand back the control to the NVM programming routine, which continues with polling the busy bit.

A description of the BootROM programming routine is provided in the following **Table 5-17**. More information on the support for background activity during NVM operation can be found in the **Section 5.4.2**.

The program operation is executed on the page selected by the previously called USER\_OPENAB. If the addressed page is already programmed, then an erase will be applied as wel, see timing diagrams below. In case the target page belongs to the NVM Data region, at the end of a successful program operation, the USER\_PROG routine properly updates the MapRAM information mapping the page just written and randomly selects a proper spare page between the available (not written and not faulty) pages. In case, for any reason, a valid spare page cannot be found, the routine returns a proper error indication. In such case all data previously written, including the page just written is still accessible (no data loss). Please check the flow diagram in Figure 5-15, it depicts the usage of the USER\_PROG function.

#### **Timing diagrams**

In the following the timing diagrams for various USER\_PROG usecases are displayed. The colored areas in the beginning and the end of a block represent the bootrom preamble and postamble code (these are not timing accurate).



# Figure 5-2 Programming an erased paged, applies to code flash as well as to data flash









Figure 5-4 Programming an used paged, applies to code flash only



Figure 5-5 Programming an used paged with enabled retry (corrective action = 1), applies to code flash only



Figure 5-6 Programming an used paged, applies to data flash only





Figure 5-7 Programming an used paged with enabled retry (corrective action = 1), applies to data flash only

Table 5-17 Programming subroutine

| Subroutine | 000038DD <sub>H</sub> : USER_PROG       |
|------------|-----------------------------------------|
|            | Prototype:                              |
|            | unsigned char USER_PROG(char PROG_FLAG) |



| Input | PROG_FLAG (char):                                                                                                                                                                                             |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Byte for controlling the programing routine.                                                                                                                                                                  |
|       | Bit 0: RAM branching control bit<br>0 = RAM branching disabled<br>1 = RAM branching enabled                                                                                                                   |
|       | Bit 1: Corrective action (retry and disturb handling) control bit<br>0 = Corrective actions disabled<br>1 = Corrective actions enabled                                                                        |
|       | Bit 2: Failing page erase control bit when addressing non linearly mapped sector (refer to the <b>Section 5.4.4.2</b> for more details)                                                                       |
|       | 0 = Failing page erase enabled. The programmed data are erased in case of fail. If the page was already used, old data are kept.                                                                              |
|       | 1 = Failing page erase disabled. Programmed data are not<br>erased in case of fail. If page was already used, old data<br>are not kept and the new failing data are accessible by<br>reading the target page. |
|       |                                                                                                                                                                                                               |

# Table 5-17 Programming subroutine (cont'd)



| Table 5-17 | Programming subroutine (cont'd)                                                                                                                                                                                                                                                                                |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output     | Return value (unsigned char):Bit 0: Pass or Fail. This bit is the OR of the bits 4, 5, 6 and 70 = Programming completed successfully. No errors<br>occurred1 = Programming failed. At least one error occurred                                                                                                 |
|            | Bit 1-3: Reserved                                                                                                                                                                                                                                                                                              |
|            | Bit 4: Verify Pass/Fail<br>0 = Pass: The verification of the programmed data passed<br>1 = Fail: The verification of the programmed data failed                                                                                                                                                                |
|            | <ul> <li>Bit 5: Emergency Operation Pass/Fail</li> <li>0 = Pass: The normal flow of the program operation has not been interrupted by an emergency operation request.</li> <li>1 = Fail: The normal flow of the program operation has not been completed due to a request of an emergency operation</li> </ul> |
|            | <ul> <li>Bit 6: Spare page selection Pass/Fail (Valid only for operation run on NVM Data pages)</li> <li>0 = Pass: A new random spare page has been properly selected</li> <li>1 = Fail: The random spare page selection failed. No random spare page selected</li> </ul>                                      |
|            | Bit 7: Execution Pass/Fail status<br>0 = Pass: Routine execution could be properly started<br>1 = Fail: Routine execution could not be properly started due<br>to missing required setting (Assembly Buffer not opened,<br>target region write protected, nested call execution)                               |
|            | Note: No NVM prog, erase or verify routine can be called until<br>this NVM operation is completed.                                                                                                                                                                                                             |

# 5.3.3 Page verify routine

# Note: This function is not available for variants with 256 Kbyte flash.

This user routine performs a verify on the target page using the Hard Read Level Erased and Hard Read Level Programmed (refer to **Figure 5-10** for read level details). The address of the target page is provided as input parameter.

MOTIX<sup>™</sup> TLE986x, MOTIX<sup>™</sup> TLE987x, BootROM



#### NVM

In case the target page belongs to the linear code flash region, the routine performs the check on the target page and returns the page status. The routine first reads the page at standard read level and then compares the data read with the content read with Hard Read levels. In case an ECC fail is found or data are not identical at all the three used read levels, a fail is returned  $(03_{\rm H}, 05_{\rm H} \text{ or } 07_{\rm H} \text{ depending on which read level the verify is failing}).$ 

In case the page belongs to the non-linearly mapped data flash, the routine first accesses the MapRAM to check that the target page is mapped. In case no valid mapping for the page is found (invalid physical page or ECC fail) a proper error is reported (41<sub>H</sub>). If a valid mapping is found, the routine performs the page verify on the related physical page and its status is returned.

The routine is not performed in case write protection is set on the target region. In this case, an error  $(81_H)$  is returned and the verify is not executed. In such case, the user is required to (temporarily) disable write protection on the target region before calling the routine.

The routine cannot be executed during any other NVM operation (it cannot be called as nested call inside other NVM related user routines).

# Note: A fail returned by this function does not mean the page is no longer readable, it means that at least some cells have reached the Hard Read levels, a refresh of the page is recommended.

| Subroutine | 00003895 <sub>H</sub> : USER_VERIFY_PAGE        |  |
|------------|-------------------------------------------------|--|
|            | Prototype:                                      |  |
|            | unsigned char USER_VERIFY_PAGE(int NVMPageAddr) |  |

Table 5-18 Page verify subroutine



| Input  | NVMPageAddr (int):                                                                                                                                                                                                                                                                            |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | NVM page address to be checked, page aligned address                                                                                                                                                                                                                                          |
| Output | Return value (char):<br>Bit 0: Pass or Fail. It is the OR of the bits 1, 2, 6 and 7<br>0 = Overall pass<br>1 = Overall fail                                                                                                                                                                   |
|        | Bit 1: Page verify on Hard Read Level Erased Pass or Fail<br>0 = Page verify on Hard Read Level Erased pass<br>1 = Page verify on Hard Read Level Erased fail                                                                                                                                 |
|        | Bit 2: Page verify on Hard Read Level Programmed Pass or Fail<br>0 = Page verify on Hard Read Level Programmed pass<br>1 = Page verify on Hard Read Level Programmed fail                                                                                                                     |
|        | Bit 3 to 5: Reserved                                                                                                                                                                                                                                                                          |
|        | Bit 6: MapRAM check Pass or Fail (valid only when addressing the DFLASH)                                                                                                                                                                                                                      |
|        | 0 = Pass: No MapRAM fail found<br>1 = Fail: MapRAM fail found (Invalid page)                                                                                                                                                                                                                  |
|        | Bit 7: Execution Pass/Fail status<br>0 = Pass: Routine execution could be properly started<br>1 = Fail: Routine execution could not be properly started due<br>to missing required setting (e.g.: Opened Assembly<br>Buffer, nested call execution, invalid address, write<br>protection set) |
|        | Note: No NVM prog, erase or verify routine can be called until this NVM operation is completed.                                                                                                                                                                                               |

# Table 5-18 Page verify subroutine (cont'd)

# 5.3.4 NVM page erasing routine

Similarly, there are 2 types of erasing available, Type 1 or Type 2 (Type 1 without or Type 2 with RAM background activity during NVM operation). Details in the following table. Please check the flow diagram in **Figure 5-15**, it depicts the usage of the USER\_ERASEPG function.



| Table 5-19 P | Fable 5-19         Page erasing subroutine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Subroutine   | 000038D5 <sub>H</sub> : USER_ERASEPG<br>Prototype:<br>unsigned char USER_ERASEPG(int *NVMPageAddr, char<br>RAM_RTNE_BRNCHNG)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Input        | *NVMPageAddr (int pointer):<br>Pointer to the NVM address (page aligned) to be erased<br>RAM_RTNE_BRNCHNG (char): To enable or disable<br>background execution from RAM.<br>Bit 0: RAM branching control bit<br>0 = RAM branching disabled<br>1 = RAM branching enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Output       | Return value (unsigned char):         Bit 0: Pass or Fail         0 = Erasing completed successfully         1 = Erasing failed         Bit 3: MapRAM ECC Pass or fail         0 = MapRAM has no ECC2 fail         1 = MapRAM has at least one ECC2 fail         Bit 3 is used only for pages in Data sector.         Bit 3 is set together with bit 0 and erase is not performed.         Bit 7: Execution Pass/Fail status         0 = Pass: Routine was correctly executed         1 = Fail: Routine was not executed         Possible reasons of failure:         • The range of the address is incorrect         • This is a protected range         Possible reason for execution fail:         • Routine called as nested call during the execution of another NVM routine (e.g. via RAM branching)         Note: No NVM prog, erase or verify routine can be called until this NVM operation is completed. |  |  |

The input NVMPageAddr should be page aligned, with bits[6:0] = 0.



## 5.3.5 Erase page verify routine

## Note: This function is not available for variants with 256 Kbyte flash.

This user routine performs an erase verify on the target page using the Hard Read Level Erased (refer to **Figure 5-10** for read level details). The address of the target page is provided as input parameter.

In case the target page belongs to the linear code flash region, the routine performs the check on the target page and returns the page status.

In case the page belongs to the non-linearly mapped data flash, the check is performed on the spare page regardless of the page address provided as input. In particular, the routine first accesses the MapRAM to check that a valid spare page link is present in the MapRAM (no ECC fail and valid link to an existing physical page). In case no valid spare page link is found, a proper error is reported (41<sub>H</sub>). In that case the user shall try to rebuild valid mapping info by calling the USER\_MAPRAM\_INIT routine. If a valid spare page selection is found, the routine performs an erase page verify on the physical page selected as spare page and its status is returned.

The routine is not performed in case write protection is set on the target region. In this case, an error  $(81_H)$  is returned and the verify is not executed. In such case, the user is required to (temporarily) disable the write protection on the target region before calling the routine.

The routine cannot be executed during any other NVM operation (it cannot be called as nested call inside other NVM related user routines.)

### Note: A fail returned by this function does not mean the page is no longer usable, it means that at least some cells have reached the Hard Read levels. In case of lineare code flash retry the page erase, in case of mapped data flash rerun USER\_MAPRAM\_INIT<sup>1)</sup>.

| Subroutine | 00003885 <sub>H</sub> : USER_ERASEPG_VERIFY        |  |
|------------|----------------------------------------------------|--|
|            | Prototype:                                         |  |
|            | unsigned char USER_ERASEPG_VERIFY(int NVMPageAddr) |  |

| Table 5-20 | Erase | page | verify | subroutine |
|------------|-------|------|--------|------------|
|            | =     | page |        | ousioutino |

<sup>&</sup>lt;sup>1)</sup> USER\_MAPRAM\_INIT selects a new erased spare page. With the next restart of the device the Service Algorithm will attempt to erase the affected page again.



| Input  | <b>NVMPageAddr (int)</b> :<br>NVM page address to be checked, page aligned address                                                                                                                                                                                                            |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output | Return value (char):<br>Bit 0: Pass or Fail. It is the OR of the bits 1, 6 and 7<br>0 = Overall pass<br>1 = Overall fail                                                                                                                                                                      |
|        | Bit 1: Erase verify on Hard Read Level Erased Pass or Fail<br>0 = Erase page verify pass<br>1 = Erase page verify fail                                                                                                                                                                        |
|        | Bit 2 to 5: Reserved                                                                                                                                                                                                                                                                          |
|        | Bit 6: MapRAM check Pass or Fail (valid only when addressing<br>the DFLASH)<br>0 = Pass: No MapRAM fail found<br>1 = Fail: MapRAM fail found (Invalid spare page)                                                                                                                             |
|        | Bit 7: Execution Pass/Fail status<br>0 = Pass: Routine execution could be properly started<br>1 = Fail: Routine execution could not be properly started due<br>to missing required setting (e.g.: Opened Assembly<br>Buffer, nested call execution, invalid address, write<br>protection set) |
|        | Note: No NVM prog, erase or verify routine can be called until<br>this NVM operation is completed.                                                                                                                                                                                            |

| Table 5-20 | Erase page | verify | subroutine | (cont'd) | ) |
|------------|------------|--------|------------|----------|---|
|------------|------------|--------|------------|----------|---|

## 5.3.6 Sector erasing routine

This routine is used to perform an erase of a NVM data sector.

## Table 5-21 Sector erasing subroutine

| Subroutine | 00003865 <sub>H</sub> : USER_ERASE_SECTOR<br>Prototype:     |
|------------|-------------------------------------------------------------|
|            | unsigned char USER_ERASE_SECTOR(unsigned int sectorAddress) |



| Input  | SectorAddress (unsigned int):<br>NVM Sector address                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output | Returned value (unsigned char):         Bit 0: Pass or Fail         0 = Erasing completed successfully         1 = Erasing failed.         Bit 7: Execution Pass/Fail status         0 = Pass: Routine was correctly executed         1 = Fail: Routine was not executed         Possible reason for execution fail:         • Routine called as nested call during the execution of another NVM routine (e.g. via RAM branching) |
|        | Note: No NVM prog, erase or verify routine can be called until<br>this NVM operation is completed.                                                                                                                                                                                                                                                                                                                                |

#### Table 5-21 Sector erasing subroutine

The input value sectorAddress should be sector aligned, with the bits[11:0] = 0.

## 5.3.7 Erase sector verify routine

#### Note: This function is not available for variants with 256 Kbyte flash.

This user routine performs an erase verify on the target sector using the Hard Read Level Erased (refer to **Figure 5-10** for read level details). The address of the target sector is provided as input parameter.

The routine accepts a 32 bit address as input parameter. Since the routine works on a sector base, the last 12 bits of the provided address are not relevant and ignored.

In case the target sector belongs to the linear code flash region, the routine performs the check on the target sector and returns the sector status. The check is performed sequentially on all the pages of the sector one by one.

In case the target sector is the non-linearly mapped data flash, the routine performs a dedicated consistency check of the MapRAM. In case a invalid spare page mapping is found (not linked to any physical page) or any logical page is mapped or in case any MapRAM entry has a ECC fail a proper error is reported (41<sub>H</sub>). In that case the user shall try to rebuild valid mapping info by calling the USER\_MAPRAM\_INIT routine. If no issue in the MapRAM is found, the routine performs an erase sector verify on all the physical pages of the sectors and the sector status is returned.

The routine is not performed in case write protection is set on the target region. In this case, an error  $(81_H)$  is returned and the verify is not executed. In such case, the user is



required to (temporarily) disable write protection on the target region before calling the routine.

The routine cannot be executed during any other NVM operation (it cannot be called as nested call inside other NVM related user routines.)

### Note: A fail returned by this function does not mean the sector is no longer usable, it means that at least some cells in at least one page have reached the Hard Read levels, it is recommended to perform a sector erase again.

| Subroutine | 0000388D <sub>H</sub> : USER_ERASE_SECTOR_VERIFY<br>Prototype:<br>unsigned char USER_ERASE_SECTOR_VERIFY(int<br>NVMSectorAddr)                                                                                                                                                                |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>NVMSectorAddr (int)</b> :<br>NVM Sector address to be checked, sector aligned address                                                                                                                                                                                                      |
| Output     | Return value (unsigned char):<br>Bit 0: Pass or Fail. It is the OR of the bits 1, 6 and 7<br>0 = Overall pass<br>1 = Overall fail                                                                                                                                                             |
|            | Bit 1: Erase verify on Hard Read Level Erased Pass or Fail<br>0 = Erase verify for all pages of the target sector passes<br>1 = Erase page verify for at least one page of the sector fails                                                                                                   |
|            | Bit 2 to 5: Reserved                                                                                                                                                                                                                                                                          |
|            | Bit 6: MapRAM check Pass or Fail (valid only when addressing<br>the DFLASH)<br>0 = Pass: No MapRAM fail found<br>1 = Fail: MapRAM fail found (Invalid spare page, mapped<br>pages, ECC mapRAM fail)                                                                                           |
|            | Bit 7: Execution Pass/Fail status<br>0 = Pass: Routine execution could be properly started<br>1 = Fail: Routine execution could not be properly started due<br>to missing required setting (e.g.: Opened Assembly<br>Buffer, nested call execution, invalid address, write<br>protection set) |
|            | Note: No NVM prog, erase or verify routine can be called until this NVM operation is completed.                                                                                                                                                                                               |

 Table 5-22
 Erase sector verify subroutine





## 5.3.8 Abort NVM programming routine

This user routine aborts the NVM programming by closing an opened assembly buffer. Please check the flow diagram in **Figure 5-15**, it depicts the usage of the USER\_ABORTPROG function.

| Table 5-23 | Abort NVM programming subroutine |
|------------|----------------------------------|
|------------|----------------------------------|

| Subroutine | 000038CD <sub>H</sub> : USER_ABORTPROG                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------|
|            | Prototype:                                                                                                                 |
|            | bool USER_ABORTPROG(void)                                                                                                  |
| Input      |                                                                                                                            |
| Output     | Return value (bool): Pass or Fail                                                                                          |
|            | 0 = Abort successfully, assembly buffer closed                                                                             |
|            | 1 = Abort failed as programming already started                                                                            |
|            | Possible reason of failure:                                                                                                |
|            | <ul> <li>Programming already started</li> </ul>                                                                            |
|            | <ul> <li>Routine called as nested call during the execution of another<br/>NVM routine (e.g. via RAM branching)</li> </ul> |

## 5.3.9 MapRAM initialization

This routine is meant to be used to re-initialize the MapRAM of the DFLASH sector.

The routine performs a complete MapRAM initialization by triggering a dedicated function of the NVM internal Finite State Machine. When triggered, the state machine resets the whole MapRAM and rebuilds information by reading the current logical to physical address information stored directly in the NVM data sector. In case of mapping errors (double or multiple mapping or faulty pages) the initialization of the MapRAM is stopped on the first error found and the routine is exited reporting a proper error indication. In case of fail, the content of the MapRAM might be only partial and the mapping information might be corrupted.

The routine can be used to try to restore a clean MapRAM status in case a MapRAM error has been reported by the startup or by the program routine or in case some data sector pages have been lost. In addition, this routine can be used to check whether the mapped sector has a consistent status. Please check the flow diagram in **Figure 5-15**, it depicts the usage of the USER\_MAPRAM\_INIT function.

Note: In case an NVM operation on the Data region is interrupted (e.g. due to reset events), the mapped sector might have an inconsistent status depending on the moment in which the interruption occurred. In case of power-on reset, brown-out reset, pin reset or wake-up reset the system performs the MapRAM initialisation during the following startup and triggers the Service Algorithm to try to repair mapping inconsistency, if required. In case of MOTIX<sup>™</sup> TLE986x, MOTIX<sup>™</sup> TLE987x, BootROM



#### NVM

software reset (e.g. issued during a RAM branching) or internal watchdog reset, the following startup sequence performs a MapRAM initialization without triggering the repair step in case of errors. The user shall then check after every reset the status of the mapped region evaluating the information reported on the MEMSTAT and SYS\_STRTUP\_STS registers. Refer to the Section 3.1.3 for MapRAM initialization flow for different reset types. If a mapping error is found the user shall not try to program or erase any page in the Data sector but shall try to trigger a new repair step by issuing a proper reset or erasing the complete sector.

| Subroutine | 0000389D <sub>H</sub> : USER_MAPRAM_INIT<br>Prototype:<br>unsigned char USER_MAPRAM_INIT(void)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Output     | <ul> <li>Return value (unsigned char):<br/>Bit 0: Pass or Fail. It is the OR of the bits 5, 6 and 7<br/>0 = MapRAM initialization pass<br/>1 = MapRAM initialization fail</li> <li>Bit 1 to 4: Reserved</li> <li>Bit 5: Double mapping<br/>0 = Pass: No double mapping found<br/>1 = Fail: The initialization failed due to double mapping</li> <li>Bit 6: Faulty page<br/>0 = Pass: No faulty pages found<br/>1 = Fail: The initialization failed due to faulty page</li> <li>Bit 7: Execution Pass/Fail status<br/>0 = Pass: Routine execution could be properly started<br/>1 = Fail: Routine execution could not be properly started due<br/>to missing required setting (e.g.: Opened Assembly<br/>Buffer, nested call execution)</li> <li>Note: No NVM prog, erase or verify routine can be called until<br/>this NVM operation is completed.</li> </ul> |

#### Table 5-24 MapRAM initialization subroutine



## 5.3.10 Read NVM status routine

This user routine checks for the NVM status.

## Table 5-25 Read NVM status subroutine

| Subroutine | 000038C5 <sub>H</sub> : USER_NVMRDY<br>Prototype:<br>bool USER_NVMRDY(void)     |
|------------|---------------------------------------------------------------------------------|
| Input      |                                                                                 |
| Output     | Return value (bool): Pass or Fail<br>0 = NVM is not busy<br>1 = NVM is busy now |



## 5.3.11 Read 100 Time Programmable parameter data routine

This routine reads the 100TP page content. For the 100TP page 1, the data offset range is listed in **Table 5-11**. Details in the following table.

| Subroutine | 00003875 <sub>H</sub> : USER_READ_100TP<br>Prototype:<br>bool USER_READ_100TP(char 100TP_Page_Sel, unsigned<br>char DataOffset, int *HundredTPData)                                                                                     |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>100TP_Page_Sel (char)</b> : 100TP page selection byte (CS_Byte, refer to Figure 5-8)<br>DataOffset (unsigned char): Data Offset in page (00 <sub>H</sub> to 7F <sub>H</sub> )                                                        |
| Output     | Returned value (bool): Pass or Fail         0 = Read is successful         1 = Read is not successful due to invalid range selected         HundredTPData (int pointer) = Pointer to the RAM location         where 100TP Data is saved |





Figure 5-8 User configuration sector pages address byte description



## 5.3.12 Program 100 Time Programmable routine

This routine programs data into the 100TP pages. The 100TP content to be programmed has to be preloaded into the RAM. The details can be found in the **Section 5.2.2**.

## Table 5-27 Program 100TP subroutine

| Subroutine | 0000386D <sub>H</sub> : USER_100TP_PROG            |
|------------|----------------------------------------------------|
|            | Prototype:                                         |
|            | unsigned char USER_100TP_PROG(char 100TP_Page_Sel) |



|        | ogram roore subroutine (cont d)                                                                                                                                                      |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input  | <b>100TP_Page_Sel (char):</b> 100TP page selection byte (CS_Byte, refer to Figure 5-8) RAM preloaded with the 100TP data to be programmed.                                           |
| Output | Returned value (unsigned char):<br>Bit 0: Program operation pass or fail flag<br>0 = Program completed successfully<br>1 = Program failed                                            |
|        | Bit 1: In page offset error flag<br>0 = All bytes have in page offset<br>1 = At least one byte has a not in page offset                                                              |
|        | Note: Not in page bytes are not programmed and do not result<br>in a program error on bit 0.<br>Counter position is already considered out of range.                                 |
|        | Bit 2: ID protected region fail flag<br>0 = All bytes do not target the reserved Customer_ID region<br>1 = At least 1 byte targets the reserved Customer_ID region                   |
|        | Note: Bytes targeting the Customer_ID region are not programmed and do not result in a program fail error on bit 0.                                                                  |
|        | Bit 7: Execution Pass/Fail status<br>0 = Pass: Routine was correctly executed<br>1 = Fail: Routine was not executed                                                                  |
|        | <ul> <li>Possible reasons of failure:</li> <li>The NVM code area is protected against programming</li> <li>The 100TP page is already programmed to a maximum of 100 times</li> </ul> |
|        | <ul> <li>Possible reason for execution fail:</li> <li>Routine called as nested call during the execution of another<br/>NVM routine (e.g. via RAM branching)</li> </ul>              |
|        | Note: No NVM prog, erase or verify routine can be called until this NVM operation is completed.                                                                                      |



## 5.3.13 NVM ECC check routines

The firmware provides 2 different routines to enable the user to check and monitor the quality of the NVM cells upon shipment and/or over the lifetime of the device.

The first routine, USER\_NVM\_ECC\_CHECK, provides an easy way for the user to perform a quick check of the status of the whole NVM array. The routine performs a read of the complete NVM returning the single and double bit ECC flags. This is meant to be used as a quick check of the programming quality of the NVM Code region and the mapped pages of the NVM Data region.

| Subroutine | 00003845 <sub>H</sub> : USER_NVM_ECC_CHECK<br>Prototype:<br>unsigned char USER_NVM_ECC_CHECK(void)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Output     | <ul> <li>Returned value (unsigned char): ECC error indication Bit 0: ECC1READ 0 = No single bit ECC error on the whole NVM read 1 = At least one single bit ECC error on the whole NVM read Bit 1: ECC2READ 0 = No double bit ECC error on the whole NVM read 1 = At least one double bit ECC error on the whole NVM read Bit 7: Execution Pass/Fail status 0 = Pass: Routine was correctly executed 1 = Fail: Routine was not executed</li> <li>Possible reason for execution fail: <ul> <li>Routine called as nested call during the execution of another NVM routine (e.g. via test is running, no RAM access should be attempted on the whole RAM. branching)</li> </ul> </li> </ul> |

Table 5-28 NVM ECC check subroutine

Note: The USER\_NVM\_ECC\_CHECK routine performs a read of the entire NVM Code region and of all the non-erased (mapped) pages of the Data region. All logical pages of the Data NVM region not yet programmed and consequently not mapped are not checked since there is no link to a physical address. In case the user needs to completely check the NVM Data region, a program of all the logical pages of the sector has to be performed before calling the USER\_NVM\_ECC\_CHECK.

Note: The USER\_NVM\_ECC\_CHECK makes use of the RAM byte at 0x18000015. Any data being stored there is overwritten.



The second routine, USER\_ECC\_CHECK, provides a way to check whether during code execution any ECC error occurred. With its return value the routine indicates if a single or a double bit error ECC error flag was set since last power-off (incl. Sleep mode) of the device, last call of this routine or since last call of a user routine for NVM operation, whatever happened last. This routine is meant to be used over device life time to monitor the occurrence of ECC errors. In addition, in case of EEC2 error, the routine will provide as an output the address of the last ECC2 error occurred.

The address is reported as an output in the RAM location passed as a pointer. The returned value always provides the starting address of the 8 byte section where the ECC error happened.

| Subroutine | 0000383D <sub>H</sub> : USER_ECC_CHECK<br>Prototype:<br>unsigned char USER_ECC_CHECK(unsigned int *ECC2Addr)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>ECC2Addr (unsigned int pointer):</b> Pointer to the RAM location where the last NVM address with ECC2 error shall be stored                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Output     | <ul> <li>Returned value (unsigned char): ECC error indication</li> <li>Bit 0: ECC1READ</li> <li>0 = No single bit ECC error on the whole NVM read</li> <li>1 = At least one single bit ECC error on the whole NVM read</li> <li>Bit 1: ECC2READ</li> <li>0 = No double bit ECC error on the whole NVM read</li> <li>1 = At least one double bit ECC error on the whole NVM read</li> <li>1 = At least one double bit ECC error on the whole NVM read</li> <li>0 = No double bit ECC error on the whole NVM read</li> <li>1 = At least one double bit ECC error on the whole NVM read</li> <li>Bit 7: Execution Pass/Fail status</li> <li>0 = Pass: Routine was correctly executed</li> <li>1 = Fail: Routine was not executed</li> <li>Possible reason for execution fail:</li> <li>Routine called as nested call during the execution of another NVM routine (e.g. via test is running, no RAM access should be attempted on the whole RAM. branching)</li> </ul> |

### Table 5-29 ECC check subroutine

- Note: The ECC error flags, provided as output of the NVM ECC check routines, are a copy of the ECC internal error flags registers. These registers are set when a read access to the NVM results in a single and/or double bit error and are cleared only in case of power-off (incl. Sleep mode) or in the following cases:
  - 1. When programming or erasing a NVM page.
  - 2. When calling the USER\_NVM\_ECC\_CHECK routine before performing the NVM complete read.
  - 3. When calling the USER ECC check routine before returning to user code.



## 5.3.14 Read NVM ECC2 address routine

This routine returns the result of the last NVM address accessed resulting in a double ECC error. Details in the following table.

| Table 5-30 Read NVM ECC2 address | subroutine |
|----------------------------------|------------|
|----------------------------------|------------|

| Subroutine | 000038AD <sub>H</sub> : USER_NVM_ECC2ADDR<br>Prototype:<br>unsigned char USER_NVM_ECC2ADDR(unsigned int<br>*ECC2Addr)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>ECC2Addr (unsigned int pointer):</b> Pointer to the RAM location where the last NVM address with ECC2 error shall be stored                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Output     | Returned Value (unsigned char):         Bit 0: Pass or Fail         0 = ECC2Addr read out successful         1 = ECC2Addr read out failed         Bit 4: ECC2 error detection         0 = No NVM ECC2 detected         1 = NVM ECC2 address detected         Bit 7: Execution Pass/Fail status         0 = Pass: Routine was correctly executed.         1 = Fail: Routine was not executed         Possible reason for execution fail:         • Null pointer passed to the routine, or invalid pointer, 0x81 is returned         • Routine called as nested call during the execution of another NVM routine (e.g. via RAM branching) |

The address reported as an output in the RAM location is passed as a pointer. The returned value always provides the starting address of the 8 byte section where the ECC error happened.

## 5.3.15 RAM MBIST starting routine

This routine is used to perform a RAM test. A linear write/read algorithm using alternating data is executed on a RAM range specified by the start and stop addresses given as input parameters. When starting the MBIST test, standard RAM interface is disabled. Therefore data stored into it will not be accessible and data stored in the memory range under test will be cleared to zero. The standard interface will be re-enabled after completion before the end of the routine execution.



Note: The start and stop address passed as parameter are offsets to be added to the RAM start address ( $18000000_H$ ).

| Subroutine | 0000384D <sub>H</sub> : USER_RAM_MBIST_START<br>Prototype:<br>unsigned char USER_RAM_MBIST_START(short<br>RAM_MBIST_Stop_Addr, short RAM_MBIST_Start_addr)                                                                                                                                                                                                                                                                       |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | RAM_MBIST_Stop_Addr (short): RAM offset of the stop<br>address of RAM range to be tested<br>RAM_MBIST_Start_addr (short): RAM offset of the start<br>address of RAM range to be tested                                                                                                                                                                                                                                           |
| Output     | Returned value (unsigned char): Pass or Fail         Bit 0: MBIST result, pass or fail         0 = MBIST test pass         1 = MBIST test fail         Bit 1: Address range fail         0 = test routine pass (address range valid)         1 = test routine fail (address range invalid)         Bit 7: Execution Pass/Fail status         0 = Pass: Routine was correctly executed         1 = Fail: Routine was not executed |
|            | <ul><li>Possible reason for execution fail:</li><li>Routine called as nested during the execution of another NVM routine (e.g. via RAM branching)</li></ul>                                                                                                                                                                                                                                                                      |

- Note: The range of memory to be tested by this function is limited to the first 4 Kbyte of the RAM. For the UH and UI step, the range of memory to be tested is based on the actual RAM size, which is dependent on the product variant.
- Note: While test is running, no RAM access should be attempted on the whole RAM.

Note: In case the RAM MBIST test fails, the RAM location 18000002<sub>H</sub> is written.



## 5.3.16 NVM protection status change routines

These routines allow to enable or disable the read or write protection individually on the NVM Code sectors (linearly mapped NVM sectors) and on the NVM Data sectors (not linearly mapped NVM sectors).

These routines control the protection status updating the value of the lower nibble of the NVM\_PROT\_STS register. The status of the register will be anyhow restored according to the NVM PASSWORD stored in the Configuration Sector at next reset. Please, refer to User Manual for NVM\_PROT\_STS bits description.

Note: Each routine requires a password (16 bit) that shall be provided as an input to the user routine call. The BootROM code will compare this password with the one stored into the configuration sector 100TP page 1 (offset  $0C_H$  for the routines addressing the linearly mapped region protection and offset  $0E_H$  for the routines addressing the non linearly mapped region protection). Only in case the password read out of the 100TP page 1 matches the password provided as input, the requested protection status change is performed (refer to Table 5-11).

| Table 5-32 | NVM Code sectors (linearly mapped NVM sectors) write protection |
|------------|-----------------------------------------------------------------|
|            | enable subroutine                                               |

| Subroutine | 00003925 <sub>H</sub> : USER_CFLASH_WR_PROT_EN<br>Prototype:<br>bool USER_CFLASH_WR_PROT_EN(unsigned short<br>CFLASH_PW)      |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>CFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset 0C <sub>H</sub> )    |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(1) to 0.

## Table 5-33 NVM Code sectors (linearly mapped NVM sectors) write protection disable subroutine

| Subroutine | 0000391D <sub>H</sub> : USER_CFLASH_WR_PROT_DIS |
|------------|-------------------------------------------------|
|            | Prototype:                                      |
|            | bool USER_CFLASH_WR_PROT_DIS(unsigned short     |
|            | CFLASH_PW)                                      |



| Table 5-33 | NVM Code sectors (linearly mapped NVM sectors) write protection |
|------------|-----------------------------------------------------------------|
|            | disable subroutine (cont'd)                                     |

| Input  | <b>CFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset $0C_H$ )             |
|--------|-------------------------------------------------------------------------------------------------------------------------------|
| Output | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(1) to 1.

## Table 5-34 NVM Code sectors (linearly mapped NVM sectors) read protection enable subroutine

| Subroutine | 00003915 <sub>H</sub> : USER_CFLASH_RD_PROT_EN<br>Prototype:<br>bool USER_CFLASH_RD_PROT_EN(unsigned short<br>CFLASH_PW)                                                                |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      | $\label{eq:cflash_PW} \begin{array}{l} \textbf{CFLASH_PW}(\textbf{unsigned short}) : \mbox{Password to be compared to} \\ the one stored in the 100TP page 1 (offset 0C_H) \end{array}$ |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match)                                                           |

This routine sets the bit NVM\_PROT\_STS(3) to 0.

| Table 5-35 | NVM Code sectors (linearly mapped NVM sectors) read protection |
|------------|----------------------------------------------------------------|
|            | disable subroutine                                             |

| Subroutine | 0000390D <sub>H</sub> : USER_CFLASH_RD_PROT_DIS<br>Prototype:<br>bool USER_CFLASH_RD_PROT_DIS(unsigned short<br>CFLASH_PW)    |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>CFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset 0C <sub>H</sub> )    |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |



This routine sets the bit NVM\_PROT\_STS(3) to 1.

# Table 5-36 NVM Data sectors (not linearly mapped NVM sectors) write protection enable subroutine

| Subroutine | 00003905 <sub>H</sub> : USER_DFLASH_WR_PROT_EN<br>Prototype:<br>bool USER_DFLASH_WR_PROT_EN(unsigned short<br>DFLASH_PW)      |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>DFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset $0E_H$ )             |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(0) to 0.

# Table 5-37 NVM Data sectors (not linearly mapped NVM sectors) write protection disable subroutine

| Subroutine | 000038FD <sub>H</sub> : USER_DFLASH_WR_PROT_DIS<br>Prototype:<br>bool USER_DFLASH_WR_PROT_DIS(unsigned short<br>DFLASH_PW)     |
|------------|--------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>DFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset $0E_H$ )              |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully.<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(0) to 1.



## Table 5-38 NVM Data sectors (not linearly mapped NVM sectors) read protection enable subroutine

| Subroutine | 000038F5 <sub>H</sub> : USER_DFLASH_RD_PROT_EN<br>Prototype:<br>bool USER_DFLASH_RD_PROT_EN(unsigned short<br>DFLASH_PW)      |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>DFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset $0E_H$ )             |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(2) to 0.

## Table 5-39 NVM Data sectors (not linearly mapped NVM sectors) read protection disable subroutine

| Subroutine | 000038ED <sub>H</sub> : USER_DFLASH_RD_PROT_DIS<br>Prototype:<br>bool USER_DFLASH_RD_PROT_DIS(unsigned short<br>DFLASH_PW)    |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| Input      | <b>DFLASH_PW(unsigned short)</b> : Password to be compared to the one stored in the 100TP page 1 (offset $0E_H$ )             |
| Output     | Returned value (bool): Pass or Fail<br>0 = Operation completed successfully<br>1 = Operation failed (Password does not match) |

This routine sets the bit NVM\_PROT\_STS(2) to 1.

User configuration sector pages (100TP) are part of the NVM Code region considering the write protection, enabled by the routine USER\_CFLASH\_WR\_PROT\_EN.

Code fetching is not influenced by the read protection.

Note: Copying code from NVM to RAM requires a normal NVM read execution and so is blocked in case NVM read protection is enabled.

The permanent NVM protection (enabled by Mode 6 as described in the Section 4.4.2.7) is meant to avoid unwanted writing/reading of the flash during code execution. In case



the application SW has to write/read Code and/or Data flash, the protection can be temporarily disabled and then enabled again, as described in the Section 5.3.16. Even if the read protection is enabled on Code region, Data regions or both, the code executed from Code NVM region can always read both NVM Code and Data regions.

## 5.3.17 Read NVM config status routine

This routine reads the NVM Configuration Status. Details in the following table.

| Subroutine | 000038B5 <sub>H</sub> : USER_NVM_CONFIG<br>Prototype:<br>bool USER_NVM_CONFIG(char *NVMSize, char<br>*MapRAMSize)                                                                                                                                                                                                                                                                                                                                                                              |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Output     | <ul> <li>Return value (bool): Pass or fail <ul> <li>0 = Configuration read successfully</li> <li>1 = Configuration read failed</li> </ul> </li> <li>NVMSize (char pointer): pointer to the RAM location where the number of available sectors of the code area (4 Kbytes each) has to be saved</li> <li>MapRAMSize (char pointer): pointer to the RAM location where to store the number of available sectors of the data area (4 Kbytes each)</li> <li>Possible reason of failure:</li> </ul> |
|            | <ul> <li>NVM Linear sector is set as 00<sub>H</sub></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## Table 5-40 Read NVM config status subroutine

## 5.3.18 Read user calibration data

All data stored in the 100TP pages can be downloaded into the RAM using this routine. In particular, this routine has been developed to help user in downloading the ADC1 calibration parameters stored at the beginning of 100TP page 1 (see Table 5-11) to an easily accessible data space (RAM). To download the data, the user needs to provide the 100TP page where data has to be read from, number of bytes to be copied, and the RAM address where data has to be copied to. The routine will copy the specified number of bytes from the selected page (starting always from first byte in the page) into the RAM (starting at the given address).

Note: The provided RAM address where data have to be copied is just an offset to the device RAM start address (18000000<sub>H</sub>).



| Table 5-41 Read u | ser calibration data subroutine                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Subroutine        | 000038BD <sub>H</sub> : USER_READ_CAL<br>Prototype:<br>unsigned char USER_READ_CAL(unsigned char<br>NumOfBytes, char Sel100TP, short RAMAddr)                                                                                                                                                                                                                                                                                                                                                                                             |
| Input             | NumOfBytes (unsigned char): Number of bytes to be copied from config sector into the RAM (allowed values are form 01 <sub>H</sub> to 80 <sub>H</sub> ).         Sel100TP (char): 100TP page to take data from (refer to Figure 5-8).         RAMAddr (short): RAM address offset to copy data to (03FF <sub>H</sub> < RAMAddr < RAMAddr + NumOfBytes < RAM size)                                                                                                                                                                          |
| Output            | Return value (unsigned char):         Bit 0: Pass or Fail         0 = Read is successful         1 = Read is not successful due to invalid input values         Bit 7: Execution Pass/Fail status         0 = Pass: Routine was correctly executed         1 = Fail: Routine was not executed         Possible reasons of failure:         • The input parameters are incorrect.         Possible reason for execution fail:         • Routine called as nested call during the execution of another NVM routine (e.g. via RAM branching) |

## 5.3.19 NVMCLKFAC setting routine

This routine is used to write the NVMCLKFAC bit in SYSCON0 register.



| Table 5-42 | NVMCLKFAC setting subroutine                                                                    |
|------------|-------------------------------------------------------------------------------------------------|
| Subroutine | 00003855 <sub>H</sub> : USER_NVMCLKFAC_SET<br>Prototype:<br>void USER_NVMCLKFAC_SET(char Value) |
| Input      | Value (char): SYSCON0.NVMCLKFAC value to be written.<br>b                                       |
| Output     |                                                                                                 |

## 

#### 5.4 NVM user applications

The NVM user routines application is described in this section.

#### 5.4.1 NVM Data sector handling

The NVM provides a special sector for data storage. Through a non-linear mapping of the address space, the FW and the NVM module provides a special feature to increase the maximum number of write-erase cycles a logical page can stand and to reduce the risk of data loss in case of interrupted NVM operations (tearing events).

The handling of this special Data sector requires the usage of an NVM internal look-up table (MapRAM) which is used to store and handle the link between logical and physical addresses of the sector's pages.

Since the MapRAM is a volatile memory, the firmware takes care to rebuild the MapRAM content at each power-up based on mapping information stored into a specific field of the Data sectors pages (mapblock). This process is called Data sector initialization (MapRAM initialization).

During this initialization phase, mapping errors induced by tearing events might be found. This would then prevent the firmware from properly restoring the link between the logical and physical addresses thus preventing proper usage of this sector. In this case, the firmware provides a specific algorithm (Service Algorithm) to identify and solve these errors. In particular, the Service Algorithm tries to repair bad pages created unintentionally into the NVM Data region due to, for example, a NVM program or erase operation interrupted by any reset or power loss (tearing events). The Service Algorithm is triggered during the startup by the NVM data sector initialization in case mapping issues are found.

The Service Algorithm provides proper analysis features to try to preserve the integrity of the NVM Data region in case ongoing NVM operation (program or erase) is unintentionally and unexpectedly aborted (e.g. due to power loss). Anyhow, it is not meant to cover all possible scenarios that can be created by an interrupted NVM operation. The user shall put in place proper action to avoid any



# possible interruption of NVM operation (e.g. using proper capacitor on the power supply).

The NVM Data sector initialization and Service Algorithm flows are described below.

## NVM Data sector initialization

After any reset, as part of the startup, the firmware triggers a NVM initialization of the NVM data sector. This initialization is performed by a hardware state machine which takes care to restore the mapping information into the MapRAM reading specific bytes (called mapblock) of the NVM Data sector pages (see **Figure 5-9**). The state machine accesses these bytes and, page by page, reads out the logical page to which the current physical page has to be linked to, updating accordingly the dedicated MapRAM location.

In case a mapblock is read as erased, the physical page is not mapped. All the logical pages for which no valid mapping is found are marked into the MapRAM as unmapped.

While reading out the info from the mapblock, the hardware state machine might find incorrect mapping info. In particular, following scenarios might appear:

- More physical pages are mapped to the same logical page (double or higher mapping)
- The mapblock information cannot be read correctly due to ECC errors (faulty page)

In this case, the hardware state machine stops the initialization on the first incorrect mapping. In case of power-on reset, brown-out reset, pin reset, WDT1 reset or wake-up from sleep in addition the execution of the Service Algorithm (SA) is triggered.



Figure 5-9 MapRAM and mapblocks



## MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

#### NVM



Figure 5-10 Read levels and faulty page





Figure 5-11 NVM data sector initialization flow

In order to detect pages whose mapblock is marginal towards the standard read level, the NVM finite state machine that performs the mapping initialization is triggered three times with three different read levels: standard read margin, soft read level erased and soft read level programmed (refer to **Figure 5-10**). As soon as the first incorrect mapping (faulty or multiple mapping) is detected by any of these three initialization sequences, depending on the reset type, the Service Algorithm is called.

At the end of the Service Algorithm execution, a new initialization of the Data sector is needed to properly initialize the mapping info. This final initialization is again executed by triggering the NVM Finite State Machine and is performed using only the standard read level.

Note: For any reset the result of the last NVM Data sector initialization executed during the startup flow is reported to the user via the bit 1 of the SYS\_STRTUP\_STS register (MRMINITSTS). If this bit is set to 1 then the last initialization failed and the mapping info might be corrupted. In this case, a reset (power-on reset, brown-out reset, pin reset or wake-up reset) can be issued in order to start the Service Algorithm to try to fix the integrity issue inside the Data NVM. If the MRAMINITSTS is still flagged afterwards, the Data NVM sector has to be re-initialized by performing a sector erase.



## Service Algorithm

The Service Algorithm is called by the NVM Data sector initialization in case incorrect mapping issues have been found. The Service Algorithm checks the data sector page by page reading the mapblocks with soft read levels (refer to **Figure 5-10**).

At first, the Service Algorithm looks for faulty pages and tries to repair them by erasing these pages. Following, the algorithm proceeds looking for double or higher mappings.

In case two or more double mappings or at least one triple or higher mapping were found the SA stops execution and reports an error on the MEMSTAT register (MEMSTAT set to  $B0_H$ ). In case, instead only one double mapping is found, the algorithm selects which page has to be erased according to the following steps:

- 1. The SA checks the 2 pages linked to the double mapping with standard, soft and hard read levels to detect which one has better quality (more margin towards the standard read level, refer to Figure 5-10). The page with smaller margin is then erased.
- 2. In case both pages have same quality, the algorithm checks some specific bits of the mapblock (called map counter) to check which of the pages has been programmed last. In this case, the older one is erased.
- 3. In case both pages have same map counter value, the SA cannot decide which page has to be erased and ends the flow reporting an error on the MEMSTAT register (e.g. MEMSTAT set to B0<sub>H</sub> for a 256 Kbyte variant).

Whenever the SA is triggered, information regarding the addressed data sector number will be stored in SECTORINFO (this is an indication that the SA was executed during the startup phase). In addition, in case the SA cannot recover all incorrect mapped pages, the SA reports a fail into the SASTATUS field of the MEMSTAT writing the value  $10_B$ . In such a case, the user shall properly handle the reported mapping issue by either triggering a reset (power-on reset, pin reset, WDT1 reset, brown-out reset or wake-up from sleep reset) in order to trigger a new NVM initialisation or to erase the whole NVM data sector to reset the mapping info.

Detailed description of the MEMSTAT register can be found in the following table **Table 5-43**.



| Field      | Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SASTATUS   | 7:6  | <ul> <li>Service Algorithm Status</li> <li>Depending on SECTORINFO, 2 possible outcomes.<br/>For SECTORINFO = 00<sub>H</sub>: NVM initialisation successful, no SA is executed.<br/>For SECTORINFO = Otherwise: SA execution successful. Only 1 mapping error fixed.</li> <li>SA execution successful. At least 1 mapping error fixed.</li> <li>SA execution failed. Map error in data sector.</li> <li>Reserved</li> </ul>                                                                                                                      |
| SECTORINFO | 5:0  | $\begin{array}{l} \textbf{Sector Information} \\ At the startup, the value of tthis field is set to 000000_B and it is written anytime the SA is executed. \\ This field is internally divided into two parts: \\ \\ Bits 5:0 : NVM Class identifier \\ 30_H: 256 Kbyte variants \\ 20_H: 128 Kbyte variants \\ 10_H: 64 Kbyte variants \\ 09_H: 36 Kbyte variants \\ Others: Reserved \\ \\ \\ \\ \\ Once the SA has been executed, regardless of the execution status, the last access sector information will be stored here. \\ \end{array}$ |

## Table 5-43 MEMSTAT Register status for NVM integrity handling

Note: The MEMSTAT register has a dual function. It is used to store the return value of the SA as well as input value for the NVM operations to indicate the Emergency Operation. For this reason, the user shall reset the MEMSTAT register after every power-on reset, brown-out reset, pin reset or wake-up reset before the execution of any NVM operation.

During the repair phase, pages with incorrect mapping are erased. Each page erase operation takes up to 4.5 ms.





## Figure 5-12 Service Algorithm: Timing examples

Due to the duration of the first WDT1 open window after reset (long open window), the maximum number of pages that can be repaired in one Service Algorithm execution is 13.

The result of the Service Algorithm repair phase is reported in the MEMSTAT register. At the end of the startup procedure, user shall evaluate the content of this register to properly handle fails and clear the register before performing any NVM operation.

The value is only available after reset before any NVM operation (Program, Erase, OpenAB) is started. The corresponding NVM address to the Sector Information read is listed in Table 5-3.

## Service Algorithm and NVM protection

In case the Service Algorithm detects mapping issues, it tries to repair mapping by erasing the wrong pages (either faulty or double mapped pages). Consequently, the repair step can modify the NVM Data sector content. To avoid data loss, the SA checks the NVM Data sector protection and proceeds towards the repair step only if the protection is not enabled.

In case protection is enabled, instead, the repair actions are not performed and a warning is provided to the user by writing the value  $FE_H$  in the MEMSTAT register.

Via a dedicated 100TP sector parameter the user can always allow Service Algorithm to perform the repair step even in case the Data sector is protected. The control byte for this feature, CS\_SA\_WITH\_PROT\_EN, is stored into the first 100TP page (refer to **Table 5-11**). When this parameter is set to the value A5<sub>H</sub> the repair step is executed even in case protection is set. The repair flow saves the protection setting, removes temporarily the protection on the data sector, performs the needed repair operation and then restores the original protection settings. The temporary protection disabling is



performed via NVM protection register setting, no access or changes to the user defined NVM protection password is performed. By default the CS\_SA\_WITH\_PROT\_EN parameter is set to  $00_{\rm H}$  (i.e. protection status is considered).

## 5.4.2 Supporting background NVM operation

There is only one NVM module present in TLE986x/TLE987x. When NVM is busy executing internal operations (e.g. cells programming or erasing, data verify), no other activities within NVM can be executed. Although the NVM programming or erasing is handled by the NVM module, the user code cannot be read or executed as the NVM module is busy.

For this reason interrupts can only be serviced when the NVM is free if the interrupt vector table or interrupt service routines are located in the NVM. A NVM program operation can take from 3.5 ms to 13.5 ms to be completed. Therefore there is a need to support the user for critical activities.

To support other user activities while NVM is busy, the BootROM can redirect code execution to RAM after triggering time consuming NVM operations like program and erase. This type of background code execution is known as Type 2 NVM operations or RAM branching. When RAM branching is active, the BootROM routines jump to the RAM address 18000400<sub>H</sub> every time it has to wait for NVM internal operation to be completed. In this way, the user can execute code from RAM while NVM is busy.

While executing user code from RAM due to RAM branching, if the ongoing internal NVM operation is completed, the BootROM code execution is not automatically restarted and the previously triggered BootROM user routine is suspended. The user needs to explicitly re-trigger the user routine code execution by giving back control to the BootROM via a return instruction (BX LR). In this way the suspended user routine execution is resumed.

The USER\_NVMRDY user routine (refer to the **Section 5.3.10**) is provided to check whether the internal on going NVM operation is finished. User can use this routine to poll the busy status of the NVM to decide when to return control to the suspended user routine.

In case the user RAM code returns control to BootROM user routine while NMV is still busy, the BootROM code waits till the internal operation is completed before continuing with the normal user routine execution.

**Table 5-44** shows RAM branching address and provides an example for the RAM code exit point. **Figure 5-13** shows how background programming can be supported during calls to a NVM programming routine.

## Note: The context switch between BootROM user routine and user RAM code in NVM operation Type 2 is user responsibility. To avoid that RAM code execution interferes with BootROM user code completion, the user must save the content of the used resources (e.g. core registers) upon starting



the RAM code execution and restore them before jumping back to the BootROM code. Under no circumstances shall the user return with modified core registers, as proper resuming the BootROM function cannot be ensured.

Note: During user RAM code execution in Type 2 NVM operations, no calls to NVM user routine are allowed. Calling other NVM user routines can change internal NVM registers content thus affecting the completion of the suspended operation.

| RAM Address                       | RAM content                                                                            |
|-----------------------------------|----------------------------------------------------------------------------------------|
| 18000400H                         | Start of user defined code. It can be directly code or jump to some other RAM location |
| End of user defined code location | BX LR (Return instruction)                                                             |

#### Table 5-44 RAM branch code structure



## MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

NVM



Figure 5-13 Background NVM programming operation with jumps to RAM code (example for non-linearly mapped sector)

MOTIX<sup>™</sup> TLE986x, MOTIX<sup>™</sup> TLE987x, BootROM



NVM

## 5.4.3 Emergency operation handling

Note: Emergency operation provides the possibility to exit an on-going NVM operation in a faster way skipping some internal time consuming steps in case high priority tasks are required. For this reason, leaving an NVM operation via an emergency operation request might leave some inconsistent data into the sector targeted by the interrupted operation. When using this feature on Data NVM sector, the user is recommended, soon after the completion of the execution of the high priority tasks, to issue a pin reset or sleep entry-exit sequence to let the firmware to properly clean the sector.

To ensure that NVM is functioning correctly, all NVM operations (i.e. program or erase) are to be completed before a new NVM operation is started. In addition, corrective activities such as retries and disturb handling are added in an NVM program routine and could add additional time. In an emergency situation, where the system needs to save important user data in the shortest time possible, this becomes critical. Therefore, a mechanism to bypass these corrective activities as well as to inform that a new NVM sequence will not be started, is needed. To support an emergency situation, the following steps are recommended in the code whenever the NVM programming is called.

## 5.4.3.1 Emergency operation handling - Type 1 routines

For Type 1 routines (including both program and erase), an emergency programming may only be handled with the interrupt enabled shown in **Table 5-45**.

| Step | Description                                                                                                                    |
|------|--------------------------------------------------------------------------------------------------------------------------------|
| 1    | User code enables interrupt and sets MEMSTAT.NVMPROP before calling NVM (Program/Erase) routines.                              |
| 2    | While the NVM operation is on-going, an event occurs triggering an interrupt.                                                  |
| 3    | Interrupt subroutine (ISR) is serviced immediately when the NVM is free.                                                       |
| 4    | ISR has to check for the MEMSTAT.NVMPROP status. If this bit is set,<br>MEMSTAT.EMPROP has to be set and ISR has to be exited. |

| Table 5-45 | Emergency operation handling in Type 1 routines |
|------------|-------------------------------------------------|
|------------|-------------------------------------------------|



#### Table 5-45 Emergency operation handling in Type 1 routines (cont'd)

| Step | Description                                                                                                                                                                                                                                                                             |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 5    | With control returned to the BootROM, the NVM routines will be executed bypassing the corrective activities. This ensures that the routines are completed in the shortest time possible.                                                                                                |  |
| 6    | Exiting the NVM routines, the user code checks the MEMSTAT.EMPROP.<br>Since it is set, the code can branch to execute a user defined emergency<br>sequence and clear the bits MEMSTAT.NVMPROP and MEMSTAT.EMPROP.<br>These activities can include the programming of the critical data. |  |

## 5.4.3.2 Emergency operation handling - Type 2 routines

For Type 2 routines (including both program and erase), an emergency programming may be handled with or without the interrupt enabled. In the case with interrupt enabled, it is similar to Type 1 Routines shown in **Table 5-45**. For the case without interrupt enabled, it is shown in **Table 5-46**.

| Step | Description                                                                                                                                                                                                                                                                             |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | User code sets MEMSTAT.NVMPROP before calling NVM (Program/Erase) routines.                                                                                                                                                                                                             |
| 2    | While the NVM operation is started, the BootROM jumps to execute a user defined code in the RAM. Within this code, the user checks periodically for critical events.                                                                                                                    |
| 3    | During the checking, an emergency event occurs. The code has to set MEMSTAT.EMPROP and give back control to BootROM.                                                                                                                                                                    |
| 4    | With control returned to the BootROM, the NVM routines will be executed bypassing the corrective activities. This ensures that the routines are completed in the shortest time possible.                                                                                                |
| 5    | Exiting the NVM routines, the user code checks the MEMSTAT.EMPROP.<br>Since it is set, the code can branch to execute a user defined emergency<br>sequence and clear the bits MEMSTAT.NVMPROP and MEMSTAT.EMPROP.<br>These activities can include the programming of the critical data. |

Table 5-46 Emergency operation handling in Type 2 routines (No interrupt)

## 5.4.3.3 Emergency operation handling timing

In this chapter some information about overall emergency operation worst case timing is provided.

**Table 5-47** describes the case in which user data has to be saved into the linear sector due to an emergency event. Flow for programming the critical information in the not lin-



early mapped region of the NVM is similar (step 6 and 7 are inverted and a few  $\mu$ s have to be added for MapRAM update) and overall worst case time is the same.

| Phase | Description                                                                                                                                                                                                                                                     |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | User code enables interrupt and sets MEMSTAT.NVMPROP before calling NVM (Program/Erase) routines.                                                                                                                                                               |
| 2     | While the NVM operation is on-going, an event occurs triggering an interrupt.<br>In the worst case interrupt comes soon after a new erase was started.                                                                                                          |
| 3     | Interrupt subroutine (ISR) is serviced immediately when the NVM is free.                                                                                                                                                                                        |
| 4     | With control returned to the BootROM, the NVM routines will be executed bypassing the corrective activities. This ensures that the routines will end in the shortest time possible even if a successful execution of the on going NVM operation is not ensured. |
| 5     | Exiting the NVM routines, the user code checks the MEMSTAT.EMPROP.<br>Since it is set, the code can branch to execute a user defined emergency<br>sequence. First step is open AB and load user relevant data.                                                  |
| 6     | Before programming new data, if target page is already used, a preliminary erase is performed.                                                                                                                                                                  |
| 7     | User critical data are programmed in the target page.                                                                                                                                                                                                           |

| Table 5-47 | Emergency operation handling in Type 1 routines |
|------------|-------------------------------------------------|
|            |                                                 |

The **Table 5-47** refers to the type 1 routines but data are similar for type 2 routines as well.



Figure 5-14 Worst case emergency handling timing when linear sector is used

Worst case time, shown in **Figure 5-14**, is then 13.5 ms. This does not include time for user code execution. It can be reduced by about 4.1 ms if the user ensures that the page used for critical data saving is erased.



## 5.4.4 NVM user routines operation

This section describes the application of some NVM user routines.

## 5.4.4.1 NVM user programming operation

In TLE986x/TLE987x, the NVM supports programming of up to 128 bytes of data at once. The user can execute the following sequence illustrated in **Figure 5-15** for NVM user programming. Once the assembly buffer has been successfully opened, the user can load the assembly buffer with the user defined contents. This can be achieved by a store instruction targeting the selected byte in the NVM page opened with the OPEN\_AB user routine.



## MOTIX™ TLE986x, MOTIX™ TLE987x, BootROM

## NVM



Figure 5-15 NVM user program



## 5.4.4.2 Tearing-safe programming

In TLE986x/TLE987x, the mapping mechanism of the non-linearly mapped sector is used like a log-structured file system. When a page is programmed in this sector, the old values are not physically overwritten, but a different physical page (spare page) in the same sector is programmed. If the programming fails, the old values are still present in the sector and user can decide, by means of a specific input parameter of the user programming routine (refer to **Table 5-17**), whether the old values or the new failing values should be physically kept in the sector.

When an erase or write procedure is interrupted by a power down, this is identified during the reconstruction of the MapRAM content after the next reset. In this case, the service algorithm routine is automatically started and repairs the NVM state exploiting the fact that either the old or the new data (or both) are fully valid.



## 5.4.4.3 NVM user erase operation

The user can execute the following sequence illustrated in **Figure 5-16** for NVM user erase.



Figure 5-16 NVM user page erase



## 5.4.4.4 NVM user programming abort operation

The user can execute the following sequence illustrated in **Figure 5-17** for NVM user programming abort.



Figure 5-17 NVM user abort program

## 5.4.5 NVM protection mechanism

The BSL Mode 6 of FastLIN or UART controls the NVM protection, providing or deleting a dedicated password (please refer to the **Section 4.4.2.7**).

Once a valid password (different from  $00_H$  and  $FF_H$ ) is programmed, write and read from FastLIN or UART is not allowed on both Code and Data NVM regions upon startup, regardless of the reset source.

Moreover, the debugging capability through the SWD interface is reduced as follows: the NVM read access is blocked and there is no possibility to halt the core from any memory location.

During normal operation, if the user wishes to program or read the NVM, the NVM protection can be temporarily be disabled (refer to the **Section 5.3.16**).

Note: The following statement is valid for all the BF-Step devices in VQFN package, produced till December 2022: when the NVM protection is set, the NVM read access from SWD interface is blocked, the core can be halted from memory locations that are not protected. For additional information about the tracking of the devices, please contact Infineon.



## **Revision history**

## 6 Revision history

| Revision | Date       | Changes                                                                                                                                                                                                                                                                                                                        |
|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.9      | 2023-10-23 | <ul> <li>Added MOTIX<sup>™</sup></li> <li>Added UI step</li> <li>Added "If MSB of the NVM_PASSWORD is 0, only<br/>Code Flash mapped sectors are protected. If the bit<br/>is 1, both Code Flash and Data Flash are protected."</li> <li>Figure 5-1 updated</li> <li>Table 5-14 updated</li> <li>Figure 5-15 updated</li> </ul> |
| 1.8      | 2022-09-23 | <ul> <li>Section 4.4.2.2 "If the NVM protection is enabled, programming to RAM is not allowed." removed</li> <li>Section 4.4.2.7 description updated</li> <li>Figure 5-1 updated</li> <li>Section 5.3.15 third note added</li> <li>Section 5.4.5 description updated; note added</li> <li>Table 5-14 updated</li> </ul>        |
| 1.7      | 2022-05-10 | <ul> <li>UH-Step added:</li> <li>Title page and header updated</li> <li>Figure 5-1 updated</li> <li>Section 5.3.15 note below Table 5-31 updated</li> <li>Section 5.4.5 third paragraph updated</li> </ul>                                                                                                                     |
| 1.6      | 2021-12-10 | Test mode removed (Section 2.1, Table 2-1)                                                                                                                                                                                                                                                                                     |
|          |            | Chapter 4 last two paragraphs removed                                                                                                                                                                                                                                                                                          |
|          |            | Section 4.1, Section 4.4.2.7 Mode 6 updated                                                                                                                                                                                                                                                                                    |
|          |            | Table 5-11 CFLASH_PW and DFLASH_PW updated                                                                                                                                                                                                                                                                                     |
|          |            | Section 5.3.16 last paragraphs updated                                                                                                                                                                                                                                                                                         |
|          |            | Section 5.4.5 desciption updated                                                                                                                                                                                                                                                                                               |
|          |            | All chapters editorial changes                                                                                                                                                                                                                                                                                                 |
| 1.5      | 2020-09-25 | TLE9862/TLE9872 (256KB) variants added                                                                                                                                                                                                                                                                                         |
|          |            | Chapter 3.1.1 MBIST timings updated                                                                                                                                                                                                                                                                                            |
|          |            | Chapter 3.1.4 target PLL frequency updated                                                                                                                                                                                                                                                                                     |
|          |            | Chapter 3.1.8 target PLL frequency updated                                                                                                                                                                                                                                                                                     |
|          |            | Table 3-4 order updated                                                                                                                                                                                                                                                                                                        |



## **Revision history**

| Revision | Date | Changes                                                                              |
|----------|------|--------------------------------------------------------------------------------------|
|          |      | Chapter 4 note regarding the UART interface added                                    |
|          |      | Table 5-2 256KB NVM size added                                                       |
|          |      | Table 5-3 extended to support 256KB variants                                         |
|          |      | Table 5-5 PKG_Type extended by TQFP-48                                               |
|          |      | Table 5-8 NVM_SIZE listed updated to remove irrelevant entries and adding 256KB size |
|          |      | Chapter 5.2.2 note updated, to use backup values instead of default values           |
|          |      | Figure 5-1 TQFP48 added                                                              |
|          |      | Table 5-13 footnote added to exclude certain function for256KB variants              |
|          |      | Table 5-14 footnote added to exclude certain function for256KB variants              |
|          |      | Chapter 5.3 user APIs reordered                                                      |
|          |      | Chapter 5.3.2 timing diagrams of USER_PROG function added                            |
|          |      | Chapter 5.3.3 editorial changes                                                      |
|          |      | Chapter 5.3.5 editorial changes                                                      |
|          |      | Chapter 5.3.7 editorial changes                                                      |
|          |      | Chapter 5.3.15 editorial changes                                                     |
|          |      | Table 5-43 SECTORINFO updated                                                        |
|          |      | Chapter 5.4.2 NVM programming timing values updated                                  |
|          |      | Figure 5-15 NVM user program flow added                                              |
|          |      | Figure 5-16 NVM user page erase flow added                                           |

Edition 2023-10-23 Published by Infineon Technologies AG 81726 München, Germany © Infineon Technologies AG 2023. All Rights Reserved.

#### Legal Disclaimer

The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics ("Beschaffenheitsgarantie"). With respect to any examples or hints given herein, any typical values stated herein and/or any information regarding the application of the device, Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of noninfringement of intellectual property rights of any third party.

#### Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office (www.infineon.com).

#### Warnings

Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office.

Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.

www.infineon.com