

**Freescale Semiconductor Application Note** 

Document Number: AN5200 Rev. 1, 12/2015

# Error Correcting Codes Implemented on MPC55xx and **MPC56xx** Devices

by: David Tosenovjan

Error Correction Code, or ECC, is commonly utilized with memories in applications where data corruption via soft-errors (SEU) is not easily tolerated. Soft errors can be caused by radiation, electro-magnetic interference, or electrical noise.

All of the ECC methods used with MPC55xx and MPC56xx devices provide Single Error Correction - Double Error Detection (SECDED) capability.

Intention of this application note is to describe how ECC protection is implemented with MPC55xx and MPC56xx devices and understand particular MCU's ECC event response. It also offers some software examples for illustration of mentioned behavior.

#### **Table of Contents**

| 1 | ECC protected memory's initialization. | 2   |
|---|----------------------------------------|-----|
| 2 | Used ECC Algorithms                    | 3   |
| 3 | Behavior in case ECC event occurs      | 4   |
| 4 | Correctable ECC error servicing        | 6   |
| 5 | Non-correctable ECC error servicing    | 6   |
| 6 | ECC error injection                    | .10 |
| 7 | ECSM/RGM/FCCU relation on safety       |     |
|   | devices                                | .12 |
| 8 | Example Codes                          | .14 |





ECC protected memory's initialization

# **1** ECC protected memory's initialization

### 1.1 SRAM initialization after Power-on-reset

Reset state of internal SRAM is random, thus data and checkbits may contain any data. Most probably the first read attempt to any address would generate non-correctable ECC error. Thus SRAM must be initialized after power-up. Typically it means the whole SRAM is deleted or written by any value, however it must be either 64-bit write or 32-bit write (according to Table 2), to completely define ECC code for data unit. Otherwise smaller sized write access results to read-modify-write with another ECC error.

### 1.2 SRAM initialization after Synchronous reset

