

Chip Errata

# MCF5208 Chip Errata

Silicon Revision: All

# Supports: MCF5207 and MCF5208

# Summary of MCF520x Errata

Early MCF5208 devices are marked as M28B mask set. The latest version of the MCF520x is marked as 2M28B.

| Errata  | Module Affected      | Date Errata Added Revision Affe | Affected? |       |
|---------|----------------------|---------------------------------|-----------|-------|
|         |                      |                                 | M28B      | 2M28B |
| SECF022 | Clock                | 8/11/05                         | Yes       | No    |
| SECF044 | SDRAMC               | 10/4/05                         | Yes       | No    |
| SECF005 | Cache                | 1/23/06                         | Yes       | Yes   |
| SECF001 | Cache                | 1/23/06                         | Yes       | Yes   |
| SECF010 | FEC                  | 1/23/06                         | Yes       | Yes   |
| SECF017 | FlexBus              | 1/23/06                         | Yes       | Yes   |
| SECF045 | SDRAMC               | 6/14/06                         | Yes       | No    |
| SECF008 | FlexBus              | 6/14/06                         | Yes       | No    |
| SECF014 | Debug                | 3/20/08                         | Yes       | Yes   |
| SECF180 | Interrupt Controller | 8/12/10                         | Yes       | Yes   |

## Table 1. Summary of MCF520x Errata

The chip identification register (CIR) can also be used to determine the silicon revision. Table 2 list the CIR[PRN] field values that correspond to given mask set.

# Table 2. CIR[PRN] to mask

| CIR[PRN] value | Mask set |
|----------------|----------|
| 0              | M28B     |
| 2              | 2M28B    |



© 2010 Freescale Semiconductor.



# **Revision History**

The table below provides a revision history for this document.

| Rev. No. | Date    | Substantive Changes                                          |
|----------|---------|--------------------------------------------------------------|
| 1        | 8/2005  | Initial revision                                             |
| 1.1      | 10/2005 | Added SECF044                                                |
| 1.2      | 2/2006  | Added SECF005, SECF001, SECF010, and SECF017                 |
| 1.3      | 6/2006  | Added SECF045 and SECF008                                    |
| 1.4      | 10/2006 | Updated errata to reflect fixed bugs for the 2M28B mask set. |
| 2        | 3/2008  | Added SECF014                                                |
| 3        | 8/2010  | Added SECF180                                                |

## **Table 3. Document Revision History**

# SECF001: Incorrect Operation of Cache Freeze (CACR[CFRZ])

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                     |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | Version 2 ColdFire Cache                                                                                                                                                                                                                                                                                                                    |
| Description:        | The cache on the V2 ColdFire core is controlled by the cache control register (CACR). When the CACR[CFRZ] bit is set, the cache freeze function is enabled and no valid cache array entry is displaced. However, this feature does not always work as specified, sometimes allowing valid lines to be displaced when CACR[CFRZ] is enabled. |
|                     | This does not cause any corrupted accesses. However, there could be cache misses for data that was originally loaded into the cache but was subsequently deallocated, even though the CACR[CFRZ] bit was set.                                                                                                                               |
|                     | Also, incoherent cache states are possible when a frozen cache is cleared via the CACR[CINV] bit.                                                                                                                                                                                                                                           |
| Workaround:         | Unfreeze the cache by clearing CACR[CFRZ] when invalidating the cache using the CACR[CINV] bit                                                                                                                                                                                                                                              |
| Workaround:         | Use the internal SRAM to store critical code/data if the system cannot handle a potential cache miss                                                                                                                                                                                                                                        |
| Fix plan:           | Currently, there are no plans to fix this.                                                                                                                                                                                                                                                                                                  |

## SECF005: Possible Cache Corruption After Clearing Cache (Setting CACR[CINV])

| Errata type:        | Silicon                                                   |  |
|---------------------|-----------------------------------------------------------|--|
| Affected component: | Version 2 ColdFire Cache                                  |  |
| Description:        | The cache on the V2 ColdFire core may function as either: |  |
|                     | <ul> <li>a unified data and instruction cache</li> </ul>  |  |

