Freescale Semiconductor, Inc.



Chip Errata DSP56303 Digital Signal Processor Mask: 0H82G

General remark: In order to prevent the usage of instructions or sequences of instructions that do not operate correctly, the user is encouraged to use the "lint563" program to identify such cases and use alternative sequences of instructions. This program is available as part of the Motorola DSP Tools CLAS package.

#### Silicon Errata

| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                                                                                                                                  | Applies<br><u>to Mask</u> |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| ES33             | Description (added 3/3/1997):                                                                                                                                                                                                                                                                                                                                                                                       | 0H82G                     |
|                  | When using the JTAG instructions SAMPLE/PRELOAD, EXTEST, and<br>CLAMP, erroneous data may be driven out on the parallel pins and<br>TDO. Data cannot be shifted through the Boundary Scan Register (BSR)<br>using the SAMPLE/PRELOAD instruction. Because the BSR must be<br>preloaded using the SAMPLE/PRELOAD instruction, the EXTEST and<br>CLAMP instructions cannot be used for testing the board connections. |                           |
|                  | Workaround: None available.                                                                                                                                                                                                                                                                                                                                                                                         |                           |
|                  | Description (added 1/27/98):                                                                                                                                                                                                                                                                                                                                                                                        | 0H82G                     |
|                  | When a DMA channel is configured using its DMA Control Register (DCR) in the following manner:                                                                                                                                                                                                                                                                                                                      |                           |
| ES54             | <ul> <li>Line Transfer mode is selected (DTM[2:0] = 010)</li> <li>Non-Three-Dimensional Address mode is selected (D3D = 0)</li> <li>Destination Address Offset Register DOR1 or DOR3 is selected (DAM[5:3] = 001 or 011)</li> <li>No Source Address Offset is selected (DAM[2:0] = 100 or 101)</li> </ul>                                                                                                           |                           |
|                  | The DMA transfer does not function as intended.                                                                                                                                                                                                                                                                                                                                                                     |                           |
|                  | Workaround:                                                                                                                                                                                                                                                                                                                                                                                                         |                           |
|                  | Select Destination Address Offset Register DOR0 or DOR2 by setting DAM[5:3] = 000 or 010.                                                                                                                                                                                                                                                                                                                           |                           |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                        | Applies<br>to Mask |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
|                  | Description (added 5/13/98):                                                                                                                                                                                                                                                              | 0H82G              |
|                  | When software disables a DMA channel (by clearing the DE bit of the DCR) , the DTD status bit of the channel may not be set if any of the following events occur:                                                                                                                         |                    |
|                  | a. Software disables the DMA channel just before a conditional trans-<br>fer stall (Described by App B-3.5.1,UM).                                                                                                                                                                         |                    |
|                  | b. Software disables the DMA channel at the end of the block transfer (that is after the counter is loaded with its initial value and transfer of the last word of the block is completed).                                                                                               |                    |
|                  | As a result, the Transfer Done interrupt might not be generated.                                                                                                                                                                                                                          |                    |
|                  | Workaround:<br>Avoid using the instruction sequence causing the conditional transfer<br>stall (See DSP56300 UM, App B-3.5.1 for description) in fast interrupt<br>service routines. Every time the DMA channel needs to be disabled by<br>software, the following sequence must be used : |                    |
| ES84             | <pre>bclr #DIE,x:M_DCR ; not needed if DIE is cleared<br/>bclr #DE,x:M_DCR<br/>; instead of two instructions above, one 'movep' instruction ;<br/>may be used<br/>; to clear DIE and DE bits<br/>movep #DCR_Dummy_Value,x:M_DCR<br/>bclr #DE,x:M_DCR<br/>nop<br/>nop</pre>                |                    |
|                  | Here, the DCR_Dummy_value is any value of the DCR register that complies with the following requirements:                                                                                                                                                                                 |                    |
|                  | <ul> <li>DE is set;</li> <li>DIE is set if Transfer Done interrupt request should be generated and cleared otherwise;</li> <li>DRS[4:0] bits must encode a reserved DMA request source (see the following list of reserved DRS values);</li> </ul>                                        |                    |
|                  | List of reserved DRS[4:0] values (per device):                                                                                                                                                                                                                                            |                    |
|                  | <ul> <li>DSP56302, DSP56309, DSP56303, DSP56306, DSP56362 — 10101-11111</li> <li>DSP56305 — 11011</li> <li>DSP56301 — 10011-11011</li> <li>DSP56307 — 10111-11111</li> </ul>                                                                                                              |                    |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Applies<br><u>to Mask</u> |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (added 6/25/98):                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0H82G                     |
| ECOO             | If the SCI Receiver is programmed to work with a different serial clock<br>than the SCI Transmitter so that either the Receiver or Transmitter is<br>using the external serial clock and the other is using the internally-<br>generated serial clock—RCM and TCM in the SCCR are programmed<br>differently)—then the internal serial clock generator will not operate<br>and the SCI portion (Receiver or Transmitter) clocked by the internal<br>clock will be stuck. |                           |
| ES89             | Workaround:                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                           |
|                  | Do not use SCI with the two SCI portions (Receiver and Transmitter) clocked by different serial clocks; use either both externally or both internally clocked.                                                                                                                                                                                                                                                                                                          |                           |
|                  | Or:                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                           |
|                  | When using both portions of the SCI (Receiver & Transmitter), do not program different values on RCM and TCM in the SCCR.                                                                                                                                                                                                                                                                                                                                               |                           |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                        | Applies<br><u>to Mask</u> |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (added 6/25/98)/Modified 4/19/99:                                                                                                                                                                                                             | 0H82G                     |
|                  | A deadlock occurs during DMA transfers if all the following conditions exist:                                                                                                                                                                             |                           |
|                  | 1. DMA transfers data between internal memory and external memory through port A.                                                                                                                                                                         |                           |
|                  | 2. DMA and the core access the same internal 0.25K memory module.                                                                                                                                                                                         |                           |
|                  | 3. One of the following occurs:                                                                                                                                                                                                                           |                           |
|                  | a. The bus arbitration system is active, i.e., $\overline{BG}$ is changing, not tied to ground.                                                                                                                                                           |                           |
| ES90             | <ul> <li>b. Packing mode (bit 7 in the AAR[3 - 0] registers) is active for DMA<br/>transfers on Port A.</li> </ul>                                                                                                                                        |                           |
|                  | Workaround:                                                                                                                                                                                                                                               |                           |
|                  | One of the following, but workarounds 2, and 3 are valid ONLY to<br>section 3 a of the errata - i.e. not valid if packing mode is used, and<br>workaround 4 is valid only to section 3 b of the errata - i.e., not valid if<br>bus arbitration is active. |                           |
|                  | 1. Use intermediate internal memory on which there is no contention with the core.                                                                                                                                                                        |                           |
|                  | 2. Tie $\overline{BG}$ to ground, or have an external arbiter that asserts $\overline{BG}$ even if BR is not asserted.                                                                                                                                    |                           |
|                  | 3. Set the BCR[BRH] bit, whenever BR must be active.                                                                                                                                                                                                      |                           |
|                  | 4. Avoid using packing mode.                                                                                                                                                                                                                              |                           |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                                  | Applies<br><u>to Mask</u> |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (added 7/22/98):                                                                                                                                                                                                                                                                                        | 0H82G                     |
|                  | If the Core reads data from the HRX while instructions are fetched from the memory Expansion Port (Port A) using 2 or more wait states, data may be lost.                                                                                                                                                           |                           |
|                  | Workaround :                                                                                                                                                                                                                                                                                                        |                           |
|                  | There are three possible workarounds:                                                                                                                                                                                                                                                                               |                           |
|                  | 1) The host should guarantee that there is no more than one word in the TXH:TXM:TXL-HRX data path at any time. This can be achieved if the host writes a word to the HI08 only when the TRDY flag is set (i.e. the data path is empty).                                                                             |                           |
| ES91             | 2) Use a service routine running from fast (i.e. one wait state) external<br>memory or internal memory to read the HRX read code; ensure that<br>code that is fetched from slow (i.e. more than 1 wait state) external<br>memory is located at least 4 instructions after the HRX register is read.<br>For example: |                           |
| E/371            | READ_HRX_DATA<br>NOP<br>NOP<br>NOP<br>NOP                                                                                                                                                                                                                                                                           |                           |
|                  | Note:                                                                                                                                                                                                                                                                                                               |                           |
|                  | a) Interrupt requests that fetch instructions from slow external memory<br>should be masked during this service routine. Nonmaskable interrupt<br>(NMI) request routines must not be in external memory.                                                                                                            |                           |
|                  | b) If running from fast external memory and if a DMA channel<br>accessing external memory is used, then the DMA may cause extra wait<br>states to the core. Thus, the DMA should have a lower priority than the<br>core so that the core can access the external memory with no more than<br>1 wait state.          |                           |
|                  | 3) Read the HRX using one of the channels of the on-chip DMA controller.                                                                                                                                                                                                                                            |                           |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                             | Applies<br><u>to Mask</u> |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (added 8/10/98):                                                                                                                                                                                                                                                   | 0H82G                     |
|                  | Enabling any DMA channel by software for transferring a block of data (TM=011 in the channel control register) might not work properly.                                                                                                                                        |                           |
|                  | Workaround:                                                                                                                                                                                                                                                                    |                           |
|                  | Triggering of a channel for block transfer by software can be replaced<br>by triggering of the DMA channel for block transfer by a peripheral (e.g.<br>Timer, SCI etc.) that is not used while the block of data should be<br>transferred by DMA. This can be done as follows: |                           |
|                  | 1. Set the DSR, DDR and DCO registers of the DMA channel according to the application case.                                                                                                                                                                                    |                           |
|                  | 2. Transfer mode of the DMA channel (in the DCR register) should be set to $TM = 000$ or $TM = 100$ (See Section 8.1.5.3, 563xx UM).                                                                                                                                           |                           |
| ES94             | 3. DMA Request Source of the DMA channel should be set according to<br>the chosen peripheral, which should trigger the DMA channel (see<br>Section 8.1.5.6 56300 UM and "DMA Request Sources" Table in the<br>CORE CONFIGURATION item of the 563xx UM).                        |                           |
|                  | 4. All others fields of the DCR register, except the DE bit, should be set according to the application case.                                                                                                                                                                  |                           |
|                  | 5. Configure the peripheral to assert its DMA request line;                                                                                                                                                                                                                    |                           |
|                  | 6. Set DE bit of the DCR register.                                                                                                                                                                                                                                             |                           |
|                  | Example 1:                                                                                                                                                                                                                                                                     |                           |
|                  | Assuming that the SCI is not used while the block of #DCO3 words is transferred by DMA channel 3, the SCI Transmit Data (TDRE = 1, DRS[4:0] = 01111) trigger can be used instead of a software trigger for channel 3.                                                          |                           |
|                  | 1. Initialize DMA channel registers                                                                                                                                                                                                                                            |                           |
|                  | <pre>movep #DSR3,x:M_DSR3 movep #DDR3,x:M_DDR3 movep #DCO3,x:M_DCO3 bset #0,x:M_PCRE</pre>                                                                                                                                                                                     |                           |
|                  | Now when the DMA channel is enabled, a transfer of the block begins.                                                                                                                                                                                                           |                           |



