# Using the Built-in Self-Test (BIST) on the MPC5744P

by: NXP Semiconductors

## **1** Introduction

The <u>MPC5744P</u> device targets chassis and safety applications which require a high Automotive Safety Integrity Level (SIL). All devices in this family are built around a safety concept based on delayed lock step, targeting an ISO26262 ASIL-D (Design) integrity level.

A requirement of the standard is to detect the accumulation of latent defects. To meet this requirement, the MPC5744P has the ability to execute Built-In Self-Test (BIST) procedures.

The BIST can be performed on the device's embedded memories and logic.

Additionally, there is "SafeAssure" Functional Safety program to reduce the development effort required by customers to meet ISO26262. As a part of this program, NXP provides an MPC5744P safety manual to advice users on how to configure the MPC5744P to obtain ISO26262 ASIL-D compliance.

## 2 Objective

This application note provides an introduction to BIST on the MPC5744P and explains how to configure and use the offline and online BIST features of the MPC5744P. After reading this application note, the user should:

- Understand the BIST features that are available on the MPC5744P.
- Understand the difference between MBIST (Memory Build-in-self-test) and LBIST (Logic Build-in-self-test).
- · Understand the difference between online and offline BIST.
- · Be able to develop application strategies for deploying online BIST testing.
- · Be able to develop application strategies for deploying offline BIST testing.
- Understand what is included in each BIST partition on the MPC5744P.
- Understand when offline and online BIST takes place.
- Be able to develop a specified configuration for offline and online BIST testing and understand how to use Device Configuration Format (DCF) clients to achieve this.



#### Contents

| 1 Introduction 1                                                                                             |
|--------------------------------------------------------------------------------------------------------------|
| 2 Objective1                                                                                                 |
| 3 Overview of Built-In Self-Test (BIST)2<br>3.1 LBIST and MBIST2<br>3.2 Offline and online BIST<br>overview2 |
| 4 Self-Test Control Unit 3                                                                                   |
| 5 MBIST and LBIST testing and<br>partitions                                                                  |
| 6 DCF records, clients, and configuration10                                                                  |
| <ul> <li>7 Online BIST configuration</li></ul>                                                               |
| 8 Offline BIST Configuration                                                                                 |
| 9 BIST results17                                                                                             |
| 10 Definitions, acronyms, and abbreviations17                                                                |
| 11 References17                                                                                              |

• Be able to invoke the desired offline and online BIST sequence using the Self-Test Control Unit (STCU2).

The application note also provides examples for offline and online self-test configurations can be directly implemented by the user. The examples are provided in the software package accompanying this document and is also explained in detail.

To aid in understanding of this document and software package, the reader should obtain the MPC5744P reference and Safety manuals from the NXP website.

## 3 Overview of Built-In Self-Test (BIST)

The term Built-In Self-Test (BIST) is used to describe the on-chip hardware mechanisms that can be used to detect latent faults within the Microcontroller Unit (MCU). The BIST allows the MCU to conduct periodic self-tests to identify faults. The results of these self-tests can then be used by the MCU to handle the faults and ensure that the device remains in a safe state.

### 3.1 LBIST and MBIST

There are two different types of BIST implemented on MPC5744P devices:

- MBIST (Memory Build-in-self-test) for memory testing purposes
- LBIST (Logic Build-in-self-test) for logical testing purposes

MBIST is implemented for each of the SRAM and peripheral memories on the MCU such as SRAM memory contained in the peripheral modules such as FlexRay or eDMA. For MBIST testing purposes, each of the memories is segmented into individual MBIST partitions. The segmentation of the memories is discussed in MBIST partitions.

Each memory is broken down into multiple partitions providing flexibility to test selected address ranges only.

LBIST tests operate on the digital logic of the device and use scan test techniques to provide high-coverage defect detection. The logic is divided up into multiple partitions, with each partition containing user recognizable logic modules (CPU, XBAR, eDMA, etc.). LBIST can be configured to test partitions sequentially or in parallel to allow a good combination of power consumption vs. execution time.

### 3.2 Offline and online BIST overview

It is anticipated that the MPC5744P automotive user application would require two standard configurations for BIST testing:

- Vehicle start-up test as much as possible within the vehicle start-up time constraints known as offline.
- Vehicle Shutdown or diagnostic testing maximum test coverage, no time constraints when vehicle powered down– known as online

For offline testing, the BIST tests can be configured to execute every time the MCU boots or gets a destructive reset. This procedure is performed while the MCU is powered and held in reset. In this mode, user configurable Device Configuration Format (DCF) records that are stored in the one-time programmable UTEST memory are loaded at start-up by the System Status and Configuration Module (SSCM) module into the STCU2 to configure the self-test procedure. When the BIST executes successfully in offline mode, the device exits reset and the application software is executed.

In addition to being able to run at start-up under control of the STCU2, the MCU allows software to write to the STCU2 during runtime to configure and trigger the execution of MBIST or LBIST. This is known as online testing.

The intended usage of online BIST is to execute a test of memory and modules that are critical to the start-up of the application. This helps to minimize the startup time of the MCU. Executing a full BIST at start-up will exceed the needs of many users. online testing is mainly intended for a full BIST of the MCU, typically performed prior to shutdown of the ECU, when execution time is not as critical. The online mode can also be used for failure diagnostics and quality control within a manufacturing environment.

## **4 Self-Test Control Unit**

