## intel

## 87C196KR SPECIFICATION UPDATE

Release Date: December, 1998
Order Number: 272861-004

The 87C196KR may contain design defects or errors known as errata. Characterized errata that may cause the 87C196KR's behavior to deviate from published specifications are documented in this specification update.

Information in this document is provided in connection with Intel products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel's Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel products are not intended for use in medical, life saving, or life sustaining applications.

Intel may make changes to specifications and product descriptions at any time, without notice.
Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.
The 87C196KR may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.
Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.
Copies of documents which have an ordering number and are referenced in this document, or other Intel literature may be obtained by calling 1-800-548-4725 or by visiting Intel's website at http://www.intel.com.
Copyright © Intel Corporation, 1998
*Third-party brands and names are the property of their respective owners.

87C196KR SPECIFICATION UPDATE

## CONTENTS

REVISION HISTORY ..... 1
PREFACE ..... 2
SUMMARY TABLE OF CHANGES ..... 4
IDENTIFICATION INFORMATION ..... 7
ERRATA ..... 8
SPECIFICATION CHANGES ..... 10
SPECIFICATION CLARIFICATIONS ..... 11
DOCUMENTATION CHANGES ..... 15

## REVISION HISTORY

| Rev. Date | Version | Description |
| :---: | :---: | :--- |
| $07 / 01 / 96$ | 001 | This is the new Specification Update document. It contains all <br> identified errata published prior to this date. |
| $01 / 08 / 97$ | 002 | Added documentation changes 1-3. |
| $04 / 07 / 97$ | 003 | Added errata 4 and specification change 1. |
| $11 / 30 / 98$ | 004 | Added errata 5. Revised Affected Documents. Updated Status for <br> all errata. |

## PREFACE

As of July, 1996, Intel has consolidated available historical device and documentation errata into this new document type called the Specification Update. We have endeavored to include all documented errata in the consolidation process, however, we make no representations or warranties concerning the completeness of the Specification Update.
This document is an update to the specifications contained in the Affected Documents/Related Documents table below. This document is a compilation of device and documentation errata, specification clarifications and changes. It is intended for hardware system manufacturers and software developers of applications, operating systems, or tools.
Information types defined in Nomenclature are consolidated into the specification update and are no longer published in other documents.
This document may also contain information that was not previously published.

## Affected Documents/Related Documents

| Title | Order |
| :--- | :---: |
| 87C196KR, 87C196JV, 87C196JT, 87C196JR, and 87C196CA Advanced <br> 16-bit CHMOS Microcontroller datasheet - Automotive | 270827 |
| 8XC196Kx, 8XC196Jx, 87C196CA Microcontroller Family User's Manual | 272258 |

## Nomenclature

Errata are design defects or errors. These may cause the published (component, board, system) behavior to deviate from published specifications. Hardware and software designed to be used with any component, board, and system must consider all errata documented.

Specification Changes are modifications to the current published specifications. These changes will be incorporated in any new release of the specification.
Specification Clarifications describe a specification in greater detail or further highlight a specification's impact to a complex design situation. These clarifications will be incorporated in any new release of the specification.
Documentation Changes include typos, errors, or omissions from the current published specifications. These will be incorporated in any new release of the specification.

## NOTE:

Errata remain in the specification update throughout the product's lifecycle, or until a particular stepping is no longer commercially available. Under these circumstances, errata removed from the specification update are archived and available upon request. Specification changes, specification clarifications and documentation changes are removed from the specification update when the appropriate changes are made to the appropriate product specification or user documentation (datasheets, manuals, etc.).

## SUMMARY TABLE OF CHANGES

The following table indicates the errata, specification changes, specification clarifications, or documentation changes which apply to the 87C196KR product. Intel may fix some of the errata in a future stepping of the component, and account for the other outstanding issues through documentation or specification changes as noted. This table uses the following notations:

## Codes Used in Summary Table

## Stepping

X:
(No mark) or (Blank box):

## Page

(Page):

## Status

Doc:
Fix:
Fixed:
NoFix:
Eval:

## Row

I
Change bar to left of table row indicates this erratum is either new or modified from the previous version of the document.

## Errata

| Number | Steppings |  |  | Page | Status | ERRATA |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | A | B | C |  |  | NoFix | VOH2/IOH2 Specification | V |
| :---: |
| 1 |

## Specification Changes

| Number | Steppings |  |  | Page | Status | SPECIFICATION CHANGES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A | B | C |  |  |  |
| 1 |  |  |  | 10 |  | A/D Conversion Times |

## Specification Clarifications