| ·                |                                                                                                                                                                                                                      |                            |                                                                                                                                          | 1                         |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|
| Errata<br>Number | <u>Errata I</u>                                                                                                                                                                                                      | Description                |                                                                                                                                          | Applies<br><u>to Mask</u> |  |
|                  | 2. Enab                                                                                                                                                                                                              | le DMA channel             |                                                                                                                                          |                           |  |
|                  | movep                                                                                                                                                                                                                | #\$867a40,x:M_DCR3         | ;; enable DMA channel 3,<br>;; block transfer mode,<br>;; DRS[4:0] = 01111                                                               |                           |  |
|                  | Exampl                                                                                                                                                                                                               | le 2 :                     |                                                                                                                                          |                           |  |
|                  | Assuming that Timer 0 is not used while a block of #DCO3 words is to<br>be transferred by DMA channel 3, the Timer0 (TCF0 = 1, DRS[4:0] =<br>10000) trigger can be used instead of a software trigger for channel 3. |                            |                                                                                                                                          |                           |  |
|                  | 1. Initia                                                                                                                                                                                                            | lize DMA channel regist    | ers                                                                                                                                      |                           |  |
|                  | <pre>movep #DSR3,x:M_DSR3 movep #DDR3,x:M_DDR3</pre>                                                                                                                                                                 |                            |                                                                                                                                          |                           |  |
|                  | movep #DCO3,x:M_DCO3                                                                                                                                                                                                 |                            |                                                                                                                                          |                           |  |
|                  | 2. Initialize Timer 0                                                                                                                                                                                                |                            |                                                                                                                                          |                           |  |
| ES94<br>cont.    | movep                                                                                                                                                                                                                | #\$0,x:M_TCSR0             | ;;no prescaling, inv=0, mode 0,<br>;; no interrupt, reload is                                                                            |                           |  |
|                  | disable<br>movep                                                                                                                                                                                                     | ed<br>#\$0,x:M TLR0        | ;;initialize load reg.                                                                                                                   |                           |  |
|                  | movep                                                                                                                                                                                                                | #\$0,x:M_TCPR0             | ;;initialize compare reg.                                                                                                                |                           |  |
|                  | 3. Generate DMA channel trigger                                                                                                                                                                                      |                            |                                                                                                                                          |                           |  |
|                  | - option 1                                                                                                                                                                                                           |                            |                                                                                                                                          |                           |  |
|                  | movep                                                                                                                                                                                                                | #\$A48254,x:M_DCR3         | ;; enable DMA channel 3, block<br>;; transfer mode, DE isn't<br>;; disabled at end of<br>;; transfer, triggered by<br>;; Timer0 (TCF0=1) |                           |  |
|                  | bset<br>nop<br>nop                                                                                                                                                                                                   | <pre>#M_TE,x:M_TCSR0</pre> | ;; enable timer                                                                                                                          |                           |  |
|                  | bclr                                                                                                                                                                                                                 | <pre>#M_TE,x:M_TCSR0</pre> | ;; disable timer                                                                                                                         |                           |  |
|                  |                                                                                                                                                                                                                      |                            |                                                                                                                                          |                           |  |



