

Silicon Errata SPRZ267I–March 2009–Revised August 2018

# TMS320C2834x Delfino™ MCUs Silicon Revision 0

### 1 Introduction

This document describes the silicon updates to the functional specifications for the TMS320C2834x microcontrollers (MCUs).

The updates are applicable to:

- 179-ball MicroStar BGA™, ZHH Suffix
- 256-ball Plastic BGA, ZFE Suffix

### 2 Device and Development Support Tool 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 (for example, **TMS**320C28345). 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, ZFE) and temperature range (for example, T).



#### 3 Device Markings

Figure 1 provides examples of the 2834x 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 the device nomenclature.



Figure 1. Examples of Device Markings

| Table 1. Determining Silicon Rev | ision From Lot Trace Code |
|----------------------------------|---------------------------|
|----------------------------------|---------------------------|

| LETTER FOLLOWING<br>WAFER FAB CODE                 | SILICON REVISION     | REVISION ID<br>Address: 0x0883 | COMMENTS                                   |
|----------------------------------------------------|----------------------|--------------------------------|--------------------------------------------|
| Blank<br>(no letter follows the<br>Wafer Fab Code) | Indicates Revision 0 | 0x0000                         | This silicon revision is available as TMS. |



Figure 2. Device Nomenclature



# 4 Usage Notes and Known Design Exceptions to Functional Specifications

## 4.1 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 usage notes will be incorporated into future documentation updates for the device (such as the device-specific data sheet), and the behaviors they describe will not be altered in future silicon revisions.

#### 4.1.1 PIE: Spurious Nested Interrupt After Back-to-Back PIEACK Write and Manual CPU Interrupt Mask Clear

#### Revision(s) Affected: 0

Certain code sequences used for nested interrupts allow the CPU and PIE to enter an inconsistent state that can trigger an unwanted interrupt. The conditions required to enter this state are:

- 1. A PIEACK clear is followed immediately by a global interrupt enable (EINT or asm(" CLRC INTM")).
- 2. A nested interrupt clears one or more PIEIER bits for its group.

Whether the unwanted interrupt is triggered depends on the configuration and timing of the other interrupts in the system. This is expected to be a rare or nonexistent event in most applications. If it happens, the unwanted interrupt will be the first one in the nested interrupt's PIE group, and will be triggered after the nested interrupt re-enables CPU interrupts (EINT or asm(" CLRC INTM")).

**Workaround:** Add a NOP between the PIEACK write and the CPU interrupt enable. Example code is shown below.

```
//Bad interrupt nesting code
PieCtrlRegs.PIEACK.all = 0xFFF; //Enable nesting in the PIE
EINT; //Enable nesting in the CPU
//Good interrupt nesting code
PieCtrlRegs.PIEACK.all = 0xFFF; //Enable nesting in the PIE
asm(" NOP"); //Wait for PIEACK to exit the pipeline
EINT; //Enable nesting in the CPU
```

# 4.1.2 Caution While Using Nested Interrupts

# Revision(s) Affected: 0

If the user is enabling interrupts using the EINT instruction inside an interrupt service routine (ISR) in order to use the nesting feature, then the user must disable the interrupts before exiting the ISR. Failing to do so may cause undefined behavior of CPU execution.



# 4.2 Known Design Exceptions to Functional Specifications

#### Table 2. Table of Contents for Advisories

| Title Page                                                                                                    | 3 |
|---------------------------------------------------------------------------------------------------------------|---|
| Advisory — Boot ROM - Incorrect MUX Configuration for Jump to XINTF x32                                       |   |
| Advisory — Memory: Prefetching Beyond Valid Memory                                                            |   |
| Advisory — SCI: Incorrect Operation of SCI in Address Bit Mode                                                |   |
| Advisory —eCAN: Abort Acknowledge Bit Not Set 7                                                               |   |
| Advisory — eCAN: Unexpected Cessation of Transmit Operation                                                   |   |
| Advisory — GPIO: GPIO Qualification                                                                           |   |
| Advisory — PWM: Internal Pullups Briefly Enabled During Power Up                                              |   |
| Advisory —eQEP: Missed First Index Event                                                                      |   |
| Advisory — eQEP: Position Counter Incorrectly Reset on Direction Change During Index                          |   |
| Advisory — eQEP: eQEP Inputs in GPIO Asynchronous Mode                                                        |   |
| Advisory — FPU: CPU-to-FPU Register Move Operation Followed By F32TOUI32, FRACF32, or UI16TOF32<br>Operations |   |
| Advisory — FPU: FPU-to-CPU Register Move Operation Preceded by Any FPU 2p Operation                           |   |

