

# **Product Update**

Errata for eZ80Acclaim!<sup>®</sup> eZ80F91 Silicon

UP006109-0910

## eZ80F91 MCU with Part Numbers and Date Codes 0317 and Later

The errata listed in Table 1 highlights the issues and workarounds (if available) for Zilog's eZ80F91 product with package part numbers eZ80F91AZ050SG, eZ80F91AZ050EG, eZ80F91NA050SG, and eZ80F91NA050EG illustrating date codes of 0317 and later, indicating assembly no earlier than the 17th week of the year 2003. Data in this document is Preliminary Only.

| No | Issue                                                                                                       | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|----|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1  | The real time clock<br>(RTC) consumes<br>excess current when<br>the eZ80F91 device is<br>not in SLEEP mode. | When the eZ80F91 device is not in SLEEP mode, the system clock drives<br>the RTC control and data registers. As a result, excess current is<br>consumed through the RTC_V <sub>DD</sub> pin, which supplies power to the portion<br>of the clock tree that drives the RTC registers. This current consumption<br>is a function of the operating frequency. The faster the frequency, the<br>more power is consumed. |  |  |  |  |
|    |                                                                                                             | <b>Workaround</b><br>To prevent the excess current consumption, design with a battery-<br>charging circuit for the RTC_V <sub>DD</sub> pin. As a result, the charge will remain<br>on the RTC battery while power is supplied to the chip.                                                                                                                                                                          |  |  |  |  |
| 2  | WP pin functionality.                                                                                       | Assertion of the WP pin protects the Flash Memory boot block from memory Writes. It also protects all blocks and the information page from Page Erases, Mass Erases, and I/O Writes.                                                                                                                                                                                                                                |  |  |  |  |
|    |                                                                                                             | Workarounds                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|    |                                                                                                             | The following two options are available:                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|    |                                                                                                             | <ol> <li>Do not assert the WP pin in your design.</li> <li>De-assert the WP pin when you are executing page erases and I/O<br/>Writes to blocks other than Block 0 or executing a page erase or I/O<br/>Write of the Information Page.Then re-assert the pin when you are<br/>finished, for example, jumper block header.</li> </ol>                                                                                |  |  |  |  |
| 3  | When the RTC oscillator is disabled,                                                                        | The RTC_X <sub>IN</sub> pin can leak to a potential higher than the approximate 1.2V due to the internal 10 M $\Omega$ resistor. This can cause the input                                                                                                                                                                                                                                                           |  |  |  |  |
|    | RTC_X <sub>IN</sub> pin leakage<br>can exceed the 10 μA<br>specification.                                   | leakage current to exceed the specification.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|    |                                                                                                             | Workarounds                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|    |                                                                                                             | To prevent this excess leakage, you can perform one of the following two actions, first being the recommended fix:                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|    |                                                                                                             | <ol> <li>Leave the RTC_X<sub>IN</sub> pin floating, if the oscillator is disabled.</li> <li>Ground the RTC_X<sub>IN</sub> pin, if the oscillator is disabled and not used at all.</li> </ol>                                                                                                                                                                                                                        |  |  |  |  |
| 4  | Superseded by errata number 7.                                                                              | This issue related to RTC time loss was determined to be the same as errata No. 7. To avoid potential confusion, it is no longer detailed here.                                                                                                                                                                                                                                                                     |  |  |  |  |





