## TMS320F28044 DSP

# **Silicon Errata**



Literature Number: SPRZ255E May 2007–Revised April 2011



| 1 | Introduction                                                     | 5  |
|---|------------------------------------------------------------------|----|
| 2 | Device and Development Tool Support Nomenclature                 | 5  |
| 3 | Device Markings                                                  | 6  |
| 4 | Silicon Change Overview                                          | 7  |
| 5 | Known Design Marginality/Exceptions to Functional Specifications | 8  |
| 6 | Documentation Support                                            | 19 |
| 7 | Revision History                                                 | 20 |



#### List of Figures

| 1 | Example of Device Markings                                       | 6  |
|---|------------------------------------------------------------------|----|
| 2 | Example of Device Nomenclature                                   | 6  |
| 3 | Difference Between Expected and Erroneous Operation of START Bit | 13 |

#### List of Tables

| 1 | Determining Silicon Revision From Lot Trace Code (F28044) | 6 |
|---|-----------------------------------------------------------|---|
| 2 | TMS320F28044 Silicon Change Overview                      | 7 |
| 3 | Advisory List                                             | 8 |



### TMS320F28044 Silicon Errata

#### 1 Introduction

This document describes the silicon updates to the functional specifications for the TMS320F28044 digital signal processor (DSP).

The updates are applicable to:

- 100-ball MicroStar BGA™, GGM, and ZGM suffix
- 100-pin thin quad flatpack, PZ suffix

#### 2 Device and Development Tool Support Nomenclature

To designate the stages in the product development cycle, TI assigns prefixes to the part numbers of all [TMS320] DSP devices and support tools. Each TMS320<sup>™</sup> DSP commercial family member has one of three prefixes: TMX, TMP, or TMS (e.g., **TMS**320F2808). 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 (TMX/TMDX) through fully qualified production devices/tools (TMS/TMDS).

- **TMX** Experimental device that is not necessarily representative of the final device's electrical specifications
- **TMP** Final silicon die that conforms to the device's electrical specifications but has not completed quality and reliability verification
- **TMS** Fully qualified production device

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

TMX and TMP devices and TMDX development-support tools are shipped against the following disclaimer:

"Developmental product is intended for internal evaluation purposes."

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

Predictions show that prototype devices (TMX or TMP) 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.

TI device nomenclature also includes a suffix with the device family name. This suffix indicates the package type (for example, GGM) and temperature range (for example, A).

5

MicroStar BGA, TMS320 are trademarks of Texas Instruments. All other trademarks are the property of their respective owners.



#### Device Markings

#### 3 Device Markings

Figure 1 provides an example of the TMS320F280x device markings and defines each of the markings. The device revision can be determined by the symbols marked on the top of the package as shown in Figure 1. Some prototype devices may have markings different from those illustrated. Figure 2 shows an example of the device nomenclature.





| SECOND LETTER<br>IN PREFIX OF<br>LOT TRACE CODE | SILICON REVISION     | REVISION ID<br>(0x0883) | F28044 COMMENTS                                  |
|-------------------------------------------------|----------------------|-------------------------|--------------------------------------------------|
| Blank (no second letter in prefix)              | Indicates Revision 0 | 0x0000                  | This silicon revision is available as TMX or TMS |



#### 4 Silicon Change Overview

Table 2 lists the change(s) made to each silicon revision.

#### Table 2. TMS320F28044 Silicon Change Overview

| REVISION | CHANGES MADE          |
|----------|-----------------------|
| 0        | First silicon release |

7



#### 5 Known Design Marginality/Exceptions to Functional Specifications

The table of contents for advisories is shown in Table 3.

#### Table 3. Advisory List

# TitlePageAdvisory — Input Clock: Device Startup Using XCLKIN Input9Advisory — Memory: Prefetching Beyond Valid Memory10Advisory — Memory: Flash and OTP Prefetch Buffer Overflow11Advisory — ADC: Simultaneous Sampling Latency12Advisory — SCI: Incorrect Operation of SCI in Address Bit Mode13Advisory — WD: Change to Watchdog Module: Bad Key Writes to WDKEY No Longer Cause RESET/Interrupt to be<br/>Generated15Advisory — GPIO: GPIO Qualification16Advisory — Pulldown Resistor for TRST Pin17Advisory — eQEP: Missed First Index Event18