### MCF5208 Chip Errata, Rev. 3, 8/2010



### SECF008: Programmable Address Hold Does Not Function Correctly

| Errata type:<br>Affected component: | Silicon<br>FlexBus                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description:                        | The programmable address hold feature for the FlexBus chip selects does<br>not function correctly. The address is held for one clock after the chip select<br>deasserts regardless of the address hold value programmed in the<br>CSCR[WRAH] or CSCR[RDAH] fields. The address hold fields creates a<br>delay at the end of the bus cycle. They can continue to be used to ensure a<br>minimum delay between bus cycles. |
| Workaround:                         | No workarounds.                                                                                                                                                                                                                                                                                                                                                                                                          |
| Fix plan:                           | Fixed starting with 2M28B mask set.                                                                                                                                                                                                                                                                                                                                                                                      |

### SECF010: FEC Interrupts will not Trigger on Consecutive Transmit Frames

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | FEC                                                                                                                                                                                                                                                                                                                                                             |
| Description:        | The late collision (LC), retry limit (RL), and underrun (UN) interrupts do not trigger on consecutive transmit frames. For example, if back-to-back frames cause a transmit underrun, only the first frame generates an underrun interrupt. No other underrun interrupts are generated until a frame is transmitted that does not underrun or the FEC is reset. |
| Workaround:         | Because late collision, retry limit, and underrun errors are not directly correlated to a specific transmit frame, in most cases a workaround for this problem is not needed. If a workaround is required, there are two independent workarounds:                                                                                                               |



- Ensure that a correct frame is transmitted after a late collision, retry limit, or underrun errors are detected.
  - Perform a soft reset of the FEC by setting ECR[RESET] when a late collision, retry limit, or underrun errors are detected.
- **Fix plan:** Currently, there are no plans to fix this.

## SECF014: Level 2 Trigger Operation Controlled by TDR[31]

| Errata type:        | Silicon                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | BDM                                                                                                                                                                                 |
| Description:        | The TDR[L2T] bit (TDR bit 15) has no effect on the level 2 trigger. Bit 31 of the TDR register provides both trigger response control and logical operation of the level 2 trigger. |
| Workaround:         | Use the TDR[31] bit to control the logical operation for the level 2 trigger as follows:                                                                                            |
|                     | <ul> <li>0 Level 2 trigger = PC_condition &amp; Address_range &amp; Data_condition</li> <li>1 Level 2 trigger = PC_condition   (Address_range &amp; Data_condition)</li> </ul>      |
|                     | Since TDR[31] is also part of the trigger response control, only certain combinations of trigger responses and logical operations are available as shown below:                     |
|                     | Table 4. TDR[31:30] Definitions                                                                                                                                                     |

| TDR[31:30] | Level 2 Trigger                      | Trigger Response |
|------------|--------------------------------------|------------------|
| 00         | PC_cond & (Add_range &<br>Data_cond) | Display on DDATA |
| 01         |                                      | Processor halt   |
| 10         | PC_cond   (Add_range &<br>Data_cond) | Debug interrupt  |
| 11         |                                      | Reserved         |

**Fix plan:** Currently, there are no plans to fix this.

## SECF017: No Bus Monitor or Watchdog Recovery for Hung FlexBus Accesses

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | FlexBus                                                                                                                                                                                                                                                                                                                                                                                                              |
| Description:        | <ul> <li>This device does not include a bus monitor or watchdog timer capable of forcing the termination of a hung FlexBus access. There are two possible cases that could lead to a hung FlexBus access:</li> <li>If an access to one of the FlexBus memory areas (0x0000_0000-0x3FFF_FFFF or 0xC000_0000-0x0FFF_FFFF) does not hit in the valid range for one of the chip selects, a 32-bit access with</li> </ul> |