The STCU2 is a programmable hardware module that controls the self-test sequence applied both during the offline and/or online conditions. It is able to manage by hardware the device's LBIST and MBIST blocks. To control offline BIST testing the STCU2 operates in conjunction with the System Status and Configuration Module (SSCM) module which has the ability load the self-test parameters from flash memory automatically during the boot phase. The SSCM interface is able only to write the configuration parameters and start the Self-Test execution once after the STCU2 global reset has been applied.

To configure online BIST testing via software, an IPS interface allows access by the device CPU(s) to the STCU2 registers. Using this interface, software can configure the STCU2 registers for execution of the online tests, or check the results of the offline tests.

For offline testing, the BIST tests can be configured to execute every time the MCU boots or gets a destructive reset. This procedure is performed while the MCU is powered and held in reset. In this mode, user configurable Device Configuration Format (DCF) Records that are stored in the one-time programmable UTEST memory are loaded at start-up by the SSCM module into the STCU2 to configure the self-test procedure. When the BIST executes successfully in offline mode, the device exits reset and the application software is executed.

NOTE In MPC5744P reference manual, BISTs are named as follows: Startup BIST = Offline BIST Shutdown BIST = Online BIST

## **5 MBIST and LBIST testing and partitions**

This section details the partitioning of the memory and logic on the MPC5744P.

### 5.1 LBIST testing

Logic Built-In Self-Test (LBIST) is implemented by 4 LBIST controllers which operate independently on each LBIST partition. This independence is needed to meet safety requirements regarding the independence and diversity of replicated IP and also helps to avoid exceeding power limits. Each of the LBIST controllers is connected independently to the STCU2. The STCU2 can be configured by user to run LBIST in parallel, sequentially or combination of parallel and sequential.

### 5.2 LBIST partitions

The self-test of each logic partition is deemed to be successful by checking the resulting Multiple Input Signature Register (MISR) value of the LBIST against a 64-bit expected MISR value. The Multiple – Input Signature Register is a type of linear feedback signature register. Each state of the MISR relies on the previous states rather than just the current state, so the MISR always generates the same correct output sequence from the same input sequence unless there is a fault in the tested logic. The STCU2 provides registers for the result and expected MISR. It is important to note that the expected MISR values and other LBIST configuration of the device may change with any modification to the internal logic design of the device.

NOTE

The expected values provided with this application note apply only to the **0N15P**, **1N15P** and **1N65H** mask set of the MPC574xP device if it is not stated otherwise.

#### Table 1. LBIST partitions

| LBIST number | Partition IP module           |                    |  |
|--------------|-------------------------------|--------------------|--|
| 0            | C0                            | z4 Main Core_0     |  |
| 0            | CO                            | PFLASHC            |  |
| 0            | CO                            | Flash memory       |  |
| 0            | CO                            | NPC                |  |
| 0            | CO                            | NXMC0 and NXMC1    |  |
| 0            | C0                            | MEMU               |  |
| 0            | CO                            | XBAR               |  |
| 0            | C0                            | DSMC               |  |
| 0            | CO                            | DMA                |  |
| 0            | CO                            | EIM                |  |
| 0            | CO                            | INTC               |  |
| 0            | CO                            | NAL                |  |
| 0            | CO                            | NAP                |  |
| 0            | CO                            | PRAMC              |  |
| 0            | CO                            | SWT                |  |
| 0            | C0                            | SMPU               |  |
| 0            | C0                            | STM                |  |
| 1            | C1                            | z4 Checker Core_0s |  |
| 1            | C1                            | CMU1               |  |
| 1            | C1                            | RCCU               |  |
| 2            | P0                            | DMA_CH_MUX0        |  |
| 2            | P0                            | FlexRay            |  |
| 2            | P0                            | WKPU               |  |
| 2            | P0                            | MC_ME              |  |
| 2            | P0                            | MC_PCU             |  |
| 2            | P0                            | SIUL2              |  |
| 2            | P0                            | IO-muxing logic    |  |
| 2            | P0                            | CRC                |  |
| 2            | P0                            | PIT                |  |
| 2            | P0                            | DSPI0 and DSPI1    |  |
| 2            | P0                            | LIN1               |  |
|              | Table continues on the next p | page               |  |

| LBIST number | Partition | IP module                        |
|--------------|-----------|----------------------------------|
| 2            | P0        | FlexPWM1                         |
| 2            | P0        | eTimer1                          |
| 2            | P0        | CTU1                             |
| 2            | P0        | SENTO                            |
| 2            | P0        | SIPI                             |
| 2            | P0        | LFAST                            |
| 2            | P0        | ВАМ                              |
| 2            | P0        | FlexCAN0, FlexCAN1, and FlexCAN2 |
| 2            | P0        | ADC1 and ADC3                    |
| 2            | P0        | ENET                             |
| 3            | P1        | DMA_CH_MUX1                      |
| 3            | P1        | FCCU                             |
| 3            | P1        | FOSU                             |
| 3            | P1        | CMU0, CMU2, CMU3, and CMU4       |
| 3            | P1        | DSPI2 and DSPI3                  |
| 3            | P1        | SGEN                             |
| 3            | P1        | LINO                             |
| 3            | P1        | FlexPWM0                         |
| 3            | P1        | eTimer0 and eTimer2              |
| 3            | P1        | СТИО                             |
| 3            | P1        | SENT1                            |
| 3            | P1        | ADC0 and ADC2                    |