| Advisory             | Input Clock: Device Startup Using XCLKIN Input                                                                                                                                                                             |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                          |  |  |
| Details              | When clock to the device is supplied using the XCLKIN pin, device may intermittently fail to startup correctly.                                                                                                            |  |  |
| Workaround(s)        | Do not use the XCLKIN pin to supply clock to the device. Instead, use either a crystal/resonator or a 1.8-V external oscillator on the X1 pin to clock the device. This will be fixed in the next revision of the silicon. |  |  |

9



| Advisory             | Memory: Prefetching Beyond Valid Memory                                                                                                                                                                                                                                                             |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                   |  |  |
| Details              | The C28x CPU prefetches instructions beyond those currently active in its pipeline. If the prefetch occurs past the end of valid memory, then the CPU may receive an invalid opcode.                                                                                                                |  |  |
| Workaround           | The prefetch queue is 8x16 words in depth. Therefore, code should not come within 8 words of the end of valid memory. This restriction applies to all memory regions and all memory types (flash, OTP, SARAM) on the device. Prefetching across the boundary between two valid memory blocks is ok. |  |  |
|                      | Example 1: M1 ends at address 0x7FF and is not followed by another memory block.<br>Code in M1 should be stored no farther than address 0x7F7. Addresses 0x7F8-0x7FF<br>should not be used for code.                                                                                                |  |  |
|                      | Example 2: M0 ends at address 0x3FF and valid memory (M1) follows it. Code in M0 can be stored up to and including address 0x3FF. Code can also cross into M1 up to and including address 0x7F7.                                                                                                    |  |  |

| www.ti.com           | Advisory — Memory: Flash and OTP Prefetch Buffer Overflow                                                                                                                                                                                                                          |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Advisory             | Memory: Flash and OTP Prefetch Buffer Overflow                                                                                                                                                                                                                                     |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                  |
| Details              | This advisory applies to code executing from flash or OTP with the flash prefetch buffer enabled. On ROM devices this applies to the ROM that replaces flash and OTP.                                                                                                              |
|                      | The flash prefetch buffer may overflow if a SBF or BF instruction is within eight 16-bit words preceding an operation using indirect or direct program-memory addressing. The window for which this can occur is shown below:                                                      |
|                      | Address<br>Offset                                                                                                                                                                                                                                                                  |
|                      | 0x0000 BF LSW (32-bit opcode)<br>0x0001 BF MSW or SBF (16-bit opcode)                                                                                                                                                                                                              |
|                      | Ox0002SBF/BF + 1 word//0x0003SBF/BF + 2 words//0x0004SBF/BF + 3 words//0x0005SBF/BF + 4 words// uses program-memory addressing it0x0006SBF/BF + 5 words// can cause the flash prefetch buffer to0x0007SBF/BF + 6 words// overflow.0x0008SBF/BF + 7 words//0x0009SBF/BF + 8 words// |
|                      | 0x0010 SBF/BF + 9 words<br>Whether or not an overflow actually occurs depends on the instruction sequence, flash wait states and CPU pipeline stalls. If an overflow occurs it will result in execution of                                                                         |

Whether or not an overflow actually occurs depends on the instruction sequence, flash wait states and CPU pipeline stalls. If an overflow occurs it will result in execution of invalid opcodes. Instructions that use program-memory addressing include MAC/XMAC, DMAC/XMACD, QMACL, IMACL, PREAD/XPREAD and PWRITE/XPWRITE.

Workaround(s)

1. Hand-coded assembly:

Use the SB/B instructions instead of SBF/BF for code targeted to execute from flash or OTP. The SB/B instructions are more efficient in wait-stated memory so a performance improvement may also be seen.

#### 2. Compiler-generated assembly:

Use the compiler switch -me to force the compiler to generate SB/B instructions instead of SBF/BF instructions. In heavily wait stated memory the SB/B instructions are more efficient than SBF/BF. In SARAM the SBF/BF instructions are more efficient. Therefore, this switch should be applied as follows:

- Use the compiler switch -me on source code that runs from flash or OTP.
- Do not use the compiler switch -me on source code that runs from SARAM.
- Use -me If a file contains functions that runs from flash as well as functions that run from SARAM.

The -me switch is available in C28x compiler as of V4.1.4, V5.0.0 and above.



Advisory — ADC: Simultaneous Sampling Latency