| Number | Steppings |  |  | Page | Status | SPECIFICATION CLARIFICATIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
|  | A | B | C |  |  |  |
| 1 | X |  |  | 11 |  | EPA Timer Reset/Write Conflict |
| 2 | X |  |  | 11 |  | Valid Time Matches |
| 3 | X |  |  | 11 |  | P6_REG.4-.7 Not Updated Immediately |
| 4 | X |  |  | 11 |  | Write Cycle During Reset |
| 5 | X |  |  | 11 |  | Indirect Shift Count Value |
| 6 | X |  |  | 12 |  | P2.7 (CLKOUT) |
| 7 | X |  |  | 12 |  | EPA Overruns |
| 8 | X |  |  | 13 |  | Indirect Addressing With AutoIncrement |

Documentation Changes

| Number | Document <br> Revision | Page | Status | DOCUMENTATION CHANGES |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $272258-002$ | 15 | Doc | High Address Inputs to the Low EPROM <br> Should be A14:8 in Figure 15-18. |
| 2 | $272258-002$ | 16 | Doc | Addresses 201DH and 201FH Should <br> Contain FFH in Table 4-2. |
| 3 | $272258-002$ | 16 | Doc | In Table 7-2, P2_DIR Description Change |

## IDENTIFICATION INFORMATION

## Markings

C-step devices can be identified by the letter " $C$ " following the eight-digit FPO number on the top of the package.

## ERRATA

## 1. $V_{\mathrm{OH} 2} / \mathrm{IOH}_{2}$ Specification

PROBLEM: In the DC Characteristics section of the datasheet, $\mathrm{V}_{\mathrm{OH} 2}$ indicates the strength of the internal weak pullups that are active during and after reset until the user writes to the Px _MODE register. C-step devices do not meet this specification. The new specification for $\overline{\mathrm{C}}$-step devices is $\mathrm{V}_{\mathrm{OH} 2}(\mathrm{~min})=\mathrm{V}_{\mathrm{OC}}-1 \mathrm{~V}$ at $\mathrm{I}_{\mathrm{OH} 2}=6 \mu \mathrm{~A}$.
IMPLICATION: Designs must comprehend the reduced drive strength of the internal "weak" pullups and make adjustments to interface circuitry if necessary.

WORKAROUND: No workaround.
STATUS: NoFix. Refer to Summary Table of Changes to determine the affected stepping(s).

## 2. External Addressing of Locations 1B00-1BDFH

PROBLEM: Affected devices cannot access external memory locations 1B00-1BDFH. Writing to these locations does not generate a bus cycle. Reading from these locations returns the value FFH, but does not generate a bus cycle.
IMPLICATION: Applications cannot access external locations 1B00H-1BDFH.
WORKAROUND: Applications must access external memory that may reside at 1B00-1BDFH at an alternative external memory location.
STATUS: NoFix. Refer to Summary Table of Changes to determine the affected stepping(s).

## AFFECTED PRODUCTS (OPTIONAL)

## 3. Port 3 Push-Pull Operation

PROBLEM: If Port3 is operating as a push-pull LSIO (Low-Speed I/O) port and an address/data bus cycle occurs, Port3 will continue to drive the address/data bus with its LSIO data during the bus cycle. It is rather unlikely that this errata would affect an application because the application would have to use Port3 for both LSIO and as an external addr/data bus. If an application uses external memory, Port3 should not be selected as push-pull LSIO.
IMPLICATION: This erratum only affects customers who are using Port3 for both LSIO and an external address/data bus. Port3 should not be selected as push-pull for LSIO if an application uses external memory.
WORKAROUND: None.
STATUS: NoFix. Refer to Summary Table of Changes to determine the affected stepping(s).

## 4. Executing Routines in the User's ROM While the Device is Operating in Serial Programming Mode

PROBLEM: All code fetches above the first 8K bytes of user ROM while the device is operating in serial port programming mode will be directed to external memory. Therefore, if the user wants to call any routines in the user ROM, the entire routine must be within the first 8 K bytes of memory ( 0 A 000 - OBFFFH in serial port programming mode). For example, if the RISM "GO" command is used with a target address of 0 COOOH , the device will attempt to fetch code from external memory rather than the on-board ROM.
IMPLICATION: This errata only affects code fetches from the user ROM. Data fetches to the entire ROM work correctly. It is not possible to execute code from above the first 8 K byte of user ROM while the device is operating in Serial Port Programming mode.
WORKAROUND: None.
STATUS: NoFix. Refer to the Summary Table of Changes to determine the affected.

## 5. $\quad$ / $D$ Conversion Error on First Conversion