#### Table 1. LBIST partitions (continued)

### 5.3 LBIST configuration

The following table shows the configurations the user should set to run LBIST on a specific partition as well as the expected MISR and coverage values at the end of the run.

| Partitio<br>n | Clock<br>Config | PRPG<br>SEED | MISR<br>SEED   | Numbe<br>r<br>of<br>Pattern<br>s | Numbe<br>r<br>of<br>Shifts | Expected<br>MISR     | Covera<br>ge |
|---------------|-----------------|--------------|----------------|----------------------------------|----------------------------|----------------------|--------------|
| C0            | 1               | 0x3FFFFFFFFF | ffffffffffffff | 2700                             | 65                         | 64'hF80DA87A23449471 | 90%          |
| C1            | 1               | 0x3FFFFF     |                | 1850                             | 50                         | 64'h8C363533900F8372 | 90%          |
| P0            | 1               | 0x3FFFFFFFF  |                | 2816                             | 61                         | 64'h2D2A280DD1933F3A | 90%          |
| P1            | 1               | 0x3FFFFFF    |                | 1856                             | 50                         | 64'hAC087BB45D1E5519 | 90%          |

#### Table 2. LBIST configuration by partition and expected MISR for cut 2.1 (1N65H)

#### Table 3. LBIST configuration by partition and expected MISR for cut 2.1b (0N15P) and newer

| Partitio<br>n | Clock<br>Config | PRPG<br>SEED | MISR<br>SEED | Numbe<br>r<br>of<br>Pattern<br>s | Numbe<br>r<br>of<br>Shifts | Expected<br>MISR     | Coverage |
|---------------|-----------------|--------------|--------------|----------------------------------|----------------------------|----------------------|----------|
| CO            | 1               | 0x3FFFFFFFFF |              | 2650                             | 65                         | 64'hBD3805126D73AE0D | 90%      |
| C1            | 1               | 0x3FFFFF     |              | 1344                             | 50                         | 64'h18916197F1B392F7 | 90%      |
| P0            | 1               | 0x3FFFFFFFF  |              | 2900                             | 61                         | 64'hFA8FB16EC97B3FA7 | 90%      |
| P1            | 1               | 0x3FFFFFF    |              | 1900                             | 50                         | 64'h108069355D01B854 | 90%      |

For LBIST online self-test, the user must program the STCU\_LBRMSW[LBRMSWn] field corresponding to the LBIST partition to "1" to generate a global functional reset at the end of the test:

- LBRMSW0: corresponds to LBIST C0
- LBRMSW1: corresponds to LBIST C1
- LBRMSW2: corresponds to LBIST P0
- LBRMSW3: corresponds to LBIST P1

### 5.4 MBIST testing

The MBIST is executed by a single MBIST controller that is programmed via the STCU2. The MBIST engine controls the self-test of multiple partitions. The MPC5744P memory is split into 27 different MBIST partitions which are numbered 0 - 26.

MBIST contains these three types of tests:

- Full Test Diagnostic test
- Reduced Test Long self-test mode
- Auto test Normal self-test mode

NOTE

Always refer to current reference manual for details about types of tests.

Using the Built-in Self-Test (BIST) on the MPC5744P, Rev. 0, June 2017

The MBIST controller has three types of March tests. It can apply those tests while running MBIST that allow for different coverage levels. The Full Test Mode tests memory using all algorithms including the open PMOS algorithm. The Reduced Test Mode tests memory using all algorithms except the open PMOS algorithm. The Auto Test Mode uses a smaller set of algorithms which has lower coverage.

The Auto Test mode is designed to quickly test the RAM with good fault coverage. Therefore, this mode is recommended for the offline BIST as it has an optimum balance of test time versus fault coverage. The Full Test Mode is comparable to the tests used in the NXP factory to test the RAM. Since NXP has already tested the parts prior to delivery, the primary concern for the user should be to detect latent defects. The Full Test is recommended for the online BIST since time constraints are typically not as critical in the user's online use case.

| MBIST<br>Type   | STCU2_<br>CFG[PMO<br>SEN] | STCU2_<br>CFG[MBU] | MBIST<br>Algoritm                                                                  | InternalNodes/<br>Circuits Additionally<br>Covered by Test                                | Usecase                                                                                                            |
|-----------------|---------------------------|--------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Full Test       | 1                         | 0                  | Test memory using all<br>built-in algorithms.<br>Open PMOS algorithm<br>included.  | Address decoder and<br>bitcell as well as<br>resistive defects in the<br>address decoder. | Used by NXP<br>production test.<br>Recommended to use<br>in the field for MBIST<br>online self-test.               |
| Reduced<br>Test | 0                         | 0                  | Test memory using all<br>built in algorithms<br>except the open PMOS<br>algorithm. | Address decoder and bitcell.                                                              | Recommended to use<br>in the field for MBIST<br>online self-test if the<br>Full Test takes too<br>long.            |
| Auto Test       | x                         | 1                  | A smaller set of<br>algorithms which target<br>latent defect<br>mechanisms.        | Latent defects such as<br>NBTI of the PMOS<br>transistors in the<br>bitcells.             | Recommended to use<br>for MBIST offline self-<br>test as an optimum<br>balance of test time vs.<br>fault coverage. |

| Table 4   | MRIST   | algorithm  | and coverad | e according | to test type |
|-----------|---------|------------|-------------|-------------|--------------|
| 1 auto 4. | IVIDI31 | aigontinin | and coveray | e accorunig | io iesi iype |