| Advisory             | ADC: Simultaneous Sampling Latency                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Details              | When the ADC conversions are initiated in simultaneous mode, the first sample pair will not give correct conversion results.                                                                                                                                                                                                                                                                                                                                           |  |  |
| Workaround(s)        | <ol> <li>If the ADC is used with a sampling window ≤ 160 nS, then the first sample pair must<br/>be discarded and a second sample of the same pair must be taken. For instance, if the<br/>sequencer is set to sample channel A0:B0/A1:B1/A2:B2 in that order, then load the<br/>sequencer with A0:B0/A0:B0/A1:B1/A2:B2 and only use the last three conversions.</li> <li>If the ADC is used with a sampling window greater than 160 ns, there is no issue.</li> </ol> |  |  |



| www.ti.com           | Advisory — SCI: Incorrect Operation of SCI in Address Bit Mode                                                                                                                                                                                                                        |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Advisory             | SCI: Incorrect Operation of SCI in Address Bit Mode                                                                                                                                                                                                                                   |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                     |  |
| Details              | SCI does not look for STOP bit after the ADDR bit. Instead, SCI starts looking for the start bit beginning on sub-sample 6 of the ADDR bit. Slow rise-time from ADDR to STOP bit can cause the false START bit to occur since the 4th sub-sample for the start bit may be sensed low. |  |
| Expected Operation:  |                                                                                                                                                                                                                                                                                       |  |

Expected Operation:



Erroneous Operation:





**Workaround(s)** Program the baud rate of the SCI to be slightly slower than the actual. This will cause the 4th sub-sample of the false START bit to be delayed in time, and therefore occur more towards the middle of the STOP bit (away from the signal transition region). The amount of baud slowing needed depends on the rise-time of the signal in the system. Alternatively, IDLE mode of the SCI module may be used, if applicable.



| Advisory             | SCI: Bootloader Does Not Clear the ABD Bit After Auto-Baud Lock                                                                                                                                                                                                                                                              |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                            |  |  |
| Details              | The SCI ROM bootloader code does not clear the Auto-Baud Detect (ABD) bit in the SCIFFCT register after the auto-baud process completes. If the SCI-A port is used after the bootloader is executed, transmit interrupts (SCITXINTA) will not be able to occur, nor will the auto-baud lock feature of SCI-A work correctly. |  |  |
| Workaround           | If the SCI bootloader has been executed, the user's application code should clear the ABD bit by writing a 1 to ABD CLR (bit 14) in the SCIFFCT register before enabling the SCITXINTA interrupt, and before using the auto-baud feature.                                                                                    |  |  |



| www.ti.com Advisory – | <ul> <li>WD: Change to Watchdog Module: Bad Key Writes to WDKEY No Longer Cause RESET/Interrupt<br/>to be Generated</li> </ul>                                                                                                                                                                                                                          |  |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Advisory              | WD: Change to Watchdog Module: Bad Key Writes to WDKEY No Longer Cause<br>RESET/Interrupt to be Generated                                                                                                                                                                                                                                               |  |
| Revision(s) Affected  | 0                                                                                                                                                                                                                                                                                                                                                       |  |
| Details               | The "Bad Key Detect" function of the WDKEY register has been disabled. When using the Watchdog (WD) module, a write of anything other than 0x55 or 0xAA to the WDKEY register will have no effect. See the <i>TMS320x280x, 2801x, 2804x DSP System Control and Interrupts Reference Guide</i> (literature number <u>SPRU712</u> ) for more information. |  |
| Workaround(s)         | To trigger an immediate reset or interrupt, perform an invalid write to the WDCHK bits the WDCR register.                                                                                                                                                                                                                                               |  |



| Advisory             | GPIO: GPIO Qualification                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Details              | If a GPIO pin is configured for "n" SYSCLKOUT cycle qualification period (where $1 \le n \le 510$ ) with "m" qualification samples (m = 3 or 6), it is possible that an input pulse of [n * m - (n - 1)] width may get qualified (instead of n * m). This depends upon the alignment of the asynchronous GPIO input signal with respect to the phase of the internal prescaled clock, and hence, is not deterministic. The probability of this kind of wrong qualification occurring is "1/n". |  |  |  |  |
|                      | Worst-case example:                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                      | If n = 510, m = 6, a GPIO input width of (n * m) = 3060 SYSCLKOUT cycles is required to pass qualification. However, because of the issue described in this advisory, the minimum GPIO input width which may get qualified is $[n * m - (n - 1)] = 3060 - 509 = 2551$ SYSCLKOUT cycles.                                                                                                                                                                                                        |  |  |  |  |
| Workaround(s)        | None. Ensure a sufficient margin is in the design for input qualification.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |



