#### NXP Semiconductors Chip Errata

Document Number: IMX28CE Rev. 3, 11/2018

# Chip Errata for the i.MX28

This document details all known silicon errata for the i.MX28. Table 1 provides a revision history for this document.

| Rev.<br>Number | Date    | Substantive Change(s)                                                                                                                                      |
|----------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3              | 07/2018 | Updated Table 2 and the following changes and additions to errata:<br>• Updated TKT131240<br>• Updated TKT140334<br>• Added ERR011495<br>• Added ERR006358 |
| 2              | 09/2012 | • Added errata ERR002656, ERR002360, 2765, 2858, 2814, 2811, TKT131240, 5837 and TKT140334.                                                                |
| 1              | 09/2010 | Updated Table 2 Deleted ENGR119940                                                                                                                         |
| 0              | 03/2010 | Initial release.                                                                                                                                           |

#### **Table 1. Document Revision History**

Table 2 provides a cross-reference to match the revision code to the revision level marked on the device.

#### Table 2. Revision Level to Part Marking Cross-Reference

| MCIMX28 Revision | Package                             | Device Marking | Mask Revision |
|------------------|-------------------------------------|----------------|---------------|
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289 | MCIMX283DVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289 | MCIMX283CVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289 | MCIMX286DVM4B  | 2M06Z         |



| MCIMX28 Revision | Package                              | Device Marking | Mask Revision |
|------------------|--------------------------------------|----------------|---------------|
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX286CVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX287CVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX281AVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX285AVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX280DVM4B  | 2M06Z         |
| 1.2              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX280CVM4B  | 2M06Z         |
| 1.3              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX280DVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8mm pitch, MAPBGA-289  | MCIMX280CVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8 mm pitch, MAPBGA-289 | MCIMX283DVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8 mm pitch, MAPBGA-289 | MCIMX283CVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8 mm pitch, MAPBGA-289 | MCIMX286DVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8 mm pitch, MAPBGA-289 | MCIMX286CVM4C  | 3M06Z         |
| 1.3              | 14 x 14 mm, 0.8 mm pitch, MAPBGA-289 | MCIMX287CVM4C  | 3M06Z         |

Table 2. Revision Level to Part Marking Cross-Reference

Table 3 summarizes all known errata.

| Errata     | Name                                                                                                                       | Projected Solution |
|------------|----------------------------------------------------------------------------------------------------------------------------|--------------------|
| ENGR116296 | HSADC: Soft reset causes unexpected request to DMA                                                                         | No fix scheduled   |
| ENGR116904 | PXP: The HW_PXP_CSCCOEFF2_C3 register can not be reset correctly under some PVT corner                                     | No fix scheduled   |
| ENGR119650 | USB: USB core INCR8 and INCR16 modes are inoperable                                                                        | No fix scheduled   |
| ENGR119653 | USB: ARM to USB register error issue                                                                                       | No fix scheduled   |
| ENGR119657 | PWM: Register write sync issue when HSADC clock frequency is lower than APBX clock frequency                               | No fix scheduled   |
| ENGR119956 | CLKCTRL: ENET 1588 clock (CLK_ENET_TIME) is not under control of ENET disable control bit                                  | No fix scheduled   |
| ENGR121613 | ENET: ENET big endian mode not compatible with ARM little endian                                                           | No fix scheduled   |
| ENGR121616 | DMA: APBH/APBX DMA channel can stall while waiting to access a APBH/APBX bus peripheral when the channel freeze bit is set | No fix scheduled   |
| ERR002656  | FlexCAN: Abort request blocks the CODE field                                                                               | No fix scheduled   |
| ERR002360  | FlexCAN: Global Masks misalignment                                                                                         | No fix scheduled   |
| 2765       | EMI Clock: Switching to synchronous mode error                                                                             | No fix scheduled   |
| 2858       | USB controller may access a wrong address for the dTD (endpoint transfer descriptor) and then hangs                        | No fix scheduled   |