| Errata<br>Number | Errata Descript                                        | ion                                                                    |                                                                                                                                                                                                                              | Applies<br>to Mask |
|------------------|--------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
|                  | - option 2                                             |                                                                        |                                                                                                                                                                                                                              |                    |
|                  | movep #\$848                                           | 254,x:M_DCR3                                                           | <pre>;; enable DMA channel 3, block ;; transfer mode, DE is ;; disabled at the end of ;; the transfer, triggered by ;; Timer0 ;; (TCF0=1)</pre>                                                                              |                    |
|                  | bset #M_TE<br>nop<br>nop                               | ,x:M_TCSR0                                                             | ;; enable timer                                                                                                                                                                                                              |                    |
|                  | -                                                      | ,x:M_TCSR0                                                             | ;; disable timer                                                                                                                                                                                                             |                    |
|                  | - option 3                                             |                                                                        |                                                                                                                                                                                                                              |                    |
|                  | bset #M TE                                             | ,x:M TCSR0                                                             | ;; enable timer                                                                                                                                                                                                              |                    |
|                  |                                                        | 254,x:M_DCR3                                                           |                                                                                                                                                                                                                              |                    |
|                  | end of                                                 |                                                                        | ;; mode, DE is disabled at the                                                                                                                                                                                               |                    |
|                  | Timer0                                                 |                                                                        | <pre>;; the transfer, triggered by ;; (TCF0=1)</pre>                                                                                                                                                                         |                    |
| ES94             | bclr #M_TE                                             | ,x:M_TCSR0                                                             |                                                                                                                                                                                                                              |                    |
| cont.            | Following are t                                        | he differences                                                         | s between these three options:                                                                                                                                                                                               |                    |
|                  |                                                        |                                                                        | should be enabled only for the first block<br>transfers can be triggered by the following                                                                                                                                    |                    |
|                  | nop<br>nop                                             | _                                                                      | ;; enable timer                                                                                                                                                                                                              |                    |
|                  | _                                                      | ,x:M_TCSR0                                                             | ;; disable timer                                                                                                                                                                                                             |                    |
|                  | Note:                                                  |                                                                        |                                                                                                                                                                                                                              |                    |
|                  | is triggered afte<br>be cleared no la<br>Otherwise, an | er the TE bit of<br>ater than 3355<br>undesirable tr<br>nel must be di | n be interrupted because the DMA channel<br>f the TCSR0 register is set. The TE bit must<br>4430 DSP clock cycles after it is set.<br>igger for the DMA channel is generated.<br>isabled every time when Timer 0 is used for |                    |
|                  | option 2 : The v<br>transfer is to be                  | -                                                                      | ce must be used every time when a block                                                                                                                                                                                      |                    |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                 | Applies<br>to Mask |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
|                  | Note:                                                                                                                                                                                                                                                                                              | 0H82G              |
|                  | Execution of this sequence may be interrupted because the DMA<br>channel is triggered after the TE bit of the TCSR0 register is set. The TE<br>bit must be cleared no later than 33554430 DSP clock cycles after is is set.<br>Otherwise, an undesirable trigger for the DMA channel is generated. |                    |
| ES94             | option 3: The whole sequence must be used every time a block transfer is to be triggered.                                                                                                                                                                                                          |                    |
| cont.            | Note:                                                                                                                                                                                                                                                                                              |                    |
|                  | Execution of the first two instructions of the sequence must be<br>uninterruptable. The TE bit of the TCSR0 register must be cleared no<br>later than 33554430 DSP clock cycles after it is set. Otherwise, an<br>undesirable trigger for the DMA channel is generated.                            |                    |
|                  | Another peripheral can be used for this purpose, but taking into consideration its specific features.                                                                                                                                                                                              |                    |
|                  | Description (added 8/15/98):                                                                                                                                                                                                                                                                       | 0H82G              |
| ECOT             | If more than a single DMA channel is enabled while the DSP stays in the WAIT processing state, and triggering one of the DMA channels causes an exit from the WAIT state (See A-6.115, UM), triggering another DMA channel might cause improper DMA operation.                                     |                    |
| ES95             | Workaround:                                                                                                                                                                                                                                                                                        |                    |
|                  | Assure that only a single DMA channel can be triggered during DSP<br>WAIT state. If the application cannot guarantee this, other DMA<br>channels should be disabled before the WAIT processing state is<br>entered and then reenabled after WAIT state is exited.                                  |                    |