### 5.5 MBIST partitions

The following table describes the mapping between the MBIST number as the STCU2 captures it, the corresponding memory, and the corresponding MBIST control register.

| Table 5 | . MBIST | mapping |
|---------|---------|---------|
|---------|---------|---------|

| emory       | Corresponding MBIST Control                |
|-------------|--------------------------------------------|
|             | Register                                   |
| AM ROM      | STCU_MB_CTRL_0                             |
| MA RAM      | STCU_MB_CTRL_1                             |
| ystem RAM 1 | STCU_MB_CTRL_2                             |
| ystem RAM 0 | STCU_MB_CTRL_3                             |
|             | M ROM<br>A RAM<br>stem RAM 1<br>stem RAM 0 |

Table continues on the next page...

I

| Partition Number | Memory               | Corresponding MBIST Control |
|------------------|----------------------|-----------------------------|
|                  |                      | Register                    |
| 4                | System RAM 3         | STCU_MB_CTRL_4              |
| 5                | System RAM 2         | STCU_MB_CTRL_5              |
| 6                | System RAM 5         | STCU_MB_CTRL_6              |
| 7                | System RAM 4         | STCU_MB_CTRL_7              |
| 8                | DLMEM 1              | STCU_MB_CTRL_8              |
| 9                | DLMEM 0              | STCU_MB_CTRL_9              |
| 10               | iCache Data Memory 3 | STCU_MB_CTRL_10             |
| 11               | iCache Data Memory 2 | STCU_MB_CTRL_11             |
| 12               | iCache Data Memory 1 | STCU_MB_CTRL_12             |
| 13               | iCache Data Memory 0 | STCU_MB_CTRL_13             |
| 14               | iCache Tag Memory    | STCU_MB_CTRL_14             |
| 15               | dCache Data Memory 3 | STCU_MB_CTRL_15             |
| 16               | dCache Data Memory 2 | STCU_MB_CTRL_16             |
| 17               | dCache Data Memory 1 | STCU_MB_CTRL_17             |
| 18               | dCache Data Memory 0 | STCU_MB_CTRL_18             |
| 19               | dCache Tag Memory    | STCU_MB_CTRL_19             |
| 20               | FlexCAN RAM 2        | STCU_MB_CTRL_20             |
| 21               | FlexCAN RAM 1        | STCU_MB_CTRL_21             |
| 22               | FlexCAN RAM 0        | STCU_MB_CTRL_22             |
| 23               | FlexRay LRAM 1       | STCU_MB_CTRL_23             |
| 24               | FlexRay LRAM 0       | STCU_MB_CTRL_24             |
| 25               | FlexRay DRAM         | STCU_MB_CTRL_25             |
| 26               | ENET Memory          | STCU_MB_CTRL_26             |

#### Table 5. MBIST mapping (continued)

### 5.6 MBIST test cycles

The following table describes the test cycles for different MBIST partitions on this chip according to test type.

| Partition | Memory                         | Size    | Full Test |          | Reduced 1 | ſest     | Auto Test |          |
|-----------|--------------------------------|---------|-----------|----------|-----------|----------|-----------|----------|
| Number    |                                |         | TCKs      | MEM Clks | TCKs      | MEM Clks | TCKs      | MEM Clks |
| 0         | BAM ROM                        | 2048x32 | 22260     | 20139    | 22260     | 17545    | 22260     | 20139    |
| 1         | DMA RAM                        | 128x72  | 22260     | 17449    | 22260     | 17409    | 22260     | 34898    |
| 2         | System<br>RAM 0 L2             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 3         | System<br>RAM 0 L1             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 4         | System<br>RAM 1 L2             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 5         | System<br>RAM 1 L1             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 6         | System<br>RAM 2 L2             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 7         | System<br>RAM 2 L2             | 8192x72 | 22260     | 275957   | 22260     | 265337   | 22260     | 551914   |
| 8         | DLMEM<br>L2                    | 8192x40 | 22260     | 144704   | 22260     | 139352   | 22260     | 578816   |
| 9         | DLMEM<br>L1                    | 8192x40 | 22260     | 144704   | 22260     | 139352   | 22260     | 578816   |
| 10        | iCache<br>Data<br>Memory<br>L4 | 256x72  | 22260     | 17696    | 22260     | 17336    | 22260     | 70784    |
| 11        | iCache<br>Data<br>Memory<br>L3 | 256x72  | 22260     | 17696    | 22260     | 17336    | 22260     | 70784    |
| 12        | iCache<br>Data<br>Memory<br>L2 | 256x72  | 22260     | 17696    | 22260     | 17336    | 22260     | 70784    |
| 13        | iCache<br>Data<br>Memory<br>L1 | 256x72  | 22260     | 17696    | 22260     | 17336    | 22260     | 70784    |
| 14        | iCache<br>Tag<br>Memory        | 128x65  | 22260     | 15600    | 22260     | 15368    | 22260     | 62400    |