| Errata    | Name                                                                                                                       | Projected Solution |
|-----------|----------------------------------------------------------------------------------------------------------------------------|--------------------|
| 2814      | The DCDC converters unexpectedly turn on when 5 V is removed while the DCDC_XFER bit is clear                              | No fix scheduled   |
| 2811      | Unreliability of VDD5V_GT_VDDIO functionality                                                                              | No fix scheduled   |
| TKT131240 | SSP0/1-SD/MMC/eMMC Boot: SSP_SCK polarity setup issue in ROM                                                               | No fix scheduled   |
| 5837      | Setting the ENABLE_DCDC bit in the HW_POWER_DCDC4P2 or<br>HW_POWER_5VCTRL registers can result in false brownout Detection | No fix scheduled   |
| TKT140334 | ONFI 3.0 NAND boot-up issue                                                                                                | No fix scheduled   |

Table 3. Summary of Silicon Errata and Applicable Revision (continued)

#### ENGR116296 HSADC: Soft reset causes unexpected request to DMA

#### **Description:**

When HSADC is initially powered on and performs a soft reset, the APBH-DMA may receive an unexpected request from the HSADC and enter into an unknown state.

#### **Projected Impact:**

HSADC operates incorrectly.

#### Workaround:

Software workaround 1:

Before completing a normal soft reset, make a timing sequence of CLKGATE and SFTRST by register programming to reset FIFO read and write pointer, and make RD\_EMPTY to the known state of 1 before normal operation.

The register programming below can be used to generate the timing sequence of CLKGATE and SFTRST before a normal soft reset.

- HW\_HSADC\_CTRL0\_CLR(BM\_HSADC\_CTRL0\_SFTRST);
- HW\_HSADC\_CTRL0\_WR((HW\_HSADC\_CTRL0\_RD() | BM\_HSADC\_CTRL0\_SFTRST) & (~BM\_HSADC\_CTRL0\_CLKGATE));
- HW\_HSADC\_CTRL0\_SET(BM\_HSADC\_CTRL0\_CLKGATE);
- HW\_HSADC\_CTRL0\_CLR(BM\_HSADC\_CTRL0\_CLKGATE);
- HW\_HSADC\_CTRL0\_SET(BM\_HSADC\_CTRL0\_CLKGATE);

#### NOTE

This sequence is only required for the first reset after power up.

Software workaround 2:

Complete a HSADC DMA channel reset after the HSADC module soft reset and before configuring/enabling the HSADC DMA channel as shown below:

- HW\_APBH\_CHANNEL\_CTRL.B.RESET\_CHANNEL = 0x1000;
- HSADC\_CTRL0\_CLKGATE and HSADC\_CTRL0\_SFTRST address is 0x80002000.

#### **Projected Solution:**

### ENGR116904 PXP: The HW\_PXP\_CSCCOEFF2\_C3 register can not be reset correctly under some PVT corner

#### **Description:**

The HW\_PXP\_CSCCOEFF2\_C3 register does not receive the correct reset value after using the PXP software reset function or after power up.

#### **Projected Impact:**

The PXP operates incorrectly with wrong coefficient setting.

#### Workaround:

Always write the HW\_PXP\_CSCCOEFF2\_C3 register with the expected value before using it. The PXP\_CSCCOEFF2 register address is 0x8002A0F0.

#### **Projected Solution:**

#### ENGR119650

#### ENGR119650 USB: USB core INCR8 and INCR16 modes are inoperable

#### **Description:**

The USB controller may not operate properly when receiving a packet in INCR8 and INCR16 modes. The packet is completed correctly (ACK is sent) on the USB bus, but cannot be seen by software.

This issue exists when all of following conditions are met:

- 1. Controller is receiving data (Host Bulk IN or Device Bulk OUT)
- 2. Primary INCR8/INCR16 mode is selected (SBUSCFG. AHBBRST of the USB register is set to 0b010 or 0b011)
- 3. Length of data received is less than the total\_byte field in TD
- 4. Data length is not a multiple of the burst size and the remainder is a sub-burst. For example, if the data length is 32n + 16 bytes in INCR8 mode, or 64n + 16/32/48 in INCR16 mode, this errata is triggered.

#### **Projected Impact:**

This is a low severity bug because INCR8 and INCR16 are not mandatory modes. Other modes should be used.

#### Workaround:

Set SBUSCFG.AHBBRST of the USB register to a modes other than 0b010 or 0b011.

#### **Projected Solution:**