| Errata<br>Number | Errata Description                                                                                                                                                                      | Applies<br><u>to Mask</u> |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|
|                  | Description (added 10/26/98):                                                                                                                                                           | 0H82G                     |  |
|                  | If the reset mode is expanded mode (for example, mode 0 or mode 8 on<br>the DSP5630x), A MOVE (not a PROGRAM FETCH) from internal P<br>memory to any destination may not work properly. |                           |  |
|                  | Workaround:                                                                                                                                                                             |                           |  |
| ES101            | After each reset (RESET) negation and before the first move from internal program memory, execute the following sequence:                                                               |                           |  |
|                  | BSET #M_CE,sr<br>NOP<br>NOP<br>BCLR #M_CE,sr                                                                                                                                            |                           |  |
|                  | Description (added 11/20/98):                                                                                                                                                           | 0H82G                     |  |
|                  | An improper operation may occur when a DMA channel uses the following transfer modes:                                                                                                   |                           |  |
|                  | • DTM(2:0) = 100                                                                                                                                                                        |                           |  |
|                  | • DTM(2:0) = 101                                                                                                                                                                        |                           |  |
|                  | where the DE bit is not automatically cleared at the end of block and the DMA channel is disabled by software (DE bit is cleared) while it is triggered for a new transfer.             |                           |  |
| ES104            | Workaround:                                                                                                                                                                             |                           |  |
|                  | The DMA channel should be disabled only when it cannot be triggered by a new transfer. Use one of the following alternatives:                                                           |                           |  |
|                  | 1. The system configuration must guarantee that no DMA trigger can occur while the DE bit is cleared.                                                                                   |                           |  |
|                  | 2. The following sequence disables the DMA channel:                                                                                                                                     |                           |  |
|                  | a/ Wait until the DTD bit is cleared<br>b/ Clear the DE bit<br>c/ Wait until the DTD bit is set                                                                                         |                           |  |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Applies<br><u>to Mask</u> |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|
|                  | Description (added 11/25/98):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |  |  |
|                  | If the core clears the HCIE bit on the HCR register while an interrupt is issued as<br>the vector is read by the interrupt controller, then when the interrupt is service<br>HCP is not cleared, since the clear equation is conditioned by HCIE=1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                           |  |  |
|                  | Workaround :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                           |  |  |
|                  | There are two possible workarounds:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                           |  |  |
|                  | <ol> <li>If only host commands are used as possible interrupt source to the core (i.e. HTIE and HRIE are both 0), then instead of bit-set and bit-clear to the HCIE, do bit-set and bit-clear instructions on the IPRP register for the HIE bit.</li> <li>If option "1" cannot be used, first turn off host interrupt requests (all the possible sources) by clearing the bits in the IPRP register that are used to enable/disable HDI08/HI08 interrupt requests (HPL on the DSP56307 and differ from chip to chip. Consult the user's manual for your DSP563xx chip to find the correct bit IPRP bit names.) Then issue 6 NOP instructions, clear the HCIE bit or the HCR, issue another 6 NOP instructions and finally re-enable the IPRP interrupt request enable/disable bit as follows:</li> </ol> |                           |  |  |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                           |  |  |
| ES105            | ;; Clear the relevant bits on IPRP register acording to ;; current host interrupt priority settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | the                       |  |  |
|                  | <pre>BCLR #M_HPL0,x:M_IPRP<br/>BCLR #M_HPL1,x:M_IPRP<br/>;; Issue 6 NOP instructions<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>;; Clear the HCIE bit on HCR register to turn off host<br/>BCLR #M_HCIE,x:M_HCR<br/>;; Issue 6 NOP instructions<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>NOP<br/>SET #M_HPL0,x:M_IPRP<br/>BSET #M_HPL1,x:M_IPRP</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                        | commands                  |  |  |

For More information On This Product, Go to: www.freescale.com



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                                        | Applies<br><u>to Mask</u> |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (added 12/12/98):                                                                                                                                                                                                                                                                                             | 0H82G                     |
| ES108            | The Timer's TIOx pin does not function properly in WatchDog mode<br>while the RESET pin is asserted. The TIOx pin is tri-stated immediately<br>after RESET assertion; it should be driven for 2.5 internal clock cycles<br>according to the specification (section 9.4.4.1 and 9.4.4.2 of the<br>DSP56303 User's Manual). |                           |
|                  | Workaround:                                                                                                                                                                                                                                                                                                               |                           |
|                  | Provide external logic in order to extend the TIOx pin assertion.                                                                                                                                                                                                                                                         |                           |
|                  | Description (added 4/19/99):                                                                                                                                                                                                                                                                                              | 0H82G                     |
| ES113            | If the DSP core is brought out of the wait processing state by a DMA request, the internal DSP clock could be extended by 1/2 cycle. This extension would be reflected in the behavior of CLKOUT, a 180 degree phase shift. DSP operation continues unaffected after this event.                                          |                           |
|                  | Workaround:                                                                                                                                                                                                                                                                                                               |                           |
|                  | None                                                                                                                                                                                                                                                                                                                      |                           |
|                  | Description (added 4/19/99, revised 4/30/99):                                                                                                                                                                                                                                                                             | 0H82G                     |
| ES114            | A DMA channel may operate improperly when the address mode of this channel is defined as three-dimensional $(D3D=1)$ and $DAM[5:0] = 1xx 1 10$ or $DAM[5:0] = 01xx 10$ (i.e., triple counter mode is E).                                                                                                                  |                           |
|                  | Workaround:                                                                                                                                                                                                                                                                                                               |                           |
|                  | Use the triple counter modes C(DAM[1:0]=00) or D(DAM[1:0]=01) instead of the E(DAM[1:0]=10) mode.                                                                                                                                                                                                                         |                           |



| Errata |                                                                                                                                                                                                                                                                                                                                                                                                               | Applies |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Number | Errata Description                                                                                                                                                                                                                                                                                                                                                                                            | to Mask |
|        | Description (added 4/19/99):                                                                                                                                                                                                                                                                                                                                                                                  | 0H82G   |
|        | When a DMA channel (called channel A) is disabled by software clearing the channel's DCR[DE] bit, the DTD bit may not get set, and the DMA end of the block interrupt may not happen if one of the following occurs:                                                                                                                                                                                          |         |
|        | 1. There is another channel (channel B) executing EXTERNAL accesses,<br>and the DE bit of channel A is being cleared by software at the end of<br>the channel B word transfer - if channel B is in Word transfer mode, or<br>at the end of the channel B line transfer - if channel B is in Line Transfer<br>mode, or at the end of the channel B block transfer - if channel B is in<br>Block transfer mode. |         |
| ES115  | 2. This channel (A) is executing EXTERNAL accesses, and the DE bit of<br>this channel (A) is being cleared by software at the end of the channel B<br>word transfer - if channel B is in Word transfer mode, or at the end of<br>the channel B line transfer - if channel B is in Line transfer mode.                                                                                                         |         |
|        | Workaround:                                                                                                                                                                                                                                                                                                                                                                                                   |         |
|        | Avoid executing a DMA external access when any DMA channel<br>should be disabled. This can be done as follows. Every time the DMA<br>channel needs to be disabled by software, the following sequence must<br>be used:                                                                                                                                                                                        |         |
|        | <pre>;; initialize an unused DMA channel "C" movep #DSR_swflag, x:M_DSRC ;; here DSR_swflag is an ;; unused X, Y or P memory ;; location, should ;; be initialized to ;; \$800000 ;; M_DSRC - address of the ;; channel C DSR register.</pre>                                                                                                                                                                 |         |