|             | <ul> <li>no chip select asserted and no internal acknowledge is generated. The resulting bus cycle continues indefinitely waiting for the assertion of the TA signal (external acknowledge).</li> <li>If a chip select is configured for external termination, but no termination is received or a timing problem prevents TA from being recognized, the bus cycle is hung and continues indefinitely.</li> </ul> |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | There is no on-chip fail-safe to exit from the hung bus state. The system needs to assert TA to terminate the hung cycle or reset the entire device.                                                                                                                                                                                                                                                              |
| Workaround: | Avoid issuing non-terminated FlexBus accesses. Ideally, a complete system does not access unused memory areas. This is harder to achieve while debugging, but as long as the debugger has access to the TA signal on the BDM header, it should be able to force termination of any hung bus cycles.                                                                                                               |
| Workaround: | Use an external bus monitor circuit that can detect hung bus cycles and generate a TA to terminate the access. The bus monitor circuit can optionally assert an external interrupt signal along with TA to indicate the error condition back to the CPU.                                                                                                                                                          |
| Workaround: | If there are unused chip selects in the system, they can be mapped over<br>unused memory areas. The only purpose of these chip selects would be to<br>terminate accesses to addresses that are not used. BDM address breakpoints<br>can then be used to generate an interrupt error.                                                                                                                              |
| Fix plan:   | Currenty, there are no plans to fix this.                                                                                                                                                                                                                                                                                                                                                                         |

## SECF022: PLL Behavior in Stop Mode

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Description:        | <ul> <li>If the PLL is disabled in stop mode, the device exits stop mode with its booted frequency regardless of the operating frequency prior to entering stop mode. Entering stop mode with an LPCR[STPMD] setting of 0b10 or 0b11 causes a hard reset to the PLL module. When stop mode is exited, the PLL re-latches the reset configuration setting for the PLL. For example: <ol> <li>The device is booted with a 166.67/83.33 MHz frequency selected.</li> <li>The device is placed into limp mode to change the operating frequency to 144/72 MHz and limp mode is exited.</li> <li>The LPCR is programmed to disable the PLL in stop mode (LPCR = 0xD0 or 0xD8).</li> <li>The stop instruction is executed.</li> <li>An interrupt is generated to exit the processor from stop mode.</li> <li>The device exits stop mode at an operating frequency of 240/80 MHz instead of 166.67/83.33144/72 MHz.</li> </ol> </li> </ul> |
| Workaround:         | If the PLL frequency has not been modified since the last reset or if limp mode<br>is being used, no workaround is needed.<br>If the PLL was reprogrammed after reset, the PLL needs to be reprogrammed<br>after exiting stop mode. The following steps show how this can be done:<br>1. Program the LPCR register to disable the PLL in stop mode (LPCR =<br>0xD0 or 0xD8).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

MCF5208 Chip Errata, Rev. 3, 8/2010



|           | 2. Save the values of the PLL registers.                                                                  |
|-----------|-----------------------------------------------------------------------------------------------------------|
|           | <ol><li>Place the device into limp mode by clearing the MISCCR[LIMP] bit.</li></ol>                       |
|           | <ol><li>Execute the STOP instruction.</li></ol>                                                           |
|           | <ol> <li>After exiting stop mode, reload the PLL with the register values saved<br/>in step 2.</li> </ol> |
|           | 6. Exit limp mode by clearing the MISCCR[LIMP] bit.                                                       |
| Fix plan: | Fixed starting with 2M28B mask set.                                                                       |

# SECF044: SDRAMC Incorrect Operation After Exiting Limp Mode

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | SDRAM controller                                                                                                                                                                                                                                                                       |
| Description:        | The circuitry that controls the SDRAMC's SD_DQS signals attempts to lock<br>to the clock when the device is in limp mode. The large difference in clock<br>speeds between limp mode and normal operation causes the SD_DQS logic<br>to become unsynchronized when limp mode is exited. |
| Workaround:         | After exiting limp mode, the value of 0x4000_0000 should be written to address 0xFC0B_8080 before attempting to initialize the SDRAMC or exit the SDRAM from self-refresh mode.                                                                                                        |
| Fix plan:           | Fixed starting with 2M28B mask set.                                                                                                                                                                                                                                                    |