#### ENGR119653 USB: ARM to USB register error issue

#### **Description:**

The ARM writes a data error to the USB core register unless SRM SWP instruction is used. The issue occurs when all of the following conditions are met:

- 1. Last AHB access is to the non-USB AHB slave
- 2. Current AHB access is to the USB
- 3. These two accesses are back-to-back
- 4. The last data phase of the last AHB access has a wait state
- 5. Only happens when D-cache is enabled

#### **Projected Impact:**

The USB register does not get correct data when writing to the USB slave through the AHB bus when D-cache is enabled.

#### Workaround:

All USB register write operations must use the ARM SWP instruction.

#### **Projected Solution:**

### ENGR119657 PWM: Register write sync issue when HSADC clock frequency is lower than APBX clock frequency

#### **Description:**

The PWM channel might not generate the required output signal when in HSADC driving mode. When in HSADC mode, if the HSADC input clock is much lower than the APBX bus clock (for example APBX Bus clock is 24 MHz and HSADC input clock is 4 MHz) the write signal to the PWM registers is missed. Write access to the following registers has no effect after HSADC mode is enabled:

- PWM Control and Status Register
- PWM Channel Active Register
- PWM Channel Period Register

As a result, dedicated PWM channel is not triggered.

#### **Projected Impact:**

HSADC or off chip linear sensor does not receive the required control signals.

#### Workaround:

If the HSADC input clock is lower than the 24 MHz APBX bus clock the APBX bus clock should be set to a lower frequency before every write to the PWM register. When the write access finishes, the APBX clock can be set back to normal.

#### **Projected Solution:**

### ENGR119956 CLKCTRL: ENET 1588 clock (CLK\_ENET\_TIME) is not under control of ENET disable control bit

#### **Description:**

The Ethernet 1588 clock (CLK\_ENET\_TIME) continues to toggle when the Ethernet module is disabled by setting ENET disable control bit in the HW\_CLKCTRL\_ENET register. The ethernet controller consumes  $30 \,\mu\text{A}$  on the 4.2 V power supply.

#### **Projected Impact:**

The Ethernet 1588 clock consumes 30  $\mu$ A on the 4.2 V power supply when the Ethernet module is disabled.

#### Workaround:

The Ethernet 1588 clock can be gated off by clearing the HW\_CLKCTRL\_ENET\_DIV\_TIME register. The HW\_CLKCTRL\_ENET\_DIV\_TIME register address is 0x80040140.

#### **Projected Solution:**

#### ENGR121613

#### ENGR121613 ENET: ENET big endian mode not compatible with ARM little endian

#### **Description:**

The endian mode of the Ethernet controller is designed to be big-endian mode which is not compatible with the ARM core and reset sections of the device.

#### **Projected Impact:**

The ARM core cannot establish data communication correctly to/from the Ethernet controller without software endian conversion.

#### Workaround:

When communicating with the Ethernet controller, an additional byte-swap routine has to be called by the ARM core.

#### **Projected Solution:**

### ENGR121616 DMA: APBH/APBX DMA channel can stall while waiting to access a APBH/APBX bus peripheral when the channel freeze bit is set

#### **Description:**

When the channel freeze bit is set, the APBH/APBX DMA channel can stall while waiting to access a peripheral on the APBH/APBX bus. This occurs if the channel freeze bit is set exactly at the same time as when the channel internal state machine changes from the PIO\_REQ state to the REQ\_WAIT state.

#### **Projected Impact:**

The data communication with the APBH/APBX DMA channel associated peripheral is stalled.

#### Workaround:

Do not use DMA PIO operation to configure the associated peripheral when using channel freeze function. Use ARM PIO operation instead.

#### **Projected Solution:**

#### ERR002656

### No fix scheduled.ERR002656FlexCAN: Abort request blocks the CODE field

#### **Description:**

An Abort request to a transmit message buffer (TxMB) can block any write operation into its CODE field. Therefore, the TxMB cannot be aborted or deactivated until it completes a valid transmission (by winning the CAN bus arbitration and transmitting the contents of the TxMB).

#### **Projected Impact:**

The TxMB cannot be aborted or deactivated until it completes a valid transmission.

#### Workaround:

Instead of aborting the transmission, use deactivation instead.