| Errata<br>Number | Errata De | scription                                                                                                                                                                                                                                                                                                                                                                                                                                       | Applies<br>to Mask |
|------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
|                  | movep     | <pre>#DDR_swflag, x:M_DDRC ;; DDR_swflag is an unused<br/>;; X, Y or P memory<br/>;; location, should be<br/>;; initialized to \$000000<br/>;; M_DDRC -<br/>;; address of the channel o<br/>;; DDR register .</pre>                                                                                                                                                                                                                             |                    |
|                  | movep     | <pre>#TR_LENGTH, x:M_DCOC ;; see below the definition ;; of the TR_LENGTH value, ;; M_DCOC - address ;; of the channel C DCO</pre>                                                                                                                                                                                                                                                                                                              | ı                  |
| ES115<br>cont.   | register  | <pre>.movep #1f0240, x:M_DCRC ;; M_DCRB - address of the<br/>;; channel C DCR register.<br/>;; Set transfer mode -<br/>;; block transfer,<br/>;; triggered by<br/>;; software highest<br/>;; priority, continuous<br/>;; mode on no-update<br/>;; source and destination<br/>;; address mode X memory<br/>;; location for source<br/>;; and destination (can be<br/>;; chosen by<br/>;; user accordingly to<br/>;; DSR_swflag/DDR_swflag)</pre> | 2                  |



| Errata<br>Number | Errata Description                                                                                                                                                                                                                                                                                   | Applies<br><u>to Mask</u> |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | <pre>Errata Description ;; disable DMA channel "A"</pre>                                                                                                                                                                                                                                             | to Mask<br>0H82G          |
|                  | external read/write DMA cycle can be defined as the length of<br>the PORTA external access. The length of the internal read/write<br>DMA cycle can be defined in the errata case as 2 DSP clock<br>cycles. The TR_LENGTH can be found as sum of the lengths of the<br>DMA read and DMA write cycles. |                           |



#### **Documentation Errata**

| Errata<br>Number | Errata Description                                                                                                                                                     | Applies<br><u>to Mask</u> |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
|                  | Description (revised 11/9/98):                                                                                                                                         | 0H82G                     |
|                  | XY memory data move does not work properly under one of the following two situations:                                                                                  |                           |
|                  | 1. The X-memory move destination is internal I/O and the Y-<br>memory move source is a register used as destination in the<br>previous adjacent move from non Y-memory |                           |
|                  | 2. The Y-memory move destination is a register used as source in the next adjacent move to non Y-memory.                                                               |                           |
|                  | Here are examples of the two cases (where x:(r1) is a peripheral):                                                                                                     |                           |
| ED1              | Example 1:                                                                                                                                                             |                           |
| EDI              | <pre>move #\$12,y0 move x0,x:(r7) y0,y:(r3) (while x:(r7) is a peripheral).</pre>                                                                                      |                           |
|                  | Example 2:                                                                                                                                                             |                           |
|                  | <pre>mac x1,y0,a x1,x:(r1)+ y:(r6)+,y0 move y0,y1</pre>                                                                                                                |                           |
|                  | Any of the following alternatives can be used:                                                                                                                         |                           |
|                  | a. Separate these two consecutive moves by any other instruction.                                                                                                      |                           |
|                  | b. Split XY Data Move to two moves.                                                                                                                                    |                           |
|                  | Pertains to: DSP56300 Family Manual, Section B-5 "Peripheral pipeline restrictions.                                                                                    |                           |
|                  | 1. Description (added 5/7/1996):                                                                                                                                       | 0H82G                     |
| ED3              | A one-word conditional branch instruction at LA-1 is not allowed.                                                                                                      |                           |
|                  | Pertains to: DSP56300 Family Manual, Appendix B, Section B.4.1.3                                                                                                       |                           |
|                  | Description (added 10/09/1997):                                                                                                                                        | 0H82G                     |
|                  | The following instructions should not start at address LA:                                                                                                             |                           |
| ED4              | MOVE to/from Program space {MOVEM, MOVEP (only the P space options)}                                                                                                   |                           |
|                  | This is not a bug but a documentation update (Appendix B, DSP56300 Family Manual).                                                                                     |                           |



|      | Description (added 1/27/98):                                                                                                                                                                                                                                                                           | 0H82G |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ED7  | When activity is passed from one DMA channel to another and the DMA interface accesses external memory (which requires one or more wait states), the DACT and DCH status bits in the DMA Status Register (DSTR) may indicate improper activity status for DMA Channel 0 (DACT = 1 and DCH[2:0] = 000). |       |
|      | Workaround:                                                                                                                                                                                                                                                                                            |       |
|      | None.                                                                                                                                                                                                                                                                                                  |       |
|      | This is not a bug, but a specification update.                                                                                                                                                                                                                                                         |       |
|      | Description (added 1/27/98):                                                                                                                                                                                                                                                                           | 0H82G |
|      | When the SCI is configured in Synchronous mode, internal clock,<br>and all the SCI pins are enabled simultaneously, an extra pulse of 1<br>DSP clock length is provided on the SCLK pin.                                                                                                               |       |
| ED9  | Workaround:                                                                                                                                                                                                                                                                                            |       |
|      | a. Enable an SCI pin other than SCLK.                                                                                                                                                                                                                                                                  |       |
|      | b. In the next instruction, enable the remaining SCI pins, including the SCLK pin.                                                                                                                                                                                                                     |       |
|      | This is not a bug, but a specification update.                                                                                                                                                                                                                                                         |       |
|      | Description (added 7/21/98):                                                                                                                                                                                                                                                                           | 0H82G |
|      | The DRAM Control Register (DCR) should not be changed while refresh is enabled. If refresh is enabled only a write operation that disables refresh is allowed.                                                                                                                                         |       |
| ED15 | Workaround:                                                                                                                                                                                                                                                                                            |       |
|      | First disable refresh by clearing the BREN bit, than change other bits<br>in the DCR register, and finally enable refresh by setting the BREN<br>bit.                                                                                                                                                  |       |
|      | Description (added 9/28/98):                                                                                                                                                                                                                                                                           | 0H82G |
| ED17 | In all DSP563xx technical datasheets, a note is to be added under<br>"AC Electrical Characteristics" that although the minimum value for<br>"Frequency of Extal" is 0MHz, the device AC test conditions are<br>15MHz and rated speed.                                                                  |       |
|      | Workaround:                                                                                                                                                                                                                                                                                            |       |
|      | N/A                                                                                                                                                                                                                                                                                                    |       |