User can omit SRAM initialization for synchronous reset sources - on most devices it is only software reset (see particular device's Reference Manual for details). For asynchronous reset there is certain risk of inducing multibit ECC error if device has been reset during SRAM write.

Thus for asynchronous reset sources application should initialize SRAM, even though content of SRAM is kept untouched over reset.

### 1.3 Initialization of other embedded SRAM memories

Most MPC55xx/56xx devices have ECC protection implemented only for internal FLASH and SRAM. However trend started with MPC5676R device is to have ECC algorithm implemented on all SRAM based internal memories, including Shared Code Memory (SCM) and Shared Parameter RAM (SPRAM) of eTPU modules and FlexRay message buffers. Note that access to this content may lead in ECC event, if it is not previously initialized.



# 2 Used ECC Algorithms

### 2.1 Internal FLASHes

Employed ECC algorithms (see Table 1) are 'modified'. The modification lies in algorithm change the way that ECC checkbits 0xFF belongs to data 0xFFFF\_FFFF\_FFFF\_FFFF. Thus fully erased flash memory is not in corrupted state.

|                       | Modified Hamming Code (64+8)                                                                                                                                                                                                                                                          | Hsiao Code (64+8)                                                                                                                                                                                                                                                               | Hsiao Code (32+7)                                                                                                          |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Code or unified flash | <ul> <li>MPC55xx</li> <li>MPC5668G/E</li> <li>MPC567xF</li> <li>MPC5602B/3B/4B</li> <li>MPC5602C/3C/4C</li> <li>MPC5603P/4P</li> <li>MPC5603P/4P</li> <li>MPC560xS</li> <li>MPC563xM</li> <li>MPC5605B/6B/7B<br/>(only Rev.1)</li> <li>PXD10</li> <li>PXN20</li> <li>PXR40</li> </ul> | <ul> <li>MPC564xS</li> <li>MPC564xL</li> <li>MPC5642A</li> <li>MPC5676R</li> <li>MPC5605B/6B/7B<br/>(Rev.2 and higher)</li> <li>MPC564xC</li> <li>MPC5601D/02D</li> <li>MPC5601P/2P</li> <li>MPC567xK</li> <li>MPC560xE</li> <li>PXS20</li> <li>PXS30</li> <li>PXD20</li> </ul> | • none                                                                                                                     |
| Data flash            | <ul> <li>MPC5602B/3B/4B</li> <li>MPC5602C/3C/4C</li> <li>MPC5603P/4P</li> <li>MPC560xS,</li> <li>MPC563xM,</li> <li>MPC5605B/6B/7B<br/>(only Rev.1)</li> <li>PXD10</li> </ul>                                                                                                         | MPC5605B/6B/7B<br>(Rev.2 and higher)                                                                                                                                                                                                                                            | <ul> <li>MPC5601D/02D</li> <li>MPC5601P/2P</li> <li>MPC564xC</li> <li>MPC567xK</li> <li>MPC560xE</li> <li>PXS30</li> </ul> |

| Table 1. ECC Algorithms on internal FLASH memories | Table 1. ECC | Algorithms on | internal FL | ASH memorie | s |
|----------------------------------------------------|--------------|---------------|-------------|-------------|---|
|----------------------------------------------------|--------------|---------------|-------------|-------------|---|

### 2.2 Internal SRAMs

Internal SRAMs use Modified Hamming Code or Hsiao Code in configuration (64+8) or (32+7).



#### Behavior in case ECC event occurs

|               | (64+8)                                                                                                                                                                              | (32+7)                                                                                                                                                                                                                                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Internal SRAM | <ul> <li>MPC5553</li> <li>MPC5554</li> <li>MPC5561</li> <li>MPC5565</li> <li>MPC5566</li> <li>MPC5674F</li> <li>MPC5676R</li> <li>MPC5675K</li> <li>PXS30</li> <li>PXR40</li> </ul> | <ul> <li>MPC553x</li> <li>MPC551x</li> <li>MPC5604B/C</li> <li>MPC5602D</li> <li>MPC5607B</li> <li>MPC5604P</li> <li>MPC5602P</li> <li>MPC5606S</li> <li>MPC5604E</li> <li>MPC5668GE</li> <li>MPC5634M</li> <li>MPC5644A</li> <li>MPC5643L</li> <li>MPC5646B/C</li> <li>PXD10</li> <li>PXN20</li> <li>PXS20</li> </ul> |

| Table 2. ECC Algorithms on inte | ernal SRAM memories |
|---------------------------------|---------------------|
|---------------------------------|---------------------|

Certain devices have SRAM organized as 2x(32+7) according to Table 3. It must be taken into account during ECC error injection (see section 6.1)

Table 3. MPC5643L, MPC5644A and MPC5646B/C SRAM organization

| Bits<br>RAM           | EVEN<br>[31-24]          |         |         | EVEN<br>[7-0] | ODD<br>[31-24]             | ODD<br>[23-16] | ODD<br>[15-8] | ODD<br>[7-0]          | Bits<br>Parity             | EVEN<br>[6-0] | ODD<br>[6-0] |
|-----------------------|--------------------------|---------|---------|---------------|----------------------------|----------------|---------------|-----------------------|----------------------------|---------------|--------------|
| ERRBIT                | [63-56]                  | [55-48] | [47-40] | [39-32]       | [31-24]                    | [23-16]        | [15-8]        | [7-0]                 | ERRBIT                     | [76-71]       | [70-64]      |
| Doubleword<br>Address | 0x0 - 0x<br>0x8 - 0x<br> | -       |         |               | 0x4 - 0x7<br>0xC - 0xF<br> |                |               | Doubleword<br>Address | 0x0 - 0x3<br>0x8 - 0xB<br> |               |              |

# **3 Behavior in case ECC event occurs**

### 3.1 z0, z1, z3, and z6 versions of e200 cores

Single bit errors are automatically corrected - no reporting.

Detection of Multiple Bit ECC errors causes one of following:



#### Behavior in case ECC event occurs

| MSR[EE] | MSR[ME] | Access Type         | Result                                                                               |
|---------|---------|---------------------|--------------------------------------------------------------------------------------|
| 0       | 0       | Instruction or data | Enter Checkstop state                                                                |
| 0       | 1       | Instruction or data | Machine Check Interrupt (IVOR 1)                                                     |
| 1       | х       | Data                | Data Storage Interrupt (IVOR2) *<br>External Termination Error bit is set in spr ESR |
| 1       | х       | Instruction         | Instruction Storage Interrupt (IVOR3) *                                              |

Table 4. Multiple Bit ECC Error detection for z0/z1/z3/z6

#### and (if enabled)

External Interrupt (IVOR4) – ECSM/MCM combined interrupt request (usually vector 9)

- in case ECC error is invoked by other master then core, for instance eDMA, only ECSM interrupt will be initiated
- in case ECC error is invoked by the core, both ECSM interrupt and particular exception will be initiated, in sequence according to their priorities.

\* MPC5553/5554 - erratum e1143 - Option with cleared MSR[EE] bit is not functional and ECC noncorrectable error will act as MSR[EE] would be set.

### 3.2 z4 and z7 versions of e200 cores

Single bit errors are automatically corrected but can be reported to ECSM module.

Detection of Multiple Bit ECC Errors causes one of following:

| MSR[EE] | MSR[ME] | Access Type         | Result                                                                                                                                  |
|---------|---------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| x       | 0       | Instruction or data | Machine Check Interrupt (IVOR 1)*<br>Error flags in MCSR register are ignored                                                           |
| x       | 1       | Instruction or data | Machine Check Interrupt (IVOR 1)<br>Error flags in MCSR register must be cleared in<br>exception service routine to avoid IVOR 1 recall |

Table 5. Multiple Bit ECC Error detection for z4/z7

#### and (if enabled)

External Interrupt (IVOR4) – ECSM/MCM combined interrupt request (usually vector 9)

- in case ECC error is invoked by other master then core, for instance eDMA, only ECSM interrupt will be initiated
- in case ECC error is invoked by the core, both ECSM interrupt and particular exception will be initiated, in sequence according to their priorities.

\* Checkstop state does not exist on z4 and z7 cores



### 3.3 FLASH Non-correctable error reporting

On certain devices, PFBIU behave the way it invalidates the entire page (128 bits) when there's a noncorrectable ECC error in any of the double-word in that page - these are all MPC56xx devices with C90LC flash + MPC5668G/E (or PXN20). Other products (with C90FL flash) invalidates only faulty double word when non-correctable ECC error occur. In other words, read operation is always 128 bits on devices highlighted in Table 6.

| Flash type    | H7Fa              |                                                                | H7Fb  |                               | C90LC                                   |                                                                                                                | C90FL           |                                                                                                          |
|---------------|-------------------|----------------------------------------------------------------|-------|-------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------|
| Device family | • N<br>• N<br>• N | MPC5553<br>MPC5554<br>MPC5561<br>MPC5565<br>MPC5566<br>MPC5567 | • • • | MPC5533<br>MPC5534<br>MPC551x | • • • • • • • • • • • • • • • • • • • • | MPC560xB<br>MPC560xP<br>MPC560xS<br>MPC560xE<br>MPC563xM<br>MPC564xB<br>MPC564xC<br>MPC567xK<br>PXD10<br>PXS30 | • • • • • • • • | MPC564xA<br>MPC564xL<br>MPC564xS<br>MPC5668x<br>MPC567xF<br>MPC5676R<br>PXN20<br>PXN20<br>PXS20<br>PXR40 |

| Table | 6.         | Internal | flash | types |
|-------|------------|----------|-------|-------|
| Iabio | <b>~</b> . | micornia | naon  | .ypoo |

### 3.4 Impact of enabled CACHE on error reporting

In case cache is enabled, there is attempt to fill the whole cache line (32 bytes) as it is burst operation. If there is a non-correctable ECC error within this line, the line is invalidated and ECC related exception is invoked. For details, see section 5.1.1.

# 4 Correctable ECC error servicing

Basically it is not needed as 1-bit ECC error are automatically corrected during data/instruction read.

Detection of 1-bit errors (only MPC56xx) could be useful for catching of gradual degradation of flash memory content caused by aging. 1-bit error may be "physically" repaired by reading the data and writing them back.

# 5 Non-correctable ECC error servicing

Fixing of multibit ECC error is application dependent and must be part of ECC error interrupt handling. It can be based IVOR1/2/3 exception handler or IVOR4 interrupt handler as described in section 5.1 and section 5.2.

# 5.1 Based on IVORx exception

This document describes IVOR1 (Machine check) handling as the most common one and available with all e200 cores. The precondition is to have MSR[ME]=1 as it guarantees exception will be taken not



only directly associated with current instruction execution stream, but also those reported by the subsystem as bus error termination (for example cache line filling). This approach however still catch only error related to the core.

If ECC non-correctable error caused by other master than the core is supposed to be serviced, handling based on ECSM interrupt must be used (section 5.2) or combination of both approaches.

### 5.1.1 Machine Check Syndrome Register (MCSR)

Register gives possibility to differentiate between sources of machine check exceptions. Exception service routine should analyze the root cause of exception:

• Error caused by read of ECC corrupted data sets MCSR[MAV, LD, BUS\_DRERR].

• Error caused by write to area affected by ECC multibit error (this can be achieved by 32-bit, 16bit and 8-bit write as it behaves as read-modify-write operation above 64-bit) sets MCSR[MAV, LD, BUS\_DRERR, BUS\_WRERR]

• Error caused by attempt to execute of instruction affected by ECC multibit error sets MCSR[MAV, IF, BUS\_IRERR].

• Error caused by cache line filling (when there are data affected by ECC multibit error within this line) set MCSR[MAV, BUS\_DRERR] or MCSR[MAV, BUS\_IRERR].

MCSR[MAV] - indicates that the address contained in the MCAR was updated by hardware. Note that next update is only performed when this bit is explicitly cleared by w1c operation (,,write 1 to clear").

### 5.1.2 Machine Check Address Register (MCAR)

Register contains effective (when MCSR[MEA]=1) or physical (when MCSR[MEA]=0) address for which the asynchronous type of the machine check exception was raised (not all machine sources updates this register).

Address is valid only when MCSR[MAV] was cleared before exception.

### 5.1.3 Machine Check Save/Restore Register 0 (MCSRR0)

Register contains address of instruction that caused the exception. At the end of exception service routine, rfmci instruction loads the content of this register as return address (program counter).

In case it is needed to return to program flow before exception (i.e. after instruction that caused the exception) then it is needed to increase exception returning address by length of instruction causing an exception (in case BookE by 4, in case VLE by 2 or 4 according to instruction opcode) – see application note AN4648.



| Bit3 | Bit0 | Instruction was | Increment MCSRR0 by |
|------|------|-----------------|---------------------|
| 0    | 0    | 16-bit          | 2                   |
| 0    | 1    | 16-bit          | 2                   |
| 1    | 0    | 32-bit          | 4                   |
| 1    | 1    | 16-bit          | 2                   |

Table 7. Read content of address given by MCSRR0 register during machine check exception

#### NOTE

Address of instruction causing an IVOR1 exception (machine check) is stored is MCSRR0 register only with devices with "new" cores (z4 and z7). MCSRR0/1 registers are not present with "old" cores (z0, z1, z3, z6) and this information is stored in SRR0 register. Also se\_rfci instruction must be used instead of se\_rfmci.

### 5.2 Based on ECSM interrupt

### 5.2.1 ECSM module

A part of Error Correction Status Module (ECSM) is dedicated to ECC handling. It provides set of registers offering extended information about last detected ECC event. In comparison to approach described in section 5.1, ESCM brings following benefits:

- is capable to distinguish between RAM and FLASH ECC event
- allows detection of ECC event from other XBAR masters then the Core (eDMA, ..)
- can detect also single bit correctable ECC events (only MPC56xx)
- offers RAM ECC error injection capability



|                               | -                                                             |
|-------------------------------|---------------------------------------------------------------|
| Register Description          | Register                                                      |
| ECC Configuration Register    | ECSM_ECR                                                      |
| ECC Status Register           | ECSM_ESR                                                      |
| ECC Error Generation Register | ECSM_EEGR                                                     |
| Flash ECC Registers           | ECSM_FEAR<br>ECSM_FEMR<br>ECSM_FEAT<br>ECSM_FEDR              |
| RAM ECC Registers             | ECSM_REAR<br>ECSM_RESR<br>ECSM_REMR<br>ECSM_REAT<br>ECSM_REDR |

### 5.2.2 Coherent software view of the reported ECC event

Following sequence clears particular flags in ECSM\_ESR register by recommended sequence to maintain the coherent software view of the reported ECC event:

```
for (;;)
{
    /* 1. Read the ECSM ESR and save it */
    ecsm esr = (uint8 t)ECSM.ESR.R;
    /* 2. Read and save all the address and attribute reporting registers */
    /* Read only RAM registers if error is caused by RAM ECC error */
    if ( (ecsm esr & ECSM ESR R1BC MASK) || (ecsm esr & ECSM ESR RNCE MASK) )
    {
        ecsm_rear = (uint32_t)ECSM.REAR.R;
        ecsm remr = (uint8 t)ECSM.REMR.R;
        ecsm_reat = (uint8_t)ECSM.REAT.R;
    }
    /* Read only FLASH registers if error is caused by FLASH ECC error */
    if ( (ecsm esr & ECSM ESR F1BC MASK) || (ecsm esr & ECSM ESR FNCE MASK) )
    {
        ecsm fear = (uint32 t)ECSM.FEAR.R;
        ecsm femr = (uint8 t)ECSM.FEMR.R;
        ecsm_feat = (uint8_t)ECSM.FEAT.R;
    }
    /* 3. Re-read the ECSM ESR and verify the current contents matches
```



```
ECC error injection
```

```
the original contents. If the two values are different, go back
        to step 1 and repeat */
    if (ecsm_esr == (uint8_t)ECSM.ESR.R)
    {
        break;
    }
}
/* 4. When the values are identical, write a 1 to the asserted ECSM_ESR flag
        to negate the interrupt request - we actually negate all flags */
ECSM.ESR.R = 0x33;
```

# 6 ECC error injection

### 6.1 Intentional generating of SRAM 2b ECC error

SRAM double-bit ECC error may be injected by ECSM module. The whole sequence (injection and handling) is being done by following steps:

1) To enable ECC reporting:

```
/* enable RAM ECC error reporting */
ECSM.ECR.R = (uint8_t)ECSM_ECR_ERNCR_MASK | // non-correctable RAM ECC error
ECSM_ECR_ER1BR_MASK ; // 1-bit RAM ECC error
```

- 2) To generate non-correctable ECC error:
  - a) enable generating of ECC error
  - b) write data to particular RAM location
  - c) read the particular location to assert ECC exception

