The 87C196KQ may contain design defects or errors known as errata. Characterized errata that may cause the 87C196KQ'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 retains the right to make changes to specifications and product descriptions at any time, without notice.

Contact your local Intel sales office or your distributor to obtain the latest specifications before placing your product order.

*Third-party brands and names are the property of their respective owners.

Copies of documents which have an ordering number and are referenced in this document, or other Intel literature, may be obtained from:

Intel Corporation
P.O. Box 7641
Mt. Prospect IL 60056-7641

or call in North America 1-800-879-4683, Europe 44-0-1793-431-155,
France 44-0-1793-421-777, Germany 44-0-1793-421-333, other countries 708-296-9333

Copyright © 1996, 1997, INTEL CORPORATION
## CONTENTS

CONTENTS ........................................................................................................... iii
REVISION HISTORY .......................................................................................... 1
PREFACE ............................................................................................................. 2
SUMMARY TABLE OF CHANGES ........................................................................ 4
IDENTIFICATION INFORMATION ..................................................................... 7
ERRATA .............................................................................................................. 8
SPECIFICATION CHANGES .............................................................................. 9
SPECIFICATION CLARIFICATIONS .................................................................. 9
DOCUMENTATION CHANGES .......................................................................... 13
### REVISION HISTORY

<table>
<thead>
<tr>
<th>Rev. Date</th>
<th>Version</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>07/01/96</td>
<td>001</td>
<td>This is the new Specification Update document. It contains all identified errata published prior to this date.</td>
</tr>
<tr>
<td>01/08/97</td>
<td>002</td>
<td>Added documentation changes 001–003.</td>
</tr>
</tbody>
</table>
PREFACE

As of July, 1996, Intel’s Semiconductor Products Group 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

<table>
<thead>
<tr>
<th>Title</th>
<th>Order</th>
</tr>
</thead>
<tbody>
<tr>
<td>87C196KR/KQ 87C196JV/JT 87C196JR/JQ Advanced 16-bit CHMOS Microcontroller datasheet</td>
<td>270827</td>
</tr>
<tr>
<td>8XC196Kx, 8XC196Jx, 87C196CA Microcontroller Family User’s Manual</td>
<td>272258</td>
</tr>
</tbody>
</table>

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 8XC196KQ 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: Errata exists in the stepping indicated. Specification Change or Clarification that applies to this stepping.

(No mark) or (Blank box): This erratum is fixed in listed stepping or specification change does not apply to listed stepping.

**Page**

(Page): Page location of item in this document.

**Status**

Doc: Document change or update will be implemented.

Fix: This erratum is intended to be fixed in a future step of the component.

Fixed: This erratum has been previously fixed.

NoFix: There are no plans to fix this erratum.

Eval: Plans to fix this erratum are under evaluation.

**Row**

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

<table>
<thead>
<tr>
<th>Number</th>
<th>Steppings</th>
<th>Page</th>
<th>Status</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>9600001</td>
<td>X</td>
<td>8</td>
<td>NoFix</td>
<td>$V_{OH2}/I_{OH2}$ Specification</td>
</tr>
<tr>
<td>9600002</td>
<td>X</td>
<td>8</td>
<td>NoFix</td>
<td>External Addressing of Locations 1B00–1BDFH</td>
</tr>
<tr>
<td>9600003</td>
<td>X</td>
<td>8</td>
<td>NoFix</td>
<td>Port 3 Complementary Operation</td>
</tr>
</tbody>
</table>

## Specification Changes

<table>
<thead>
<tr>
<th>Number</th>
<th>Steppings</th>
<th>Page</th>
<th>Status</th>
<th>Specification Changes</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>None for this revision of this specification update.</td>
</tr>
</tbody>
</table>

## Specification Clarifications

<table>
<thead>
<tr>
<th>Number</th>
<th>Steppings</th>
<th>Page</th>
<th>Status</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td></td>
<td>9</td>
<td></td>
<td>EPA Timer Reset/Write Conflict</td>
</tr>
<tr>
<td>002</td>
<td></td>
<td>9</td>
<td></td>
<td>Valid Time Matches</td>
</tr>
<tr>
<td>003</td>
<td></td>
<td>9</td>
<td></td>
<td>P6_PIN.4-.7 Not Updated Immediately</td>
</tr>
<tr>
<td>004</td>
<td></td>
<td>9</td>
<td></td>
<td>Write Cycle during Reset</td>
</tr>
<tr>
<td>005</td>
<td></td>
<td>10</td>
<td></td>
<td>Indirect Shift Clock Value</td>
</tr>
<tr>
<td>006</td>
<td></td>
<td>10</td>
<td></td>
<td>P2.7 (CLKOUT)</td>
</tr>
<tr>
<td>007</td>
<td></td>
<td>10</td>
<td></td>
<td>EPA Overruns</td>
</tr>
<tr>
<td>008</td>
<td></td>
<td>11</td>
<td></td>
<td>Indirect Addressing with AutoIncrement</td>
</tr>
</tbody>
</table>

## Documentation Changes