| www.ti.com           | Usage Notes and Known Design Exceptions to Functional Specifications                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Advisory             | Boot ROM - Incorrect MUX Configuration for Jump to XINTF x32                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Details              | The boot ROM incorrectly configures GPBMUX2 for peripheral operation instead of XD[31:16]. This issue affects the jump to XINTF x32 boot mode.                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Workaround           | None. Use "Jump to XINTF x16 boot mode" instead as x32 mode is not supported in this device family.                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| 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 8 x16 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, XINTF) on the device. Prefetching across the boundary between two valid memory blocks is all right. |  |  |  |  |  |  |  |  |
|                      | 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 SCI: Incorrect Operation of SCI in Address Bit Mode

Revision(s) Affected

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:



Erroneous Operation:



Figure 3. Difference Between Expected and Erroneous Operation of START Bit

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

| www.ti.com           | Usage Notes and Known Design Exceptions to Functional Specifications                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Advisory             | eCAN: Abort Acknowledge Bit Not Set                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| Details              | After setting a Transmission Request Reset (TRR) register bit to abort a message, there are some rare instances where the TRRn and TRSn bits will clear without setting the Abort Acknowledge (AAn) bit. The transmission itself is correctly aborted, but no interrupt is asserted and there is no indication of a pending operation.                                                              |  |  |  |  |  |  |  |  |
|                      | In order for this rare condition to occur, all of the following conditions must happen:                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|                      | <ol> <li>The previous message was not successful, either because of lost arbitration or<br/>because no node on the bus was able to acknowledge it or because an error frame<br/>resulted from the transmission. The previous message need not be from the same<br/>mailbox in which a transmit abort is currently being attempted.</li> </ol>                                                       |  |  |  |  |  |  |  |  |
|                      | 2. The TRRn bit of the mailbox should be set in a CPU cycle immediately following the cycle in which the TRSn bit was set. The TRSn bit remaining set due to incompletion of transmission satisfies this condition as well; that is, the TRSn bit could have been set in the past, but the transmission remains incomplete.                                                                         |  |  |  |  |  |  |  |  |
|                      | 3. The TRRn bit must be set in the exact SYSCLKOUT cycle where the CAN module is in idle state for one cycle. The CAN module is said to be in idle state when it is not in the process of receiving/transmitting data.                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|                      | If these conditions occur, then the TRRn and TRSn bits for the mailbox will clear $t_{clr}$ SYSCLKOUT cycles after the TRR bit is set where:                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| t <sub>clr</sub> =   | [(mailbox_number) * 2] + 3 SYSCLKOUT cycles                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                      | The TAn and AAn bits will not be set if this condition occurs. Normally, either the TA or AA bit sets after the TRR bit goes to zero.                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Workaround(s)        | When this problem occurs, the TRRn and TRSn bits will clear within $t_{clr}$ SYSCLKOUT cycles. To check for this condition, first disable the interrupts. Check the TRRn bit $t_{clr}$ SYSCLKOUT cycles after setting the TRRn bit to make sure it is still set. A set TRRn bit indicates that the problem did not occur.                                                                           |  |  |  |  |  |  |  |  |
|                      | If the TRRn bit is cleared, it could be because of the normal end of a message and the corresponding TAn or AAn bit is set. Check both the TAn and AAn bits. If either one of the bits is set, then the problem did not occur. If they are both zero, then the problem did occur. Handle the condition like the interrupt service routine would except that the AAn bit does not need clearing now. |  |  |  |  |  |  |  |  |
|                      | If the TAn or AAn bit is set, then the normal interrupt routine will happen when the interrupt is re-enabled.                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Advisory             | eCAN: Unexpected Cessation of Transmit Operation                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| Details              | In rare instances, the cessation of message transmission from the eCAN module has been observed (while the receive operation continues normally). This anomalous state may occur without any error frames on the bus.                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Workaround(s)        | The Time-out feature (MOTO) of the eCAN module may be employed to detect this condition. When this occurs, set and clear the CCR bit (using the CCE bit for verification) to remove the anomalous condition.                                                                                                                                                                                        |  |  |  |  |  |  |  |  |