```
/* align this to a 0-modulo-8 address (aligned to 8 bytes) */
static vuint32_t test[2] __attribute__ ((aligned (8))) =
{ 0x0ul, 0x0ul };
static vuint32_t test_read = 0;
ECSM.EEGR.R = (uint16_t)(ECSM_EEGR_FR1NCI_MASK | 0x0001); // RAM[1] is inverted
test[0] = 0xCAFEBEEF;
test_read = test[0];
```

3) To service ECC exception according (Section 5.1) and/or (Section 5.2)





### 6.2 Intentional generating of FLASH 2b ECC error

ECC errors can be generated in the flash by over programming memory locations.

A multiple bit error will be detected but not corrected, therefore it is easier to see it has occurred. A procedure for creating a multiple bit error is as follows.

This will create a multiple bit ECC error and will be flagged in the ECC module.

Note that it is needed to choose such data patterns that have different ECC checkbits because overprogramming does not necessarily generates ECC error. For instance, patterns shown in Table 9 has the same ECC checkbits and thus may be overwritten without generating of ECC error. Moreover this feature is utilized by EEPROM emulation drivers.

| Doubleword                              | Checkbits |
|-----------------------------------------|-----------|
| 0xFFFF_FFFF_FFFFFFFFFFFFFFFFFFFFFFFFFFF | 0xFF      |
| 0xFFFF_FFFF_FFF_0000                    | 0xFF      |
| 0xFFFF_FFF_0000_FFFF                    | 0xFF      |
| 0xFFFF_0000_FFFF_FFFF                   | 0xFF      |
| 0x0000_FFFF_FFFF_FFFF                   | 0xFF      |
| 0xFFFF_FFF_0000_0000                    | 0xFF      |
| 0xFFFF_0000_FFFF_0000                   | 0xFF      |
| 0x0000_FFFF_FFF_0000                    | 0xFF      |
| 0xFFFF_0000_0000_FFFF                   | 0xFF      |
| 0x0000_FFFF_0000_FFFF                   | 0xFF      |
| 0x0000_0000_FFFF_FFF                    | 0xFF      |
| 0xFFFF_0000_0000_0000                   | 0xFF      |
| 0x0000_FFFF_0000_0000                   | 0xFF      |
| 0x0000_0000_0000_0000                   | 0xFF      |