Note that there is a chance the deactivated TxMB can be transmitted without setting IFLAG and updating the CODE field if it is deactivated.

#### **Projected Solution:**

#### ERR002360 FlexCAN: Global Masks misalignment

#### **Description:**

During CAN message reception by FlexCAN, the RXGMASK (Rx Global Mask) is used as an acceptance mask for most of the Rx message buffers (MB). When the FIFO Enable bit in the FlexCAN Module Configuration Register (CANx\_MCR[FEN], bit 29) is set, the RXGMASK also applies to most of the elements of the ID filter table. However, there is a misalignment between the position of the ID field in the RxMB and that in the RXIDA, RXIDB and RXIDC fields of the ID tables. In fact, the RXIDA filter in the ID tables is shifted one bit to the left from the RxMBs ID position, as shown below:

RxMB ID = bits 28-0 of ID word corresponding to message ID bits 28-0 RXIDA = bits 29-1 of ID Table corresponding to message ID bits 28-0

Note that the mask bits align to the ID filter bits, not to the incoming ID bits. For example, the bit 4 in RXGMASK masks bit 4 in RxMB ID, but it does not mask bit 4 in incoming message ID. This misalignment leads the RXGMASK to affect RxMB and Rx FIFO filtering in different ways.

For example, if the user intends to mask out bit 4 of the ID filter of message buffer then the RXGMASK will be configured as 0xffff\_ffef. As a result, bit 4 of the ID field of the incoming message is ignored during the filtering process for message buffers. This very same configuration of RXGMASK, which would lead bit 4 of RXIDA to be "do not care" and thus bit 3 of the ID field of the incoming message would be ignored during the filtering process for the Rx FIFO.

Similarly, both RXIDB and RXIDC filters have multiple misalignments with regards to position of the ID field in the RxMBs, which can lead to erroneous masking during the filtering process for either Rx FIFO or MBs.

RX14MASK (Rx 14 Mask) and RX15MASK (Rx 15 Mask) have the same structure as the RXGMASK. This includes the misalignment problem between the position of the ID field in the RxMBs and in the RXIDA, RXIDB and RXIDC fields of the ID Tables.

#### **Projected Impact:**

Leading to mask misalignment between RxMB and Rx FIFO filtering.

#### Workaround:

It is recommended that one of the following actions be taken to avoid problems:

• Do not enable the RxFIFO. If CANx\_MCR[FEN]=0 then the Rx FIFO is disabled and thus the masks RXGMASK, RX14MASK and RX15MASK do not affect it.

#### ERR002360

- Enable Rx Individual Mask Registers. If the Backwards Compatibility Configuration bit in the FlexCAN Module Configuration Register (CANx\_MCR[BCC], bit 16) is set then the Rx Individual Mask Registers (RXIMR0-63) are enabled and thus the masks RXGMASK, RX14MASK and RX15MASK are not used.
- Do not use the masks RXGMASK, RX14MASK and RX15MASK (leave them in reset value which is 0xffff\_ffff) when CANx\_MCR[FEN]=1 and CANx\_MCR[BCC]=0. In this case, filtering processes for both RxMBs and Rx FIFO are not affected by those masks.
- Do not configure any MB as Rx (leave all MBs as either Tx or inactive) when CANx\_MCR[FEN]=1 and CANx\_MCR[BCC]=0. In this case, the masks RXGMASK, RX14MASK and RX15MASK can be used to affect ID tables without affecting filtering process for RxMBs.

#### **Projected Solution:**

#### 2765 EMI Clock: Switching to synchronous mode error

#### **Description:**

In order to switch the EMI clock from asynchronous to synchronous mode, both the xtal\_ref and the cpu\_ref must be active, even if both BYPASS\_CPU and BYPASS\_EMI are set in the HW\_CLKCTRL\_CLKSEQ register.

#### **Projected Impact:**

The i.MX28 locks up.

#### Workaround:

If cpu\_ref is inactive, then activate the cpu\_ref before attempting to switch to synchronous mode.

#### **Projected Solution:**

### 2858 USB controller may access a wrong address for the dTD (endpoint transfer descriptor) and then hangs

#### **Description:**

Currently, software checks the active bit in dTD to see whether it is finished. If the Active bit is 0, then software frees the allocated memory for the dTD.