| Partition | Memory                         | Size    | Full Test |          | Reduced T | est      | Auto Test |          |
|-----------|--------------------------------|---------|-----------|----------|-----------|----------|-----------|----------|
| Number    |                                |         | TCKs      | MEM Clks | TCKs      | MEM Clks | TCKs      | MEM Clks |
| 15        | dCache<br>Data<br>Memory<br>L4 | 128x80  | 22260     | 15600    | 22260     | 15368    | 22260     | 62400    |
| 16        | dCache<br>Data<br>Memory<br>L3 | 128x80  | 22260     | 15600    | 22260     | 15368    | 22260     | 62400    |
| 17        | dCache<br>Data<br>Memory<br>L2 | 128x80  | 22260     | 15600    | 22260     | 15368    | 22260     | 62400    |
| 18        | dCache<br>Data<br>Memory<br>L1 | 128x80  | 22260     | 15600    | 22260     | 15368    | 22260     | 62400    |
| 19        | dCache<br>Tag<br>Memory        | 64x71   | 22260     | 14560    | 22260     | 14384    | 22260     | 58240    |
| 20        | FlexCAN<br>RAM L3              | 192x104 | 22260     | 25456    | 22260     | 25612    | 22260     | 26456    |
| 21        | FlexCAN<br>RAM L2              | 192x104 | 22260     | 25456    | 22260     | 25612    | 22260     | 26456    |
| 22        | FlexCAN<br>RAM L1              | 192x104 | 22260     | 25456    | 22260     | 25612    | 22260     | 26456    |
| 23        | FlexRay<br>LRAM L2             | 64x63   | 22260     | 17548    | 22260     | 17548    | 22260     | 17548    |
| 24        | FlexRay<br>LRAM 0<br>L1        | 64x63   | 22260     | 17548    | 22260     | 17548    | 22260     | 17548    |
| 25        | FlexRay<br>DRAM                | 128x26  | 22260     | 18794    | 22260     | 18401    | 22260     | 37588    |
| 26        | ENET<br>Memory                 | 512x66  | 22260     | 30389    | 22260     | 29217    | 22260     | 60778    |

#### Table continued from the previous page...

## 6 DCF records, clients, and configuration

DCF records are used to configure device register values during reset phase. When reset is released the desired registers contain values defined by DCF content. Figure 1. Reset sequence on page 11 represents microcontroller execution flow during preset phases.



Figure 1. Reset sequence

The offline BIST tests are configured using DCF records that automatically configure the STCU2 to enable and run BIST at start-up or following a destructive reset or long functional reset.

The DCF is a mechanism to automatically configure specific registers during system boot and to set up an initial configuration for the device after reset or start-up. The term DCF client is used to describe a module of which registers can be written by DCF record, e.g., the STCU2 is a DCF client. DCF records are stored in both TEST and UTEST flash. During the boot sequence of the device, the SSCM automatically loads the DCF records to the DCF clients.



Figure 2. DCF record mechanism

## **7 Online BIST configuration**

To successfully perform online BIST, the correct configuration must be done before BIST execution. This chapter describes how to correctly prepare, setup and execute online BIST.

### 7.1 Preparation before initiating an STCU online self-test

Before start of an STCU online self-test, it is required to complete the following prerequisite procedure to prepare the chip:

- 1. End the currently running application, including smooth termination of peripherals as required by the application.
- 2. Configure FlexRay, CAN clock sources, and divider for self-test:
  - a. Configure FRAY\_PLL\_CLK clock as PLL0 PHI divided by 2: MC\_CGM\_AC1\_DC0[DIV]=1h.

MC\_CGM.AC1\_DC0.R = 0x80000000 | 0x10000;

b. Select FRAY\_PLL\_CLK as the FRAY\_CLK clock source: FR\_MCR[CLKSEL]=1.

FR\_0.MCR.B.CLKSEL = 1;

Using the Built-in Self-Test (BIST) on the MPC5744P, Rev. 0, June 2017

c. Select CAN\_PLL\_CLK as the CAN\_CLK clock source: CAN\_CTRL1[CLKSRC]=1.

CAN\_0.CTRL1.B.CLKSRC=1;

3. Ensure PBRIDGE clock is not over clocked (maximum frequency is 50MHz) when SYS\_CLK is switched to 200MHz.

MC CGM.SC DC0.R = 0x80000000 | 0x3;

- 4. Configure DRUN to turn off PLL1 (to save power), turn off PLL0 so PLL0 can be re-configured for the required 200MHz self-test clock frequency, turn on the XOSC as it is needed to provide the PLL0 reference clock during self-test, and select IRCOSC to source SYS\_CLK:
  - a. Select IRCOSC as the SYS\_CLK clock source: MC\_ME\_DRUN\_MC[SYSCLK]=0b.

MC\_ME.DRUN\_MC.B.SYSCLK = 0;

b. Enable XOSC: MC\_ME\_DRUN\_MC[XOSCON]=1 (will be required for PLL0).

MC\_ME.DRUN\_MC.B.XOSCON = 1;

c. Disable PLL0: MC\_ME\_DRUN\_MC[PLL0ON]=0.

MC\_ME.DRUN\_MC.B.PLLOON = 0;

d. Disable PLL1: MC\_ME\_DRUN\_MC[PLL1ON]=0.

MC\_ME.DRUN\_MC.B.PLL1ON = 0;

NO NE DIDI DO[0] D DDIDI

e. Gate off all peripheral clocks because they should not be running: MC\_ME\_RUN\_PC0[DRUN]=0, MC\_ME\_PCTLn[RUN\_CFG]=0b.