#### Table 9. Data patterns with same ECC checkbits



ECSM/RGM/FCCU relation on safety devices

# 7 ECSM/RGM/FCCU relation on safety devices

This section is related only to MPC564xL and MPC567xK devices and describes their specific implementation. ECC error is now also reported to FCCU and RGM modules as shown in the Figure 1. ECSM detection of multibit ECC error also cause FCCU critical faults CF16 and CF17.





### 7.1 MPC564xL

- Non-correctable ECC error reporting is directly routed from ECSM into RGM module via RGM\_FES[F\_FL\_ECC\_RCC] flag. RGM\_FERD[D\_FL\_ECC\_RCC] and RGM\_FESS[SS\_FL\_ECC\_RCC] bits are read-only and thus not configurable what means that flash, ECC, or lock-step error event always triggers a reset sequence starting from PHASE1. This cannot be changed on MPC564xL device.
- If ECSM\_ECR[EPRNCR/EPFNCR] bit is set and so ECSM Non-Correctable Reporting is enabled and multibit ECC error even occurs (either unintentional or injected), device is reset.



 Platform Flash ECC registers (PFEAR, PFEMR, PFEAT, PFEDRH, PFEDRL) and Platform RAM ECC registers (PREAR, PRESR, PREMR, PREAT, PREDRH, PREDRL) are maintained through the MCU functional reset. This can be however used only with ECC error injection because ECSM\_ECR is being cleared during reset, user cannot distinguish whether the reason was ECC error in FLASH or RAM. Although these registers are maintained, only the half of them is readable. For instance if Multibit ECC error occurs in RAM, device goes to reset and then Platform RAM ECC registers are maintained. But Platform FLASH ECC registers contains random data (and different for ECSM\_0 and ECSM\_1) so attempts to read any of Platform FLASH ECC register (in order to distinguish between RAM and FLASH error) leads in lock-step error and another reset. And vice versa when Multibit ECC error occurs in RAM, Platform FLASH ECC registers are not usable.