The hardware sequence after all data of a dTD is transferred is as follows:

- 1. Update the dTD. This includes an AHB write access of three DWords. The active bit is cleared in the first DW write.
- 2. Update the qHead (this includes an AHB write access of three DWords).
- 3. Read the dTD again to check if software added a new dTD (this is a SINGLE AHB read). At the same time, send out an interrupt if needed.

After step 1, if software finds the Active bit is cleared, then the dTD memory space is freed and may be allocated for another thread's use. In step 3, hardware may get a wrong dTD.

This issue does not occur if some delay is added before freeing the dTD memory space.

This issue only occurs in USB INCR8 mode, because steps 1 and 2 have 6 SINGLE AHB transfers in INC8 mode, but only two burst AHB transfers in INCR mode.

This issue only occurs when the dTD list is used; because if only one dTD is used, the software only checks the Active bit after an interrupt is received (step 3). However, when the dTD list is used, the software may check the entire list after the interrupt for the first dTD is received, when the hardware has just finished the transfer of the second dTD.

Figure 1 illustrates this issue.



Figure 1. dTD Issue Sequence of Events

Chip Errata for the i.MX28, Rev. 3

#### 2858

#### **Projected Impact:**

USB Controller may hang if dTD is freed too quickly.

#### Workaround:

Postpone freeing the current dTD; free it when its next dTD can be freed, so the last completed dTD (followed by an ACTIVE dTD) is always freed when the next IOC irq comes.

#### **Projected Solution:**

### 2814 The DCDC converters unexpectedly turn on when 5 V is removed while the DCDC\_XFER bit is clear

#### **Description:**

If the DCDC\_XFER bit is clear, the DCDC converter should not automatically turn on when 5 V is removed. Instead, a power-down should occur if 5 V is removed, when DCDC\_XFER and ENABLE\_DCDC are zero.

#### **Projected Impact:**

DCDC converter input source may switch to DCDC\_BATT pin but no power source is present there. This may latch-up the DCDC converter circuit.

#### Workaround:

In order to power down the system properly when 5 V is removed, set PWDN\_5VBRNOUT bit in Register HW\_POWER\_5VCTRL.

#### **Projected Solution:**

No fix scheduled

#### 2814

#### 2811 Unreliability of VDD5V\_GT\_VDDIO functionality

#### **Description:**

Due to unreliability of the VDD5V\_GT\_VDDIO functionality, the power supply should never be configured to be used as the 5-V plug/unplug detection method.

#### **Projected Impact:**

VDD5V\_GT\_VDDIO output may not change to "0" (and VDD5V\_GT\_VDDIO\_IRQ may not be triggered) when 5 V is unplugged.

#### Workaround:

Use the VBUSVALID comparator for 5V plug/unplug detection. Actually, the VBUSVALID comparator is recommended in the reference manual, not VDD5V\_GT\_VDDIO.

