# Sitara<sup>™</sup> AM335x ARM<sup>®</sup> Cortex<sup>™</sup>-A8 Microprocessors (MPUs) Silicon Revisions 2.1, 2.0, 1.0

# Silicon Errata



Literature Number: SPRZ360E October 2011–Revised April 2013



# **Contents**

| 1    | Introdu   | uction     |                                                                                       | . 3 |
|------|-----------|------------|---------------------------------------------------------------------------------------|-----|
|      | 1.1       | AM335x     | Device and Development Support Tool Nomenclature                                      | . 3 |
|      | 1.2       | Revision   | Identification                                                                        | . 4 |
| 2    | All Erra  | ata Listed | With Silicon Revision Number                                                          | 6   |
| 3    | Usage     | Notes an   | d Known Design Exceptions to Functional Specifications                                | 8   |
|      | 3.1       |            | lotes                                                                                 |     |
|      |           | 3.1.1      | LCD: Color Assignments of LCD_DATA Terminals                                          |     |
|      |           | 3.1.2      | DDR3: JEDEC Compliance for Maximum Self-Refresh Command Limit                         |     |
|      |           | 3.1.3      | Boot: USB Boot ROM Code Uses Default DATAPOLARITY                                     | . ( |
|      |           | 3.1.4      | Boot: Multiplexed Signals GPMC_WAIT0, GMII2_CRS, and RMII2_CRS_DV Cause NAND Boolssue |     |
|      |           | 3.1.5      | Pin Multiplexing: Valid IO Sets and Restrictions                                      | 10  |
|      |           | 3.1.6      | Boot: Multiplexed Signals GPMC_WAIT0 and GMII2_CRS Cause NAND Boot Issue              | 10  |
|      |           | 3.1.7      | OSC1: RTC_XTALIN Terminal Has an Internal Pull-up Resistor When OSC1 is Disabled      | 11  |
|      | 3.2       | Known D    | Design Exceptions to Functional Specifications                                        | 12  |
| Revi | sion Hist | tory       |                                                                                       | 32  |



# Sitara<sup>™</sup> AM335x ARM<sup>®</sup> Cortex<sup>™</sup>-A8 Microprocessors (MPUs) (Silicon Revision 2.1, 2.0, 1.0)

#### 1 Introduction

This document describes the known exceptions to the functional specifications for the Sitara<sup>™</sup> AM335x ARM® Cortex<sup>™</sup>-A8 Microprocessors (MPUs). [See the *Sitara AM335x ARM Cortex-A8 Microprocessors (MPUs)* data manual (literature number <u>SPRS717</u>).]

For additional information, see the latest version of the *Sitara AM335x ARM Cortex-A8 Microprocessors* (MPUs) Technical Reference Manual (literature number SPRUH73).

# 1.1 AM335x Device and Development Support Tool Nomenclature

To designate the stages in the product development cycle, TI assigns prefixes to the part numbers of all microprocessors (MPUs) and support tools. Each device has one of three prefixes: X, P, or null (no prefix) (for example, XAM3358ZCE). Texas Instruments recommends two of three possible prefix designators for its support tools: TMDX and TMDS. These prefixes represent evolutionary stages of product development from engineering prototypes (TMDX) through fully qualified production devices and tools (TMDS).

Device development evolutionary flow:

- **X** Experimental device that is not necessarily representative of the final device's electrical specifications and may not use production assembly flow.
- **P** Prototype device that is not necessarily the final silicon die and may not necessarily meet final electrical specifications.

**null** — Production version of the silicon die that is fully qualified.

Support tool development evolutionary flow:

**TMDX** — Development-support product that has not yet completed Texas Instruments internal qualification testing.

**TMDS** — Fully-qualified development-support product.

X and P devices and TMDX development-support tools are shipped against the following disclaimer:

"Developmental product is intended for internal evaluation purposes."

Production devices and TMDS development-support tools have been characterized fully, and the quality and reliability of the device have been demonstrated fully. Tl's standard warranty applies.

Predictions show that prototype devices (X or P) have a greater failure rate than the standard production devices. Texas Instruments recommends that these devices not be used in any production system because their expected end-use failure rate still is undefined. Only qualified production devices are to be used.

Sitara is a trademark of Texas Instruments.

Cortex is a trademark of ARM Ltd or its subsidiaries.

ARM is a registered trademark of ARM Ltd or its subsidiaries.

All other trademarks are the property of their respective owners.



Introduction www.ti.com

## 1.2 Revision Identification

The device revision can be determined by the symbols marked on the top of the package. Figure 1 provides an example of the AM335x device markings.



Figure 1. Example of Device Revision Codes for the AM335x Microprocessor

#### NOTES:

- (A) Non-qualified devices are marked with the letters "X" or "P" at the beginning of the device name, while qualified devices have a "blank" at the beginning of the device name.
- (B) The AM3352 and AM3359 devices shown in this device marking example are two of several valid part numbers for the AM335x family of devices.
- (C) The device revision code is the device revision (A, B, and so on).
- (D) YM denotes year and month.
- (E) LLLL denotes Lot Trace Code.
- (F) 962 is a generic family marking ID.
- (G) G1 denotes green, lead-free.
- (H) ZCE or ZCZ is the package designator.
- (I) S denotes Assembly Site Code.
- (J) On some "X" devices, the device speed may not be shown.



www.ti.com Introduction

Silicon revision is identified by a code marked on the package. The code is of the format AM3352x or AM3358x, where "x" denotes the silicon revision. Table 1 lists the information associated with each silicon revision for each device type. For more details on device nomenclature, see the device-specific data manual.

**Table 1. Production Device Revision Codes** 

| DEVICE REVISION CODE | SILICON REVISION | COMMENTS                |
|----------------------|------------------|-------------------------|
| (blank)              | 1.0              | Silicon revision is new |
| А                    | 2.0              | Silicon revision 2.0    |
| В                    | 2.1              | Silicon revision 2.1    |

Each silicon revision uses a specific revision of TI's ARM® Cortex™-A8 processor. The ARM Cortex-A8 processor variant and revision can be read from the Main ID Register. The DEVREV field (bits 31-28) of the Device\_ID register located at address 0x44E10600 provides a 4-bit binary value that represents the device revision. The ROM code revision can be read from address 2BFFCh. The ROM code version consists of two decimal numbers: major and minor. The major number is always 22, minor number counts ROM code version. The ROM code version is coded as hexadecimal readable values; for example, ROM version 22.02 is coded as 0000 2202h. Table 2 shows the ARM Cortex-A8 Variant and Revision, Device Revision, and ROM Code Revision values for each silicon revision of the device.

Table 2. Silicon Revision Variables

| SILICON<br>REVISION | ARM CORTEX-A8 VARIANT AND REVISION | DEVICE<br>REVISION | ROM<br>REVISION |
|---------------------|------------------------------------|--------------------|-----------------|
| 1.0                 | r3p2                               | 0000               | 22.02           |
| 2.0                 | r3p2                               | 0001               | 22.03           |
| 2.1                 | r3p2                               | 0010               | 22.03           |



## 2 All Errata Listed With Silicon Revision Number

Advisories are numbered in the order in which they were added to this document. Some advisory numbers may be moved to the next revision and others may have been removed because the design exception was fixed or documented in the device-specific data manual or peripheral user's guide. When items are moved or deleted, the remaining numbers remain the same and are not re-sequenced.

**Table 3. All Usage Notes** 

| NUMBER        | TITLE                                                                                   | SILICON REVISION AFFECTED |     |     |
|---------------|-----------------------------------------------------------------------------------------|---------------------------|-----|-----|
| NUMBER        | IIILE                                                                                   | 1.0                       | 2.0 | 2.1 |
| Section 3.1.1 | LCD: Color Assignments of LCD_DATA Terminals                                            | Χ                         | Х   | Х   |
| Section 3.1.2 | DDR3: JEDEC Compliance for Maximum Self-Refresh Command Limit                           | Х                         | Х   | Х   |
| Section 3.1.3 | Boot: USB Boot ROM Code Uses Default DATAPOLARITY                                       | Х                         | Х   | Х   |
| Section 3.1.4 | Boot: Multiplexed Signals GPMC_WAIT0, GMII2_CRS, and RMII2_CRS_DV Cause NAND Boot Issue | Х                         |     |     |
| Section 3.1.5 | Pin Multiplexing: Valid IO Sets and Restrictions                                        | Х                         | Х   | Х   |
| Section 3.1.6 | Boot: Multiplexed Signals GPMC_WAIT0 and GMII2_CRS Cause NAND Boot Issue                |                           | Х   | Х   |
| Section 3.1.7 | OSC1: RTC_XTALIN Terminal Has an Internal Pull-up Resistor When OSC1 is Disabled        | Х                         | Х   | х   |

**Table 4. All Design Exceptions to Functional Specifications** 

| NUMBER          | TITLE                                                                                                                            | SILICO | N REVISION AF | FECTED |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------|--------|---------------|--------|
| NUMBER          | IIILE                                                                                                                            | 1.0    | 2.0           | 2.1    |
| Advisory 1.0.1  | DDR2, DDR3, mDDR PHY: Control and Status Registers Configured for Write Only                                                     | Х      | х             | Х      |
| Advisory 1.0.2  | Debug Subsystem: EMU[4:2] Signals Are Not Available by Default After Reset                                                       | Х      | х             | Х      |
| Advisory 1.0.3  | Debug Subsystem: Internal Inputs Tied-off to the Wrong Value                                                                     | Х      | х             | Х      |
| Advisory 1.0.4  | PRU-ICSS: Clock Domain Crossing (CDC) Issue                                                                                      | Х      |               |        |
| Advisory 1.0.5  | RTC: 32.768-kHZ Clock is Gating Off                                                                                              | Х      |               |        |
| Advisory 1.0.6  | EXTINTn: Input Function of the EXTINTn Terminal is Inverted                                                                      | Х      |               |        |
| Advisory 1.0.7  | Boot: Ethernet Boot ROM Code PHY Link Speed Detection                                                                            | Χ      |               |        |
| Advisory 1.0.8  | Boot: Ethernet Boot ROM Code Sends an Incorrect Vendor Class Identifier in BOOTP Packet                                          | Х      |               |        |
| Advisory 1.0.9  | Ethernet Media Access Controller and Switch Subsystem:<br>C0_TX_PEND and C0_RX_PEND Interrupts Not Connected<br>to ARM Cortex-A8 | Х      |               |        |
| Advisory 1.0.10 | GMII_SEL Register: RGMII1_IDMODE and RGMII2_IDMODE Bits Reset to Non-supported Mode of Operation                                 | Х      |               |        |
| Advisory 1.0.11 | USB: Attached Non-compliant USB Device that Responds to Spurious Invalid Short Packet May Lock Up Bus                            | Х      |               |        |
| Advisory 1.0.12 | UART: Extra Assertion of FIFO Transmit DMA Request, UARTi_DMA_TX                                                                 | Х      | х             | Х      |
| Advisory 1.0.13 | USB: Data May be Lost When USB Subsystem is Operating in DMA Mode and More Than One Endpoint is Transferring Data                | Х      |               |        |
| Advisory 1.0.14 | GMII_SEL and CPSW Related Pad Control Registers:<br>Context of These Registers is Lost During Transitions of<br>PD_PER           | Х      |               |        |
| Advisory 1.0.15 | ARM Cortex-A8: OPP50 Operation on MPU Domain Not Supported                                                                       | Х      |               |        |



# Table 4. All Design Exceptions to Functional Specifications (continued)

| AU MADED        | TITLE                                                                                                                          | SILICON | N REVISION AF | FECTED |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------|---------|---------------|--------|
| NUMBER          | TITLE                                                                                                                          | 1.0     | 2.0           | 2.1    |
| Advisory 1.0.16 | RMII: 50-MHz RMII Reference Clock Output Does Not<br>Satisfy Clock Input Requirements of RMII Ethernet PHYs                    | Х       | х             | Х      |
| Advisory 1.0.17 | VDDS_DDR: High-Power Consumption During DeepSleep0                                                                             | Χ       |               |        |
| Advisory 1.0.18 | ROM: Ethernet Boot Code Does Not Change Default<br>Direction of RMII1 Reference Clock When Booting from<br>Ethernet Using RMII | Х       |               |        |
| Advisory 1.0.19 | DDR3: Fully-Automated Hardware READ and WRITE Leveling Not Supported                                                           | Х       | Х             | Х      |
| Advisory 1.0.20 | Boot: USB Boot ROM Code Overlapping Data in TXFIFO and RXFIFO                                                                  | Х       |               |        |
| Advisory 1.0.21 | SmartReflex: Limited Support Due to Issue Described in Advisory 1.0.15                                                         | Х       |               |        |
| Advisory 1.0.22 | EMIF: Dynamic Voltage Frequency Scaling (DVFS) is Not Supported                                                                | Х       | Х             | Х      |
| Advisory 1.0.23 | Ethernet Media Access Controller and Switch Subsystem:<br>Reset Isolation Feature is Not Supported                             | Х       | Х             | Х      |
| Advisory 1.0.24 | Boot: System Boot is Not Reliable if Reset is Asserted While Operating in OPP50                                                | Х       | Х             | Х      |
| Advisory 1.0.25 | Boot: System Boot Temporarily Stalls if an Attempt to Boot from Ethernet is Not Successful                                     | Х       | Х             | Х      |
| Advisory 1.0.26 | I2C: SDA and SCL Open-Drain Output Buffer Issue                                                                                | Х       | Х             |        |
| Advisory 1.0.27 | LCDC: LIDD DMA Mode Issue                                                                                                      | Х       | Х             | Х      |
| Advisory 1.0.28 | LCDC: Raster Mode, Hardware Auto Underflow Restart<br>Does Not Work                                                            | Х       | х             | Х      |
| Advisory 1.0.29 | Latch-up Performance: Latch-up Performance Limits for Silicon Revsions 1.0 and 2.0                                             | Х       | Х             |        |



# 3 Usage Notes and Known Design Exceptions to Functional Specifications

# 3.1 Usage Notes

This document contains Usage Notes. Usage Notes highlight and describe particular situations where the device's behavior may not match presumed or documented behavior. This may include behaviors that affect device performance or functional correctness. These notes may be incorporated into future documentation updates for the device (such as the device-specific data manual), and the behaviors they describe may or may not be altered in future device revisions.

#### 3.1.1 LCD: Color Assignments of LCD\_DATA Terminals

The blue and red color assignments to the LCD data pins are reversed when operating in RGB888 (24bpp) mode compared to RGB565 (16bpp) mode. In order to correctly display RGB888 data from the SGX, or any source formatted as RGB in memory, it is necessary to connect the LCD panel as shown in Figure 2. Using the LCD Controller with this connection scheme limits the use of RGB565 mode. Any data generated for the RGB565 mode requires the red and blue color data values be swapped in order to display the correct color.



24-bit panel

Figure 2. RGB888 Mode LCD Controller Output Pin Mapping (LCD\_DATA[23:0])

When operating the LCD Controller in RGB565 mode the LCD panel should be connected as shown in Figure 3. Using the LCD Controller with this connection scheme limits the use of RGB888 mode. Any data generated for the RGB888 mode requires the red and blue color data values be swapped in order to display the correct color.



24-bit panel

Figure 3. RGB565 Mode LCD Controller Output Pin Mapping (LCD DATA[23:0])

# 3.1.2 DDR3: JEDEC Compliance for Maximum Self-Refresh Command Limit

When using DDR3 EMIF Self-Refresh, it is possible to violate the maximum refresh command requirement specified in the JEDEC standard DDR3 SDRAM Specification (JESD79-3E, July 2010). This requirement states that the DDR3 EMIF controller should issue no more than 16 refresh commands within any 15.6-µs interval.

To avoid this requirement violation, when using the DDR3 EMIF and Self-Refresh (setting LP\_MODE = 0x2 field in the PMCR), the SR\_TIM value in the PMCR must to be programmed to a value greater than or equal to 0x9.



#### 3.1.3 Boot: USB Boot ROM Code Uses Default DATAPOLARITY

The AM335x USB PHYs supports a DATAPOLARITY feature that allows the data plus (DP) and data minus (DM) data signals to be swapped. This feature was added to simplify PCB layout.

In some cases, the DP and DM data signals may need to cross over each other to connect to the respective USB connector pins. Crossing these signals on the PCB may cause signal integrity issues if not implemented properly since they must be routed as high-speed differential transmission lines. The DATAPOLARITY feature in the USB PHYs can be used resolve this issue.

The DATAPOLARITY feature is controlled by DATAPOLARITY\_INV (bit 23) of the respective USB\_CTRL register.

The USB boot ROM code uses the default value for DATAPOLARITY\_INV when booting from USB. Therefore, the PCB must be designed to use the default DATAPOLARITY if the system must support USB boot.

# 3.1.4 Boot: Multiplexed Signals GPMC\_WAIT0, GMII2\_CRS, and RMII2\_CRS\_DV Cause NAND Boot Issue

The AM335x device multiplexes the GPMC\_WAIT0, GMII2\_CRS, and RMII2\_CRS\_DV signals on the same terminal. This causes a problem when the system must support NAND boot while an MII or RMII Ethernet PHY is connected to port 2 of the Ethernet media access controller and switch (CPSW). The GPMC\_WAIT0 signal is required for NAND boot. The GMII2\_CRS or RMII2\_CRS\_DV signal is required by the respective MII or RMII Ethernet PHY and the only pin multiplexing option for these signals is GPMC\_WAIT0.

In this case, there are two sources that need to be connected to the GPMC\_WAIT0 terminal. The NAND READY or BUSY output must source the GPMC\_WAIT0 terminal during NAND boot and the MII CRS or RMII CRS\_DV output must source the GPMC\_WAIT0 terminal when the application software is using port 2 of the CPSW. Therefore, a GPIO-controlled external 2-to-1 multiplexer must be implemented in the system to select between the two sources. The GPIO selected to control the 2-to-1 multiplexer needs to have an internal or external resistor that selects the NAND READY or BUSY output as soon as power is applied and remains in that state until the application software initializes the CPSW.

The TI TS5A3157 SPDT analog switch is an example device that can be used as a 2-to-1 multiplexer. This device inserts minimum propagation delay to the signal path since it is an analog switch. The propagation delay inserted by the 2-to-1 multiplexer must be analyzed to confirm it does not cause timing violations for the respective interface.

The NAND, Ethernet PHY, AM335x VDDSHV1, AM335x VDDSHV3 (when using the ZCZ package), and 2-to-1 multiplexer IO power supply domains may need to operate at the same voltage since they share common signals.



# 3.1.5 Pin Multiplexing: Valid IO Sets and Restrictions

The AM335x device contains many peripheral interfaces. In order to reduce package size and lower overall system cost while maintaining maximum functionality, many of the AM335x terminals can multiplex up to eight signal functions. Although there are many combinations of pin multiplexing that are possible, only a certain number of sets, called IO Sets, are valid due to timing limitations. These valid IO Sets were carefully chosen to provide many possible application scenarios for the user.

Texas Instruments has developed a Windows®-based application called Pin Mux Utility that helps a system designer select the appropriate pin-multiplexing configuration for their AM335x-based product design. The Pin Mux Utility provides a way to select valid IO Sets of specific peripheral interfaces to ensure the pin multiplexing configuration selected for a design only uses valid IO Sets supported by the AM335x device.

A few IO Sets have additional restrictions not defined in the Pin Mux Utility. These additional restrictions are described below:

- MMC0, MMC1, MMC2 Interfaces
  - Only Standard (STD) and High Speed (HS) modes are supported. SDR12, SDR25, SDR50 modes as defined in SD3.0 specification are not supported.
- GEMAC CPSW Interface
  - Operation of GEMAC\_CPSW is not supported for OPP50.

# 3.1.6 Boot: Multiplexed Signals GPMC\_WAIT0 and GMII2\_CRS Cause NAND Boot Issue

The AM335x device multiplexes the GPMC\_WAIT0 and GMII2\_CRS signals on the same terminal. This causes a problem when the system must support NAND boot while an MII Ethernet PHY is connected to port 2 of the Ethernet media access controller and switch (CPSW). The GPMC\_WAIT0 signal is required for NAND boot. The GMII2\_CRS signal is required by the MII Ethernet PHY and the only pin multiplexing option for these signals is GPMC\_WAIT0.

In this case, there are two sources that need to be connected to the GPMC\_WAIT0 terminal. The NAND READY or BUSY output must source the GPMC\_WAIT0 terminal during NAND boot and the MII CRS output must source the GPMC\_WAIT0 terminal when the application software is using port 2 of the CPSW. Therefore, a GPIO-controlled external 2-to-1 multiplexer must be implemented in the system to select between the two sources. The GPIO selected to control the 2-to-1 multiplexer needs to have an internal or external resistor that selects the NAND READY or BUSY output as soon as power is applied and remains in that state until the application software initializes the CPSW.

The TI TS5A3157 SPDT analog switch is an example device that can be used as a 2-to-1 multiplexer. This device inserts minimum propagation delay to the signal path since it is an analog switch. The propagation delay inserted by the 2-to-1 multiplexer must be analyzed to confirm it does not cause timing violations for the respective interface.

The NAND, Ethernet PHY, AM335x VDDSHV1, AM335x VDDSHV3 (when using the ZCZ package), and 2-to-1 multiplexer IO power supply domains may need to operate at the same voltage since they share common signals.



#### 3.1.7 OSC1: RTC XTALIN Terminal Has an Internal Pull-up Resistor When OSC1 is Disabled

The RTC\_XTALIN terminal has an internal pull-up resistor that is turned on when OSC1 is disabled. OSC1 is disabled by default after power is applied.

This internal pull-up resistor was not properly documented in data sheet revisions D and earlier. These early data sheet revisions recommended an external pull-down resistor to be connected to the RTC\_XTALIN terminal if OSC1 was not used. The recommendation should have been to leave this terminal open-circuit when not using OSC1.

Connecting an external pull-down to the RTC\_XTALIN terminal may cause unexpected leakage current.

The current recommendation is to remove any external pull-down resistor from the RTC\_XTALIN terminal and leave this terminal open-circuit when not using OSC1.



# 3.2 Known Design Exceptions to Functional Specifications

The following advisories are known design exceptions to functional specifications. Advisories are numbered in the order in which they were added to this document. Some advisory numbers may be moved to the next revision and others may have been removed because the design exception was fixed or documented in the device-specific data manual or peripheral user's guide. When items are moved or deleted, the remaining numbers remain the same and are not re-sequenced.

Advisory 1.0.1 DDR2, DDR3, mDDR PHY: Control and Status Registers Configured for Write Only

Revisions Affected 2.1, 2.0, 1.0

Details The DDR2, DDR3, mDDR PHY control and status registers mapped in address range

0x44e12000-0x44E123FF are configured for write-only operations, so the contents of

these register cannot be read.

These registers must be configured by performing write-only operations.

**Workarounds** There is no workaround for this issue.

Advisory 1.0.2 Debug Subsystem: EMU[4:2] Signals Are Not Available by Default After Reset

Revisions Affected 2.1, 2.0, 1.0

**Details** All Debug subsystem components should remain unchanged when warm reset is

asserted. For example, warm reset should not affect export of debug trace messages on

the EMU[4:0] signals.

The AM335x EMU[4:2] signals can not be used to export trace messages from the Debug subsystem since AM335x does support warm reset and the EMU[4:2] signals are

not assigned to pins after reset is asserted.

**Workarounds** Do not assert warm reset while performing trace functions.

Advisory 1.0.3 Debug Subsystem: Internal Inputs Tied-off to the Wrong Value

Revisions Affected 2.1, 2.0, 1.0

Details Internal inputs dbg\_dpio\_attr\_dp\_app\_owner[4:0] and dbg\_dpio\_attr\_dp\_debug\_only[4:0] to the Debug subsystem are used to report which EMU[4:0] signals can currently be

used to export trace messages. These inputs were tied-off to the wrong value. The tie-off values used always indicates EMU[4:2] signals are not available and EMU[1:0] signals

are available to export trace messages.

This should not cause a problem for EMU[4:2] since these signals can not be used to export trace messages for the reason explained in advisory 1.3. However, the AM335x pins used for EMU[1:0] signals may be configured as GPIO. The Debug subsystem would not know these signals are not available for exporting trace messages when these

pins are configured as GPIO.

Workarounds Do not configure the AM335x EMU[1:0] pins to operate as GPIO if you need to export

trace messages.



# Advisory 1.0.4 PRU-ICSS: Clock Domain Crossing (CDC) Issue

**Revisions Affected** 

1.0

**Details** 

The PRU-ICSS has a clock domain crossing issue when the MII receive multiplexer is configured to connect PR1\_MII1 signals to PRU0 and PR1\_MII0 signals to PRU1.

The multiplexer logic always uses the PR1\_MII\_MR0\_CLK input to synchronize the PRU0 MII receive signals and the PR1\_MII\_MR1\_CLK input to synchronize the PRU1 MII receive signals. This cause the wrong clock to be used when the MII receive multiplexer is configured to connect PR1\_MII1 signals to PRU0 and PR1\_MII0 signals to PRU1.

As a result of this issue, support for EtherCAT media redundancy is not available.

Workarounds

There is no workaround for this issue.

# Advisory 1.0.5

#### RTC: 32.768-kHZ Clock is Gating Off

#### **Revisions Affected**

1.0

#### **Details**

The RTC has a clock gating issue that stops the internal 32.768-kHz clock when the VDD\_CORE voltage domain drops below the recommended operating range or the PWRONRSTn input terminal is held low. This issue has the following side effects:

- The RTC counters stop incrementing when the 32.768-kHz clock is gated. This causes the RTC to lose time while the clock is gated.
- A wakeup event applied to the EXT\_WAKEUP input terminal is masked if the EXT\_WAKEUP\_DB\_EN bit in the RTC PMIC register (0x98) is set to 1 which enables the de-bounce function for the EXT\_WAKEUP input. This occurs because the 32.768-kHz clock is being used to clock the de-bounce circuit.

#### Workarounds

Do not turn off the VDD\_CORE power source or source a logic low to the PWRONRSTn input while expecting RTC to keep an accurate time.

Do not enable the de-bounce circuit on the EXT\_WAKEUP input if an external wakeup event needs to be detected while the 32.768-kHz clock is gated.

# Advisory 1.0.6

#### EXTINTn: Input Function of the EXTINTn Terminal is Inverted

**Revisions Affected** 

1.0

**Details** 

The EXTINTn input is active high.

Workarounds

Use an active high interrupt source or use an external inverter to change the polarity of any active low interrupt source.



# Advisory 1.0.7 Boot: Ethernet Boot ROM Code PHY Link Speed Detection

**Revisions Affected** 

1.0

**Details** 

The device ROM code relies on the external PHY's Control Register (Register 0), specifically bits 0.6 [Speed Selection (MSB)] and 0.13 [Speed Selection (LSB)], to determine the operating speed of the link.

If the external PHY does not update its link speed selection bits to reflect the current operating speed, the ROM code incorrectly assumes the PHY is operating at the speed indicated by the link speed selection bits and configure the device Ethernet MAC to the wrong speed. For example, if the default value of the PHY link speed selection bits indicates 100 Mbps, when the PHY is actually operating at 1 Gbps, the ROM incorrectly configures the device Ethernet MAC for 100 Mbps mode.

The IEEE 802.3 specification states: When the Auto-Negotiation Enable (bit 0.12) is enabled, bits 0.6 and 0.13 can be read or written to, but the state of bits 0.6 and 0.13 have no effect on the link configuration, and it is not necessary for bits 0.6 and 0.13 to reflect the operating speed of the link when it is read. While some PHYs update the link speed in these bits to reflect the current operating speed, other PHYs do not update these bits because it is not mandatory according to the specification.

Workarounds

When using Ethernet boot, an external PHY that updates the Register 0 link speed selection bits (0.6 and 0.13) to reflect the current operating speed is required.

#### Advisory 1.0.8

Boot: Ethernet Boot ROM Code Sends an Incorrect Vendor Class Identifier in BOOTP Packet

**Revisions Affected:** 

1.0

**Details:** 

When using Ethernet boot, the device ROM code should send a BOOTP request with a unique identifier to distinguish itself from other devices on the same network. Instead, the ROM code sends the same identifier, "DM814x ROM v1.0", for all devices (DM814x, DM816x, and AM335x); hence, the download host attempting to bootstrap the devices can no longer determine which device is requesting the code to be downloaded.

Applications using the DM814x, DM816x, and AM335x devices cannot coexist in the same network if they are booted from Ethernet.

Workaround:

There is no workaround for this issue.

For some applications, it might be necessary to uniquely identify and service BOOTP packets from a client. The recommended approach to uniquely identify clients is to use the MAC address. Every device comes with a unique MAC address. A list of MAC addresses and the device type can be made available to the host in advance, so that the host can take device-specific action when it receives a BOOTP packet from a MAC address on the host's list.



# Ethernet Media Access Controller and Switch Subsystem: C0\_TX\_PEND and C0\_RX\_PEND Interrupts Not Connected to ARM Cortex-A8

#### **Revisions Affected**

1.0

#### **Details**

The Ethernet Media Access Controller/Switch (CPSW) subsystem C0\_TX\_PEND and C0\_RX\_PEND interrupt outputs provide a single transmit interrupt that combines transmit channel interrupts TXPEND[7:0] and a single receive interrupt that combines receive channel interrupts RXPEND[7:0]. The TXPEND[0] and RXPEND[0] interrupt outputs are connected to the ARM Cortex-A8 interrupt controller (INTC) rather than the C0\_TX\_PEND and C0\_RX\_PEND interrupt outputs. This only allows channel 0 to interrupt the ARM Cortex-A8.

The C0\_TX\_PEND and C0\_RX\_PEND interrupt outputs are the only interrupt outputs that support interrupt pacing. If transmit channel interrupts 1-7, receive channel interrupts 1-7, or interrupt pacing is required, the following workaround must be implemented.

#### Workarounds

#### **DMTIMER Workaround**

The C0\_TX\_PEND and C0\_RX\_PEND interrupts can be re-routed to the ARM Cortex-A8 through two of the AM335x timers. TIMER5 and TIMER6 can be used when configured to operate in capture mode. The time captured while operating in this mode is not relevant, since the capture event notification to the ARM Cortex-A8 represents the original causal interrupts coming from the EMAC and Switch subsystem.

The re-routed interrupts path are:

- ARM Cortex-A8: TINT5 (interrupt 93) <-- TIMER5 Capture Event <-- [Event Capture Mux: event 8] <-- EMAC and Switch: C0\_RX\_PEND</li>
- ARM Cortex-A8: TINT6 (interrupt 94) <-- TIMER6 Capture Event <-- [Event Capture Mux: event 9] <-- EMAC and Switch: C0\_TX\_PEND</li>

#### Configuration

The following configurations are required to use timer capture module interrupts:

- TIMER5 and TIMER6 are enabled with capture mode during initialization.
  - Set bit 2 of the TIMER5 IRQENABLE set register located at 0x4804 602C to 1b.
  - Set bit 2 of the TIMER6 IRQENABLE set register located at 0x4804\_802C to 1b.
- Write the value 0x908 to the TIMER\_EVT\_CAPT register located at 0x44E1\_0FD0 to select EMAC and Switch event 8 (C0\_RX\_PEND) for TIMER 5 and EMAC and Switch event 9 (C0\_TX\_PEND) for TIMER6.
- Configure TIMER5 and TIMER6 to single-capture mode by resetting the CAPT MODE bit of each TCLR register.
  - Reset bit 13 of the TIMER5 TCLR register located at 0x4804\_6038 to 0b.
  - Reset bit 13 of the TIMER6 TCLR register located at 0x4804\_8038 to 0b.
- Select rising-edge transition by setting the TCM bit of the TCLR register.
  - Set bit 8 of the TIMER5 TCLR register located at 0x4804\_6038 to 1b.
  - Set bit 8 of the TIMER6 TCLR register located at 0x4804\_8038 to 1b.
- Use ARM Cortex-A8 interrupt 93 for C0\_RX\_PEND and interrupt 94 for C0\_TX\_PEND instead of interrupts 41 and 42.

#### Interrupt Servicing

The following is the recommended procedure for servicing interrupts. This method clears and re-enables the interrupts properly to ensure no interrupts are missed by the DMTimer edge detection logic. This procedure applies for both receive and transmit interrupts.

 Clear the timer capture interrupt by writing 1 to the TCAR\_IT\_FLAG bit of the respective IRQSTATUS register.



- Clear the TIMER5 interrupt by setting bit 2 of the TIMER5 IRQSTATUS register located at 0x4804 6028 to 1b.
- Clear the TIMER6 interrupt by setting bit 2 of the TIMER6 IRQSTATUS register located at 0x4804\_8028 to 1b.
- Disable all CPSW interrupts by clearing the C0\_xx\_EN field in the respective C0\_RX\_EN/C0\_TX\_EN register.
- Acknowledge the interrupt by writing the appropriate RX or TX vector to the CPDMA\_EOI\_VECTOR register.
- Process all received or transmitted packets.
- Enable the desired CPSW interrupts in the C0\_xx\_EN field in the respective C0\_RX\_EN/C0\_TX\_EN register.



GMII\_SEL Register: RGMII1\_IDMODE and RGMII2\_IDMODE Bits Reset to Nonsupported Mode of Operation

**Revisions Affected** 

1.0

**Details** 

The reset state of RGMII1\_IDMODE (bit 4) and RGMII2\_IDMODE (bit 5) in the GMII\_SEL register enables internal delay mode on the transmit clock of the respective RGMII port. The AM335x device does not support internal delay mode, so RGMII1\_IDMODE and RGMII2\_IDMODE must be set to 1b.

Workarounds

Many RGMII Ethernet PHYs provide an internal delay mode that may be enabled to insert delays required to meet the setup and hold timing requirements of the AM335x device and attached RGMII PHY. A timing analysis is recommended before the printed circuit board (PCB) design has been completed, in case it is necessary to insert additional delays on the RGMII signals connecting the AM335x device and attached RGMII PHY.

It is necessary to insert PCB delays if the RGMII PHY being connected to the AM335x device does not support internal delay mode. A complete timing analysis is required to determine the optimum delay of each PCB signal trace.



# USB: Attached Non-compliant USB Device that Responds to Spurious Invalid Short Packet May Lock Up Bus

#### **Revisions Affected**

1.0

#### **Details**

The integrated USB PHY (analog transceiver) has a timing error that turns on its receiver too early and occasionally detects the end of its own transmit data as receive data. This causes the USB controller to transmit an invalid short packet. Normally this invalid short packet would be ignored by the attached USB device and the data transmission would continue as expected.

At least one mass storage class USB device has been found to be non-compliant to the USB specification, by responding to this packet. This non-compliant response (NACK) to the invalid short packet violates USB protocol and causes the bus to hang.

Poor signal integrity of the differential signal pair used to connect the attached USB device may contribute to this issue. Impedance discontinuities and mismatched terminations on the differential signal pair may cause reflections to propagate longer than expected, which allows the transceiver to detect these reflections of its own transmit data as receive data.

#### Workarounds

There is no workaround for this issue.

To prevent an unexpected response to any invalid short packets, attach only USB devices that are compliant with the USB specification.

To minimize reflections, it is also recommended that the USB DP and DM signals are routed as a  $90-\Omega$  differential pair transmission line with minimum impedance discontinuities and proper terminations.

#### Advisory 1.0.12

#### UART: Extra Assertion of FIFO Transmit DMA Request, UARTi\_DMA\_TX

#### **Revisions Affected**

2.1, 2.0, 1.0

**Details** 

A UART transmit request with a DMA THRESHOLD default configuration of 64 bytes results in an extra DMA request assertion when the FIFO TX\_FULL is switched from high to low.

#### Workarounds

To avoid an extra DMA request assertion, use:

TX THRESHOLD + TRIGGER LEVEL ≤ 63 (TX FIFO Size - 1).



USB: Data May be Lost When USB Subsystem is Operating in DMA Mode and More Than One Endpoint is Transferring Data

#### **Revisions Affected**

1.0

#### **Details**

Data loss may occur due to a USB data toggle synchronization error that occurs when an internal data toggle counter is erroneously reset from the DATA1 state to the DATA0 state while the USB subsystem is actively receiving data from more than one endpoint. The erroneous reset of the data toggle counter occurs because the associated logic in the USB subsystem DMA contains an error that does not support the correct data toggle update with data transfers from multiple endpoints.

If the DATA1 state is erroneously reset to the DATA0 state immediately following a USB transaction in which the PID is DATA0, the transmitter and receiver become desynchronized. This data toggle synchronization error causes the receiver, per the USB specification, to silently discard the non-synchronized packet, which causes the packet and any data contain therein to be lost.

NOTE: For more information related to the definition of DATA0 and DATA1 PIDs and functional requirements of data toggle synchronization, see sections 8.4.4 and 8.6 of the Universal Serial Bus Specification Revision 2.0.

#### Workarounds

- Operating in USB host mode The workaround involves detecting and correcting the data toggle mismatch by software after receiving each USB packet. In order to implement this workaround, the CPPI4.1 DMA must be configured to operate in transparent mode; generic RNDIS mode cannot be used. Software must save the previous data toggle value then compare the current data toggle value and the saved value to detect a data toggle mismatch. If a synchronization error is detected, it must be corrected by simultaneously writing 1b to the data toggle write enable and data toggle bits in the respective RxCSR registers.
- Operating in USB device mode There is no workaround for this mode of operation.



GMII\_SEL and CPSW Related Pad Control Registers: Context of These Registers is Lost During Transitions of PD\_PER

**Revisions Affected** 

1.0

**Details** 

The GMII\_SEL and CPSW related pad control registers listed below are reset to their default state during transitions of peripheral power domain (PD\_PER) while the ISO\_CONTROL bit in the RESET\_ISO register is set to its default value (0b). This occurs when the AM335x device enters or exits DeepSleep0.

| REGISTER NAME      | REGISTER ADDRESS |
|--------------------|------------------|
| GMII_SEL           | 0x44E1_0650      |
| CONF_GPMC_A0       | 0x44E1_0840      |
| CONF_GPMC_A1       | 0x44E1_0844      |
| CONF_GPMC_A2       | 0x44E1_0848      |
| CONF_GPMC_A3       | 0x44E1_084C      |
| CONF_GPMC_A4       | 0x44E1_0850      |
| CONF_GPMC_A5       | 0x44E1_0854      |
| CONF_GPMC_A6       | 0x44E1_0858      |
| CONF_GPMC_A7       | 0x44E1_085C      |
| CONF_GPMC_A8       | 0x44E1_0860      |
| CONF_GPMC_A9       | 0x44E1_0864      |
| CONF_GPMC_A10      | 0x44E1_0868      |
| CONF_GPMC_A11      | 0x44E1_086C      |
| CONF_GPMC_WAIT0    | 0x44E1_0870      |
| CONF_GPMC_WPN      | 0x44E1_0874      |
| CONF_GPMC_BEN1     | 0x44E1_0878      |
| CONF_MII1_COL      | 0x44E1_0908      |
| CONF_MII1_CRS      | 0x44E1_090C      |
| CONF_MII1_RX_ER    | 0x44E1_0910      |
| CONF_MII1_TX_EN    | 0x44E1_0914      |
| CONF_MII1_RX_DV    | 0x44E1_0918      |
| CONF_MII1_TXD3     | 0x44E1_091C      |
| CONF_MII1_TXD2     | 0x44E1_0920      |
| CONF_MII1_TXD1     | 0x44E1_0924      |
| CONF_MII1_TXD0     | 0x44E1_0928      |
| CONF_MII1_TX_CLK   | 0x44E1_092C      |
| CONF_MII1_RX_CLK   | 0x44E1_0930      |
| CONF_MII1_RXD3     | 0x44E1_0934      |
| CONF_MII1_RXD2     | 0x44E1_0938      |
| CONF_MII1_RXD1     | 0x44E1_093C      |
| CONF_MII1_RXD0     | 0x44E1_0940      |
| CONF_RMII1_REF_CLK | 0x44E1_0944      |
| CONF_MDIO          | 0x44E1_0948      |
| CONF_MDC           | 0x44E1_094C      |

Workarounds

Re-initialize these registers after exiting DeepSleep0.



# Advisory 1.0.15 ARM Cortex-A8: OPP50 Operation on MPU Domain Not Supported

Revisions Affected 1.0

Details Reliability tests have shown that a logic cell used in the ARM Cortex-A8 exhibits

weakness during low-voltage operation as defined by OPP50. This eliminates support for operating the ARM Cortex-A8 at the lower voltage defined by OPP50. Therefore, the minimum voltage limit for the ARM Cortex-A8 power terminals (VDD\_MPU on the ZCZ package and VDD\_CORE on the ZCE package) is the minimum voltage limit defined by

OPP100.

Workarounds To minimize power consumption, the ARM Cortex-A8 may be operated at the lower

frequencies defined by OPP50, but the respective power terminal (VDD\_MPU for ZCZ package and VDD\_CORE for ZCE package) must be operated as defined by OPP100. Table 5 below provides register settings for operating the MPU PLL at 275 MHz for each

supported input clock frequency.

Table 5. MPU PLL

| CLK_M_OSC<br>(MHz) | N<br>CM_CLKSEL_DPLL_MPU[6:0] | REFCLK<br>(MHz) | M<br>CM_CLKSEL_DPLL_MPU[18:8] | M2<br>CM_DIV_M2_DPLL_MPU[4:0] | CLKOUT<br>(MHz) |
|--------------------|------------------------------|-----------------|-------------------------------|-------------------------------|-----------------|
| 19.2               | 95                           | 0.2             | 1375                          | 1                             | 275             |
| 24                 | 23                           | 1               | 275                           | 1                             | 275             |
| 25                 | 24                           | 1               | 275                           | 1                             | 275             |
| 26                 | 25                           | 1               | 275                           | 1                             | 275             |

Advisory 1.0.16 RMII: 50-MHz RMII Reference Clock Output Does Not Satisfy Clock Input Requirements of RMII Ethernet PHYs

Revisions Affected 2.1, 2.0, 1.0

Details The 50-MHz RMII reference clock output is sourced from the ADPLLS CORE PLL which

is not a low-jitter clock source. Therefore, the clock jitter of this output is greater than the

input requirements for most RMII Ethernet PHYs.

Workarounds Configure the respective RMII reference clock to input mode and use an external low-

jitter LVCMOS clock source or RMII Ethernet PHY with a clock output to source the RMII

reference clock.

RMII1\_REFCLK can be configured to input mode by setting bit 6 of the GMII\_SEL register to 1b. RMII2\_REFCLK can be configured to input mode by setting bit 7 of the

GMII\_SEL register to 1b.



# Advisory 1.0.17 VDDS\_DDR: High-Power Consumption During DeepSleep0

Revisions Affected

1.0

**Details** 

The REG\_PHY\_ENABLE\_DYNAMIC PWRDN bit in the DDR\_PHY\_CTRL\_1 register provides control for powering down the SSTL and HSTL input buffers to achieve lower power consumption from the VDDS\_DDR power source. This register is reset to its default value during DeepSleep0 which prevents powering down the DDR SSTL and HSTL input buffers which causes higher power consumption during DeepSleep0.

Workarounds

Input buffers associated with the bi-directional DDR terminals can be configured to operate as SSTL and HSTL or LVCMOS inputs. Low-power consumption can be achieved during DeepSleep0 by configuring the input buffers to operate in LVCMOS mode and enabling internal pull-downs on each of the bi-directional DDR terminals before entering DeepSleep0. Power consumption from the VDDS\_DDR power source of this solution is similar to powering down the DDR SSTL and HSTL input buffers.

The DDR PHY can be configured to operate in LVCMOS mode by setting the MDDR SEL bit in the DDR IO CTRL register to 1b.

The internal pull-downs are configured by writing

the DDR\_DATA0\_IOCTRL and DDR\_DATA1\_IOCTRL registers.

Advisory 1.0.18

ROM: Ethernet Boot Code Does Not Change Default Direction of RMII1 Reference Clock When Booting from Ethernet Using RMII

**Revisions Affected** 

1.0

**Details** 

The default direction of the RMII1 reference clock is output mode. This mode of operation is not supported, as described in Advisory 1.0.16.

When the SYSBOOT[7:6] boot mode inputs are set to 01b, which selects RMII mode, the RMII1\_REF\_CLK terminal is configured to operate in the non-supported output mode as soon as the ROM code changes the MUXMODE bits of the CONF\_RMII1\_REF\_CLK register from the default state of GPIO0\_29 (111b) to RMII1\_REFCLK (000b).

This causes contention on the RMII1 reference clock signal if the ROM code attempts to boot from RMII since the only RMII mode of operation supported requires the RMII1\_REF\_CLK terminal to be driven by an external 50-MHz RMII reference clock source. Therefore, the ROM code must never be configured such that it attempts to boot from RMII.

Workarounds

Use MII if Ethernet boot is required.



# DDR3: Fully-Automated Hardware READ and WRITE Leveling Not Supported

#### **Revisions Affected**

2.1, 2.0, 1.0

#### **Details**

DDR3-based systems use a "fly-by" layout routing scheme where the address, clock, and control signals are connected to multiple memory devices using a daisy-chain topology, as opposed to DDR2-based systems which connect multiple devices using a balanced T-topology. The "fly-by" routing scheme introduces skew in the arrival time of the DDR signals to each memory device. DDR3 memories and DDR3 memory controller provide hardware assisted training that optimizes timing for each data byte lane. This is commonly referred to as READ and WRITE leveling. The objective of the READ and WRITE leveling is to obtain correct values of the DLL ratios to compensate for the skew and is done automatically during the initialization process.

The DDR3 controller does not reliably arrive at the optimal DLL ratios during the automatic training process. Therefore, the automated hardware READ and WRITE leveling is not supported.

#### Workarounds

Use the software-leveling procedure outlined below to obtain optimal DLL ratios that compensate READ and WRITE timing:

- Disable automated hardware READ and WRITE leveling by setting the REG\_RDWRLVL\_EN bit in the RDWR\_LVL\_RMP\_CTRL register to 0b.
- Configure all EMIF4D registers, including AC timing values, as required for the attached DDR3 memory device.
- Determine the initial seed DLL ratio values to be used in the software-leveling algorithm. These values are based on board trace lengths of DDR\_CK(n) and DDR\_DQS(n).
- 4. Run the software-leveling algorithm with the initial seed DLL ratio values. The algorithm iterates several times to find the optimum values for the given configuration.
- 5. The software-leveling algorithm determines the optimum values for the following registers in the DDR controller. Use the optimum values obtained from the program when initializing the DDR controller.
  - DATA PHY RD DQS SLAVE RATIO
  - DATA\_PHY\_FIFO\_WE\_SLAVE\_RATIO
  - DATA\_PHY\_WR\_DQS\_SLAVE\_RATIO
  - DATA PHY WR DATA SLAVE RATIO

This procedure is only required once for a given combination of DDR3 memory devices, DDR3 operating frequency, and printed circuit board layout. If there are any changes to memory devices, operating frequency, or printed circuit board layout, the procedure outlined above must be re-run.



Advisory 1.0.20 Boot: USB Boot ROM Code Overlapping Data in TXFIFO and RXFIFO

Revisions Affected 1.0

**Details** The USB boot ROM code is overlapping data in the TXFIFO and RXFIFO which leads to

data corruption. This data corruption causes a data abort and prevents USB boot from

working.

**Workarounds** There is no workaround for this issue.

Advisory 1.0.21 SmartReflex: Limited Support Due to Issue Described in Advisory 1.0.15

Revisions Affected 1.0

**Details** SmartReflex is not supported on the VDD\_MPU power domain of the ZCZ package

when configured for OPP100 because SmartReflex may reduce the VDD\_MPU voltage to OPP50 levels. Advisory 1.0.15 describes why operating the ARM Cortex-A8 at the lower voltage defined by OPP50 is not supported. For more details related to this issue,

see Advisory 1.0.15.

SmartReflex is not supported on the ZCE package.

SmartReflex is supported on the ZCZ package for the following power domain and OPP

combinations:

VDD\_CORE configured for OPP100.

• VDD\_MPU configured for any valid OPP greater than OPP100.

**Workarounds** There is no workaround for this issue.



Advisory 1.0.22 EMIF: Dynamic Voltage Frequency Scaling (DVFS) is Not Supported

Revisions Affected 2.1, 2.0, 1.0

Details The L3 Interconnect and EMIF internal hookup does not allow changing the EMIF

operating frequency while OCP transactions are pending. This prevents dynamic switching from OPP100 to OPP50 or from OPP50 to OPP100. The application software

must initialize a static OPP50 or OPP100 configuration before enabling EMIF.

**Workarounds** There is no workaround for this issue.

Advisory 1.0.23 Ethernet Media Access Controller and Switch Subsystem: Reset Isolation Feature

is Not Supported

Revisions Affected 2.1, 2.0, 1.0

Details The Ethernet Media Access Controller and Switch (CPSW) subsystem may lock up if the

Reset Isolation feature is enabled when a warm reset is applied while the host port is transmitting data. Since most warm reset sources can be asynchronous events, this

lock-up condition can only be prevented by not enabling this feature.

The Reset Isolation feature is not enabled by default.

**Workarounds** There is no workaround for this issue.



# Boot: System Boot is Not Reliable if Reset is Asserted While Operating in OPP50

#### **Revisions Affected**

2.1, 2.0, 1.0

#### **Details**

The system attempts to boot using the ARM (A8), L3, L4, and respective DDR clock frequencies defined by OPP100 when a reset is asserted. The system may fail to boot if the system is operating with reduced VDD\_MPU and VDD\_CORE power supply voltages as defined by OPP50 when reset is asserted. This issue occurs because the device is being operated at OPP100 clock frequencies with OPP50 supply voltages. This unsupported operating condition potentially over-clocks the logic which was only timing closed to operate at OPP50 clock frequencies with OPP50 supply voltages.

There are three basic reset sources, the PWRONRSTn terminal, the WARMRSTn terminal, and the internal watchdog timer, that need to be considered when designing a product that supports OPP50.

It is important to return VDD\_MPU and VDD\_CORE power supplies to OPP100 defined voltages before any of these resets sources are asserted.

#### Workarounds

Only source the PWRONRSTn terminal from a power management circuit that always returns VDD\_MPU and VDD\_CORE power supplies to OPP100 defined voltages before asserting PWRONRSTn.

There are two possible workarounds that can be applied to the other two reset sources. The first workaround provides the lowest power consumption option but eliminates the watchdog timer and WARMRSTn terminal functions. The second workaround retains the watchdog timer and WARMRSTn terminal functions, but causes the device to consume higher power.

- Disable the watchdog timer and do not assert the WARMRSTn terminal while the VDD\_MPU and VDD\_CORE power supply voltages are less than those defined by OPP100.
- Retain the VDD\_MPU and VDD\_CORE power supply voltages defined by OPP100
  while operating the ARM (A8), L3, L4, and the respective DDR clocks at the reduced
  frequencies defined by OPP50.



Boot: System Boot Temporarily Stalls if an Attempt to Boot from Ethernet is Not Successful

#### **Revisions Affected**

2.1, 2.0, 1.0

#### **Details**

The system is delayed for up to 4.5 minutes before continuing to the next boot device if an attempt to boot from Ethernet fails for any reason.

This delay is likely to cause an undesirable user experience when the boot sequence attempts Ethernet boot before booting from the primary boot device. For example, it may be desirable to select SYSBOOT [4:0] = 00111b for a product that would normally skip over Ethernet boot which is the first boot device in this sequence and boots from MMC0 which is the second boot device in this sequence. This example boot sequence provides an option to boot from Ethernet as a way to break into the boot sequence to update MMC0 boot code by simply connecting it to an Ethernet host capable of booting the product for the purpose of updating MMC0 boot code. However, this boot sequence attempts to boot from Ethernet first which would insert an undesirable long delay when booting from MMC0.

#### Workarounds

There is no device-level workaround, but it may be possible to develop a system-level solution that mitigates the effect of this issue when an occasional Ethernet boot is required. In the example described above, the system could be designed with the boot sequence defined by SYSBOOT [4:0] = 11001b which attempts to boot from MMC0 before Ethernet. This does not provide a default method to break into the boot sequence with Ethernet boot, but the product could be designed with a switch that temporarily disables MMC0 boot as a way to invoke Ethernet boot. The switch would only be used to temporarily disable MMC0 while the product boots from Ethernet. Once the product has booted from Ethernet, the switch would be returned to its normal operating mode before the MMC0 boot code is updated.



#### I2C: SDA and SCL Open-Drain Output Buffer Issue

**Revisions Affected** 

2.0, 1.0

**Details** 

The I2Cx\_SDA and I2Cx\_SCL outputs are implemented with push-pull 3-state output buffers rather than open-drain output buffers as required by I2C. While it is possible for the push-pull 3-state output buffers to behave as open-drain outputs, an internal timing skew issue causes the outputs to drive a logic-high for a duration of (0–5 ns) before the outputs are disabled. The unexpected high-level pulse will only occur when the SCL or SDA outputs transition from a driven low state to a high-impedance state and there is sufficient internal timing skew on the respective I2C output.

This short high-level pulse injects energy in the I2C signals traces, which causes the I2C signals to sustain a period of ringing as a result of multiple transmission line reflections. This ringing should not cause an issue on the SDA signal because it only occurs at times when SDA is expected to be changing logic levels and the ringing will have time to damp before data is latched by the receiving device. The ringing may have enough amplitude to cross the SCL input buffer switching threshold several times during the first few nanoseconds of this ringing period, which may cause clock glitches. This ringing should not cause a problem if the amplitude is damped within the first 50 ns because I2C devices are required to filter their SCL inputs to remove clock glitches. Therefore, it is important to design the PCB signal traces to limit the duration of the ringing to less than 50 ns. One possible solution is to insert series termination resistors near the AM335x SCL and SDA terminals to attenuate transmission line reflections.

This issue may also cause the SDA output to be in contention with the slave SDA output for the duration of the unexpected high-level pulse when the slave begins its ACK cycle. This occurs because the slave may already be driving SDA low before the unexpected high-level pulse occurs. The glitch that occurs on SDA as a result of this short period of contention does not cause any I2C protocol issue but the peak current applies unwanted stress to both I2C devices and potentially increases power supply noise. Therefore, a series termination resistor located near the respective AM335x SDA terminal is required to limit the current during the short period of contention.

A similar contention problem can occur on SCL when connected to I2C slave devices that support clock stretching. This occurs because the slave is driving SCL low before the unexpected high-level pulse occurs. The glitch that occurs on SCL as a result of this short period of contention does not cause any I2C protocol issue because I2C devices are required to apply a glitch filter to their SCL inputs. However, the peak current applies unwanted stress to both I2C devices and potentially increases power supply noise. Therefore, a series termination resistor located near the respective AM335x SCL terminal is required to limit the current during the short period of contention.

If another master is connected, the unexpected high-level pulses on the SCL and SDA outputs can cause contention during clock synchronization and arbitration. The series termination resistors described above will also limit the contention current in this use case without creating any I2C protocol issue.

Workarounds

Insert series termination resistors on the SCL and SDA signals and locate them near the AM335x SCL and SDA terminals. The SCL and SDA pullup resistors should also be located near the AM335x SCL and SDA terminals. The placement of the series termination resistor and pullup resistor should be connected as shown in Figure 4.





Figure 4. Placement of Series Termination Resistor and Pullup Resistor

Table 6 provides series termination and pullup resistor value recommendations. The I2C signal level and respective VDDSHVx power supply voltage is shown in the first column. Two resistor value combination options are provided for each voltage. One option supports a maximum high-level input current of 200 uA to all attached I2C devices, while the other option supports a maximum high-level input current of 100 uA to all attached I2C devices.

Table 6. Recommended Values for Series Termination Resistor and Pullup Resistor

| I2C SIGNAL LEVEL AND<br>RESPECTIVE VDDSHVx<br>POWER SUPPLY (V) | SERIES TERMINATION<br>RESISTOR (Ω) | PULLUP RESISTOR (Ω) | NOTES                                         |
|----------------------------------------------------------------|------------------------------------|---------------------|-----------------------------------------------|
| 1.8                                                            | 60                                 | 1500                | Maximum high-level input current up to 200 μA |
| 1.8                                                            | 75                                 | 3300                | Maximum high-level input current up to 100 μA |
| 3.3                                                            | 60                                 | 3300                | Maximum high-level input current up to 200 μA |
| 3.3                                                            | 75                                 | 6600                | Maximum high-level input current up to 100 μA |



# Advisory 1.0.27 LCDC: LIDD DMA Mode Issue

**Revisions Affected** 

2.1, 2.0, 1.0

**Details** 

After a DMA transfer is complete, the LIDD\_DMA\_EN bit in the LIDD\_CTRL register is driven low and the read/write pointers of the Asynchronous FIFO are designed to reset. However, only the write pointer gets reset and, therefore, the FIFO sequence is corrupt. This could cause flickering or tearing of images being displayed on an LCD.

Workarounds

After each DMA transfer, wait for Done interrupt by polling the DONE\_RAW\_SET bit in the IRQSTATUS\_RAW register, and then write 1 to the DMA\_RST and LIDD\_RST bits in the CLKC\_RESET register to perform software reset of the L3 and LIDD clock domains. This returns the write and read FIFO pointers to their default values and allows for proper FIFO operation.

This workaround has a side effect that needs to be considered. The LCDC drives the LCD control signals to their active state when software reset is asserted if the active states of the LCD panel inputs are opposite the LCDC default states. If this is the case, it may be necessary to add a hardware isolation circuit to the LCD panel chip select signal that disconnects the LCDC output from the LCD panel input before the software reset is asserted. The LCDC output could be reconnected to the LCD panel input after LCDC has been re-initialized. An example isolation circuit may be a single channel bus FET switch inserted in the chip select signal path with the enable being controlled by a GPIO. The LCD panel input would need a pull-up or pull-down resistor to force an inactive state while the switch is open.



#### LCDC: Raster Mode, Hardware Auto Underflow Restart Does Not Work

#### **Revisions Affected**

2.1, 2.0, 1.0

**Details** 

The hardware restart of the LCDC during a FIFO underflow condition does not work. Setting the AUTO\_UFLOW\_RESTART bit in the LCDC control register has no effect.

#### Workarounds

This functionality can be implemented using the software reset method outlined in Section 13.4.6, Disable and Software Reset Sequence, of the *AM335x ARM Cortex-A8 Microprocessors (MPUs) Technical Reference Manual* (literature number SPRUH73).

Below are the summarized steps to perform a software reset:

- 1. Write 0 to the LCDEN bit in the RASTER\_CTRL register.
- Wait for Done interrupt by polling the DONE\_RAW\_SET bit in the IRQSTATUS\_RAW register.
- Write 1 to the MAIN\_RST, or DMA\_RST and CORE\_RST bits in the CLKC\_RESET register.
- 4. Wait several clock cycles.
- 5. Write 0 to the MAIN\_RST, or DMA\_RST and CORE\_RST bits in the CLKC\_RESET register.
- Write 1 to the LCDEN bit in the RASTER\_CTRL register.

#### Advisory 1.0.29

# Latch-up Performance: Latch-up Performance Limits for Silicon Revsions 1.0 and 2.0

#### **Revisions Affected**

2.0, 1.0

#### **Details**

Latch-up performance was improved in silicon revision 2.1 devices and the new limits have been updated in revision F of the *AM335x ARM Cortex-A8 Microprocessors (MPUs)* data manual (literature number <u>SPRS717</u>).

Table 7 provides latch-up performance limits published in previous revisions of the AM335x data manual and these limits apply to silicon revisions 1.0 and 2.0.

Table 7. Latch-up Performance Limits - Silicon Revisions 1.0 and 2.0

| PARAMET              | MIN              | MAX | UNITS |    |
|----------------------|------------------|-----|-------|----|
| Latch-up Performance | Class II (105°C) | 25  |       | mA |

#### Workarounds

Not applicable.



Revision History www.ti.com

# **Revision History**

| Cł | nanges from D Revision (February 2013) to E Revision                                                      | Page |
|----|-----------------------------------------------------------------------------------------------------------|------|
| •  | Modified Table 1, Production Device Revision Codes                                                        | 5    |
| •  | Modified Table 2, Silicon Revision Variables                                                              | 5    |
| •  | Modified Table 3, All Usage Notes                                                                         | 6    |
| •  | Modified Table 4, All Design Exceptions to Functional Specifications                                      | 6    |
| •  | Deleted McASP0 and McASP1 list items in Section 3.1.5, Pin Multiplexing: Valid IO Sets and Restrictions   | 10   |
| •  | Added 2.1 to Revision Affected on all applicable Advisories                                               | 12   |
| •  | Added Advisory 1.0.29, Latch-up Performance: Latch-up Performance Limits for Silicon Revsions 1.0 and 2.0 | 31   |

NOTE: Page numbers for previous revisions may differ from page numbers in the current version.

#### IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products (also referred to herein as "components") are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of significant portions of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed a special agreement specifically governing such use.

Only those TI components which TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components which have *not* been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.

Products Applications

Audio www.ti.com/audio Automotive and Transportation www.ti.com/automotive Communications and Telecom **Amplifiers** amplifier.ti.com www.ti.com/communications **Data Converters** dataconverter.ti.com Computers and Peripherals www.ti.com/computers **DLP® Products** www.dlp.com Consumer Electronics www.ti.com/consumer-apps

DSP **Energy and Lighting** dsp.ti.com www.ti.com/energy Clocks and Timers www.ti.com/clocks Industrial www.ti.com/industrial Interface interface.ti.com Medical www.ti.com/medical logic.ti.com Logic Security www.ti.com/security

Power Mgmt power.ti.com Space, Avionics and Defense www.ti.com/space-avionics-defense

Microcontrollers <u>microcontroller.ti.com</u> Video and Imaging <u>www.ti.com/video</u>

RFID www.ti-rfid.com

OMAP Applications Processors <u>www.ti.com/omap</u> TI E2E Community <u>e2e.ti.com</u>

Wireless Connectivity <u>www.ti.com/wirelessconnectivity</u>