# SECF045: Potential Boot Failure Using 32-Bit Wide SDRAM

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | SDRAM controller                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Description:        | If the SD_CKE signal to the SDRAM deasserts while one or more banks are active, the SDRAM enters a clock suspend state. If the SDRAM was driving the data lines before entering the clock suspend state, the buffers continue to drive.                                                                                                                                                                                                                 |
|                     | During a reset, the processor deasserts SD_CKE without any graceful stop<br>period to ensure that the SDRAM banks are all in an IDLE state. In some<br>cases, the SDRAM could be driving the data bus during and immediately<br>after reset. This can lead to possible bus contention while latching reset<br>configuration (RCON) values and/or while reading boot code from flash, and<br>that could cause the processor to enter an undefined state. |
| Workaround:         | Use a split bus mode configuration with DDR SDRAM or SDR SDRAM. This creates a dedicated 16-bit port for the SDRAM on D[31:16]. In this configuration, the SDRAM does not share data lines with other devices, so bus contention is not an issue.                                                                                                                                                                                                       |
| Workaround:         | Additional workarounds TBD. We are investigating workarounds that can be used for 32-bit wide SDRAM configurations.                                                                                                                                                                                                                                                                                                                                     |
| Fix plan:           | Fixed starting with 2M28B mask set.                                                                                                                                                                                                                                                                                                                                                                                                                     |



# SECF180: Spurious Interrupts Can Cause Incorrect Vector Fetch

| Errata type:        | Silicon                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Affected component: | INTC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Description:        | In rare cases the interrupt controller's spurious detection logic can cause a fetch to an incorrect vector number. This can occur when the core is starting the IACK for a spurious interrupt. During this small window of time, if a second interrupt at a different level arrives, the second interrupt causes the interrupt controller logic to clear the spurious request. Therefore, the interrupt controller sees no valid interrupt pending at the requested level and returns vector number 0 for INTCO. |
|                     | The second interrupt can be at any level other than the level that caused the spurious interrupt (it can even be a lower priority than the spurious interrupt). If the second interrupt is at the same level as the spurious interrupt, then the correct vector number for the second interrupt is returned.                                                                                                                                                                                                     |
| Workaround:         | In many systems spurious interrupts represent error conditions in and of<br>themselves. So, it is always a good design practice to eliminate potential<br>causes of spurious interrupts during product development. Proper interrupt<br>management can help to prevent or reduce the possibility of spurious interrupts<br>(and the potential occurrence of this errata). The correct procedure for masking<br>an interrupt in the INTC or inside the module is:                                                 |
|                     | <ol> <li>Write the interrupt level mask in the core's status register (SR[I]) to a value higher than the priority level of the interrupt you want to mask.</li> <li>Mask the interrupt using the INTC's IMR and/or an interrupt mask register inside the module.</li> <li>Write the original value back to the core's status register.</li> </ol>                                                                                                                                                                |
|                     | Even when steps are taken to remove spurious interrupts, it is still desirable<br>to have a spurious interrupt handler to help manage unexpected events and<br>glitches in a system. A workaround to allow for correct spurious interrupt<br>handling is to:                                                                                                                                                                                                                                                     |
|                     | <ol> <li>After boot, copy the vector table to RAM</li> <li>Modify the vector 0 entries so that they point to the spurious interrupt<br/>handler.</li> </ol>                                                                                                                                                                                                                                                                                                                                                      |
|                     | This way the system performs the same for any potential spurious interrupt vectors. Vectors 0 and 24 (the correct spurious interrupt vector) should point to the same handler.                                                                                                                                                                                                                                                                                                                                   |
| Fix plan:           | Currently, there are no plans to fix this.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### How to Reach Us:

Home Page: www.freescale.com

Web Support: http://www.freescale.com/support

#### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 +1-800-521-6274 or +1-480-768-2130 www.freescale.com/support

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 10 5879 8000 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center 1-800-441-2447 or +1-303-675-2140 Fax: +1-303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com Information in this document is provided solely to enable system and sofware implementers to use Freescale Semiconductors products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor 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 Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor prodcuts are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claims alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.

RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics as their non-RoHS-complaint and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative.

For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp.

Freescale<sup>™</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners.

© 2010 Freescale Semiconductor.



Document Number: MCF5208DE Rev. 3, 8/2010