PROBLEM: The first A/D conversion performed after a reset of the device may produce a result that is less accurate than the accuracy specification in the datasheet. The amount of error is dependent on several environmental conditions including process variation, light exposure, temperature, and $\mathrm{V}_{\mathrm{CC}} / \mathrm{V}_{\mathrm{REF}}$ differential.
IMPLICATION: If the application is sensitive to A/D accuracy, an error in the application may occur as a result of the first conversion error.
WORKAROUND: Do not compare for the A/D result on the first conversion. All subsequent conversions should produce accurate results.
STATUS: NoFix. Refer to the Summary Table of Changes to determine the affected.

## SPECIFICATION CHANGES

## 1. $\quad A / D$ Conversion Times

ITEM: The second paragraph incorrectly states the A/D conversion time as " $<5 \mu \mathrm{~s}$ ". The correction reads: ...analog-to-digital converter with programmable $\mathrm{S} / \mathrm{H}$ times with conversion times < $15 \mu \mathrm{~s}$ at $16 \mathrm{MHz}, \ldots$

## SPECIFICATION CLARIFICATIONS

## 1. EPA Timer Reset/Write Conflict

PROBLEM: If software writes to the EPA timer at the same time that an EPA channel resets that timer, it is indeterminate which action will take precedence. Software should not write to a timer that is being reset by EPA signals.

## 2. Valid Time Matches

PROBLEM: A timer must increment or decrement to the compare value in order for a match to occur. Loading a timer with a value that is equal to an EPA compare value does cause a match. Likewise, with an EPA compare value of 0 , a timer reset does not cause a match.

## 3. P6__REG.4-. 7 Not Updated Immediately

PROBLEM: A value written to any of the upper four bits of P6_REG is temporarily held in a buffer until the corresponding P6_MODE bit is cleared, at which time the value is loaded into the P6_REG bit. A value read from a P6_REG bit is the value currently in the register, not the value in the buffer. Therefore, any change to a P6_REG bit can be read only after the corresponding P6_MODE bit is cleared.

## 4. Write Cycle During Reset

PROBLEM: If a reset occurs while the microcontroller is writing to an external memory device, the contents of the external memory device may be corrupted.

## 5. Indirect Shift Count Value

PROBLEM: The SHRL and SHLL instructions function correctly with count values 0-31, inclusive. However, a shift count value of XX100000B causes 32 shifts, which results in no shift taking place. With all other count values, the upper 3 bits are masked off and the remaining bits specify the number of shifts. Also, a shift count value of XX1XXXXXB causes the overflow flag and the overflow-trap flag to be set.
IMPLICATION: Customers using SHRL and SHLL instructions with a count value greater than 31 will be affected.

WORKAROUND: Ensure that the count value never exceeds 31.
STATUS: Refer to Summary Table of Changes to determine the affected stepping(s).

## 6. P2.7 (CLKOUT)

PROBLEM: P2.7 (CLKOUT) does not operate in open drain mode.

## 7. EPA Overruns

PROBLEM: The EPA can lock up if overruns are handled incorrectly. Overruns occur when an EPA input transitions at a rate that cannot be handled by the EPA interrupt service routine. If no overrun handling strategy is in place, and if the following three conditions exist, a situation may occur where both the capture buffer and the EPAx_TIME register contain data, and no EPA interrupt pending bit is set:

- an input signal with a frequency high enough to cause overruns is present on an enabled EPA pin, and
- the overwrite bit is set (EPAx_CON. $0=1$; old data is overwritten on overrun), and
- the EPAx_TIME register is read at the exact instant that the EPA recognizes the captured edge as valid.
The input frequency at which this occurs depends on the length of the interrupt service routine as well as other factors. Unless the interrupt service routine includes a check for overruns, this situation will remain the same until the device is reset or the EPAx_TIME register is read. The act of reading EPAx_TIME allows the buffered time value to be moved into EPAx_TIME. This clears the buffer and allows another event to be captured. Remember that the act of transferring the buffer contents to the EPAx_TIME register is what actually sets the EPAx interrupt pending bit and generates the interrupt.
WORKAROUND: Any one of the following methods can be used to prevent or recover from an EPA overrun situation.
- Clear EPAx_CON. 0

When the overwrite bit (EPAx_CON.0) is zero and both the EPAx_TIME register than the buffer are full, the EPA does not consider a captured edge until the EPAx_TIME register is read and the data in the capture buffer is transferred to EPAX_TIME. This prevents overruns by ignoring new input capture events when both the capture buffer and EPAx_TIME contain valid capture times. The OVRx pending bit in EPA_PEND is set to indicate that an overrun occurred.