| Advisory GPIO: GPIO Qualification |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Revision(s) Affected              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Details                           | If a GPIO pin is configured for "n" SYSCLKOUT cycle qualification period<br>(where $1 \le n \le 510$ ) with "m" qualification samples (m = 3 or 6), it is possible that an<br>input pulse of [n * m – (n – 1)] width may get qualified (instead of n * m). This depends<br>upon the alignment of the asynchronous GPIO input signal with respect to the phase of<br>the internal prescaled clock, and hence, is not deterministic. The probability of this kind<br>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                          | PWM: Internal Pullups Briefly Enabled During Power Up                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
| Revision(s) Affected              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Details                           | During power up, the pullups on the PWM pins are forced on briefly. This causes a low current glitch on the pin. <i>This is not an issue during a warm reset.</i>                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Workaround(s)                     | This can be overcome by using a 1–2 $k\Omega$ resistor to ground the pin.                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |

| www.ti.com           | Usage Notes and Known Design Exceptions to Functional Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 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 cloc<br>cycle before the corresponding QEPA/QEPB edge to two system clock cycles after the<br>corresponding QEPA/QEP edge, then the eQEP module may miss this index event. The<br>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 (that is, QEPI edge occurs before the corresponding QEPA/QEPB edge), the QEPI signal should be delayed by an amount greater than "t <sub>d</sub> + 2*SYSCLKOUT".                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Advisory             | eQEP: Position Counter Incorrectly Reset on Direction Change During Index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| Details              | While using the PCRM = 0 configuration, if the direction change occurs when the index input is active, the position counter (QPOSCNT) could be reset erroneously, resulting in an unexpected change in the counter value. This could result in a change of up to $\pm 4$ counts from the expected value of the position counter and lead to unexpected subsequent setting of the error flags.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|                      | While using the PCRM = 0 configuration [that is, Position Counter Reset on Index Event (QEPCTL[PCRM] = 00)], if the index event occurs during the forward movement, then the position counter is reset to 0 on the next eQEP clock. If the index event occurs during the reverse movement, then the position counter is reset to the value in the QPOSMAX register on the next eQEP clock. The eQEP peripheral records the occurrence of the first index marker (QEPSTS[FIMF]) and direction on the first index event marker (QEPSTS[FIDF]) in QEPSTS registers. It also remembers the quadrature edge on the first index marker so that same relative quadrature transition is used for index event reset operation. |  |  |  |  |  |  |  |
|                      | If the direction change occurs while the index pulse is active, the module would still continue to look for the relative quadrature transition for performing the position counter reset. This results in an unexpected change in the position counter value.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| Workaround(s)        | Do not use the PCRM = 0 configuration if the direction change could occur while the index is active and the resultant change of the position counter value could affect the application.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                      | Other options for performing position counter reset, if appropriate for the application [such as Index Event Initialization (IEI)], do not have this issue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |



| Advisory             | eQEP: eQEP Inputs in GPIO Asynchronous Mode                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| Details              | If any of the eQEP input pins are configured for GPIO asynchronous input mode via the GPxQSELn registers, the eQEP module may not operate properly. For example, QPOSCNT may not reset or latch properly, and pulses on the input pins may be missed. This is because the eQEP peripheral assumes the presence of external synchronization to SYSCLKOUT on inputs to the module. |  |  |  |  |  |  |  |  |
|                      | For proper operation of the eQEP module, input GPIO pins should be configured via the GPxQSELn registers for synchronous input mode (with or without qualification). This is the default state of the GPxQSEL registers at reset. All existing eQEP peripheral examples supplied by TI also configure the GPIO inputs for synchronous input mode.                                |  |  |  |  |  |  |  |  |
|                      | The asynchronous mode should not be used for eQEP module input pins.                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Workaround(s)        | Configure GPIO inputs configured as eQEP pins for non-asynchronous mode (any GPxQSELn register option except "11b = Asynchronous").                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |

| www.ti.com           | Usage Notes and Known Design Exceptions to Functional Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Advisory             | FPU: CPU-to-FPU Register Move Operation Followed By F32TOUI32, FRACF32, or UI16TOF32 Operations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Details              | <ul> <li>This advisory applies when the write phase of a CPU-to-FPU register write coincides with the execution phase of the F32TOUI32, FRACF32, or UI16TOF32 instructions. If the F32TOUI32 instruction execution and CPU-to-FPU register write operation occur in the same cycle, the target register (of the CPU-to-FPU register write operation) gets overwritten with the output of the F32TOUI32 instruction instead of the data present on the C28x data write bus. This scenario also applies to the following instructions:</li> <li>F32TOUI32 RaH, RbH</li> <li>FRACF32 RaH, RbH</li> <li>UI16TOF32 RaH, mem16</li> <li>UI16TOF32 RaH, RbH</li> </ul> |  |  |  |  |  |  |  |  |
| Workaround(s)        | A CPU-to-FPU register write must be followed by a gap of five NOPs or non-conflicting instructions before F32TOUI32, FRACF32, or UI16TOF32 can be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                      | The C28x code generation tools v6.0.5 (for the 6.0.x branch), v6.1.2 (for the 6.1.x branch), and later check for this scenario.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|                      | Example of Problem:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|                      | SUBF32 R5H, R3H, R1H<br>   MOV32 *XAR4, R4H<br>EISQRTF32 R4H, R2H<br>UI16TOF32 R2H, R3H<br>MOV32 R0H, @XAR0 ; Write to R0H register<br>NOP ;<br>NOP ;<br>F32TOUI32 R1H, R1H ; R1H gets written to R0H<br>I16TOF32 R6H, R3H                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|                      | Example of Workaround:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|                      | SUBF32 R5H, R3H, R1H<br>   MOV32 *XAR4, R4H<br>EISQRTF32 R4H, R2H<br>UI16TOF32 R2H, R3H<br>MOV32 R0H, @XAR0 ; Write to R0H register<br>NOP<br>NOP<br>NOP<br>NOP<br>NOP<br>NOP<br>F32TOUI32 R1H, R1H<br>I16TOF32 R6H, R3H                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |



| Advisory             | FPU: FPU-to-CPU Register Move Operation Preceded by Any FPU 2p Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Revision(s) Affected | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
| Details              | This advisory applies when a multi-cycle (2p) FPU instruction is followed by a FPU-to-<br>CPU register transfer. If the FPU-to-CPU read instruction source register is the same as<br>the 2p instruction destination, then the read may be of the value of the FPU register<br>before the 2p instruction completes. This occurs because the 2p instructions rely on<br>data-forwarding of the result during the E3 phase of the pipeline. If a pipeline stall<br>happens to occur in the E3 phase, the result does not get forwarded in time for the read<br>instruction. |  |  |  |  |  |  |  |  |
|                      | The 2p instructions impacted by this advisory are MPYF32, ADDF32, SUBF32, and MACF32. The destination of the FPU register read must be a CPU register (ACC, P, T, XAR0XAR7). This advisory does not apply if the register read is a FPU-to-FPU register transfer.                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                      | In the example below, the 2p instruction, MPYF32, uses R6H as its destination. The FPU register read, MOV32, uses the same register, R6H, as its source, and a CPU register as the destination. If a stall occurs in the E3 pipeline phase, then MOV32 will read the value of R6H before the MPYF32 instruction completes.                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|                      | Example of Problem:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
|                      | <pre>MPYF32 R6H, R5H, R0H ; 2p FPU instruction that writes to R6H    MOV32 *XAR7++, R4H F32TOUI16R R3H, R4H ; delay slot ADDF32 R2H, R2H, R0H    MOV32 *SP, R2H ; alignment cycle MOV32 @XAR3, R6H ; FPU register read of R6H</pre>                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |

Figure 4 shows the pipeline diagram of the issue when there are no stalls in the pipeline.