The VBUSVALID\_5VDETECT bit in HW\_POWER\_5VCTRL should be set to "1" (it's default value) and never cleared. The detection threshold can be changed in the VBUSVALID\_TRSH bit field in HW\_POWER\_5VCTRL.

#### **Projected Solution:**

No silicon fix scheduled.

#### TKT131240

#### TKT131240 SSP0/1-SD/MMC/eMMC Boot: SSP\_SCK polarity setup issue in ROM

#### **Description:**

ROM incorrectly sets the polarity of the SSP SCK. According to the SD/eMMC specification, the data/cmd must output on the falling edge of the CLK signal, however, due to this issue the data/cmd outputs on the rising edge.

#### **Projected Impact:**

Silicon Revision 1.2: Write command error may occur when booting from the SD/MMC/eMMC on SSP0/SSP1 and result in boot failure.

Silicon Revision 1.3: The fix only impacts customers using the ROM I2C/SPI EEPROM patch. Customers must boot directly from SSP0 or SSP1 instead of booting from the I2C/SPI EEPROM patch.

#### Workaround:

If tISU at SD/MMC/eMMC input is violated and a write command error occurs during boot from SD/MMC/eMMC, a ROM patch of 1kByte size loaded from the EEPROM is required to fix this issue. Boot mode must then be set to [0001] for the EEPROM on I2C0 or [1000] for the EEPROM on SPI3. The patch executes from the EEPROM, patches the ROM SSP driver code, and switches boot to either SSP0 or SSP1. There are separate patch binaries to boot from SSP0 and SSP1.

#### **Projected Solution:**

Silicon Revision 1.2: No silicon fix.

If tISU at SD/MMC/eMMC input is violated and a write command error occurs during boot from SD/MMC/eMMC, a ROM patch of 1kByte size loaded from the EEPROM is required to fix this issue. Boot mode must be set to [0001] for the EEPROM on I2C0 or [1000] for the EEPROM on SPI3. The patch executes from the EEPROM, patches the ROM SSP driver code, and switches boot to either SSP0 or SSP1. There are separate patch binaries to boot from SSP0 and SSP1.

Silicon Revision 1.3: ROM code is updated to set the BF\_SSP\_CTRL1\_POLARITY register bit to resolve this issue.

# Setting the ENABLE\_DCDC bit in the HW\_POWER\_DCDC4P2 or HW\_POWER\_5VCTRL registers can result in false brownout Detection

#### **Description:**

When the ENABLE\_DCDC bit in HW\_POWER\_DCDC4P2 or HW\_POWER\_5V\_CTRL is set, a glitch is propagated through the brownout comparators. If the glitch is sufficiently large, it can cause a false brownout detection. The VDDD, VDDA, VDDIO, and VBUSVALID comparators are all susceptible to the glitch.

#### **Projected Impact:**

Can result in a false brownout detection.

#### Workaround:

The sequence below is needed to work around this issue prior to setting the ENABLE\_DCDC bit in HW\_POWER\_DCDC4P2:

- 1. Disable the power rail brownout interrupts (clear HW\_POWER\_CTRL VDDA, VDDD, VDDIO ENIRQ bits).
- 2. Set the HW\_POWER\_5VCTRL PWRUP\_VBUS\_CMPS bit.
- 3. Set the HW\_POWER\_5VCTRL VBUSVALID\_TRSH to 0x0 (2.9 V).
- 4. Set the HW\_POWER\_5VCTRL VBUSVALID\_5VDETECT bit to 1.
- 5. Disable VBUSDROOP status and interrupts (clear VDD5V\_DROOP\_IRQ).
- 6. Set the ENABLE\_DCDC bit in HW\_POWER\_DCDC4P2.
- 7. Wait 100 µs
- 8. Check VBUSVALID\_IRQ bit. If it is set, then set and clear the PWD\_CHARGE\_4P2 bit to repower on the 4P2 regulator because it is automatically shut off on a VBUSVALID false condition. It may be helpful to ramp up the CHARGE\_4P2\_ILIMIT value at this point to gradually draw power from 5 V rail. If HW\_POWER\_5VCTRL ENABLE\_DCDC is already set, the DCDC will draw current from VDD4P2 as soon as PWD\_CHARGE\_4P2 is cleared.
- 9. Clear VBUSDROOP, VBUSVALID, and the output rails IRQ bits as needed.
- 10. Restore the output rail ENIRQ bits, the VBUSVALID\_TRSH level, VBUSVALID\_5VDETECT value, ENIRQ\_VBUS\_VALID, and ENIRQ\_VDD5V\_DROOP to their original values.

The sequence below is needed to work-around this issue prior to setting the ENABLE\_DCDC bit in HW\_POWER\_5VCTRL and HW\_POWER\_DCDC4P2. Note that the below workaround assumes the usual requirements for setting the HW\_POWER\_5VCTRL ENABLE\_DCDC bit are met (that is, the hardware and/or software battery brownout protection mechanism is enabled to properly protect the system against the DCDC sourcing from the battery if the battery voltage is too low).

1. Disable the power rail brownout interrupts (clear HW\_POWER\_CTRL VDDA, VDDD, VDDIO ENIRQ bits).

- 2. Set the HW\_POWER\_5VCTRL PWRUP\_VBUS\_CMPS bit.
- 3. Set the HW\_POWER\_5VCTRL VBUSVALID\_TRSH to 0x0 (2.9 V).
- 4. Set the HW\_POWER\_5VCTRL VBUSVALID\_5VDETECT bit to 1.
- 5. Disable VBUSDROOP status and interrupts (clear VDD5V\_DROOP\_IRQ).
- 6. Set the ENABLE\_DCDC bit in HW\_POWER\_5VCTRL.
- 7. Wait 100 µs.
- 8. Check VBUSVALID\_IRQ bit. If it is set, and 5 V is present and the VDD4P2 rail was enabled, then repeat the sequence for enabling the 4P2 regulator and DCDC from VDD4P2. This bit indicates that the DCDC has tried to source from the battery, even if 4P2 sourcing is enabled. This is because a VBUSVALID false condition automatically disables the 4P2 regulator, so the DCDC then falls back to battery sourcing.
- 9. Clear VBUSDROOP, VBUSVALID, and the output rails IRQ bits as needed.
- 10. Restore the output rail ENIRQ bits, the VBUSVALID\_TRSH level, VBUSVALID\_5VDETECT value, ENIRQ\_VBUS\_VALID, and ENIRQ\_VDD5V\_DROOP to their original values.

#### **Projected Solution:**

No silicon fix scheduled.

#### TKT140334 ONFI 3.0 NAND boot-up issue

#### **Description:**

BA NAND devices are obsolete. However, i.MX28 ROM supports booting from BA NAND and uses code to identify the BA NAND device using the parameter page content. The parameter page content is not compatible with the regular ONFI NAND and ROM incorrectly interprets a regular ONFI NAND device as BA NAND device and will fail to boot.

#### **Conditions:**

Boot mode set to boot from GPMI boot mode.

#### **Projected Impact:**

System mounted with ONFI 3.0 NAND device will fail to boot-up.

#### Workaround:

Contact ONFI NAND vendor to supply NAND device with the "supports extended parameter page" bit set to "0", so that the i.MX28 boot ROM will not treat it as BA-NAND.

#### **Projected Solution:**

Fixed in i.MX 28 Silicon Revision 1.3 ROM. The fuse ENABLE\_LBA\_NAND\_ONLY is used to boot from BA NAND. This fuse must not be blown when booting from regular ONFI NAND devices.

For Silicon Revision 1.2: Contact ONFI NAND vendor to supply NAND device with the "supports extended parameter page" bit set to "0" so that the i.MX28 boot ROM will not treat it as BA-NAND.

### ERR006358 ENET: Write to Transmit Descriptor Active Register (ENET\_TDAR) is ignored

#### **Description:**

If the ready bit in the transmit buffer descriptor (TxBD[R]) is previously detected as not set during a prior frame transmission, then the ENET\_TDAR[TDAR] bit is cleared at a later time, even if additional TxBDs were added to the ring and the ENET\_TDAR[TDAR] bit is set. This results in frames not being transmitted until there is a 0-to-1 transition on ENET\_TDAR[TDAR].

#### **Projected Impact:**

Reduced ENET performance due to delayed servicing of interrupts.

#### Workaround:

Code can use the transmit frame interrupt flag (ENET\_EIR[TXF]) as a method to detect whether the ENET has completed transmission and the ENET\_TDAR[TDAR] has been cleared. If ENET\_TDAR[TDAR] is detected as cleared when packets are queued and waiting for transmit, then a write to the TDAR bit will restart TxBD processing.

#### **Projected Solution:**

### ERR011495 SSP: DDR read may be fail upon SFTRST when SSP\_SCK clock is running

#### **Description:**

Executing SFTRST when SSP\_SCK clock is running will reset the asynchronous FIFO in SSP. In some cases, the read address of asynchronous FIFO is incorrect after reset which causes missing read data in DDR mode. This does not affect read in SDR mode.

#### **Projected Impact:**

SSP DDR read may be fail.

#### Workaround:

Before executing SFTRST, software must ensure SSP\_SCK clock is off by confirming the following conditions:

1) DMA\_SM, MMC\_SM, and CMD\_SM are set to 0 in the SSP\_STATUS register.

2) CONT\_CLKING\_EN is set to 0 in SSP\_CM0 register.

#### **Projected Solution:**

#### 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.

While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

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, 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.

© 2012-2018 NXP B.V.

Document Number: IMX28CE Rev. 3 11/2018



## arm