| No | Issue                                                                                           | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|----|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 5  | The Test Data Input<br>(TDI) pin does not<br>meet the 1149.1<br>boundary scan<br>specification. | Warning: TDI is an I/O pin without a pull-up resistor.<br>NORMAL mode, following RESET,<br>configures TDI as an input. An off-chip pull-<br>up resistor is recommended.                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|    |                                                                                                 | Workaround Add a 10 K $\Omega$ pull-up resistor to the TDI pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| 6  | GPIO edge trigger<br>interrupt mapping<br>error.                                                | For edge triggered interrupts (Mode 6 and Mode 9), erroneous logic dependencies for the interrupt clearing logic exist on all port pins within each of the specific ports. To achieve proper interrupt clearing behavior for a particular port pin its "mirror" pin must be programmed in a similar manner. This affects how the designer utilizes GPIO alternate function pins with GPIO interrupt modalities of those port pins. The definition <i>mirrored pin</i> refers to any PORT where for Port X, pin 0 is mirrored to pin 7, pin 1 is mirrored to pin 6, pin 2 is mirrored to pin 5, pin 3 |  |  |  |  |
|    |                                                                                                 | is mirrored to pin 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|    |                                                                                                 | <b>Note:</b> X is defined as Port A, B, C, or D.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|    |                                                                                                 | For example, if PB0 is programmed as an edge triggered interrupt, to logic dependency to clear the interrupt by writing to PB0_DR and                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|    |                                                                                                 | protecting the actual PB0_DR register value from change comes from the mirror pin PB7 logic. This is an errata problem which causes erratic behavior problems.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|    |                                                                                                 | In the above example, the problem is that PB0_DR itself can be altered<br>and might change the mode of operation for the port pin PB0. To correctl<br>set up the logic dependencies, the <i>mirrored pin</i> must be placed in the<br>same mode as its counterpart. As the functionally of these port pins nee-<br>to be <i>mirrored</i> in order to correct the logic dependency, the alternate<br>function assignments of these ports would not work correctly.                                                                                                                                    |  |  |  |  |
|    |                                                                                                 | To use the SPI alternate function modality (for example, SPI alternate function pins PB2, PB3, PB6, and PB7) you will not be able to use the "mirror" port pins PB5, PB4, PB1, and PB0 for mode 6 and Mode 9                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|    |                                                                                                 | interrupt and vice versa. Any Port pin configured with Mode 6 or Mode 9 (an edge triggered interrupt) exhibits this behavior and affects the alternate function modality. The mirror mapping affects all Ports, specifically within the respective port pin pairs 0 and 7, 1 and 6, 2 and 5, and 3 and 4.                                                                                                                                                                                                                                                                                            |  |  |  |  |
|    |                                                                                                 | <b>Note:</b> This design flaw in no way affects the IVECT address for the GPIO interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |

(continued)