### 7.1.1 Handling through reset

```
/* Save RGM status register before initialization for subsequent usage */
RGM_FES_reg = RGM.FES.R;
/* Initialize HW common way */
HW_init();
/* check ECC error */
if(RGM_FES_reg & RGM_FES_F_FL_ECC_RCC)
{
    /* apply ECC error handling */
}
```

### 7.1.2 Possible ECC error handling through reset solution

### 7.1.2.1 Option 1

- After reset caused by ECC error, do not enable ECSM reporting
- Scan the whole flash memory range (0-0x00F0\_3FFF) and handle possible ECC error in Machine check exception (IVOR1)
- If none error occurs, consider there was an error in RAM, already corrected by SRAM initialization
- Pros and cons:
  - + catches all multibit ECC errors from all masters
  - slow recover due to reset and impossibility to simply find an error



### 7.1.2.2 Option 2

- Do not use ESCM reporting at all
- Pros and cons:
  - + possible fast recover by IVOR1 exception
  - does not catch ECC errors from other masters than the core
  - it is not possible to inject Multibit RAM ECC error

# 7.2 MPC567xK

The same approach as described in section 7.1 can be used as well.

Contrary to MPC564xL, RGM\_FERD[D\_FL\_ECC\_RCC] bit is writable and MPC567xK device can be configured the way not to generate reset in case double bit ECC error occurs.