|    | Instruction                                   | F1 | F2      | D1     | D2 | R1 | R2        | E  | w  |           | Comments                                                                                                                                                                                                                                                                     |
|----|-----------------------------------------------|----|---------|--------|----|----|-----------|----|----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |                                               | -  | FPU pip | eline: | >  | R1 | R2        | E1 | E2 | E3        | Comments                                                                                                                                                                                                                                                                     |
| I1 | MPYF32 R6H, R5H, R0H<br>   MOV32 *XAR7++, R4H | I1 |         |        |    |    |           |    |    |           |                                                                                                                                                                                                                                                                              |
| I2 | F32TOUI16R R3H, R4H                           | I2 | I1      |        |    |    |           |    |    |           |                                                                                                                                                                                                                                                                              |
| I3 | ADDF32 R3H, R2H, R0H<br>   MOV32 *SP, R2H     | I3 | I2      | I1     |    |    |           |    |    |           |                                                                                                                                                                                                                                                                              |
| I4 | MOV32 @XAR3, R6H                              | I4 | I3      | I2     | I1 |    |           |    |    |           |                                                                                                                                                                                                                                                                              |
|    |                                               |    | I4      | I3     | I2 | I1 |           |    |    |           |                                                                                                                                                                                                                                                                              |
|    |                                               |    |         | I4     | I3 | I2 | I1        |    |    |           |                                                                                                                                                                                                                                                                              |
|    |                                               |    |         |        | I4 | I3 | I2        | I1 |    |           |                                                                                                                                                                                                                                                                              |
|    |                                               |    |         |        |    | I4 | I3        | I2 | I1 |           |                                                                                                                                                                                                                                                                              |
|    |                                               |    |         |        |    |    | <u>14</u> | I3 | 12 | <u>11</u> | I4 samples the result as it enters<br>the R2 phase. The product<br>R6H=R5H*R0H (I1) finishes<br>computing in the E3 phase, but is<br><b>forwarded</b> as an operand to I4.<br>This makes I4 appear to be a 2p<br>instruction, but I4 actually takes<br>3p cycles to compute. |
|    |                                               |    |         |        |    |    |           | I4 | I3 | I2        |                                                                                                                                                                                                                                                                              |
|    |                                               |    |         |        |    |    |           |    | I4 | I3        |                                                                                                                                                                                                                                                                              |

### Figure 4. Pipeline Diagram of the Issue When There are no Stalls in the Pipeline

Usage Notes and Known Design Exceptions to Functional Specifications

|    | Instruction          | F1 | F2      | D1     | D2 | R1 | R2        | Е  | w  |               |                                                                                                                                                                                                                                              |
|----|----------------------|----|---------|--------|----|----|-----------|----|----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | Instruction          |    |         |        |    |    |           |    |    |               | Comments                                                                                                                                                                                                                                     |
|    |                      |    | FPU pip | eline> | ,  | R1 | R2        | E1 | E2 | E3            |                                                                                                                                                                                                                                              |
| I1 | MPYF32 R6H, R5H, R0H | т1 |         |        |    |    |           |    |    |               |                                                                                                                                                                                                                                              |
| 11 | MOV32 *XAR7++, R4H   | 11 |         |        |    |    |           |    |    |               |                                                                                                                                                                                                                                              |
| I2 | F32TOUI16R R3H, R4H  | I2 | I1      |        |    |    |           |    |    |               |                                                                                                                                                                                                                                              |
| 13 | ADDF32 R3H, R2H, R0H | T3 | I2      | I1     |    |    |           |    |    |               |                                                                                                                                                                                                                                              |
| 13 | MOV32 *SP, R2H       | 13 | 12      | 11     |    |    |           |    |    |               |                                                                                                                                                                                                                                              |
| I4 | MOV32 @XAR3, R6H     | I4 | I3      | I2     | I1 |    |           |    |    |               |                                                                                                                                                                                                                                              |
|    |                      |    | I4      | I3     | I2 | I1 |           |    |    |               |                                                                                                                                                                                                                                              |
|    |                      |    |         | I4     | I3 | I2 | I1        |    |    |               |                                                                                                                                                                                                                                              |
|    |                      |    |         |        | I4 | I3 | I2        | I1 |    |               |                                                                                                                                                                                                                                              |
|    |                      |    |         |        |    | I4 | I3        | I2 | I1 |               |                                                                                                                                                                                                                                              |
|    |                      |    |         |        |    |    | <u>14</u> | I3 | 12 | I1<br>(STALL) | I4 samples the result as it enters<br>the R2 phase, but I1 is stalled in<br>E3 and is unable to forward the<br>product of R5H*R0H to I4 (R6H does<br>not have the product yet due to a<br>design bug). So, I4 reads the old<br>value of R6H. |
|    |                      |    |         |        |    |    | I4        | 13 | I2 | Il            | There is no change in the pipeline<br>as it was stalled in the previous<br>cycle. I4 had already sampled the<br>old value of R6H in the previous<br>cycle.                                                                                   |
|    |                      |    |         |        |    |    |           | I4 | IЗ | I2            | Stall over                                                                                                                                                                                                                                   |