| No                                          | Issue                                   | Detailed Description<br>(continued from previous page)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|---------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                             |                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                                             |                                         | Workaround                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                                             |                                         | Below is an example setup:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                                             |                                         | PB0 Input, falling edge interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                             |                                         | PB1 Input, dual edge interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|                                             |                                         | PB2 Input, falling edge interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                             |                                         | PB3 Input, falling or rising edge interrupt, depending on hardware<br>configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                                             |                                         | PB4 Input (not used)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                                             |                                         | PB5 Input, falling edge interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                                             |                                         | PB6 Input, dual edge interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|                                             |                                         | PB7 Input, falling edge interrupt – This could be Rising, Dual, or even left floating (OPEN connection)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                                             |                                         | Using the above example, if PB0 is Input, falling edge interrupt, then PB7 must be a separate input, EDGE MODE interrupt. In this example, PB7 is setup as a falling edge interrupt the same way as PB0.                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                                             |                                         | This additional separate input interrupt signal connected to PB7 could be rising, falling, dual, or you can leave it unconnected (OPEN) as well. You must not use PB7 for GPIO I/O or LEVEL sensitive interrupts. This same thought process is applicable to all Port bits pairs, specifically bits 0 and 7, 1 and 6, 2 and 5, and 3 and 4.                                                                                                                                                                                                                                                        |  |  |  |  |  |
| amounts of time at internal address bits [7 |                                         | The RTC clock divider counter can potentially be reset anytime the eZ80 <sup>®</sup> internal address bits [7:0] transition to or through the hex value $0xED$ while the internal I/O WRITE_ENABLE (IOWR) signal is asserted (Active Low).                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                                             | vary between software<br>compiler runs. | Workaround                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                                             |                                         | This RTC problem can be triggered by any eZ80 CPU instruction that causes an I/O Write operation (such as OUT0) to any I/O mapped register or location. If the last byte of the I/O Write operation resides at the address location xxxxEC, the next available address is then 0xED and the I/O WRITE_ENABLE signal may deactivate during the address transition. If this does happen, the RTC clock divider counter gets reset. To avoid this problem you have to shift these instructions down with a NOP instruction to avoid the last byte of the I/O instruction landing on the 0xEC address. |  |  |  |  |  |
|                                             |                                         | There are 17 instructions that can be affected:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                                             |                                         | (continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |



| No | Issue | Detailed Descri | ption          |          |
|----|-------|-----------------|----------------|----------|
|    |       | (continued from | previous page) |          |
|    |       | out0 (n),a      |                |          |
|    |       | outd2r          | oti2r          | out(n),a |
|    |       | otdm            | otim           | outd     |
|    |       | otdmr           | otimr          | outd2    |
|    |       | otdr            | otir           | outi     |
|    |       | otdrx           | otirx          | outi2    |
|    |       |                 | out (bc),a     |          |

You must iterate through the following 4-step sequence until all the I/O instructions are located at a safer address location. The steps in the sequence below use the OUTO instruction as an example. This instruction is 3 bytes long. Therefore, the starting address for an OUTO to cause the RTC problem would be 3 bytes back from address xxxxEC = xxxxEA. The following assembly code snippet might look like this:

ld A, 02 OUTO (%4D), A

After the linker process, assume that the same code snippet can be found in the hex file search as follows:

| 0003E8 | 3E | ; | This          | is | the | ld A, | 02 in: | strı | action.      |
|--------|----|---|---------------|----|-----|-------|--------|------|--------------|
| 0003E9 | 02 |   |               |    |     |       |        |      |              |
| 0003EA | ED | ; | This          | is | the | OUT0  | (%4D)  | , A  | instruction. |
| 0003EB | 39 |   |               |    |     |       |        |      |              |
| 0003EC | 4D |   |               |    |     |       |        |      |              |
| 0003ED | 3E | ; | This<br>inst: |    |     | start | of ai  | notł | ner LD       |

To move the OUT0 last byte away from address 0x0003EC, perform the following sequence:

- (1) Post-process the complete software build so that the addresses for the executable code are resolved.
- (2) Search for the first OUT0 instruction that starts with address location xxxxEA.
- (3) If the instruction traces back from the hex address through the map file to the C or .asm function, return to the source code and add a NOP instruction just before the OUT0 instruction. If an assembly source code, just add a NOP instruction. If C source code, just add the in-line ASM statement \_asm("\tNOP\n");.
- (4) Recompile, link, and re-inspect the hex output file, starting at step 2.



| No | Issue                                                                                  | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8  | The UART is<br>continually<br>interrupting; the user<br>cannot clear the<br>interrupt. | The root cause of this issue has been duplicated with certain signal conditions after which a software instruction was executed to clear the receive FIFO. The signals involved were from bit 0 of the ISR, and the trigger counter with RXFIFO enabled and RXINTERRUPT disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|    |                                                                                        | Workarounds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|    |                                                                                        | To prevent this error condition from occurring, you can perform one of the following two actions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|    |                                                                                        | <ol> <li>Do not enable the transmit or receive FIFO if it is not required. The<br/>Receive FIFO was the initial problem; however, both the TX and RX<br/>FIFOs are affected. Set bit 0 (FIFOEN) of the UART0_FCTL (0x0C2h)<br/>or UART1_FCTL (0x0D2h) registers to a value of zero.</li> <li>If you are using either the transmit or receive FIFOs, mask off the<br/>following two bit locations to avoid changing the default bit value of<br/>zero. If bit 0 (FIFOEN) of the UART0_FCTL (0x0C2h) or<br/>UART1_FCTL (0x0D2h) registers is set to 1, then mask off bit 1 (CLR-<br/>RxF) and bit 2 (CLRTxF) so that any Write accesses to the<br/>UART0_FCTL (0x0C2h) or UART1_FCTL (0x0D2h) registers will not<br/>alter this default zero value.</li> <li>To correct this error condition when the UART Rx interrupt occurs but<br/>there is no Rx data detected, you can clear the condition in software<br/>by putting the UART in loopback mode and then transmitting a single</li> </ol> |
|    |                                                                                        | character. The following is an example of this workaround:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|    |                                                                                        | //====================================                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|    |                                                                                        | /*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|    |                                                                                        | * Check for `stuck' Fifo<br>*/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|    |                                                                                        | if( (Iir == SD_IIR_RX_INT) && ((Lsr & LSR_DR) == ) )<br>{                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|    |                                                                                        | UINT32 Mcr;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|    |                                                                                        | <pre>/*  * To clear this condition, put the Uart in loopback  * mode and send a character  */</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|    |                                                                                        | Mcr = BSP_RD32 ( pUART->Base UART_REG_MCTL );<br>BSP_WR32( pUart->Base UART_REG_MCTL, Mcr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|    |                                                                                        | MCTL_LOOP);<br>BSP_WR32( pUart->Base UART_REG_THR, `Z' );                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|    |                                                                                        | /*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|    |                                                                                        | * Wait for the character to hit the Rx fifo */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|    |                                                                                        | <pre>Lsr = BSP_RD32( pUart-&gt;Base   UART_REG_LSR ); while( !(Lsr &amp; LSR_DR) )</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|    |                                                                                        | {<br>_ Lsr = BSP_RD32( pUart->Base   UART_REG_LSR );                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|    |                                                                                        | }<br>(continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| No | Issue                                         | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|----|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|    |                                               | (continued from previous page)                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|    |                                               | /*  * Ignore any data trapped in the Rx fifo  */                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|    |                                               | while( Lsr & LSR_DR ) {                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|    |                                               | <pre>Lsr = BSP_RD32( pUart-&gt;Base   UART_REG_RBR );<br/>Lsr = BSP_RD32( pUart-&gt;Base   UART_REG_LSR ); }</pre>                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|    |                                               | /*     * Return to normal operation     */                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|    |                                               | /<br>BSP_WR32( pUart->Base UART_REG_MCTL, Mcr  <br>MCTL_LOOP);                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|    |                                               | /* * Record this event                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|    |                                               | */<br>StuckRxCount++;<br>}                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|    |                                               | //====================================                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| 9  | The timer misses timer<br>End-of-Count (EOC). | The root cause for the eZ80F91 timer to lose track of timer EOC has been traced to an internal signal within the timer block that is preventing timer EOC. This issue affects only the timer functions of the eZ80F91 MCU. No other eZ80Acclaim! <sup>®</sup> devices are affected.                                                                                                                                     |  |  |  |  |  |
|    |                                               | The timer EOC is blocked when three conditions are met during the execution of user software, as follows.                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|    |                                               | (1) The lower 8 bits of the internal eZ80paddress bus are equal to the<br>specific timer control register (TMRx_CTL) where x = 0, 1, 2, or 3.<br>The internal data bus value is odd, meaning that bit 0 is equal to 1.                                                                                                                                                                                                  |  |  |  |  |  |
|    |                                               | (2) The specific timer block in which the control register address identified<br>in the first condition above has timed out (generated a<br>time-out EOC).                                                                                                                                                                                                                                                              |  |  |  |  |  |
|    |                                               | If all of the above internal conditions are met, the timer EOC is missed.                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|    |                                               | How the internal data bus is driven depends on the current instruction. For the LD A, n instruction, the internal data bus is driven with immediate data. If the LD A, 01 instruction is placed at an address where the lower 8 bits are equal to the timer control register address 01, the HoldTimerEnable signal is asserted as the 01 is being fetched. If the timer is about to time out, the timer EOC is missed. |  |  |  |  |  |
|    |                                               | If the fetched data value is an even number, the problem is<br>not visible, and the timer EOC is not missed.<br>(continued)                                                                                                                                                                                                                                                                                             |  |  |  |  |  |



| No | Issue | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       | (continued from previous page)                                                                                                                                                                                                                                                                                                                                                                                              |
|    |       | Additionally, a timer configured for SINGLE PASS mode will fail to stop<br>and instead will reload and continue counting after an occurrence above<br>three conditions. If the conditions do not occur at the subsequent EOC,<br>the timer will correctly stop.                                                                                                                                                             |
|    |       | All timer functions that utilize the EOC to determine their result are affected. The input capture, event count, and output capture work correctly since they do not rely on the timer EOC signal.                                                                                                                                                                                                                          |
|    |       | Workaround                                                                                                                                                                                                                                                                                                                                                                                                                  |
|    |       | To prevent this error from occurring (and the only way to guarantee that<br>you do not miss any timer EOC), use two timers programmed to run in<br>synchronization so that their time-out EOC occur at the same time. The<br>key element is to ensure that these timer EOC occur at the same time ar<br>on the same interval.                                                                                               |
|    |       | As a result, you are guaranteed that, if the first timer has met all three conditions, the second timer will not have met the first condition, and therefore does not miss an EOC, and vice versa. Any other method tha results in removing one of the three conditions above will ensure that th you will not miss any timer EOC, but the task becomes painful and user code-dependent due to selectable wait states, etc. |
|    |       | For example, you can determine missed timer EOC using timer 3 code f<br>timer 3 usage and look for out instructions that provide an odd value on<br>the data bus. Once this code has been located, the you can move the<br>timer code by using a NOP instruction.                                                                                                                                                           |
|    |       | Assume you use a timer 3 and has written the following ASM code segments:                                                                                                                                                                                                                                                                                                                                                   |
|    |       | <pre>;******* Init Timer3 ************************************</pre>                                                                                                                                                                                                                                                                                                                                                        |
|    |       | (continued)                                                                                                                                                                                                                                                                                                                                                                                                                 |

| No | Issue                                                                                                                                                     | <b>Detailed Description</b>                                                                             |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|    |                                                                                                                                                           | (continued from previous page)                                                                          |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|    |                                                                                                                                                           | The assembly listing fo                                                                                 | r this                                                | s coo                          | le could be similar to the following:                                                                                                                                                                                                                   |  |  |
|    |                                                                                                                                                           | , ,                                                                                                     | A                                                     |                                | ;******* Init Timer3                                                                                                                                                                                                                                    |  |  |
|    |                                                                                                                                                           | * * * * * * * * * * * * * *                                                                             |                                                       | 10                             | ,                                                                                                                                                                                                                                                       |  |  |
|    |                                                                                                                                                           | 000084 21350C00                                                                                         | A                                                     | 41                             | ld hl,250 * (CPU_Freq / 10                                                                                                                                                                                                                              |  |  |
|    |                                                                                                                                                           | 000088 ED2977                                                                                           | A                                                     | 42                             | out0 (TMR3_RR_L),1                                                                                                                                                                                                                                      |  |  |
|    |                                                                                                                                                           | 00008B ED2178                                                                                           | A                                                     |                                | out0 (TMR3_RR_H),h                                                                                                                                                                                                                                      |  |  |
|    |                                                                                                                                                           | 00008E 3E07                                                                                             | A                                                     |                                | ld a, %07                                                                                                                                                                                                                                               |  |  |
|    |                                                                                                                                                           | 000090 ED3974<br>000093 3E01                                                                            | A<br>A                                                |                                | out0 (TMR3_CTL),a<br>ld a,%01                                                                                                                                                                                                                           |  |  |
|    |                                                                                                                                                           | 000095 ED3975                                                                                           | A                                                     |                                | out0 (TMR3_IER),a                                                                                                                                                                                                                                       |  |  |
|    |                                                                                                                                                           | 000098 FB                                                                                               | A                                                     |                                | ei                                                                                                                                                                                                                                                      |  |  |
|    |                                                                                                                                                           | 000099 C3 72 04 00                                                                                      | A                                                     |                                | jp testproc                                                                                                                                                                                                                                             |  |  |
|    |                                                                                                                                                           |                                                                                                         |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|    |                                                                                                                                                           |                                                                                                         |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|    |                                                                                                                                                           | 000471                                                                                                  | A                                                     |                                | testproc:                                                                                                                                                                                                                                               |  |  |
|    |                                                                                                                                                           | 000471 3E01                                                                                             | A                                                     | 69                             | ld a,%01                                                                                                                                                                                                                                                |  |  |
|    |                                                                                                                                                           | Two key items to be aw                                                                                  | are                                                   | of a                           | re:                                                                                                                                                                                                                                                     |  |  |
|    |                                                                                                                                                           | (1) The address in the<br>TMR3_CTL(0x0074                                                               |                                                       | ware                           | is 0471, which is close to                                                                                                                                                                                                                              |  |  |
|    |                                                                                                                                                           | (2) The LD a, %01 instruction in bringing in an odd data byte. One                                      |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|    |                                                                                                                                                           |                                                                                                         |                                                       | -                              | u is to insert a NOP instruction at address<br>e testproc statement down 1 byte to the                                                                                                                                                                  |  |  |
|    |                                                                                                                                                           | 000471                                                                                                  | A                                                     | 68                             | testproc:                                                                                                                                                                                                                                               |  |  |
|    |                                                                                                                                                           | 000471 00                                                                                               | A                                                     |                                | NOP                                                                                                                                                                                                                                                     |  |  |
|    |                                                                                                                                                           | 000472 3E01                                                                                             | A                                                     | 70                             | ld a,%01                                                                                                                                                                                                                                                |  |  |
| 10 | The infrared encoder/<br>decoder (endec)<br>receiver misses bits<br>when configured for<br>low data rates and the<br>incoming signals are<br>only 1.6 µs. | divided by 16. This san<br>incoming pulses when<br>This short pulse, 1.6 µs<br>transmitters use this pa | nplin<br>they<br>s, is<br>irticu<br>/ <sub>16</sub> I | g rat<br>use<br>with<br>llar s | IR pulses, using the baud rate clock<br>te can be insufficient to capture the<br>a short-pulse format and low-data rates.<br>in IrDA specifications; however, not all<br>signalling format. When the external<br>llses, the endec on the eZ80F91 device |  |  |
| 11 | GPIO Port B and Port<br>C pins draw current<br>when input voltage                                                                                         | •                                                                                                       |                                                       |                                | pins, when the input voltage exceeds / supply voltage), current is drawn by the                                                                                                                                                                         |  |  |
|    | exceeds one diode<br>drop above the supply                                                                                                                | Workaround                                                                                              |                                                       |                                |                                                                                                                                                                                                                                                         |  |  |
|    | voltage.                                                                                                                                                  | For GPIO pins that toge<br>placed between the GF                                                        |                                                       |                                | v frequencies, a 10 K $\Omega$ resistor can be                                                                                                                                                                                                          |  |  |



| No | Issue                                                                                                            | Detailed Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 12 | A pulse on the Serial<br>Clock (SCL) line while<br>the I <sup>2</sup> C bus is idle and<br>the Serial Data (SDA) | A pulse on the SCL line prior to a START condition or after a STOP condition causes the $I^2C$ to lock up. This situation occurs irrespective of the $I^2C$ Control Register ENAB settings (I2C_CTL). When this situation occurs, an $I^2C$ Software Reset does not unlock the $I^2C$ bus.                                                                                                                                                                                                                                                       |  |  |  |
|    | line is held High<br>causes the I <sup>2</sup> C to lock.                                                        | <b>Workarounds</b><br>To prevent lock-up, it is possible to completely disable the $I^2C$ block prior<br>to any bus activity using the Clock Peripheral Power-Down Register 1<br>(CLK_PPD1) before setting ENAB in the $I^2C$ Control Register.<br>In the event that lock-up of the $I^2C$ block occurs, then after the SCL line is<br>released, another device on the bus can issue a STOP condition by<br>pulsing the SDA line. As a result, the $I^2C$ should unlock.<br>Another option is to initiate an overall SYSTEM RESET of the eZ80F91 |  |  |  |
|    |                                                                                                                  | device to reset the I <sup>2</sup> C block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 13 | Disable of PLL when selected as system clock source.                                                             | If the PLL is selected as the system clock source, the PLL can be<br>disabled by the eZ80 CPU. As a result, the system clock stops. The<br>eZ80F91 will not respond to RESET pin assertion without a system clock.<br>If the system clock source is disabled, the eZ80F91 can only be reset by a<br>WDT reset, a POR reset, or a RTC SLP_WAKE.                                                                                                                                                                                                   |  |  |  |





### LIFE SUPPORT POLICY

ZILOG'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS PRIOR WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF ZILOG CORPORATION.

#### As used herein

Life support devices or systems are devices which (a) are intended for surgical implant into the body, or (b) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury to the user. A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness.

#### **Document Disclaimer**

©2010 by Zilog, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology described is intended to suggest possible uses and may be superseded. ZILOG, INC. DOES NOT ASSUME LIABILITY FOR OR PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED IN THIS DOCUMENT. ZILOG ALSO DOES NOT ASSUME LIABILITY FOR INTELLECTUAL PROPERTY INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED HEREIN OR OTHERWISE. The information contained within this document has been verified according to the general principles of electrical and mechanical engineering.

Z8, Z8 Encore!, Z8 Encore! XP, Z8 Encore! MC, Crimzon, eZ80, eZ80Acclaim! and ZNEO are trademarks or registered trademarks of Zilog, Inc. All other product or service names are the property of their respective owners.