<table>
<thead>
<tr>
<th>Number</th>
<th>Document Revision</th>
<th>Page</th>
<th>Status</th>
<th>Documentation Changes</th>
</tr>
</thead>
<tbody>
<tr>
<td>001</td>
<td>272258-002</td>
<td>13</td>
<td>Doc</td>
<td>High address inputs to the low EPROM should be A14:8 in Figure 15-18.</td>
</tr>
</tbody>
</table>


## Documentation Changes

<table>
<thead>
<tr>
<th>Doc</th>
<th>272258-002</th>
<th>14</th>
<th>Addresses 201DH and 201FH should contain FFH in Table 4-2.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Doc</td>
<td>272258-002</td>
<td>15</td>
<td>In Table 7-2, P2_DIR description change.</td>
</tr>
</tbody>
</table>
IDENTIFICATION INFORMATION

Markings

C-Step Devices can be identified by a special mark following the eight-digit FPO number on the top of the package. The following chart specifies what these marking are for various device steppings.

<table>
<thead>
<tr>
<th>Device</th>
<th>Topside Marking</th>
</tr>
</thead>
<tbody>
<tr>
<td>KR, KQ C-step</td>
<td>“C”</td>
</tr>
<tr>
<td>JR, JQ D-step</td>
<td>“D”</td>
</tr>
<tr>
<td>JV, JT A-step</td>
<td>“A”</td>
</tr>
</tbody>
</table>
ERRATA

9600001. VOH2/IOH2 Specification

PROBLEM: In the DC Characteristics section of the datasheet, $V_{OH2}$ indicates the strength of the internal weak pullups that are active during and after reset until the user writes to the $P_x\_MODE$ register. C-step devices do not meet this specification. The new specification for C-step devices is $V_{OH2} \ (\text{min}) = V_{OC} - 1V$ at $I_{OH2} = 6\mu A$. Note that JR/JQ D-step devices are not affected by this errata and meet the published specification.

IMPLICATION: Designs must comprehend the reduced drive strength of the internal “weak” pull-ups 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).

9600002. 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).

9600003. Port 3 Complementary Operation

PROBLEM: If port 3 is configured as a complementary, general-purpose I/O port (sometimes called push-pull LSIO) when an address/data bus cycle occurs, port 3 will continue to drive the address-data bus with its general-purpose I/O data (the P3_REG data) during the bus cycle.

IMPLICATION: Applications that use port 3 for both general-purpose I/O and address/data bus will be affected. Applications that use external memory should not configure port 3 as complementary, general-purpose I/O.

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

SPECIFICATION CHANGES
None for this revision of this specification update.

SPECIFICATION CLARIFICATIONS

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

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

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

004. **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.
005. *Indirect Shift Clock 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).

006. *P2.7 (CLKOUT)*

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

007. *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 EPA 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).

008. *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 ax = 1CH and bx = 40H.

The following code causes the CPU to access the operand at the incremented address:

```
lor ax, #ax
lor bx, [ax]
lor 1CH, #1CH; load location 1CH with value 1CH
lor 40H, [1CH]; save 1CH into temp register
        ;1CH (1CH; increment the contents of 1CH
        ;40H (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 ax = 1CH, bx = 1DH, and cx = 40H. The following code causes the CPU to access the operand at the intended, unincremented address:

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

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

**DOCUMENTATION CHANGES**

**001.** *High address inputs to the low EPROM should be A14:8 in Figure 15-18.*

**ITEM:** The next revision of the user’s manual will include the following corrected graphic.
002. **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

<table>
<thead>
<tr>
<th>Hex Address</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>207F 205E</td>
<td>Reserved (each byte must contain FFH)</td>
</tr>
<tr>
<td>206D 2040</td>
<td>PTS vectors</td>
</tr>
<tr>
<td>203F 2030</td>
<td>Upper interrupt vectors</td>
</tr>
<tr>
<td>202F 2020</td>
<td>Security key</td>
</tr>
<tr>
<td>201F</td>
<td>Reserved (must contain FFH)</td>
</tr>
<tr>
<td>201E</td>
<td>Reserved (must contain FFH)</td>
</tr>
<tr>
<td>201D</td>
<td>Reserved (must contain FFH)</td>
</tr>
<tr>
<td>201C</td>
<td>Reserved (must contain FFH)</td>
</tr>
<tr>
<td>201B</td>
<td>Reserved (must contain 20H)</td>
</tr>
<tr>
<td>201A</td>
<td>CCB1</td>
</tr>
<tr>
<td>2019</td>
<td>Reserved (must contain 20H)</td>
</tr>
<tr>
<td>2018</td>
<td>CCB0</td>
</tr>
<tr>
<td>2017 2016</td>
<td>OFD flag (see page 13-12 and page 16-8)</td>
</tr>
<tr>
<td>2015 2014</td>
<td>Reserved (each byte must contain FFH)</td>
</tr>
<tr>
<td>2013 2000</td>
<td>Lower interrupt vectors</td>
</tr>
</tbody>
</table>

003. **In Table 7-2, P2_DIR description change.**

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

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