Figure 5 shows the pipeline diagram of the issue if there is a stall in the E3 slot of the instruction I1.

#### Figure 5. Pipeline Diagram of the Issue if There is a Stall in the E3 Slot of the Instruction I1

Workaround(s)

Treat MPYF32, ADDF32, SUBF32, and MACF32 in this scenario as 3p-cycle instructions. Three NOPs or non-conflicting instructions must be placed in the delay slot of the instruction.

The C28x Code Generation Tools v.6.2.0 and later will both generate the correct instruction sequence and detect the error in assembly code. In previous versions, v6.0.5 (for the 6.0.x branch) and v.6.1.2 (for the 6.1.x branch), the compiler will generate the correct instruction sequence but the assembler will not detect the error in assembly code.

#### **Example of Workaround:**

| MPYF32 R6H, R5H, R0H<br>   MOV32 *XAR7++, R4H<br>F32TOUI16R R3H, R4H<br>ADDF32 R2H, R2H, R0H | ; 3p FPU instruction that writes to R6H<br>; delay slot         |
|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| <pre>   MOV32 *SP, R2H NOP MOV32 @XAR3, R6H</pre>                                            | ; delay slot<br>; alignment cycle<br>; FPU register read of R6H |

Figure 6 shows the pipeline diagram with the workaround in place.



#### Usage Notes and Known Design Exceptions to Functional Specifications

www.ti.com

|    | Instruction                                   | F1            | F2 | D1 | D2 | R1 | R2 | E  | w  |               | Comments                                                                                                                                                 |
|----|-----------------------------------------------|---------------|----|----|----|----|----|----|----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |                                               | FPU pipeline> |    |    |    | R1 | R2 | E1 | E2 | E3            | Comments                                                                                                                                                 |
| I1 | MPYF32 R6H, R5H, R0H<br>   MOV32 *XAR7++, R4H | Il            |    |    |    |    |    |    |    |               |                                                                                                                                                          |
| I2 | F32TOUI16R R3H, R4H                           | I2            | I1 |    |    |    |    |    |    |               |                                                                                                                                                          |
| I3 | ADDF32 R3H, R2H, R0H<br>   MOV32 *SP, R2H     | I3            | I2 | I1 |    |    |    |    |    |               |                                                                                                                                                          |
| I4 | NOP                                           | I4            | I3 | I2 | I1 |    |    |    |    |               |                                                                                                                                                          |
| Ι5 | MOV32 @XAR3, R6H                              | I5            | I4 | I3 | I2 | I1 |    |    |    |               |                                                                                                                                                          |
|    |                                               |               | I5 | I4 | I3 | I2 | I1 |    |    |               |                                                                                                                                                          |
|    |                                               |               |    | Ι5 | I4 | I3 | I2 | I1 |    |               |                                                                                                                                                          |
|    |                                               |               |    |    | I5 | I4 | I3 | I2 | I1 |               |                                                                                                                                                          |
|    |                                               |               |    |    |    | I5 | I4 | I3 | I2 | I1<br>(STALL) | Due to one extra NOP, I5 does not<br>reach R2 when I1 enters E3; thus,<br>forwarding is not needed.                                                      |
|    |                                               |               |    |    |    | I5 | I4 | I3 | I2 | Il            | There is no change due to the stall in the previous cycle.                                                                                               |
|    |                                               |               |    |    |    |    | 15 | I4 | 13 | I2            | Il moves out of E3 and I5 moves to<br>R2. R6H has the result of R5H*R0H<br>and is read by I5. There is no<br>need to forward the result in this<br>case. |
|    |                                               |               |    |    |    |    |    | I5 | I4 | I3            |                                                                                                                                                          |

Figure 6. Pipeline Diagram With Workaround in Place



# 5 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 2834x devices, see the *TMS320C2834x Delfino Microcontrollers Data Manual*.



**Documentation Support** 

www.ti.com

#### **Trademarks**

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



# **Revision History**