- Enable the OVRx interrupt and read the EPAx_TIME register within the ISR

If an overrun occurs, the overrun (OVRx) interrupt will be generated. The OVRx interrupt will then be acknowledged and its interrupt service routine will read the EPAx_TIME register. After the CPU reads the EPAx_TIME register, the buffered data moves from the buffer to the EPAx_TIME register. This sets the EPA interrupt pending bit.

- Check for pending EPAx interrupts before exiting an EPAx ISR

Another method for avoiding this situation is to check for pending EPA interrupts before exiting the EPA interrupt service routine. This is an easy way to detect overruns and additional interrupts. It can also save loop time by eliminating the latency necessary to service the pending interrupt. However, this method cannot be used with the peripheral transaction server (PTS).
STATUS: Refer to Summary Table of Changes to determine the affected stepping(s).

## 8. Indirect Addressing With AutoIncrement

PROBLEM: For indirect addressing with autoincrement, a pointer that points to itself results in an access to the incremented pointer address rather than the original pointer address.

The CPU stores the pointer's value in a temporary register, increments the pointer, then accesses the operand at the address contained in the temporary register, as shown in this flowchart.


Therefore, if the pointer points to itself, the CPU accesses the operand at the incremented address contained in the pointer.
For example, assume $\mathrm{ax}=1 \mathrm{CH}$ and $\mathrm{bx}=40 \mathrm{H}$. The following code causes the CPU to access the operand at the incremented address:

```
ld ax,#ax
ldb bx,[ax]+
ld 1CH,#1CH;1CH\leftarrow1CH;load location 1CH with value 1CH
ldb 40H,[1CH]+;temp\leftarrow1CH;save 1CH into temp register
    ;1CH\leftarrow1DH;increment the contents of 1CH
    ;40H\leftarrow 1DH;load the contents of location 1CH
        ; (location 1CH
        ; now contains the value 1DH) into 40H
```

WORKAROUND: Avoid using an indirect address pointer that points to itself.
For example, assume $a x=1 \mathrm{CH}, \mathrm{bx}=1 \mathrm{DH}$, and $\mathrm{cx}=40 \mathrm{H}$. The following code causes the CPU to access the operand at the intended, unincremented address:

```
ld ax,#bx ; where bx\not=ax
ldb cx,[ax]+
ld 1CH,#1DH;1CH\leftarrow1DH;load location 1CH with value 1DH
ldb 40H,[1CH]+;temp\leftarrow1DH;save 1DH (contents of 1CH) into temp
                ;register
    ;1CH\leftarrow1EH;increment the contents of 1CH
    ;40H\leftarrow1DH;load the contents of temp into 40H
```

STATUS: Refer to Summary Table of Changes to determine the affected stepping(s).

## DOCUMENTATION CHANGES

1. High Address Inputs to the Low EPROM Should be A14:8 in Figure

ITEM: The next revision of the user's manual will include the following corrected graphic.


Figure 1. 16-bit System with EPROM

## 2. Addresses 201DH and 201FH Should Contain FFH in Table 4-2.

ITEM: The next revision of the user's manual will include the following corrected table.

Table 0-1. Special-purpose Memory Addresses

| Hex Address | Description |
| :---: | :--- |
| 207 F | Reserved (each byte must contain FFH) |
| 205 E | 205D |
| 2040 | PTS vectors |
| 203 F | Upper interrupt vectors |
| 2030 | Security key |
| 202 F |  |
| 2020 | Reserved (must contain FFH) |
| 201 F | Reserved (must contain FFH) |
| 201 E | Reserved (must contain FFH) |
| 201 D | Reserved (must contain FFH) |
| 201 C | Reserved (must contain 20H) |
| 201 B | CCB1 |
| 201 A | Reserved (must contain 20H) |
| 2019 | CCBO |
| 2018 | OFD flag (see page 13-12 and page 16-8) |
| 2017 |  |
| 2016 | Reserved (each byte must contain FFH) |
| 2015 | Lower interrupt vectors |
| 2014 |  |
| 2013 |  |

## 3. In Table 7-2, P2_DIR Description Change

ITEM: The next revision of the user's manual will include the following corrected register description.

| Mnemonic | Address | Description |
| :--- | :--- | :--- |
| P2_DIR | 1FCBH | Port Direction Register <br> Each bit controls the configuration of the corresponding pin. <br> Clearing a bit configures the corresponding pin as a complementary <br> output; setting a bit configures the corresponding pin as an <br> open-drain output or a high-impedance input. |