|      | Description (added 11/24/98):                                                                                                                                                                      | 0H82G |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ED20 | In the Technical Datasheet Voh-TTL should be listed at 2.4 Volts, not as:<br>TTL = Vcc-0.4                                                                                                         |       |
|      | Workaround:                                                                                                                                                                                        |       |
|      | This is a documentation update.                                                                                                                                                                    |       |
|      | Description (added 11/24/98):                                                                                                                                                                      | 0H82G |
| ED21 | In the Technical Datasheet Iol should be listed as 1.6 mA, not as 3.0 mA.                                                                                                                          |       |
|      | Workaround:                                                                                                                                                                                        |       |
|      | This is a documentation update.                                                                                                                                                                    |       |
|      | Description (added 11/24/98):                                                                                                                                                                      | 0H82G |
| ED24 | The technical datasheet supplies a maximum value for internal<br>supply current in Normal, Wait, and Stop modes. These values will<br>be removed because we will specify only a "Typical" current. |       |
|      | Workaround:                                                                                                                                                                                        |       |
|      | This is a documentation update.                                                                                                                                                                    |       |
|      | Description (added 1/6/99):                                                                                                                                                                        | 0H82G |
|      | The specification DMA Chapter is wrong.                                                                                                                                                            |       |
| ED26 | "Due to the DSP56300 Core pipeline, after DE bit in DCRx is set, the corresponding DTDx bit in DSTR will be cleared only after two instruction cycles."                                            |       |
|      | Should be replaced with:                                                                                                                                                                           |       |
|      | "Due to the DSP56300 Core pipeline, after DE bit in DCRx is set, the corresponding DTDx bit in DSTR will be cleared only after three instruction cycles."                                          |       |



| ·    |                                                                                                                                                                                                                                                                                                  |       |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|      | Description (added $1/7/1997$ ; identified as Documentation Errata $2/1/99$ ):                                                                                                                                                                                                                   | 0H82G |
|      | When two consecutive LAs have a conditional branch instruction at LA-1 of the internal loop, the part does not operate properly. For example, the following sequence may generate incorrect results:                                                                                             |       |
| ED28 | DO #5, LABEL1<br>NOP<br>DO #4, LABEL2<br>NOP<br>MOVE (R0) +<br>BSCC _DEST ; conditional branch at LA-1 of<br>internal loop<br>NOP ; internal LA<br>LABEL2<br>NOP ; external LA<br>LABEL1<br>NOP<br>DEST NOP<br>NOP<br>RTS                                                                        |       |
|      | Workaround: Put an additional NOP between LABEL2 and LABEL1.                                                                                                                                                                                                                                     |       |
|      | <b>Pertains to:</b> DSP56300 Family Manual, Appendix B, Section B-4.1.3, "At LA-1."                                                                                                                                                                                                              |       |
|      | Description (added $9/12/1997$ ; identified as a Documentation errata $2/1/99$ ):                                                                                                                                                                                                                | 0H82G |
| ED29 | When the ESSI transmits data with the CRA Word Length Control<br>bits<br>(WL[2:0]) = 100, the ESSI is designed to duplicate the last bit of the<br>24-bit transmission eight times to fill the 32-bit shifter. Instead, after<br>shifting the 24-bit word correctly, eight 0s are being shifted. |       |
|      | Workaround:                                                                                                                                                                                                                                                                                      |       |
|      | None at this time.                                                                                                                                                                                                                                                                               |       |
|      | <b>Pertains to:</b> UM, Section 7.4.1.7, "CRA Word Length Control." The table number is 7-2.                                                                                                                                                                                                     |       |



|      | Description (added $9/12/1997$ ; identified as a Documentation errata $2/1/99$ ):                                                                                                                                                                                                                                                                                                                                    | 0H82G |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|      | When the ESSI transmits data in the On-Demand mode (i.e., $MOD = 1$ in CRB and $DC[4:0] = \$00000$ in CRA) with $WL[2:0] = 100$ , the transmission does not work properly.                                                                                                                                                                                                                                           |       |
| ED30 | Workaround:                                                                                                                                                                                                                                                                                                                                                                                                          |       |
|      | To ensure correct operation, do not use the On-Demand mode with<br>the<br>WL[2:0] = 100 32-bit Word-Length mode.                                                                                                                                                                                                                                                                                                     |       |
|      | <b>Pertains to:</b> UM, Section 7.5.4.1, "Normal/On-Demand Mode Selection."                                                                                                                                                                                                                                                                                                                                          |       |
|      | Description (added 9/12/1997; modified 9/15/1997; identified as a Documentation errata 2/1/99):                                                                                                                                                                                                                                                                                                                      | 0H82G |
|      | Programming the ESSI to use an internal frame sync (i.e., SCD2 = 1<br>in CRB) causes the SC2 and SC1 signals to be programmed as<br>outputs. If however, the corresponding multiplexed pins are<br>programmed by the Port Control Register (PCR) to be GPIOs, then<br>the GPIO Port Direction Register (PRR) chooses their direction, but<br>this causes the ESSI to use an external frame sync if GPIO is selected. |       |
| ED31 | Note: This errata and workaround apply to both ESSI0 and ESSI1.                                                                                                                                                                                                                                                                                                                                                      |       |
|      | Workaround:                                                                                                                                                                                                                                                                                                                                                                                                          |       |
|      | To assure correct operation, either program the GPIO pins as outputs or configure the pins in the PCR as ESSI signals.                                                                                                                                                                                                                                                                                               |       |
|      | <b>Note:</b> The default selection for these signals after reset is GPIO.                                                                                                                                                                                                                                                                                                                                            |       |
|      | <b>Pertains to:</b> UM, Section 7.4.2.4, "CRB Serial Control Direction 2 (SCD2) Bit 4"                                                                                                                                                                                                                                                                                                                               |       |