| Changes from November 10, 2015 to August 7, 2018 (from H Revision (November 2015) to I Revision) |                                                                                                                                                                  |    |  |  |  |
|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|
| •                                                                                                | Figure 1 (Examples of Device Markings): Updated figure.                                                                                                          | 2  |  |  |  |
| •                                                                                                | Table 1 (Determining Silicon Revision From Lot Trace Code): Updated table                                                                                        | 2  |  |  |  |
| •                                                                                                | Section 4.1 (Usage Notes): Added Caution While Using Nested Interrupts usage note                                                                                | 3  |  |  |  |
| •                                                                                                | Section 4.2 (Known Design Exceptions to Functional Specifications): Updated FPU: FPU-to-CPU Register Move<br>Operation Preceded by Any FPU 2p Operation advisory | 12 |  |  |  |

#### IMPORTANT NOTICE FOR TI DESIGN INFORMATION AND RESOURCES

Texas Instruments Incorporated ('TI") technical, application or other design advice, services or information, including, but not limited to, reference designs and materials relating to evaluation modules, (collectively, "TI Resources") are intended to assist designers who are developing applications that incorporate TI products; by downloading, accessing or using any particular TI Resource in any way, you (individually or, if you are acting on behalf of a company, your company) agree to use it solely for this purpose and subject to the terms of this Notice.

TI's provision of TI Resources does not expand or otherwise alter TI's applicable published warranties or warranty disclaimers for TI products, and no additional obligations or liabilities arise from TI providing such TI Resources. TI reserves the right to make corrections, enhancements, improvements and other changes to its TI Resources.

You understand and agree that you remain responsible for using your independent analysis, evaluation and judgment in designing your applications and that you have full and exclusive responsibility to assure the safety of your applications and compliance of your applications (and of all TI products used in or for your applications) with all applicable regulations, laws and other applicable requirements. You represent that, with respect to your applications, you have all the necessary expertise to create and implement safeguards that (1) anticipate dangerous consequences of failures, (2) monitor failures and their consequences, and (3) lessen the likelihood of failures that might cause harm and take appropriate actions. You agree that prior to using or distributing any applications. TI has not conducted any testing other than that specifically described in the published documentation for a particular TI Resource.

You are authorized to use, copy and modify any individual TI Resource only in connection with the development of applications that include the TI product(s) identified in such TI Resource. NO OTHER LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE TO ANY OTHER TI INTELLECTUAL PROPERTY RIGHT, AND NO LICENSE TO ANY TECHNOLOGY OR INTELLECTUAL PROPERTY RIGHT OF TI OR ANY THIRD PARTY IS GRANTED HEREIN, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information regarding or referencing third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of TI Resources 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.

TI RESOURCES ARE PROVIDED "AS IS" AND WITH ALL FAULTS. TI DISCLAIMS ALL OTHER WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED, REGARDING TI RESOURCES OR USE THEREOF, INCLUDING BUT NOT LIMITED TO ACCURACY OR COMPLETENESS, TITLE, ANY EPIDEMIC FAILURE WARRANTY AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT OF ANY THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

TI SHALL NOT BE LIABLE FOR AND SHALL NOT DEFEND OR INDEMNIFY YOU AGAINST ANY CLAIM, INCLUDING BUT NOT LIMITED TO ANY INFRINGEMENT CLAIM THAT RELATES TO OR IS BASED ON ANY COMBINATION OF PRODUCTS EVEN IF DESCRIBED IN TI RESOURCES OR OTHERWISE. IN NO EVENT SHALL TI BE LIABLE FOR ANY ACTUAL, DIRECT, SPECIAL, COLLATERAL, INDIRECT, PUNITIVE, INCIDENTAL, CONSEQUENTIAL OR EXEMPLARY DAMAGES IN CONNECTION WITH OR ARISING OUT OF TI RESOURCES OR USE THEREOF, AND REGARDLESS OF WHETHER TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

You agree to fully indemnify TI and its representatives against any damages, costs, losses, and/or liabilities arising out of your noncompliance with the terms and provisions of this Notice.

This Notice applies to TI Resources. Additional terms apply to the use and purchase of certain types of materials, TI products and services. These include; without limitation, TI's standard terms for semiconductor products <a href="http://www.ti.com/sc/docs/stdterms.htm">http://www.ti.com/sc/docs/stdterms.htm</a>), evaluation modules, and samples (<a href="http://www.ti.com/sc/docs/stdterms.htm">http://www.ti.com/sc/docs/stdterms.htm</a>), evaluation

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