| $MC_ME.RON_PC[0].B.DRON = 0;$          |    |                                                  |
|----------------------------------------|----|--------------------------------------------------|
| MC_ME.PCTL9.B.RUN_CFG = 0;             | /* | LFAST_0 Peripheral Control Register*/            |
| MC_ME.PCTL11.B.RUN_CFG = 0;            | /* | SIPI_0 Peripheral Control Register */            |
| <pre>MC_ME.PCTL12.B.RUN_CFG = 0;</pre> | /* | ENET_0 Peripheral Control Register */            |
| MC_ME.PCTL30.B.RUN_CFG = 0;            | /* | PIT_0 Peripheral Control Register */             |
| MC_ME.PCTL36.B.RUN_CFG = 0;            | /* | DMAMUX_0 Peripheral Control Register */          |
| MC_ME.PCTL38.B.RUN_CFG = 0;            | /* | CRC_0 Peripheral Control Register */             |
| <pre>MC_ME.PCTL77.B.RUN_CFG= 0;</pre>  | /* | CAN_2 Peripheral Control Register */             |
| MC_ME.PCTL78.B.RUN_CFG = 0;            | /* | CAN_1 Peripheral Control Register */             |
| <pre>MC_ME.PCTL79.B.RUN_CFG= 0;</pre>  | /* | CAN_0 Peripheral Control Register */             |
| <pre>MC_ME.PCTL91.B.RUN_CFG= 0;</pre>  | /* | LINFlex_1 Peripheral Control Register */         |
| <pre>MC_ME.PCTL98.B.RUN_CFG= 0;</pre>  | /* | DSPI_1 Peripheral Control Register */            |
| <pre>MC_ME.PCTL99.B.RUN_CFG= 0;</pre>  | /* | DSPI_0 Peripheral Control Register */            |
| <pre>MC_ME.PCTL104.B.RUN_CFG= 0;</pre> | /* | <pre>SENT_0 Peripheral Control Register */</pre> |
| <pre>MC_ME.PCTL107.B.RUN_CFG= 0;</pre> | /* | FLEXRAY Peripheral Control Register */           |
| <pre>MC_ME.PCTL124.B.RUN_CFG= 0;</pre> | /* | ADC_3 Peripheral Control Register */             |
| <pre>MC_ME.PCTL126.B.RUN_CFG= 0;</pre> | /* | ADC_1 Peripheral Control Register */             |
| <pre>MC_ME.PCTL137.B.RUN_CFG= 0;</pre> | /* | ETIMER_1 Peripheral Control Register */          |
| <pre>MC_ME.PCTL141.B.RUN_CFG= 0;</pre> | /* | CTU_1 Peripheral Control Register */             |
| <pre>MC_ME.PCTL144.B.RUN_CFG= 0;</pre> | /* | <pre>PWM_1 Peripheral Control Register */</pre>  |
| <pre>MC_ME.PCTL146.B.RUN_CFG= 0;</pre> | /* | DMAMUX_1 Peripheral Control Register */          |
| MC_ME.PCTL204.B.RUN_CFG= 0;            | /* | LINFlex_0 Peripheral Control Register */         |
| MC_ME.PCTL208.B.RUN_CFG= 0;            | /* | DSPI_3 Peripheral Control Register */            |
| <pre>MC_ME.PCTL209.B.RUN_CFG= 0;</pre> | /* | DSPI_2 Peripheral Control Register */            |
| <pre>MC_ME.PCTL214.B.RUN_CFG= 0;</pre> | /* | <pre>SENT_1 Peripheral Control Register */</pre> |
| MC_ME.PCTL235.B.RUN_CFG= 0;            | /* | ADC_2 Peripheral Control Register */             |
| MC_ME.PCTL237.B.RUN_CFG= 0;            | /* | ADC_0 Peripheral Control Register */             |
|                                        |    |                                                  |

```
MC_ME.PCTL239.B.RUN_CFG= 0; /* SGEN_0 Peripheral Control Register */
MC_ME.PCTL245.B.RUN_CFG= 0; /* ETIMER_2 Peripheral Control Register */
MC_ME.PCTL247.B.RUN_CFG= 0; /* ETIMER_0 Peripheral Control Register */
MC_ME.PCTL251.B.RUN_CFG= 0; /* CTU_0 Peripheral Control Register */
MC_ME.PCTL255.B.RUN_CFG= 0; /* PWM_0 Peripheral Control Register*/
```

5. Activate the new configuration by performing mode change to DRUN: MC\_ME\_MCTL[TARGET\_MODE]=0011b (see the MC\_ME chapter for mode change request details).

```
/* Mode transition to apply the IRC setup and set Normal mode with PLL */
MC_ME.MCTL.R = 0x30005AF0; //DRUN Mode & Key
MC_ME.MCTL.R = 0x3000A50F; //DRUN Mode & Key
while(MC_ME.GS.B.S_MTRANS); //Waiting for end of transaction
while(MC_ME.GS.B.S_CURRENT_MODE != DRUN_MODE); // ME_GS Check DRUN mode has
successfully been entered
```

- 6. Configure PLL0 for the required 200MHz self-test frequency:
  - a. Configure PLL0 to provide 200MHz at its PHI output: PLLDIG\_PLL0DV (values depend on XOSC frequency).

b. Select XOSC as PLL0's reference clock: MC\_CGM\_AC3\_SC[SELCTL]=1.

MC\_CGM.AC3\_SC.B.SELCTL =1; //connect (8..40MHz) XTALL to the PLL0