| Advisory             | Pulldown Resistor for TRST Pin                                                                                                                                                                                                                                                                                                                     |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                  |
| Details              | In the device data sheet, the recommendation of an external pulldown resistor has now been made a requirement. Earlier, the data sheet suggested leaving this pin unconnected in low-noise environments. Since the term "low-noise" is not easily quantified, an external pulldown resistor has been made a requirement for more robust operation. |
| Workaround(s)        | An external pulldown resistor is required on the TRST pin.                                                                                                                                                                                                                                                                                         |



| Advisory             | eQEP: Missed First Index Event                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Details              | If the first index event edge at the QEPI input occurs at any time from one system clock cycle before the corresponding QEPA/QEPB edge to two system clock cycles after the corresponding QEPA/QEP edge, then the eQEP module may miss this index event. This can result in the following behavior:                                                                                                                                                                            |  |  |  |  |
|                      | <ul> <li>QPOSCNT will not be reset on the first index event if QEPCTL[PCRM] = 00b or 10b<br/>(position counter reset on an index event or position counter reset on the first index<br/>event).</li> </ul>                                                                                                                                                                                                                                                                     |  |  |  |  |
|                      | <ul> <li>The first index event marker flag (QEPSTS[FIMF]) will not be set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| Workaround(s)        | Reliable operation is achieved by delaying the index signal such that the QEPI event edge occurs at least two system clock cycles after the corresponding QEPA/QEPB signal edge. For cases where the encoder may impart a negative delay ( $t_d$ ) to the QEPI signal with respect to the corresponding QEPA/QEPB signal (i.e., QEPI edge occurs before the corresponding QEPA/QEPB edge), the QEPI signal should be delayed by an amount greater than " $t_d$ + 2*SYSCLKOUT". |  |  |  |  |



#### 6 Documentation Support

For device-specific data sheets and related documentation, visit the TI web site at: http://www.ti.com.

For further information regarding the TMS320F28044 DSP, please see the *TMS320F28044 Digital Signal Processor Data Manual* (literature number <u>SPRS357</u>).

**Documentation Support** 



#### 7 Revision History

This revision history highlights the technical changes made to the SPRZ255D errata document to make it an SPRZ255E revision.

Scope: See table below.

| LOCATION  | ADDITIONS, DELETIONS, AND MODIFICATIONS                           |
|-----------|-------------------------------------------------------------------|
| Section 5 | Known Design Marginality/Exceptions to Functional Specifications: |
|           | Added eQEP: Missed First Index Event" advisory                    |

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

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

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

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI 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 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. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

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

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

| Products                    |                        | Applications                     |                                   |
|-----------------------------|------------------------|----------------------------------|-----------------------------------|
| Audio                       | www.ti.com/audio       | Communications and Telecom       | www.ti.com/communications         |
| Amplifiers                  | amplifier.ti.com       | Computers and Peripherals        | www.ti.com/computers              |
| Data Converters             | dataconverter.ti.com   | Consumer Electronics             | www.ti.com/consumer-apps          |
| DLP® Products               | www.dlp.com            | Energy and Lighting              | www.ti.com/energy                 |
| DSP                         | dsp.ti.com             | Industrial                       | www.ti.com/industrial             |
| Clocks and Timers           | www.ti.com/clocks      | Medical                          | www.ti.com/medical                |
| Interface                   | interface.ti.com       | Security                         | www.ti.com/security               |
| Logic                       | logic.ti.com           | Space, Avionics and Defense      | www.ti.com/space-avionics-defense |
| Power Mgmt                  | power.ti.com           | Transportation and<br>Automotive | www.ti.com/automotive             |
| Microcontrollers            | microcontroller.ti.com | Video and Imaging                | www.ti.com/video                  |
| RFID                        | www.ti-rfid.com        | Wireless                         | www.ti.com/wireless-apps          |
| RF/IF and ZigBee® Solutions | www.ti.com/lprf        |                                  |                                   |

**TI E2E Community Home Page** 

e2e.ti.com

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2011, Texas Instruments Incorporated