| ED32 | Description (added $11/9/98$ ; identified as a Documentation errata $2/1/99$ ):                                                                                                                                                                                              | 0H82G |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|      | When returning from a long interrupt (by RTI instruction), and the first instruction after the RTI is a move to a DALU register (A, B, X, Y), the move may not be correct, if the 16-bit arithmetic mode bit (bit 17 of SR) is changed due to the restoring of SR after RTI. |       |
|      | Workaround:                                                                                                                                                                                                                                                                  |       |
|      | Replace the RTI with the following sequence:                                                                                                                                                                                                                                 |       |
|      | movec ssl,sr<br>nop<br>rti                                                                                                                                                                                                                                                   |       |
|      | <b>Pertains to:</b> DSP56300 Family Manual. Add a new section to Appendix B that is entitled "Sixteen-Bit Compatibility Mode Restrictions."                                                                                                                                  |       |



Description (added 12/16/98; identified as a Documentation errata 0H82G 2/1/99): When Stack Extension mode is enabled, a use of the instructions BRKcc or ENDDO inside do loops might cause an improper operation. If the loop is non nested and has no nested loop inside it, the erratais relevant only if LA or LC values are being used outside the loop. Workaround: If Stack Extension is used, emulate the BRKcc or ENDDO as in the following examples. We split between two cases, finite loops and do forever loops. 1) Finite DO loops (i.e. not DO FOREVER loops) BRKcc Original code: **ED33** do #N,label1 . . . . . . . . . . do #M,label2 . . . . . . . . . . BRKcc . . . . . . . . . . label2 . . . . . . . . . . label1 Will be replaced by: do #N, label1 . . . . . . . . . . do #M, label2 . . . . . . . . . . fix brk routine Jcc . . . . . . . . . .



| r          |                                     |       |
|------------|-------------------------------------|-------|
|            | nop_before_label2                   | 0H82G |
|            | nop ; This instruction must be NOP. |       |
|            | label2                              |       |
|            | •••••                               |       |
|            | ·····                               |       |
|            | label1                              |       |
|            |                                     |       |
|            |                                     |       |
|            | fix_brk_routine                     |       |
|            | move #1,lc                          |       |
|            | jmp nop_before_label2               |       |
|            | ENDDO                               |       |
|            |                                     |       |
|            | Original code:                      |       |
|            | do #M,label1                        |       |
|            |                                     |       |
| ED33 cont. |                                     |       |
| ED55 cont. | do #N,label2                        |       |
|            | •••••                               |       |
|            |                                     |       |
|            | ENDDO                               |       |
|            |                                     |       |
|            | label2                              |       |
|            |                                     |       |
|            |                                     |       |
|            | label1                              |       |
|            | Will be replaced by:                |       |
|            | do #M, label1                       |       |
|            |                                     |       |
|            |                                     |       |
|            | do #N, label2                       |       |
|            |                                     |       |
|            |                                     |       |
|            | JMP fix_enddo_routine               |       |



|            |                                     | _     |
|------------|-------------------------------------|-------|
|            | nop_after_jmp                       | 0H82G |
|            | NOP ; This instruction must be NOP. |       |
|            |                                     |       |
|            |                                     |       |
|            | label2                              |       |
|            |                                     |       |
|            | label1                              |       |
|            |                                     |       |
|            |                                     |       |
|            |                                     |       |
|            | fix_enddo_routine                   |       |
|            | move #1,1c                          |       |
|            | move #nop_after_jmp,la              |       |
|            | jmp nop_after_jmp                   |       |
|            | 2) DO FOREVER loops                 |       |
| ED33 cont. |                                     |       |
|            | BRKcc                               |       |
|            |                                     |       |
|            | Original code:                      |       |
|            | do #M,label1                        |       |
|            |                                     |       |
|            | <br>do forever,label2               |       |
|            |                                     |       |
|            |                                     |       |
|            | BRKcc                               |       |
|            |                                     |       |
|            |                                     |       |
|            | label2                              |       |
|            |                                     |       |
|            | label1                              |       |
|            |                                     |       |



Will be replaced by: 0H82G do #M,label1 . . . . . . . . . . do forever, label2 . . . . . . . . . . fix brk forever routine ; <---JScc note: JScc and not Jcc . . . . . . . . . . nop before label2 nop ; This instruction must be NOP. label2 . . . . . . . . . . ED33 cont. label1 . . . . . . . . fix brk forever routine move ssh, x:<...>; <...> is some reserved not used address (for temporary data) move #nop\_before\_label2,ssh bclr #16,ssl ; move #1,lc ; <---- note: "rti" and not "rts" ! rti ENDDO \_ \_ \_ \_ \_ \_ Original code: do #M,label1 . . . . . . . . . .



| r          |                                                                        |       |
|------------|------------------------------------------------------------------------|-------|
|            | do forever,label2                                                      | 0H82G |
|            |                                                                        |       |
|            | ENDDO                                                                  |       |
|            |                                                                        |       |
|            |                                                                        |       |
|            | label2                                                                 |       |
|            |                                                                        |       |
|            |                                                                        |       |
|            | label1                                                                 |       |
|            | Will be replaced by:                                                   |       |
|            | do #M,label1                                                           |       |
|            |                                                                        |       |
|            |                                                                        |       |
|            | do forever,label2                                                      |       |
|            |                                                                        |       |
|            | JSR fix_enddo_routine ; < note:                                        |       |
| ED33 cont. | JSR and not JMP                                                        |       |
|            | nop_after_jmp                                                          |       |
|            | NOP ; This instruction should be NOP                                   |       |
|            | •••••                                                                  |       |
|            | label2                                                                 |       |
|            |                                                                        |       |
|            |                                                                        |       |
|            | label1                                                                 |       |
|            |                                                                        |       |
|            | ••••                                                                   |       |
|            | fix_enddo_routine                                                      |       |
|            | nop                                                                    |       |
|            | move #1,1c                                                             |       |
|            | bclr #16,ssl                                                           |       |
|            | <pre>move #nop_after_jmp,la rti ; &lt; note: "rti" and not "rts"</pre> |       |
|            |                                                                        |       |
|            | <b>Pertains to:</b> DSP56300 Family Manual, Section B-4.2, "General Do |       |
|            | Restrictions."                                                         |       |