If RGM\_FERD[D\_FL\_ECC\_RCC] = 1, ECC double bit error generates safe mode request and device goes to machine check exception. However this machine check is invoked two times, firstly by Read Bus Error, secondly by FCCU non-maskable interrupt (delay between this two events is not precisely defined as Core and FCCU module are driven by different and independent clock sources). Multiply IVOR1 issuing cause loosing of returning address (MCSRR0) thus this exception is non-recoverable and application must be reset anyway by software reset.

# 8 Example Codes

# 8.1 MPC5634M 2b\_RAM\_ECC\_error\_injection

ECSM Error Generation Register is used to generate a non-correctable ECC error in RAM. The bad data is accessed then, so the IVOR1/2/3 exception is generated and handled. It shows also ECSM combined interrupt service routine and how to correct the wrong data.

Use macro Induce\_ECC\_error\_by\_DMA\_read to select whether ECC error will be injected by DMA read or CPU read.

At the end of main file you can select particular ME/EE setup by comment/uncomment of particular function calls.



# 8.2 MPC5674F 1b+2b\_RAM\_ECC\_error\_injection

ECSM Error Generation Register is used to generate a non-correctable (or single bit ECC) error in RAM. The bad data is accessed then, so the IVOR1 exception (or 1b ECC error handler) is generated and handled. It shows also ECSM combined interrupt service routine and how to correct the wrong data.