- 7. Configure DRUN mode to turn on PLL0 and select PLL0 PHI to source SYS\_CLK:
  - a. Enable XOSC: MC\_ME\_DRUN\_MC[XOSCON]=1.

MC\_ME.DRUN\_MC.B.XOSCON = 1;

b. Enable PLL0: MC\_ME\_DRUN\_MC[PLL0ON]=1.

MC\_ME.DRUN\_MC.B.PLLOON = 1;

c. Disable PLL1: MC\_ME\_DRUN\_MC[PLL1ON]=0.

MC\_ME.DRUN\_MC.B.PLL1ON = 0;

d. Select PLL0 PHI as the SYS\_CLK clock source: MC\_ME\_DRUN\_MC[SYSCLK]=0010b.

MC\_ME.DRUN\_MC.B.SYSCLK = 2;

8. Activate the new configuration by performing mode change to DRUN: MC\_ME\_MCTL[TARGET\_MODE]=0011b (see the MC\_ME chapter for mode change request details).

```
MC_ME.MCTL.R = 0x30005AF0; //DRUN Mode & Key
MC_ME.MCTL.R = 0x3000A50F; //DRUN Mode & Key
while(!MC_ME.GS.B.S_PLL0); //ME_GS Wait for PLL stabilization.
while(MC_ME.GS.B.S_MTRANS); //Waiting for end of transaction
while(MC_ME.GS.B.S_CURRENT_MODE != DRUN_MODE); // ME_GS Check DRUN mode has
successfully been entered
```

9. Select PLL0 PHI to source all auxiliary clocks used during self-test:

a. Select PLL0 PHI as the MOTC\_CLK, SGEN\_CLK, and ADC\_CLK clock source: MC\_CGM\_AC0\_SC[SELCTL]=2h.

```
MC CGM.AC0 SC.B.SELCTL =0x2; //connect PLL0 to AXU 0
```

b. Select PLL0 PHI as the LFAST PLL clock source: MC\_CGM\_AC5\_SC[SELCTL]=2h.

MC\_CGM.AC5\_SC.B.SELCTL =0x2; //connect PLL0 to AXU\_5

### 7.2 Online self-test initiation procedure

To initiate a shutdown self-test, execute the following steps for the desired self-test mode. All accesses must be processed without interruption.

1. Configure the STCU\_SKC register by first writing the key1 value and then writing the key2 value.

```
STCU.SKC.R = 0x753F924E;
STCU.SKC.R = 0x8AC06DB1;
```

2. Configure the STCU\_MBn\_CTRL registers.

```
STCU.MB_CTRL[0].R = 0x9100000; /* MBIST CTRL00, next in sequence is MBIST 1*/
STCU.MB_CTRL[1].R = 0x9800000; /* MBIST CTRL01, next in sequence is MBIST 8*/
STCU.MB_CTRL[2].R = 0x9300000; /* MBIST CTRL03, next in sequence is MBIST 3*/
STCU.MB_CTRL[3].R = 0x9400000; /* MBIST CTRL03, next in sequence is MBIST 5*/
STCU.MB_CTRL[5].R = 0x9700000; /* MBIST CTRL04, next in sequence is MBIST 5*/
STCU.MB_CTRL[6].R = 0x9700000; /* MBIST CTRL05, next in sequence is MBIST 6*/
STCU.MB_CTRL[6].R = 0x9700000; /* MBIST CTRL06, next in sequence is MBIST 7*/
STCU.MB_CTRL[6].R = 0x9700000; /* MBIST CTRL06, next in sequence is MBIST 7*/
STCU.MB_CTRL[8].R = 0x9900000; /* MBIST CTRL06, next in sequence is MBIST 16*/
STCU.MB_CTRL[9].R = 0x900000; /* MBIST CTRL08, next in sequence is MBIST 10*/
STCU.MB_CTRL[10].R = 0x900000; /* MBIST CTRL10, next in sequence is MBIST 11*/
STCU.MB_CTRL[10].R = 0x900000; /* MBIST CTRL10, next in sequence is MBIST 12*/
STCU.MB_CTRL[11].R = 0x9E00000; /* MBIST CTRL10, next in sequence is MBIST 12*/
STCU.MB_CTRL[12].R = 0x9E00000; /* MBIST CTRL11, next in sequence is MBIST 14*/
STCU.MB_CTRL[13].R = 0x9E00000; /* MBIST CTRL11, next in sequence is MBIST 14*/
STCU.MB_CTRL[14].R = 0x9E00000; /* MBIST CTRL13, next in sequence is MBIST 15*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL14, next in sequence is MBIST 16*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL16, next in sequence is MBIST 16*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL16, next in sequence is MBIST 16*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL16, next in sequence is MBIST 16*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL10, next in sequence is MBIST 12*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL10, next in sequence is MBIST 12*/
STCU.MB_CTRL[16].R = 0xA000000; /* MBIST CTRL10, next in sequence is MBIST 22*/
STCU.MB_CTRL[20].R = 0xA000000; /* MBIST CTRL20, next in sequence is MBIST 22*/
STCU.MB_CTRL[21].R = 0xA000000; /* MBIST CTRL21, next in sequence is MBIST 22*/
STCU.MB_CTRL[21].R = 0xA000000; /* MBIST CTRL24, next in seque
```

3. Configure the STCU\_CFG register.

```
/* Auto test - Normal self-test mode */
STCU.CFG.R = 0x12000008;
```