|      | Description (added 1 /5 /00, identified as a Demonstration (                                                                                                                                                                                          | 011000 |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|      | Description (added $1/5/99$ ; identified as a Documentation errata $2/1/99$ ):                                                                                                                                                                        | 0H82G  |
|      | When stack extansion is enabled, the read result from stack may be<br>improper if two previous executed instructions cause sequential<br>read and write operations with SSH. Two cases are possible:                                                  |        |
|      | Case 1:                                                                                                                                                                                                                                               |        |
|      | For the first executed instruction: move from SSH or bit<br>manipulation on SSH (i.e. jclr, brclr, jset, brset, btst, bsset, jsset, bsclr,<br>jsclr).                                                                                                 |        |
|      | For the second executed instruction: move to SSH or bit manipulation on SSH (i.e. jsr, bsr, jscc, bscc).                                                                                                                                              |        |
| ED24 | For the third executed instruction: an SSL or SSH read from the stack<br>result may be improper - move from SSH or SSL or bit manipulation<br>on SSH or SSL (i.e., bset, bclr, bchg, jclr, brclr, jset, brset, btst, bsset,<br>jsset, bsclr, jsclr).  |        |
| ED34 | Workaround:                                                                                                                                                                                                                                           |        |
|      | Add two NOP instructions before the third executed instruction.                                                                                                                                                                                       |        |
|      | Case 2:                                                                                                                                                                                                                                               |        |
|      | For the first executed instruction: bit manipulation on SSH (i.e. bset, bclr, bchg).                                                                                                                                                                  |        |
|      | For the second executed instruction: an SSL or SSH read from the<br>stack result may be improper - move from SSH or SSL or bit<br>manipulation on SSH or SSL (i.e., bset, bclr, bchg, jclr, brclr, jset,<br>brset, btst, bsset, jsset, bsclr, jsclr). |        |
|      | Workaround:                                                                                                                                                                                                                                           |        |
|      | Add two NOP instructions before the second executed instruction.                                                                                                                                                                                      |        |
|      | <b>Pertains to:</b> DSP56300 Family Manual, Appendix B, add a new section called "Stack Extension Enable Restrictions." Cover all cases. Also, in Section 6.3.11.15, add a cross reference to this new section.                                       |        |



|      | Description (added 7/14/99):                                                                                                                                                                                                                                                                                                                                                           | 0H82G |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ED38 | If Port A is used for external accesses, the BAT bits in the AAR3-0 registers must be initialized to the SRAM access type (i.e. BAT = 01) or to the DRAM access type (i.e. BAT = 10). To ensure proper operation of Port A, this initialization must occur even for an AAR register that is not used during any Port A access. Note that at reset, the BAT bits are initialized to 00. |       |
|      | <b>Pertains to:</b> <i>DSP56300 Family Manual</i> , Port A Chapter (Chapter 9 in Revision 2), description of the BAT[1–0] bits in the AAR3 - AAR0 registers. Also pertains to the core chapter in device-specific user's manuals that include a description of the AAR3 - AAR0 registers with bit definitions (usually Chapter 4).                                                     |       |



|      | Description (added 11/11/99):                                                                                                                                                                                                                                                                                                                                                                                              | 0H82G  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|      | When an instruction with all the following conditions follows a repeat instruction, then the last move will be corrupted.:                                                                                                                                                                                                                                                                                                 | 011020 |
|      | 1. The repeated instruction is from external memory.                                                                                                                                                                                                                                                                                                                                                                       |        |
|      | 2. The repeated instruction is a DALU instruction that includes 2 DAL registers, one as a source, and one as destination (e.g. tfr, add).                                                                                                                                                                                                                                                                                  |        |
|      | 3. The repeated instruction has a double move in parallel to the DALU instruction: one move's source is the destination of the DALU instruction (causing a DALU interlock); the other move's destination is the source of the DALU instruction.                                                                                                                                                                            |        |
|      | Example:                                                                                                                                                                                                                                                                                                                                                                                                                   |        |
|      | rep #number                                                                                                                                                                                                                                                                                                                                                                                                                |        |
|      | tfr x0, a $x(r0)+x0$ a, y0; This instruction is from external memory                                                                                                                                                                                                                                                                                                                                                       |        |
|      | > This is condition 3 second part.<br>  > This is condition 3, first part - DALU interlock                                                                                                                                                                                                                                                                                                                                 |        |
| ED40 | In this example, the second iteration before the last, the $"x(r0)+,x0"$ doesn't happen. On the first iteration before the last, the X0 register is fixed with the $"x(r0)+,x0"$ , but the "tfr x0,a" gets the wrong value from the previous iteration's X0. Thus, at the last iteration the A register is fixed with "tfr x0,a", but the "a,y0" transfers the wrong value from the previous iteration's A register to Y0. |        |
|      | Workaround:<br>1. Use the DO instruction instead; mask any necessary interrupts<br>before the DO.                                                                                                                                                                                                                                                                                                                          |        |
|      | 2. Run the REP instructions from internal memory.                                                                                                                                                                                                                                                                                                                                                                          |        |
|      | 3. Don't make DALU interlocks in the repeated instruction. After the repeat make the move. In the example above, all the "move a,y0" are redundant so it can be done in the next instruction:                                                                                                                                                                                                                              |        |
|      | rep #number<br>tfr x0,a x(r0)+,x0<br>move a,y0                                                                                                                                                                                                                                                                                                                                                                             |        |
|      | If no interrupts before the move is a must, mask the interrupts<br>before the REP. <b>Pertains to:</b> <i>DSP56300 Family Manual</i> , Rev. 2,<br>Section A.3, "Instruction Sequence Restrictions."                                                                                                                                                                                                                        |        |



| ED42 | Description (added on 3/22/2000)                                                                                                                                                               | 0H82G |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|      | The DMA End-of-Block-Transfer interrupt cannot be used if DMA is operating in the mode in which DE is not cleared at the end of the block transfer (DTM = $100$ or $101$ ).                    |       |
|      | Pertains to:                                                                                                                                                                                   |       |
|      | <i>DSP56300 Family Manual</i> , Rev. 2, Section 10.4.1.2, "End-of-Block-Transfer Interrupt." Also, Section 10.5.3.5, "DMA Control Registers (DCR[5–0]," discussion of bits 21 – 19 (DTM bits). |       |
| ED50 | Description (added 9/10/1996 as ES29; reclassified as a documentation erratum on 8/2/2002):                                                                                                    | 0H82G |
|      | When the SCI transmitter is used in Synchronous mode, the last bit<br>of the transmitted byte might be truncated to the half of the serial<br>cycle.                                           |       |
|      | Workaround: Not available.                                                                                                                                                                     |       |

Motorola and (1) are registered trademarks of Motorola, Inc. OnCE is a trademark of Motorola, Inc.

# NOTES

- 1. An over-bar (i.e.,  $\overline{xxxx}$ ) indicates an active-low signal.
- 2. The letters seen to the right of the errata tell which DSP56303 mask numbers apply.
- 3. The Motorola DSP website has additional documentation updates that can be accessed at the following URL:

http://www.mot.com/SPS/DSP/home/eng/tec/doc\_update.html

-end-