Use macro Induce\_ECC\_error\_by\_DMA\_read to select whether ECC error will be injected by DMA read or CPU read.

At the end of main file you can choose if single bit or multi bit is injected and select particular ME/EE setup by comment/uncomment of particular function calls.

# 8.3 MPC5643L 1b\_RAM\_ECC\_error\_injection

Example demonstrates MCU behavior when single bit RAM ECC error occurs by intentional ECC error injection.

# 8.4 MPC5643L 2b\_RAM+2b\_FLASH\_ECC\_error\_injection

Purpose of the example is to show how to generate Multi bit ECC error in internal SRAM or FLASH (user must choose it in the option at the end of main function) and how to handle this error with respect to constraints given by MPC5643L architecture (ECSM/RGM/FCCU relation and ECC error handling through reset). The example is only possible to run in internal\_FLASH target. Power-on-reset is required after downloading the code into MCU's flash. The example displays notices in the terminal window (19200-8-no parity-1 stop bit-no flow control on eSCI\_A). No other external connection is required.

# 8.5 MPC5675K 2b\_RAM+2b\_FLASH\_ECC\_error\_injection

Purpose of the example is to show how to generate Multi bit ECC error in internal SRAM or FLASH (user can choose it in the option at the end of main function) and how to handle this error with respect to constraints given by MPC5675K architecture (ECSM/RGM/FCCU relation and ECC error handling through reset). The example is only possible to run in internal\_FLASH target. Power-on-reset is required after downloading the code into MCU's flash. The example displays notices in the terminal window (19200-8-no parity-1 stop bit-no flow control on eSCI\_A). No other external connection is required.

Example also shows impact of enabled cache (macro OPTIMIZATIONS\_ON).



How to Reach Us:

Home Page: freescale.com

Web Support: freescale.com/support Information in this document is provided solely to enable system and software implementers to use Freescale 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. Freescale reserves the right to make changes without further notice to any products herein.

Freescale makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale 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 Freescale 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. Freescale does not convey any license under its patent rights nor the rights of others. Freescale sells products pursuant to standard terms and conditions of sale, which can be found at the following address: freescale.com/SalesTermsandConditions.

Freescale and the Freescale logo are trademarks of Freescale Semiconductor, Inc., Reg. U.S. Pat. & Tm. Off. All other product or service names are the property of their respective owners.

© 2015 Freescale Semiconductor, Inc.

Document Number: AN5200 Rev.1 12/2015