4. Configure all STCU\_LBn\_CTRL and STCU\_LBn\_PCS registers.

```
STCU.LB[0].CTRL.R = 0x83031107;
STCU.LB[0].PCS.R = 0x00006978;
STCU.LB[1].CTRL.R = 0x82031107;
STCU.LB[1].PCS.R = 0x00000708;
STCU.LB[2].CTRL.R = 0x7F031107;
STCU.LB[2].PCS.R = 0x00000B00;
STCU.LB[3].CTRL.R = 0x01031107;
STCU.LB[3].PCS.R = 0x0000740;
```

5. Configure all STCU\_LBn\_MISRELSW and STCU\_LBn\_MISREHSW registers according to used cut of device.

```
/* valid for cut 1N15P and 0N15P */
STCU.LB[0].MISRELSW.R = 0x6D73AE0D;
STCU.LB[0].MISREHSW.R = 0xBD380512;
STCU.LB[1].MISRELSW.R = 0xF1B392F7;
STCU.LB[1].MISRELSW.R = 0x18916197;
STCU.LB[2].MISRELSW.R = 0xC97B3FA7;
STCU.LB[2].MISREHSW.R = 0xFA8FB16E;
STCU.LB[3].MISRELSW.R = 0x5D01B854;
STCU.LB[3].MISREHSW.R = 0x10806935;
```

6. Configure the STCU\_WDG register.

```
/* Auto test - Normal self-test mode */
STCU.WDG.R = 0xFFFFFFF; /* max value */
```

7. Configure the STCU\_LBRMSW register.

STCU.LBRMSW.R = 0x000000F;

8. Configure the DCL\_IPS0 register.

DCL.IPSO.R = 0x03008214;

9. Configure the STCU\_RUNSW register. This access immediately initiates the shutdown self-test execution.

 $STCU.RUNSW.R = 0 \times 00000301;$ 

### 7.3 Online BIST execution flow

The configured online BIST configuration executes as the following figure represents:



Figure 3. Online BIST execution flow

## **8 Offline BIST Configuration**

To successfully perform offline BIST, the correct configuration must be done before BIST execution. The default STCU2 configuration is already pre-programmed by NXP during testing of the production devices. User can select from two following available modes:

- 1. Normal start-up self-test
- 2. No self-test execution

### 8.1 Normal start-up self-test

This configuration is already present in the device and offline BIST is by default enabled and running. The diagram given above describes BIST flow already programed by NXP.

### 8.2 No self-test execution

To bypass the BIST execution, it is necessary to program following STCU2 DCF client in UTEST user memory area. This sets the BIST pointer in STCU2 CFG register to 0x7F which represents no BIST execution.

Bypass BIST DCF record: 0x7F00\_0000\_0008\_000C

Example of Lauterbach programing script:

```
data.set 0x00400218 %QUAD 0x7F000000008000C ;Bypass Off-line BIST
```

## **9 BIST results**

STCU2 provides set of registers where results of self-tests are stored corresponding to the execution of the selected BIST. Below is the list of these registers.

• STCU2 Error Register (STCU2\_ERR\_STAT)

Registers dedicated to offline self-test:

- STCU2 Offline LBIST Status Register (STCU2\_LBS)
- STCU2 Offline LBIST End Flag Register (STCU2\_LBE)
- STCU2 Offline MBIST Status Low Register (STCU2\_MBSL)
- STCU2 Offline MBIST End Flag Low Register (STCU2\_MBEL)

Registers dedicated to online self-test:

- STCU2 Online LBIST Status Register (STCU2\_LBSSW)
- STCU2 Online LBIST End Flag Register (STCU2\_LBESW)
- STCU2 Online MBIST Status Low Register (STCU2\_MBSLSW)
- STCU2 Online MBIST End Flag Low Register (STCU2\_MBELSW)

## 10 Definitions, acronyms, and abbreviations

#### Table 6. Acronyms table

| Term/Acronym | Definition                             |
|--------------|----------------------------------------|
| STCU2        | Self-Test Control Unit                 |
| DCF          | Device Configuration Format            |
| BIST         | Build In Self-Test                     |
| MBIST        | Memory Build In Self-Test              |
| LBIST        | Logic Build In Self-Test               |
| FCCU         | Fault Collection and Control Unit      |
| SSCM         | System Status and Configuration Module |
| MISR         | Multiple Input Signature Register      |
| eDMA         | Enhanced Direct Memory Access          |

## **11 References**

- Using the Built-in Self-Test (BIST) on the MPC5777M (Document ID: AN5131)
- MPC574 4P Reference Manual (Document ID: MPC5744PRM)



#### How To Reach Us

Home Page:

nxp.com

Web Support:

nxp.com/support

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

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

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREENCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT. MIFARE4MOBILE. MIGLO. NTAG. ROADLINK. SMARTLX. SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, C-5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C-Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorIQ, QorIQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other product or service names are the property of their respective owners. ARM, AMBA, ARM Powered, Artisan, Cortex, Jazelle, Keil, SecurCore, Thumb, TrustZone, and µVision are registered trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. ARM7, ARM9, ARM11, big.LITTLE, CoreLink, CoreSight, DesignStart, Mali, mbed, NEON. POP. Sensinode, Socrates, ULINK and Versatile are trademarks of ARM Limited (or its subsidiaries) in the EU and/or elsewhere. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© 2017 NXP B.V.

AN11993 Rev. 0 June 2017



