# M80C196KB <br> 16-BIT HIGH PERFORMANCE CHMOS MICROCONTROLLER 

Military

■ 232 Byte Register File
■ Register-to-Register Architecture

- 28 Interrupt Sources/16 Vectors

■ $2.3 \mu \mathrm{~s} 16 \times 16$ Multiply ( 12 MHz )
■ $4.0 \mu \mathrm{~s} 32 / 16$ Divide ( 12 MHz )
■ Powerdown and Idle Modes
■ Five 8-Bit I/O Ports
■ 16-Bit Watchdog Timer
■ Dynamically Configurable 8-Bit or 16-Bit Buswidth

- Available in 68-Lead PGA and 68-Lead Ceramic Quad Flat Pack

■ Full Duplex Serial Port
■ High Speed I/O Subsystem
■ 16-Bit Timer

- 16-Bit Up/Down Counter with Capture

■ Pulse-Width-Modulated Output
■ Four 16-Bit Software Timers
■ 10-Bit A/D Converter with S/H
■ 12 MHz Version - M80C196KB
■ Available in Two Product Grades:

- MIL-STD-883, $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (TC)
- Military Temperature Only (MTO), $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}\left(\mathrm{T}_{\mathrm{C}}\right)$

The M80C196KB 16-bit microcontroller is a high performance member of the MCS®-96 microcontroller family. The M80C196KB is pin-for-pin compatible and uses a true superset of the M8096 instructions. Intel's CHMOS process provides a high performance processor along with low power consumption. To further reduce power requirements, the processor can be placed into Idle or Powerdown Mode.

Bit, byte, word and some 32-bit operations are available on the M80C196KB. With a 12 MHz oscillator a 16-bit addition takes $0.66 \mu \mathrm{~s}$, and the instruction times average $0.5 \mu \mathrm{~s}$ to $1.5 \mu \mathrm{~s}$ in typical applications.

Four high-speed capture inputs are provided to record times when events occur. Six high-speed outputs are available for pulse or waveform generation. The high-speed output can also generate four software timers or start an A/D conversion. Events can be based on the timer or up/down counter.

Also provided on-chip are an A/D converter with Sample and Hold, serial port, watchdog timer, and a pulse-width-modulated output signal.


Figure 1. M80C196KB Block Diagram

## ARCHITECTURE

The M80C196KB is a member of the MCS® ${ }^{\circledR}-96$ family, and as such has the same architecture and uses the same instruction set as the M8096. Many new features have been added on the M80C196KB including:

## CPU FEATURES

Divide by 2 instead of divide by 3 clock for 1.5X performance
Faster instructions, especially indexed/indirect data operations
$2.33 \mu \mathrm{~s} 16 \times 16$ multiply with 12 MHz clock (was $6.25 \mu \mathrm{~s}$ ) on the 8096
Faster interrupt response (almost twice as fast as 8096)
Powerdown and Idle Modes
6 new instructions including Compare Long and Block Move
8 new interrupt vectors/6 new interrupt sources

## PERIPHERAL FEATURES

SFR Window switching allows read-only registers to be written and vice-versa
Timer2 can count up or down by external selection
Timer2 has an independent capture register
HSO line events are stored in a register
HSO has CAM Lock and CAM Clear commands
New Baud Rate values are needed for serial port, higher speeds possible in all modes
Double buffered serial port transmit register
Serial Port Receive Overrun and Framing Error Detection
PWM has a Divide-by-2 Prescaler

## NEW INSTRUCTIONS

PUSHA - PUSHes the PSW, IMASK, IMASK1, and WSR
(Used instead of PUSHF when new interrupts and registers are used.)
assembly language format: PUSHA
object code format: <11110100>
bytes: 1
states: on-chip stack: 12 off-chip stack: 18

POPA - POPs the PSW, IMASK, IMASK1, and WSR
(Used instead of POPF when new interrupts and registers are used.)
assembly language format: POPA
object code format: <11110101>
bytes: 1
states: on-chip stack: 12 off-chip stack:18

IDLPD - Sets the part into Idle or Powerdown Mode
assembly language format: IDLPD \#key (key=1 for Idle, key=2 for Powerdown.)
object code format: < 11110110> < key >
bytes: 2
states: legal key: 8
illegal key: 25
DJNZW - Decrement Jump Not Zero using a Word counter assembly language format: DJNZW wreg, cadd
object code format: < 11100001> <wreg> <disp>
bytes: 3
states: jump not taken: 6 jump taken: 10

CMPL - Compare 2 long direct values
assembly language format: DST SRC
CMPL Lreg, Lreg
object code format: < 11000101> <src Lreg> < dst Lreg>
bytes: 3
states: 7

BMOV - Block move using 2 auto-incrementing pointers and a counter assembly language format: PTRS CNTREG BMOV Lreg, wreg
object code format: <11000001><wreg><Lreg>
bytes: 3
states: internal/internal: 8 per transfer +6
external/internal: 11 per transfer +6 external/external: 14 per transfer +6

## SFR OPERATION

All of the registers that were present on the M8096 work the same way as they did, except that the baud rate value is different. The new registers shown in the memory map control new functions. The most important new register is the Window Select Register (WSR) which allows reading of the formerly write-only registers and vice-versa. Using the WSR is described later in this data sheet.

## PACKAGING

The M80C196KB is available in a ceramic pin grid array, shown in Figure 2, and a leaded ceramic quad pack shown in Figure 3. A comparison of the pinouts for both of these package types is shown in Tables 1a-1c.


271089-2
Figure 2. Pin Grid Array Pinout


271089-3
Figure 3. 68-Lead Ceramic Quad Flat Pack Pinout
Table 1a. M80C196KB Pinout - in PGA Pin Order

| PGA | Signal | PGA | Signal |
| :---: | :---: | :---: | :---: |
| 1 | ACH7/P0.7 | 24 | AD6/P3.6 |
| 2 | ACH6/P0.6 | 25 | AD7/P3.7 |
| 3 | ACH2/P0. 2 | 26 | AD8/P4.0 |
| 4 | ACH0/P0.0 | 27 | AD9/P4.1 |
| 5 | ACH1/P0.1 | 28 | AD10/P4.2 |
| 6 | ACH3/P0.3 | 29 | AD11/P4.3 |
| 7 | NMI | 30 | AD12/P4.4 |
| 8 | EA | 31 | AD13/P4.5 |
| 9 | $V_{C C}$ | 32 | AD14/P4.6 |
| 10 | $\mathrm{V}_{\text {SS }}$ | 33 | AD15/P4.7 |
| 11 | XTAL1 | 34 | T2CLK/P2.3 |
| 12 | XTAL2 | 35 | READY |
| 13 | CLKOUT | 36 | T2RST/P2.4/ $\overline{\text { AINC }}$ |
| 14 | BUSWIDTH | 37 | BHE/WRH |
| 15 | INST | 38 | $\overline{\mathrm{WR}} / \overline{\mathrm{WRL}}$ |
| 16 | ALE/ $\overline{\text { ADV }}$ | 39 | PWM/P2.5 |
| 17 | RD | 40 | T2CAPTURE/P2.7/PACT |
| 18 | AD0/P3.0 | 41 | $V_{\text {PP }}$ |
| 19 | AD1/P3.1 | 42 | $V_{S S}$ |
| 20 | AD2/P3.2 | 43 | HSO. 3 |
| 21 | AD3/P3.3 | 44 | HS0. 2 |
| 22 | AD4/P3.4 | 45 | T2UP-DN/P2.6 |
| 23 | AD5/P3.5 | 46 | P1.7 |


| PGA | Signal |
| :---: | :--- |
| 47 | P1.6 |
| 48 | P1.5 |
| 49 | HSO.1 |
| 50 | HSO.0 |
| 51 | HSO.5/HSI.3 |
| 52 | HSO.4/HSI.2 |
| 53 | HSI.1 |
| 54 | HSI.0 |
| 55 | P1.4 |
| 56 | P1.3 |
| 57 | P1.2 |
| 58 | P1.1 |
| 59 | P1.0 |
| 60 | TXD/P2.0 |
| 61 | RXD/P2.1 |
| 62 | RESET |
| 63 | EXTINT/P2.2 |
| 64 | VSS |
| 65 | VREF |
| 66 | ANGND |
| 67 | ACH4/P0.4 |
| 68 | ACH5/P0.5 |
|  |  |

Table 1b. M80C196KB Pinout - in CQFP Pin Order

| CQFP | Signal |
| :---: | :--- |
| 1 | $\mathrm{~V}_{\mathrm{CC}}$ |
| 2 | $\overline{\mathrm{EA}}$ |
| 3 | NMI |
| 4 | $\mathrm{ACH3/P0.3}$ |
| 5 | $\mathrm{ACH} 1 / \mathrm{P} 0.1$ |
| 6 | ACH0/P0.0 |
| 7 | ACH2/P0.2 |
| 8 | ACH6/P0.6 |
| 9 | ACH7/P0.7 |
| 10 | ACH5/P0.5 |
| 11 | ACH4/P0.4 |
| 12 | ANGND |
| 13 | $\mathrm{~V}_{\mathrm{REF}}$ |
| 14 | $\mathrm{~V}_{\mathrm{SS}}$ |
| 15 | EXTINT/P2.2 |
| 16 | $\overline{R E S E T}$ |
| 17 | RXD/P2.1 |
| 18 | TXD/P2.0 |
| 19 | P1.0 |
| 20 | P1.1 |
| 21 | P1.2 |
| 22 | P1.3 |
| 23 | P1.4 |


| CQFP | Signal |
| :---: | :--- |
| 24 | HSI.0 |
| 25 | HSI.1 |
| 26 | HSO.4/HSI.2 |
| 27 | HSO.5/HSI.3 |
| 28 | HSO.0 |
| 29 | HSO.1 |
| 30 | P1.5 |
| 31 | P1.6 |
| 32 | P1.7 |
| 33 | T2UP-DN/P2.6 |
| 34 | HSO.2 |
| 35 | HSO.3 |
| 36 | VSS |
| 37 | VPP |
| 38 | T2CAPTURE/P2.7/PACT |
| 39 | PWM/P2.5 |
| 40 | $\overline{\text { WR/WRL }}$ |
| 41 | $\overline{\text { BHE/WRH }} \overline{42}$ |
| 43 | T2RST/P2.4/AINC |
| 44 | READY |
| 45 | AD15/P4.7 |
| 46 | AD14/P4.6 |


| CQFP | Signal |
| :---: | :--- |
| 47 | AD13/P4.5 |
| 48 | AD12/P4.4 |
| 49 | AD11/P4.3 |
| 50 | AD10/P4.2 |
| 51 | AD9/P4.1 |
| 52 | AD8/P4.0 |
| 53 | AD7/P3.7 |
| 54 | AD6/P3.6 |
| 55 | AD5/P3.5 |
| 56 | AD4/P3.4 |
| 57 | AD3/P3.3 |
| 58 | AD2/P3.2 |
| 59 | AD0/P3.0 |
| 60 | RD |
| 61 | ALE/ADV |
| 62 | INST |
| 63 | BUSWIDTH |
| 64 | CLKOUT |
| 65 | XTAL2 |
| 66 | XTAL1 |
| 67 | VSS |
| 68 |  |
|  |  |

Table 1c. M80C196KB Pinout - in Signal Order

| Signal | PGA | CQFP | Signal | PGA | CQFP | Signal | PGA | CQFP |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ACH0/P0.0 | 4 | 6 | T2CAPTURE/P2.7/ $\overline{\text { PACT }}$ | 40 | 38 | HSI. 0 | 54 | 24 |
| ACH1/P0.1 | 5 | 5 | AD0/P3.0 | 18 | 60 | HSI. 1 | 53 | 25 |
| ACH2/P0.2 | 3 | 7 | AD1/P3.1 | 19 | 59 | $\overline{\mathrm{RD}}$ | 17 | 61 |
| ACH3/P0.3 | 6 | 4 | AD2/P3.2 | 20 | 58 | $\overline{\mathrm{WR}} / \overline{\mathrm{WRL}}$ | 38 | 40 |
| ACH4/P0.4 | 67 | 11 | AD3/P3.3 | 21 | 57 | $\overline{\mathrm{BHE}} / \overline{\mathrm{WRH}}$ | 37 | 41 |
| ACH5/P0.5 | 68 | 10 | AD4/P3.4 | 22 | 56 | BUSWIDTH | 14 | 64 |
| ACH6/P0.6 | 2 | 8 | AD5/P3.5 | 23 | 55 | ALE/ $\overline{\text { ADV }}$ | 16 | 62 |
| ACH7/P0.7 | 1 | 9 | AD6/P3.6 | 24 | 54 | $\overline{E A}$ | 8 | 2 |
| P1.0 | 59 | 19 | AD7/P3.7 | 25 | 53 | INST | 15 | 63 |
| P1.1 | 58 | 20 | AD8/P4.0 | 26 | 52 | READY | 35 | 43 |
| P1.2 | 57 | 21 | AD9/P4.1 | 27 | 51 | NMI | 7 | 3 |
| P1.3 | 56 | 22 | AD10/P4.2 | 28 | 50 | RESET | 62 | 16 |
| P1.4 | 55 | 23 | AD11/P4.3 | 29 | 49 | XTAL1 | 11 | 67 |
| P1.5 | 48 | 30 | AD12/P4.4 | 30 | 48 | XTAL2 | 12 | 66 |
| P1.6 | 47 | 31 | AD13/P4.5 | 31 | 47 | CLKOUT | 13 | 65 |
| P1.7 | 46 | 32 | AD14/P4.6 | 32 | 46 | ANGND | 66 | 12 |
| TXD/P2.0 | 60 | 18 | AD15/P4.7 | 33 | 45 | $V_{\text {REF }}$ | 65 | 13 |
| RXD/P2.1 | 61 | 17 | HSO. 0 | 50 | 28 | $V_{P P}$ | 41 | 37 |
| EXTINT/P2.2 | 63 | 15 | HSO. 1 | 49 | 29 | $V_{\text {CC }}$ | 9 | 1 |
| T2CLK/P2.3 | 34 | 44 | HSO. 2 | 44 | 34 | $V_{S S}$ | 10 | 68 |
| T2RST/P2.4/ $\overline{\text { AINC }}$ | 36 | 42 | HSO. 3 | 43 | 35 | $V_{S S}$ | 42 | 36 |
| PWM/P2.5 | 39 | 39 | HSO.4/HSI. 2 | 52 | 26 | $V_{S S}$ | 64 | 14 |
| T2UP-DN/P2.6 | 45 | 33 | HSO.5/HSI. 3 | 51 | 27 |  |  |  |

PIN DESCRIPTIONS

| Symbol | Name and Function |
| :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | Main supply voltage (5V). |
| $\mathrm{V}_{\text {SS }}$ | Digital circuit ground ( OV ). There are three $\mathrm{V}_{\mathrm{SS}}$ pins, all of which must be connected. |
| $\mathrm{V}_{\text {REF }}$ | Reference voltage for the $\mathrm{A} / \mathrm{D}$ converter ( 5 V ). $\mathrm{V}_{\mathrm{REF}}$ is also the supply voltage to the analog portion of the A/D converter and the logic used to read Port 0 . Must be connected for $A / D$ and Port 0 to function. |
| ANGND | Reference ground for the A/D converter. Must be held at nominally the same potential as $V_{S S}$. |
| $V_{\text {PP }}$ | Timing pin for the return from powerdown circuit. Connect this pin with a $1 \mu \mathrm{~F}$ capacitor to $\mathrm{V}_{\mathrm{SS}}$ and a $1 \mathrm{M} \Omega$ resistor to $\mathrm{V}_{\mathrm{CC}}$. If this function is not used $\mathrm{V}_{\mathrm{PP}}$ may be tied to $\mathrm{V}_{\mathrm{CC}}$. This pin was $\mathrm{V}_{\mathrm{BB}}$ on the 8X9X-90 parts and is the programming voltage on EPROM part. |
| XTAL1 | Input of the oscillator inverter and of the internal clock generator. |
| XTAL2 | Output of the oscillator inverter. |
| CLKOUT | Output of the internal clock generator. The frequency of CLKOUT is $1 / 2$ the oscillator frequency. It has a $50 \%$ duty cycle. |
| RESET | Reset input to the chip. Input low for at least 4 state times to reset the chip. The subsequent low-to-high transition re- synchronizes CLKOUT and commences a 10 -statetime sequence in which the PSW is cleared, a byte read from 2018 H loads CCR, and a jump to location 2080 H is executed. Input high for normal operation. $\overline{\text { RESET }}$ has an internal pullup. |
| BUSWIDTH | Input for buswidth selection. If CCR bit 1 is a one, this pin selects the bus width for the bus cycle in progress. If BUSWIDTH is a 1 , a 16 -bit bus cycle occurs. If BUSWIDTH is a 0 an 8 -bit cycle occurs. If CCR bit 1 is a 0 , the bus is always an 8 -bit bus. This pin is the TEST pin on 8X9X-90 parts. Systems with TEST tied to $\mathrm{V}_{\mathrm{CC}}$ do not need to change. |

PIN DESCRIPTIONS (Continued)

| Symbol | Name and Function |
| :---: | :---: |
| NMI | A positive transition causes a vector through 203EH. |
| INST | Output high during an external memory read indicates the read is an instruction fetch. INST is valid throughout the bus cycle. INST is activated only during external memory accesses and output low for a data fetch. |
| $\overline{E A}$ | $\overline{\mathrm{EA}}$ must be equal to a TTL-low to cause address locations 2000 H through 3FFFH to be directed to off-chip memory. |
| ALE/ $\overline{\text { ADV }}$ | Address Latch Enable or Address Valid output, as selected by CCR. Both pin options provide a latch to demultiplex the address from the address/data bus. When the pin is $\overline{\mathrm{ADV}}$, it goes inactive high at the end of the bus cycle. $\overline{\mathrm{ADV}}$ can be used as a chip select for external memory. ALE/ $\overline{A D V}$ is activated only during external memory accesses. |
| $\overline{\mathrm{RD}}$ | Read signal output to external memory. $\overline{R D}$ is activated only during external memory reads. |
| $\overline{\text { WR } / \overline{W R L}}$ | Write and Write Low output to external memory, as selected by the CCR. $\overline{W R}$ will go low for every external write, while WRL will go low only for external writes where an even byte is being written. $\overline{W R} / \overline{W R L}$ is activated only during external memory writes. |
| $\overline{\mathrm{BHE}} / \overline{\mathrm{WRH}}$ | Bus High Enable or Write High output to external memory, as selected by the CCR. $\overline{\text { BHE }}$ $=0$ selects the bank of memory that is connected to the high byte of the data bus. $\mathrm{A} 0=0$ selects the bank of memory that is connected to the low byte of the data bus. Thus accesses to a 16-bit wide memory can be to the low byte only ( $\mathrm{A} 0=0, \overline{\mathrm{BHE}}=1$ ), to the high byte only $(\mathrm{AO}=1, \overline{\mathrm{BHE}}=0)$, or both bytes $(\mathrm{AO}=0, \overline{\mathrm{BHE}}=0)$. If the $\overline{\mathrm{WRH}}$ function is selected, the pin will go low if the bus cycle is writing to an odd memory location. $\overline{\mathrm{BHE}} /$ $\overline{\text { WRH }}$ is valid only during 16-bit external memory write cycles. |
| READY | Ready input to lengthen external memory cycles, for interfacing to slow or dynamic memory, or for bus sharing. If the pin is high, CPU operation continues in a normal manner. If the pin is low prior to the falling edge of CLKOUT, the memory controller goes into a wait mode until the next positive transition in CLKOUT occurs with READY high. When the external memory is not being used, READY has no effect. Internal control of the number of wait states inserted into a bus cycle held not ready is available through configuration of CCR. |
| HSI | Inputs to High Speed Input Unit. Four HSI pins are available: HSI.0, HSI.1, HSI.2, and HSI.3. Two of them (HSI. 2 and HSI.3) are shared with the HSO Unit. |
| HSO | Outputs from High Speed Output Unit. Six HSO pins are available: HSO.0, HSO.1, HSO.2, HSO.3, HSO.4, and HSO.5. Two of them (HSO. 4 and HSO.5) are shared with the HSI Unit. |
| Port 0 | 8-bit high impedance input-only port. Three pins can be used as digital inputs and/or as analog inputs to the on-chip A/D converter. |
| Port 1 | 8-bit quasi-bidirectional I/O port. |
| Port 2 | 8-bit multi-functional port. All of its pins are shared with other functions in the M80C196KB. |
| Ports 3 and 4 | 8 -bit bi-directional I/O ports with open drain outputs. These pins are shared with the multiplexed address/data bus which has strong internal pullups. |

Instruction Summary

| Mnemonic | Operands | Operation (Note 1) | Flags |  |  |  |  |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Z | N | C | v | VT | ST |  |
| ADD/ADDB | 2 | $D \leftarrow D+A$ | $\checkmark$ | $\checkmark$ | $\nu$ | $\nu$ | $\uparrow$ | - |  |
| ADD/ADDB | 3 | $D \leftarrow B+A$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| ADDC/ADDCB | 2 | $D \leftarrow D+A+C$ | $\downarrow$ | $\checkmark$ | $\nu$ | $\checkmark$ | $\uparrow$ | - |  |
| SUB/SUBB | 2 | $\mathrm{D} \leftarrow \mathrm{D}-\mathrm{A}$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\nu$ | $\uparrow$ | - |  |
| SUB/SUBB | 3 | $D \leftarrow B-A$ | $\checkmark$ | $\nu$ | $\nu$ | $\nu$ | $\uparrow$ | - |  |
| SUBC/SUBCB | 2 | $\mathrm{D} \leftarrow \mathrm{D}-\mathrm{A}+\mathrm{C}-1$ | $\downarrow$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| CMP/CMPB | 2 | D - A | $\checkmark$ | $\checkmark$ | $\nu$ | $\nu$ | $\uparrow$ | - |  |
| MUL/MULU | 2 | $\mathrm{D}, \mathrm{D}+2 \leftarrow \mathrm{D} \times \mathrm{A}$ | - | - | - | - | - | - | 2 |
| MUL/MULU | 3 | $\mathrm{D}, \mathrm{D}+2 \leftarrow \mathrm{~B} \times \mathrm{A}$ | - | - | - | - | - | - | 2 |
| MULB/MULUB | 2 | $\mathrm{D}, \mathrm{D}+1 \leftarrow \mathrm{D} \times \mathrm{A}$ | - | - | - | - | - | - | 3 |
| MULB/MULUB | 3 | $\mathrm{D}, \mathrm{D}+1 \leftarrow \mathrm{~B} \times \mathrm{A}$ | - | - | - | - | - | - | 3 |
| DIVU | 2 | $D \leftarrow(\mathrm{D}, \mathrm{D}+2) / \mathrm{A}, \mathrm{D}+2 \leftarrow$ remainder | - | - | - | $\checkmark$ | $\uparrow$ | - | 2 |
| DIVUB | 2 | $\mathrm{D} \leftarrow(\mathrm{D}, \mathrm{D}+1) / \mathrm{A}, \mathrm{D}+1 \leftarrow$ remainder | - | - | - | $\nu$ | $\uparrow$ | - | 3 |
| DIV | 2 | $\mathrm{D} \leftarrow(\mathrm{D}, \mathrm{D}+2) / \mathrm{A}, \mathrm{D}+2 \leftarrow$ remainder | - | - | - | $\checkmark$ | $\uparrow$ | - |  |
| DIVB | 2 | $\mathrm{D} \leftarrow(\mathrm{D}, \mathrm{D}+1) / \mathrm{A}, \mathrm{D}+1 \leftarrow$ remainder | - | - | - | $\checkmark$ | $\uparrow$ | - |  |
| AND/ANDB | 2 | $\mathrm{D} \leftarrow \mathrm{D}$ AND A | $\checkmark$ | $\checkmark$ | 0 | 0 | - | - |  |
| AND/ANDB | 3 | $\mathrm{D} \leftarrow \mathrm{BAND} A$ | $\nu$ | $\nu$ | 0 | 0 | - | - |  |
| OR/ORB | 2 | $\mathrm{D} \leftarrow \mathrm{DORA}$ | $\checkmark$ | $r$ | 0 | 0 | - | - |  |
| XOR/XORB | 2 | $\mathrm{D} \leftarrow \mathrm{D}$ (ecxl. or) A | $\checkmark$ | $\checkmark$ | 0 | 0 | - | - |  |
| LD/LDB | 2 | $D \leftarrow A$ | - | - | - | - | - | - |  |
| ST/STB | 2 | $\mathrm{A} \leftarrow \mathrm{D}$ | - | - | - | - | - | - |  |
| LDBSE | 2 | $\mathrm{D} \leftarrow \mathrm{A} ; \mathrm{D}+1 \leftarrow \operatorname{SIGN}(\mathrm{~A})$ | - | - | - | - | - | - | 3,4 |
| LDBZE | 2 | $\mathrm{D} \leftarrow \mathrm{A} ; \mathrm{D}+1 \leftarrow 0$ | - | - | - | - | - | - | 3,4 |
| PUSH | 1 | $\mathrm{SP} \leftarrow \mathrm{SP}-2 ; \mathrm{SP}) \leftarrow \mathrm{A}$ | - | - | - | - | - | - |  |
| POP | 1 | $\mathrm{A} \leftarrow(\mathrm{SP})$; SP + 2 | - | - | - | - | - | - |  |
| PUSHF | 0 | $\begin{aligned} & \mathrm{SP} \leftarrow \mathrm{SP}-2 ;(\mathrm{SP}) \leftarrow \mathrm{PSW} ; \\ & \text { PSW } \leftarrow \mathrm{OOOOH} ; \mathrm{I} \leftarrow 0 \end{aligned}$ | 0 | 0 | 0 | 0 | 0 | 0 |  |
| POPF | 0 | $\mathrm{PSW} \leftarrow(\mathrm{SP})$; SP $\leftarrow \mathrm{SP}+2 ; \mathrm{l}$ ¢ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |  |
| SJMP | 1 | $\mathrm{PC} \leftarrow \mathrm{PC}+11$-bit offset | - | - | - | - | - | - | 5 |
| LJMP | 1 | $\mathrm{PC} \leftarrow \mathrm{PC}+16$-bit offset | - | - | - | - | - | - | 5 |
| BR[indirect] | 1 | $\mathrm{PC} \leftarrow(\mathrm{A})$ | - | - | - | - | - | - |  |
| SCALL | 1 | $\begin{aligned} & \mathrm{SP} \leftarrow \mathrm{SP}-2 ; \\ & (\mathrm{SP}) \leftarrow \mathrm{PC} ; \mathrm{PC} \leftarrow \mathrm{PC}+\text { 11-bit offset } \end{aligned}$ | - | - | - | - | - | - | 5 |
| LCALL | 1 | $\begin{aligned} & \mathrm{SP} \leftarrow \mathrm{SP}-2 ;(\mathrm{SP}) \leftarrow \mathrm{PC} ; \\ & \mathrm{PC} \leftarrow \mathrm{PC}+16 \text {-bit offset } \end{aligned}$ | - | - | - | - | - | - | 5 |

M80C196KB

Instruction Summary (Continued)

| Mnemonic | Operands | Operation (Note 1) | Flags |  |  |  |  |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Z | N | C | V | VT | ST |  |
| RET | 0 | $\mathrm{PC} \leftarrow(\mathrm{SP}) ; \mathrm{SP} \leftarrow \mathrm{SP}+2$ | - | - | - | - | - | - |  |
| $J$ (conditional) | 1 | $\mathrm{PC} \leftarrow \mathrm{PC}+8$-bit offset (if taken) | - | - | - | - | - | - | 5 |
| JC | 1 | Jump if $C=1$ | - | - | - | - | - | - | 5 |
| JNC | 1 | jump if $\mathrm{C}=0$ | - | - | - | - | - | - | 5 |
| JE | 1 | jump if $Z=1$ | - | - | - | - | - | - | 5 |
| JNE | 1 | Jump if $Z=0$ | - | - | - | - | - | - | 5 |
| JGE | 1 | Jump if $N=0$ | - | - | - | - | - | - | 5 |
| JLT | 1 | Jump if $N=1$ | - | - | - | - | - | - | 5 |
| JGT | 1 | Jump if $\mathrm{N}=0$ and $\mathrm{Z}=0$ | - | - | - | - | - | - | 5 |
| JLE | 1 | Jump if $N=1$ or $Z=1$ | - | - | - | - | - | - | 5 |
| JH | 1 | Jump if $C=1$ and $Z=0$ | - | - | - | - | - | - | 5 |
| JNH | 1 | Jump if $C=0$ or $Z=1$ | - | - | - | - | - | - | 5 |
| JV | 1 | Jump if $\mathrm{V}=0$ | - | - | - | - | - | - | 5 |
| JNV | 1 | Jump if $\mathrm{V}=1$ | - | - | - | - | - | - | 5 |
| JVT | 1 | Jump if $\mathrm{VT}=1$; Clear $\mathrm{V} T$ | - | - | - | - | 0 | - | 5 |
| JNVT | 1 | Jump if VT = 0; Clear VT | - | - | - | - | 0 | - | 5 |
| JST | 1 | Jump if $S T=1$ | - | - | - | - | - | - | 5 |
| JNST | 1 | Jump if ST $=0$ | - | - | - | - | - | - | 5 |
| JBS | 3 | Jump if Specified Bit $=1$ | - | - | - | - | - | - | 5,6 |
| JBC | 3 | Jump if Specified Bit $=0$ | - | - | - | - | - | - | 5,6 |
| DJNZ/ DJNZW | 1 | $\begin{aligned} & D \leftarrow D-1 ; \\ & \text { If } D \neq 0 \text { then } P C \leftarrow P C+8 \text {-bit offset } \end{aligned}$ | - | - | - | - | - | - | 5 |
| DEC/DECB | 1 | $D \leftarrow D-1$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| NEG/NEGB | 1 | $D \leftarrow 0-D$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| INC/INCB | 1 | $D \leftarrow D+1$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| EXT | 1 | $\mathrm{D} \leftarrow \mathrm{D} ; \mathrm{D}+2 \leftarrow \operatorname{Sign}(\mathrm{D})$ | $\checkmark$ | $\checkmark$ | 0 | 0 | - | - | 2 |
| EXTB | 1 | $\mathrm{D} \leftarrow \mathrm{D} ; \mathrm{D}+1 \leftarrow \operatorname{Sign}(\mathrm{D})$ | $\checkmark$ | $\checkmark$ | 0 | 0 | - | - | 3 |
| NOT/NOTB | 1 | $\mathrm{D} \leftarrow$ Logical Not (D) | $\checkmark$ | $\checkmark$ | 0 | 0 | - | - |  |
| CLR/CLRB | 1 | $\mathrm{D} \leftarrow 0$ | 1 | 0 | 0 | 0 | - | - |  |
| SHL/SHLB/SHLL | 2 | $\mathrm{C} \leftarrow \mathrm{msb}-\cdots-\mathrm{lsb} \leftarrow 0$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - | 7 |
| SHR/SHRB/SHRL | 2 | $0 \rightarrow$ msb---- Isb $\rightarrow$ C | $\checkmark$ | $\checkmark$ | $\checkmark$ | 0 | - | $\checkmark$ | 7 |
| SHRA/SHRAB/SHRAL | 2 | msb $\rightarrow$ msb----Isb $\rightarrow$ C | $\checkmark$ | $\checkmark$ | $\checkmark$ | 0 | - | $\checkmark$ | 7 |
| SETC | 0 | $C \leftarrow 1$ | - | - | 1 | - | - | - |  |
| CLRC | 0 | $\mathrm{C} \leftarrow 0$ | - | - | 0 | - | - | - |  |

Instruction Summary (Continued)

| Mnemonic | Operands | Operation ( Note 1) | Flags |  |  |  |  |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Z | N | C | v | VT | ST |  |
| CLRVT | 0 | VT $\leftarrow 0$ | - | - | - | - | 0 | - |  |
| RST | 0 | $\mathrm{PC} \leftarrow 2080 \mathrm{H}$ | 0 | 0 | 0 | 0 | 0 | 0 | 8 |
| DI | 0 | Disable All Interupts ( $1 \leftarrow 0$ ) | - | - | - | - | - | - |  |
| El | 0 | Enable All Interupts ( $\leftarrow$ ) | - | - | - | - | - | - |  |
| NOP | 0 | $\mathrm{PC} \leftarrow \mathrm{PC}+1$ | - | - | - | - | - | - |  |
| SKIP | 0 | $\mathrm{PC} \leftarrow \mathrm{PC}+2$ | - | - | - | - | - | - |  |
| NORML | 2 | Left shift till msb $=1$; $\mathrm{D} \leftarrow$ shift count | $\checkmark$ | $\checkmark$ | 0 | - | - | - | 7 |
| TRAP | 0 | $\begin{aligned} & \hline \mathrm{SP} \leftarrow \mathrm{SP}-2 ; \\ & \mathrm{SP}) \leftarrow \mathrm{PC} ; \mathrm{PC} \leftarrow(2010 \mathrm{H}) \end{aligned}$ | - | - | - | - | - | - | 9 |
| PUSHA | 1 | $\begin{aligned} & \hline \mathrm{SP} \leftarrow \mathrm{SP}-2 ;(\mathrm{SP}) \leftarrow \mathrm{PSW} ; \\ & \mathrm{PSW} \leftarrow \text { oo00H; SP } \leftarrow \text { SP-2; } \\ & (\mathrm{SP}) \leftarrow \text { IMASK1 } 1 \text { WSR; IMASK1 } \leftarrow \mathrm{OOH} \\ & \hline \end{aligned}$ | 0 | 0 | 0 | 0 | 0 | 0 |  |
| POPA | 1 | $\begin{aligned} & \text { IMASK1/WSR } \leftarrow(S P) ; \text { SP } \leftarrow \mathrm{SP}+2 \\ & \mathrm{PSW} \leftarrow(\mathrm{SP}) ; \mathrm{SP} \leftarrow \mathrm{SP}+2 \end{aligned}$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\nu$ | $\checkmark$ | $\checkmark$ |  |
| IDLPD | 1 | IDLE MODE IF KEY=1; POWERDOWN MODE IF KEY $=2$; CHIP RESET OTHERWISE | - | - | - | - | - | - |  |
| CMPL | 2 | D-A | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\uparrow$ | - |  |
| BMOV | 2 | [PTR_HI] + $\leftarrow$ [PTR_LOW] +; <br> UNTIL COUNT $=0$ | - | - | - | - | - | - |  |

## NOTES:

1. If the mnemonic ends in " $B$ " a byte operation is performed, otherwise a word operation is done. Operands $D, B$, and $A$ must conform to the alignment rules for the required operand type. $D$ and $B$ are locations in the Register File; A can be located anywhere in memory.
2. $D, D+2$ are consecutive WORDS in memory; $D$ is DOUBLE-WORD aligned.
3. $D, D+1$ are consecutive BYTES in memory; $D$ is WORD aligned.
4. Changes a byte to word.
5. Offset is a 2's complement number.
6. Specified bit is one of the 2048 bits in the register file.
7. The " $L$ " (Long) suffix indicates double-word operation.
8. Initiates a Reset by pulling RESET low. Software should re-initialize all the necessary registers with code starting at 2080 H .
9. The assembler will not accept this mnemonic.

Instruction Execution State Times (Minimum) (1)

| MNEMONIC | DIRECT | IMMED | INDIRECT |  | INDEXED |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | NORMAL* | A-INC* | SHORT* | LONG* |
| ADD (3-op) | 5 | 6 | 7/10 | 8/11 | 7/10 | 8/11 |
| SUB (3-op) | 5 | 6 | 7/10 | 8/11 | 7/10 | 8/11 |
| ADD (2-op) | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| SUB (2-op) | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| ADDC | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| SUBC | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| CMP | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| ADDB (3-op) | 5 | 5 | 7/10 | 8/11 | 7/10 | 8/11 |
| SUBB (3-op) | 5 | 5 | 7/10 | 8/11 | 7/10 | 8/11 |
| ADDB (2-op) | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| SUBB (2-op) | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| ADDCB | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| SUBCB | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| CMPB | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| MUL (3-op) | 16 | 17 | 18/21 | 19/22 | 19/22 | 20/23 |
| MULU (3-op) | 14 | 15 | 16/19 | 17/19 | 17/20 | 18/21 |
| MUL (2-op) | 16 | 17 | 18/21 | 19/22 | 19/22 | 20/23 |
| MULU (2-op) | 14 | 15 | 16/19 | 17/19 | 17/20 | 18/21 |
| DIV | 26 | 27 | 28/31 | 29/32 | 29/32 | 30/33 |
| DIVU | 24 | 25 | 26/29 | 27/30 | 27/30 | 28/31 |
| MULB (3-op) | 12 | 12 | 14/17 | 15/18 | 15/18 | 16/19 |
| MULUB (3-op) | 10 | 10 | 12/15 | 13/15 | 12/16 | 14/17 |
| MULB (2-op) | 12 | 12 | 14/17 | 15/18 | 15/18 | 16/19 |
| MULUB (2-op) | 10 | 10 | 12/15 | 13/15 | 12/16 | 14/17 |
| DIVB | 18 | 18 | 20/23 | 21/24 | 21/24 | 22/25 |
| DIVUB | 16 | 16 | 18/21 | 19/22 | 19/22 | 20/23 |
| AND (3-op) | 5 | 6 | 7/10 | 8/11 | 7/10 | 8/11 |
| AND (2-op) | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| OR (2-op) | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| XOR | 4 | 5 | 6/8 | 7/9 | 6/8 | 7/9 |
| ANDB (3-op) | 5 | 5 | 7/10 | 8/11 | 7/10 | 8/11 |
| ANDB (2-op) | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| ORB (2-op) | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| XORB | 4 | 4 | 6/8 | 7/9 | 6/8 | 7/9 |
| LD/LDB | 4 | 5 | 5/8 | 6/8 | 6/9 | 7/10 |
| ST/STB | 4 | 5 | 5/8 | 6/9 | 6/9 | 7/10 |
| LDBSE | 4 | 4 | 5/8 | 6/8 | 6/9 | 7/10 |
| LDBZE | 4 | 4 | 5/8 | 6/8 | 6/9 | 7/10 |
| BMOV | $6+8$ per word |  |  | $6+11 / 14$ per word |  |  |
| PUSH (int stack) | 6 | 7 | 9/12 | 10/13 | 10/13 | 11/14 |
| POP (int stack) | 8 | - | 10/12 | 11/13 | 11/13 | 12/14 |
| PUSH (ext stack) | 8 | 9 | 11/14 | 12/15 | 12/15 | 13/16 |
| POP (ext stack) | 11 | - | 13/15 | 14/16 | 14/16 | 15/17 |

*Times for (Internal/External) Operands

## NOTE:

1. Execution times for instructions accessing external data memory may be one to two states higher depending on the instruction stream being executed. In sixteen bit mode, the minimum execution state times apply for instructions accessing internal register space. Execution times do not reflect eight bit mode or insertion of wait states.

Instruction Execution State Times (Continued)

| MNEMONIC |  | MNEMONIC |  |
| :---: | :---: | :---: | :---: |
| PUSHF (int stack) | 6 | PUSHF (ext stack) | 8 |
| POPF (int stack) | 7 | POPF (ext stack) | 10 |
| PUSHA (int stack) | 12 | PUSHA (ext stack) | 18 |
| POPA (int stack) | 12 | POPA (ext stack) | 18 |
| TRAP (int stack) | 16 | TRAP (ext stack) | 18 |
| LCALL (int stack) | 11 | LCALL (ext stack) | 13 |
| SCALL (int stack) | 11 | SCALL (ext stack) | 13 |
| RET (int stack) | 11 | RET (ext stack) | 14 |
| CMPL | 7 | DEC/DECB | 3 |
| CLR/CLRB | 3 | EXT/EXTB | 4 |
| NOT/NOTB | 3 | INC/INCB | 3 |
| NEG/NEGB | 3 |  |  |
| LJMP | 7 |  |  |
| SJMP | 7 |  |  |
| BR [indirect] | 7 |  |  |
| JNST, JST | 4/8 jump not taken/jump taken |  |  |
| JNH, JH | 4/8 jump not taken/jump taken |  |  |
| JGT, JLE | 4/8 jump not taken/jump taken |  |  |
| JNC, JC |  |  |  |
| JNVT, JVT | 4/8 jump not taken/jump taken |  |  |
| JNV, JV | 4/8 jump not taken/jump taken |  |  |
| JGE, JLT | 4/8 jump not taken/jump taken |  |  |
| JNE, JE | 4/8 jump not taken/jump taken |  |  |
| JBC, JBS | 5/9 jump not taken/jump taken |  |  |
| DJNZ | 5/9 jump not taken/jump taken 5/9 jump not taken/jump taken |  |  |
| DJNZW |  |  |  |
| NORML | $8+1$ per shift ( 9 for 0 shift) |  |  |
| SHRL | $7+1$ per shift ( 8 for 0 shift) |  |  |
| SHLL | $7+1$ per shift ( 8 for 0 shift) |  |  |
| SHRAL | $7+1$ per shift ( 8 for 0 shift) |  |  |
| SHR/SHRB | $6+1$ per shift ( 7 for 0 shift) |  |  |
| SHL/SHLB | $6+1$ per shift ( 7 for 0 shift) |  |  |
| SHRA/SHRAB | $6+1$ per shift ( 7 for 0 shift) |  |  |
| CLRC | 2 |  |  |
| SETC | 2 |  |  |
| DI | 2 |  |  |
| EI | 2 |  |  |
| CLRVT | 2 |  |  |
| NOP | 2 |  |  |
| RST | 15 (includes fetch of configuration byte) |  |  |
| SKIP | ( l cludes fetch of conigura |  |  |
| IDLPD | 8/25 (proper key/improper key) |  |  |

M80C196KB

| MEMORY MAP |  | M80C196KB INTERRUPTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EXTERNAL MEMORY OR I/O | OFFFFH$4000 \mathrm{H}$ | Number | Source | Vector Location | Priority |
|  |  | INT15 | NMI | 203EH | 15 |
| INTERNAL ROM/EPROM OR <br> EXTERNAL MEMORY |  | INT14 | HSI FIFO Full | 203CH | 14 |
| RESERVED | 2080 | INT13 | EXTINT Pin | 203AH | 13 |
|  | 2040H | INT12 | TIMER2 Overflow | 2038 H | 12 |
| UPPER 8 INTERRUPT VECTORS | 2030H | INT11 | TIMER2 Capture | 2036H | 11 |
| ROM/EPROM SECURITY KEY* | 2020H | INT10 | 4th Entry into HSI FIFO | 2034H | 10 |
| RESERVED |  | INT09 | RI | 2032H | 9 |
| CHIP CONFIGURATION BYTE | 2019 H | INT08 | TI | 2030H | 8 |
|  | 2018H | SPECIAL | Unimplemented Opcode | 2012H | N/A |
| RESERVED | 2014H | SPECIAL | Trap | 2010 H | N/A |
| LOWER 8 INTERRUPT VECTORS PLUS 2 SPECIAL INTERRUPTS |  | INT07 | EXTINT | 200EH | 7 |
|  | 2000 H | INT06 | Serial Port | 200 CH | 6 |
| PORT 3 AND PORT 4 | 1FFEH | INT05 | Software Timer | 200AH | 5 |
| EXTERNAL MEMORY OR I/O |  | INT04 | HSI. 0 Pin | 2008 H | 4 |
| INTERNAL DATA MEMORY - REGISTER FILE (STACK POINTER, RAM AND SFRS) EXTERNAL PROGRAM CODE MEMORY | 0000H | INT03 | High Speed Outputs | 2006H | 3 |
|  |  | INT02 | HSI Data Available | 2004H | 2 |
|  |  | INT01 | A/D Conversion Complete | 2002H | 1 |
| *ROM/EPROM is available for the 80C196 |  | INTOO | Timer Overflow | 2000 H | 0 |



## USING THE ALTERNATE REGISTER WINDOW (WSR = 15)

I/O register expansion on the new CHMOS members of the MCS-96 family has been provided by making two register windows available. Switching between these windows is done using the Window Select Register (WSR). The PUSHA and POPA instructions can be used to push and pop the WSR and second interrupt mask when entering or leaving interrupts, so it is easy to change between windows.

On the M80C196KB only Window 0 and Window 15 are active. Window 0 is a true superset of the standard 8096 SFR space, while Window 15 allows the read-only registers to be written and write-only registers to be read. The only major exception to this is the Timer2 register which is the Timer2 capture register in Window 15. The writeable register for Timer2 is in Window 0 . There are also some minor changes and cautions. The descriptions of the registers which have different functions in Window 15 than in Window 0 are listed below:
AD__COMMAND (02H) — Read the last written command
AD__RESULT $(02 \mathrm{H}, 03 \mathrm{H})$ — Write a value into the result register
HSI__MODE (03H) — Read the value in HSI__MODE
$\mathrm{HSI} \quad$ TIME $(04 \mathrm{H}, 05 \mathrm{H})$ — Write to FIFO Holding register
HSO_TIME $(04 \mathrm{H}, 05 \mathrm{H})$ — Read the last value placed in the holding register
HSI__STATUS (06H) — Write to status bits but not to HSI pin bits. (Pin bits are 1,3,5,7).
HSO__COMMAND (06H) — Read the last value placed in the holding register
SBUF(RX) (07H) - Write a value into the receive buffer
$\operatorname{SBUF}(T X)(07 \mathrm{H}) \quad$ - Read the last value written to the transmit buffer
WATCHDOG $(\mathrm{OAH})$ - Read the value in the upper byte of the WDT
TIMER1 (OAH,0BH) — Write a value to Timer1
TIMER2 ( $0 \mathrm{CH}, 0 \mathrm{DH}$ ) — Read/Write the Timer2 capture register. Note that Timer2 read/write is done with $\mathrm{WSR}=0$.

IOC2 (0BH)
BAUD__RATE (0EH)
— Last written value is readable, except bit 7 (note 1)

PORTO (0EH)
PORT1
SP__STAT (11H)
SP__CON (11H)
IOSO (15H)
IOC0 (15H)
IOS1 (16H)

IOC1 (16H)
IOS2 (17H)

- No function, cannot be read
- No function, no output drivers on the pins. Register reserved.
- IOPORT1 cannot be read or written in Window 15. Register reserved.
- Set the status bits, TI and RI can be set, but it will not cause an interrupt
- Read the current control byte
- Writing to this register controls the HSO pins. Bits 6 and 7 are inactive for writes.
— Last written value is readable, except bit 1 (note 1)
- Writing to this register will set the status bits, but not cause interrupts. Bits 6 and 7 are not functional
- Last written value is readable
— Writing to this register will set the status bits, but not cause interrupts.
PWM__CONTROL (17H) — Read the duty cycle value written to PWM__CONTROL
NOTE:

1. IOC2.7 (CAM CLEAR) and IOC0.1 (T2RST) are not latched and will read as a 1 (precharged bus) .

Being able to write to the read-only registers and vice-versa provides a lot of flexibility. One of the most useful advantages is the ability to set the timers and HSO lines for initial conditions other than zero.

Reserved registers may be used for testing as future features. Do not write to these registers. Read from reserved registers will return indeterminate values.

## SFR BIT SUMMARY

A summary of the SFRs which control I/O functions has been included in this section. The summary is separated into a list of those SFRs which have changed on the M80C196KB and a list of those which have remained almost the same.

The following M80C196KB SFRs are different than those on the M8096BH:
(The Read and Write comments indicate the register's function in Window 0 unless otherwise specified.)

## SBUF(TX): <br> Now double buffered <br> 07h <br> write

## BAUD RATE:

Uses new Baud Rate Values
OEh
write

SP__STAT:

11h
read

## IPEND1: <br> IMASK1:

12h,13h
read/write

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RB8/ <br> RPE | RI | TI | FE | TXE | OE | X | X |

RPE: Receive Parity Error
RI: Receive Indicator
TI: Transmit Indicator
FE: Framing Error
TXE: Transmitter Empty
OE: Receive Overrun Error

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NMI | FIFO <br> FULL | EXT <br> INT | T2 <br> OVF | T2 <br> CAP | $\mathrm{HSI4}$ | RI | TI |

NMI: Non-Maskable Interrupt (set to 0 for future compatibility)
FIFO FULL : HSIO FIFO full
EXTINT: External Interrupt Pin
T2OVF: Timer2 Overflow
T2CAP: Timer2 Capture
HSI4: $\quad \mathrm{HSI}$ has 4 or more entries in FIFO
RI: Receive Interrupt
TI: Transmit Interrupt

WSR:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | $W$ | $W$ | $W$ | $W$ |

14h
read/write
$W W W W=0: S F R s$ function like a superset of M8096 SFRs
$W W W W=14:$ PPW register
$W W W W=15$ : Exchange read/write registers
$W W W W=O T H E R$ : Undefined, do not use
0000 : These bits must always be written as zeros to provide compatibility with future products.

IOS2:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| START <br> A2D | T2 <br> RESET | HSO.5 | HSO.4 | HSO.3 | HSO.2 | HSO.1 | HSO.0 |

10C2:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLEAR <br> CAM | ENA <br> LOCK | T2ALT <br> INT | A2D <br> CPD | $x$ | SLOW <br> PWM | T2UD <br> ENA | FAST <br> T2EN |

OBh
write
Indicates which HSO event occured
START A2D: HSO__CMD 15, start A to D
T2RESET: HSO__CMD 14, Timer 2 reset
HSO.0-5 :

Output pins HSO. 0 through HSO. 5

CLEAR__CAM : Clear Entire CAM
ENA_LOCK: Enable lockable CAM entry feature
T2ALT INT: Enable T2 Alternate Interrupt at 8000H
A2D__CPD: Clock Prescale Disable for low XTAL frequency (A to D conversion in fewer state times)
$X$ : Set to 0
SLOW__PWM : Turn on divide by 2 Prescaler on PWM
T2UD ENA: Enable Timer 2 as up/down counter
FAST__T2EN : Enable Fast increment of T2; once per state time.
The following registers are the same on the M80C196KB as they were on the M8096BH:




WHERE EACH 2-BIT MODE CONTROL FIELD DEFINES ONE OF 4 POSSIBLE MODES:

008 POSITIVE TRANSITIONS
01 EACH POSITIVE TRANSITION
10 EACH NEGATIVE TRANSITION
11 EVERY TRANSITION (POSITIVE AND NEGATIVE)

271089-7


WHERE FOR EACH 2 - BIT STATUS FIELD THE LOWER BIT INDICATES WHETHER OR NOT AN EVENT HAS OCCURRED ON THIS PIN AND THE UPPER BIT INDICATES THE CURRENT STATUS OF THE PIN.

271089-8

HSO Command ( 06 H )
CHANNEL: O-5 HSO.O-HSO.5


271089-9


IOCO (15H)

| 0 | - hSI. 0 Infut enable / DISABLE |
| :---: | :---: |
| 1 | TIMER 2 RESET EACH WRITE |
|  |  |
| 2 | HSI. 1 INPUT ENABLE / DISABLE |
| 3 | TIMER 2 EXTERNAL RESET ENABLE / $\overline{\text { IISABLE }}$ |
| 4 | hSI. 2 INPUT ENABLE / DISABLE |
|  |  |
| 5 | IMER 2 RESET SOURCE HSI.0 / T2RST |
| 6 | HSI. 3 InPUT ENABLE / DISABLE |
| 7 | - TIMER 2 CLOCK SOURCE HSI. 1 / T2CLK |



|  | IOC1 (16H) |
| :---: | :---: |
| 0 | - SELECT PWM / SELECT P2.5 |
| 1 | - EXTERNAL INTERRUPT ACH7 / EXTINT |
| 2 | - TIMER 1 OVERFLOW INTERRUPT ENABLE / DISABLE |
| 3 | - TIMER 2 OVERFLOW INTERRUPT ENABLE / DISABLE |
| 4 | - HSO.4 OUTPUT ENABLE / DISABLE |
| 5 | - SELECT TXD / SELECT P2.0 |
| 6 | - HSO. 5 OUTPUT ENABLE / DISABLE |
| 7 | - HSI INTERRUPT |
|  | FIFO FULL / HOLDING REGISTER LOADED |

271089-14

Port 2 Multiple Functions

| Pin | Func. | Alternative <br> Function | Control <br> Reg. |
| :--- | :--- | :--- | :--- |
| 2.0 | Output | TXD (Serial Port <br> Transmit) | IOC1.5 |
| 2.1 | Input | RXD (Serial Port <br> Receive) | SPCON.3 |
| 2.3 | Input | T2CLK (Timer2 Clock <br> \& Baud) | IOC0.7 |
| 2.4 | Input | T2RST (Timer2 Reset) | IOC0.5 |
| 2.5 | Output | PWM Output | IOC1.0 |
| 2.6 | QBD* | Timer2 up/ <br> down select | IOC2.1 |
| 2.7 | QBD* | Timer2 Capture | N/A |

## Baud Rate Calculations

Asynchronous Modes 1, 2 and 3:
Baud_Reg $=\frac{\text { XTAL1 }}{\text { Baud Rate } \times 16}-1$ OR $\frac{\text { T2CLK }}{\text { Baud Rate } \times 8}$
Synchronous Mode 0:
Baud_Reg $=\frac{\text { XTAL1 }}{\text { Baud Rate } \times 2}-1$ OR $\frac{\text { T2CLK }}{\text { Baud Rate }}$
Baud Rates and Baud Register Values

| Baud <br> Rate | XTAL Frequency |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{8 . 0} \mathbf{~ M H z}$ |  | $\mathbf{1 0 . 0} \mathbf{~ M H z}$ |  | $\mathbf{1 2 . 0} \mathbf{~ M H z}$ |  |
| 300 | 1666 | -0.02 | 2082 | 0.02 | 2499 | 0.00 |
| 1200 | 416 | -0.08 | 520 | -0.03 | 624 | 0.00 |
| 2400 | 207 | 0.16 | 259 | 0.16 | 312 | -0.16 |
| 4800 | 103 | -0.16 | 129 | 0.16 | 155 | 0.16 |
| 9600 | 51 | -0.16 | 64 | 0.16 | 77 | 0.16 |
| 19.2 K | 25 | 0.16 | 32 | 1.40 | 38 | 0.16 |

Baud Register Value/\% Error

A maximum baud rate of 750 Kbaud is available in the asynchronous modes with 12 MHz on XTAL1. The synchronous mode has a maximum rate of 3.0 Mbaud with a 12 MHz clock. Location OEH is the Baud Register. It is loaded sequentially in two bytes, with the low byte being loaded first. This register may not be loaded with zero in serial port Mode 0.

NOTE:
The maximum T2CLK rate is 3 MHz when used to set the baud rate.

## ELECTRICAL CHARACTERISTICS

## Absolute Maximum Ratings*

| Case Temperature under Bias . | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperatu | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage On Any Pin | -0.5 V to +7.0 V |
| Power Diss | . 1.5 W |

NOTICE: This data sheet contains preliminary information on new products in production. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design.
*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## OPERATING CONDITIONS

## MIL-STD-883

| Symbol | Description | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature (Instant On) | -55 | +125 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Digital Supply Voltage | 4.50 | 5.50 | V |
| $\mathrm{~V}_{\text {REF }}$ | Analog Supply Voltage | 4.50 | 5.50 | V |
| $\mathrm{f}_{\mathrm{OSC}}$ | Oscillator Frequency | 3.5 | 12 | MHz |

## Military Temperature (MTO)

| Symbol | Description | Min | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{C}}$ | Case Temperature (Instant On) | -55 | +125 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Digital Supply Voltage | 4.50 | 5.50 | V |
| $\mathrm{~V}_{\text {REF }}$ | Analog Supply Voltage | 4.50 | 5.50 | V |
| $\mathrm{f}_{\mathrm{OSC}}$ | Oscillator Frequency | 3.5 | 12 | MHz |

NOTE:
ANGND and $\mathrm{V}_{\text {SS }}$ should be nominally at the same potential.
DC Characteristics (Over Specified Operating Conditions)

| Symbol | Description | Min | Max | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (Note 1) | $0.2 \mathrm{~V}_{\mathrm{CC}}+1.0$ | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage on XTAL 1 | $0.7 \mathrm{~V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 2}$ | Input High Voltage on RESET | 2.2 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | $\begin{gathered} \hline 0.3 \\ 0.45 \\ 1.5 \\ \hline \end{gathered}$ | $\begin{aligned} & \hline V \\ & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=200 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=7 \mathrm{~mA} \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (Standard Outputs) (Note 2) | $\begin{aligned} & V_{C C}-0.3 \\ & V_{C C}-0.7 \\ & V_{C C}-1.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-7 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage <br> (Quasi-bidirectional Outputs) (Note 3) | $\begin{aligned} & V_{C C}-0.3 \\ & V_{C C}-0.7 \\ & V_{C C}-1.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-30 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-60 \mu \mathrm{~A} \end{aligned}$ |

## NOTES:

1. All pins except $\overline{\text { RESET and XTAL1. }}$
2. Standard Outputs include ADO-15, $\overline{\text { RD, }} \overline{W R}$, ALE, $\overline{B H E}$, INST, HSO pins, PWM/P2.5, CLKOUT, RESET, Ports 3 and 4, TXD/P2.0, and RXD (in serial mode 0 ). The $\mathrm{V}_{\mathrm{OH}}$ specification is not valid for RESET. Ports 3 and 4 are open-drain outputs.
3. QBD (Quasi-bidirectional) pins include Port 1, P2.6 and P2.7.

DC Characteristics (Over Specified Operating Conditions) (Continued)

| Symbol | Description | Min | Max | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current (Std. Inputs) (Note 4) |  | $\pm 10$ | $\mu \mathrm{A}$ | $0<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {CC }}-0.3 \mathrm{~V}$ |
| $\mathrm{l}_{\text {LI } 1}$ | Input Leakage Current () |  | $\pm 7$ | mA | $0<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {REF }}$ |
| $\mathrm{I}_{\mathrm{TL}}$ | 1 to 0 Transition Current (QBD Pins) (Note 3) |  | -800 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=2.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {IL }}$ | Logical 0 Input Current (QBD Pins) (Note 3) |  | -50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |
| IL1 | Logical 0 Input Current in Reset (Note 5) (ALE, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{BHE}}, \mathrm{INST}, \mathrm{P} 2.0)$ |  | -850 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0.45 \mathrm{~V}$ |
| ICC | Active Mode Current in Reset |  | 60 | mA | XTAL1 $=12 \mathrm{MHz}$ |
| IREF | A/D Converter Reference Current |  | 5 | mA | $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{REF}}=5.5 \mathrm{~V}$ |
| IIDLE | Idle Mode Current |  | 25 | mA |  |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Active Mode Current |  | 30 | mA | XTAL1 $=3.5 \mathrm{MHz}$ |
| $\mathrm{I}_{\mathrm{PD}}$ | Powerdown Mode Current |  | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=V_{P P}=V_{R E F}=5.5 \mathrm{~V} \\ & \text { XTAL1 }=12 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{R}_{\text {RST }}$ | Reset Pullup Resistor | 6K | 50K | $\Omega$ |  |
| $\mathrm{C}_{S}$ | Pin Capacitance (Any Pin to $\mathrm{V}_{\text {SS }}$ ) |  | 10 | pF | $\mathrm{f}_{\text {TEST }}=1.0 \mathrm{MHz}$ |

## NOTES:

(Notes apply to all specifications)
2. Standard Outputs include ADO-15, $\overline{\text { RD, }} \overline{\mathrm{WR}}, \mathrm{ALE}, \overline{\mathrm{BHE}}, \mathrm{INST}, \mathrm{HSO}$ pins, PWM/P2.5, CLKOUT, RESET, Ports 3 and 4, TXD/P2.0, and RXD (in serial mode 0 ). The $\mathrm{V}_{\mathrm{OH}}$ specification is not valid for RESET. Ports 3 and 4 are open-drain outputs.
3. QBD (Quasi-bidirectional) pins include Port 1, P2.6 and P2.7.
4. Standard Inputs include HSI pins, EA, READY, BUSWIDTH, NMI, RXD/P2.1, EXTINT/P2.2, T2CLK/P2.3, and T2RST/

P2.4.
5. Holding these pins below $\mathrm{V}_{\mathrm{IH}}$ in Reset may cause the part to enter test modes.
6. Maximum current per pin must be externally limited to the following values if $\mathrm{V}_{\mathrm{OL}}$ is held above 0.45 V or $\mathrm{V}_{\mathrm{OH}}$ is held below $\mathrm{V}_{\mathrm{CC}}-0.7 \mathrm{~V}$ :

IOL on Output pins: 10 mA
$\mathrm{I}_{\mathrm{OH}}$ on quasi-bidirectional pins: self limiting
IOH on Standard Output pins: 10 mA
7. Maximum current per bus pin (data and control) during normal operation is $\pm 3.2 \mathrm{~mA}$.
8. During normal (non-transient) conditions the following total current limits apply:
Port 1, P2.6
HSO, P2.0, RXD, RESET
P2.5, P2.7, WR, BHE
AD0-AD15
Iol: 29 mA
$\mathrm{IOH}_{\mathrm{OH}}$ is self limiting
$\mathrm{I}_{\mathrm{OL}}: 29 \mathrm{~mA} \quad \mathrm{I}_{\mathrm{OH}}: 26 \mathrm{~mA}$
lol: 13 mA
ІОН: 11 mA
Iol: 52 mA
ІН: 52 mA
RD, ALE, INST-CLKOUT
loL: 13 mA
$\mathrm{IOH:}^{13 \mathrm{~mA}}$


271089-16
Figure 4. ICC and I IDLE vs Frequency

M80C196KB

AC Characteristics (Over Specified Operating Conditions)
Test Conditions: Capacitive load on all pins $=100 \mathrm{pF}$, Rise and fall times $=10 \mathrm{~ns}, \mathrm{fosc}=12 \mathrm{MHz}$
The system must meet these specifications to work with the M80C196KB:

| Symbol | Description | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAVYV | Address Valid to READY Setup |  | 2 TOSC -85 | ns |  |
| TLLYV | ALE Low to READY Setup M80C196KB |  | TOSC -75 | ns |  |
| TYLYH | Non READY Time | No up | er limit | ns |  |
| TCLYX | READY Hold after CLKOUT Low | 0 | TOSC -30 | ns | (Note 1) |
| TLLYX | READY Hold after ALE Low | TOSC - 15 | 2 OSSC $^{-40}$ | ns | (Note 1) |
| TAVGV | Address Valid to Buswidth Setup |  | 2 TOSC -85 | ns |  |
| TLLGV | ALE Low to Buswidth Setup |  | TOSC - 70 | ns |  |
| TCLGX | Buswidth Hold after CLKOUT Low | 0 |  | ns |  |
| TAVDV | Address Valid to Input Data Valid M80C196KB |  | 3 OSC $^{\text {O }}$-67 | ns |  |
| TRLDV | $\overline{\mathrm{RD}}$ Active to Input Data Valid M80C196KB |  | TOSC -23 | ns |  |
| TCLDV | CLKOUT Low to Input Data Valid |  | TOSC - 50 | ns |  |
| T RHDZ | End of $\overline{R D}$ to Input Data Float |  | TOSC - 20 | ns |  |
| TRXDX | Data Hold after $\overline{\mathrm{RD}}$ Inactive | 0 |  | ns |  |

## NOTE:

1. If max is exceeded, additional wait states will occur.

AC Characteristics (Over Specified Operating Conditions) (Continued)
Test Conditions: Capacitive load on all pins $=100 \mathrm{pF}$, Rise and fall times $=10 \mathrm{~ns}, \mathrm{fosc}=12 \mathrm{MHz}$
The M80C196KB will meet these specifications:

| Symbol | Description | Min | Max | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| FXTAL | Frequency on XTAL $_{1}$ <br> M80C196KB | 3.5 | 12 | MHz |  |
| Tosc | I/FXTAL <br> M80C196KB | 83 | 286 | ns |  |
| $\mathrm{T}_{\mathrm{XHCH}}$ | XTAL1 High to CLKOUT High or Low | 20 | 110 | ns |  |
| TCLCL | CLKOUT Cycle Time | $2 \mathrm{~T}_{\text {Osc }}$ |  | ns |  |
| $\mathrm{T}_{\text {CHCL }}$ | CLKOUT High Period | TOSC - 10 | Tosc +10 | ns |  |
| TCLLH | CLKOUT Falling Edge to ALE Rising | -10 | 10 | ns |  |
| TLLCH | ALE Falling Edge to CLKOUT Rising | -15 | 15 | ns |  |
| TLHLH | ALE Cycle Time | 4Tosc |  | ns |  |
| TLHLL | ALE High Period | TOSC - 12 | TOSC +12 | ns |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Setup to ALE Falling Edge | Tosc - 20 |  | ns |  |
| TLLAX | Address Hold after ALE Falling Edge | Tosc - 40 |  | ns |  |
| TLLRL | ALE Falling Edge to $\overline{\mathrm{RD}}$ Falling Edge | Tosc - 40 |  | ns |  |
| TrLCL | $\overline{\mathrm{RD}}$ Low to CLKOUT Falling Edge | 4 | 25 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Low Period | Tosc ${ }^{-5}$ |  | ns |  |
| $\mathrm{T}_{\text {RHLH }}$ | $\overline{\mathrm{RD}}$ Rising Edge to ALE Rising Edge | Tosc | Tosc +25 | ns | (Note 2) |
| TrLAZ | $\overline{\mathrm{RD}}$ Low to Address Float |  | 10 | ns |  |
| TLLWL | ALE Falling Edge to $\overline{\text { WR }}$ Falling Edge | Tosc - 10 |  | ns |  |
| TCLWL | CLKOUT Low to $\overline{\text { WR }}$ Falling Edge | 0 | 25 | ns |  |
| TQVWH | Data Stable to $\overline{\text { WR Rising Edge }}$ M80C196KB | Tosc - 23 |  | ns |  |
| TCHWH | CLKOUT High to $\overline{\text { WR Rising Edge }}$ | -5 | 15 | ns |  |
| TWLWH | $\overline{\mathrm{WR}}$ Low Period | Tosc - 30 |  | ns |  |
| TWHQX | Data Hold after WR Rising Edge | Tosc - 15 |  | ns |  |
| TWHLH | WR Rising Edge to ALE Rising Edge | TOSC - 15 | TosC +10 | ns | (Note 2) |
| T WHBX | $\overline{\text { BHE, INST HOLD after } \overline{\text { WR }} \text { Rising Edge }}$ | TOSC - 15 |  | ns |  |

NOTE:
2. Assuming back-to-back bus cycles.

M80C196KB

System Bus Timings


EXTERNAL CLOCK DRIVE

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $1 / T_{X L X L}$ | Oscillator Frequency <br> M80C196KB | 3.5 | 12.0 | MHz |
| $\mathrm{T}_{\mathrm{XLXL}}$ | Oscillator Period <br> M80C196KB | 83 | 286 | ns |
| $\mathrm{~T}_{\mathrm{XHXX}}$ | High Time | 32 |  | ns |
| $\mathrm{~T}_{\mathrm{XLXX}}$ | Low Time | 32 |  | ns |
| $\mathrm{~T}_{\mathrm{XLXH}}$ | Rise Time |  | 10 | ns |
| $\mathrm{~T}_{\mathrm{XHXL}}$ | Fall Time |  | 10 | ns |

## EXTERNAL CLOCK DRIVE WAVEFORMS



AC TESTING INPUT, OUTPUT WAVEFORMS


## FLOAT WAVEFORMS



## EXPLANATION OF AC SYMBOLS

Each symbol is two pairs of letters prefixed by "T" for time. The characters in a pair indicate a signal and its condition, respectively. Symbols represent the time between the two signal/condition points.

## Conditions:

H - High
L - Low
V - Valid
X - No Longer Valid
Z - Floating

## Signals:

A - Address
$L-A L E / \overline{A D V}$

B - $\overline{\mathrm{BHE}}$
C - CLKOUT
D - DATA
G - Buswidth

R - $\overline{R D}$
W - $\overline{\mathrm{WR}} / \overline{\mathrm{WRH}} / \overline{\mathrm{WRL}}$
X - XTAL1
Y - READY

## AC CHARACTERISTICS—SERIAL PORT—SHIFT REGISTER MODE

SERIAL PORT TIMING-SHIFT REGISTER MODE

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| TXLXL | Serial Port Clock Period (BRR $\geq 8002 \mathrm{H}$ ) | 6 Tosc |  | ns |
| TXLXH | Serial Port Clock Falling Edge to Rising Edge (BRR $\geq 8002 \mathrm{H}$ ) | 4 TOSC - 50 | $4 \mathrm{~T}_{\text {OSC }}+50$ | ns |
| $\mathrm{T}_{\text {XLXL }}$ | Serial Port Clock Period (BRR $=8001 \mathrm{H}$ ) | $4 \mathrm{~T}_{\text {OSC }}$ |  | ns |
| TXLXH | Serial Port Clock Falling Edge to Rising Edge $(B R R=8001 \mathrm{H})$ | 2 Tosc - 50 | 2 TOSC +50 | ns |
| TQVXH | Output Data Setup to Clock Rising Edge | 2 TOSC $^{-50}$ |  | ns |
| TXHQX | Output Data Hold after Clock Rising Edge | 2 TOSC $^{-50}$ |  | ns |
| TXHQV | Next Output Data Valid after Clock Rising Edge |  | 2 Tosc +50 | ns |
| $\mathrm{T}_{\text {DVXH }}$ | Input Data Setup to Clock Rising Edge | TOSC +50 |  | ns |
| TXHDX | Input Data Hold after Clock Rising Edge | 0 |  | ns |
| TXHQZ | Last Clock Rising to Output Float |  | Tosc | ns |

## WAVEFORM—SERIAL PORT—SHIFT REGISTER MODE

## SERIAL PORT WAVEFORM-SHIFT REGISTER MODE



## A TO D CHARACTERISTICS

There are two modes of A/D operation: with or without clock prescaler. The speed of the A/D converter can be adjusted by setting a clock prescaler on or off. At high frequencies more time is needed for the comparator to settle. The maximum frequency with the clock prescaler disabled is 8 MHz . The conversion times with the prescaler turned on or off is shown in the table below.

The converter is ratiometric, so the absolute accuracy is directly dependent on the accuracy and
stability of $\mathrm{V}_{\text {REF }} \mathrm{V}_{\text {REF }}$ must be close to $\mathrm{V}_{\mathrm{CC}}$ since it supplies both the resistor ladder and the digital section of the converter.

## A/D CONVERTER SPECIFICATIONS

The specifications given below assume adherence to the Operating Conditions section of this data sheet. Testing is performed in Mode 2 with $\mathrm{V}_{\text {REF }}=$ 5.12 V and 12 MHz on XTAL1.

| Clock Prescaler On <br> IOC2.4 $=\mathbf{0}$ | Clock Prescaler Off <br> IOC2.4 $=\mathbf{1}$ |
| :---: | :---: |
| Mode $0-158$ States | Mode $2-91$ States |
| $26.33 \mu$ s @ 12 MHz | $22.75 \mu \mathrm{~s} @ 8 \mathrm{MHz}$ |

## A/D CHARACTERISTICS (Over Specified Operating Conditions)

| Parameter | Typical*(1) | Minimum | Maximum | Units** | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Resolution |  | 256 | $\begin{gathered} 1024 \\ 10 \end{gathered}$ | Levels Bits |  |
| Absolute Error |  | 0 | $\pm 4$ | LSBs |  |
| Full Scale Error | $-0.5 \pm 0.5$ |  |  | LSBs |  |
| Zero Offset Error | $\pm 0.5$ |  |  | LSBs |  |
| Non-Linearity |  | 0 | $\pm 4$ | LSBs |  |
| Differential Non-Linearity |  | 0 | $\pm 2$ | LSBs |  |
| Channel-to-Channel Matching |  | 0 | $\pm 1$ | LSBs |  |
| Repeatability | $\pm 0.25$ |  |  | LSBs |  |
| Temperature Coefficients: <br> Offset <br> Full Scale Differential Non-Linearity | $\begin{aligned} & 0.009 \\ & 0.009 \\ & 0.009 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{LSB} /{ }^{\mathrm{C}} \mathrm{C} \\ & \mathrm{LSB} /{ }^{\mathrm{C}} \\ & \mathrm{LSB} /{ }^{\circ} \mathrm{C} \end{aligned}$ |  |
| Off Isolation |  | $-60$ |  | dB | 2, 3 |
| Feedthrough | -60 |  |  | dB | 2 |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply Rejection | -60 |  |  | dB | 2 |
| Input Resistance |  | 750 | 1.2K | $\Omega$ |  |
| DC Input Leakage |  | 0 | 3.0 | $\mu \mathrm{A}$ |  |
| Sample Time Slow Mode Fast Mode | $\begin{gathered} 15 \\ 8 \end{gathered}$ |  |  | States <br> States | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ |
| Input Capacitance | 3 |  |  | pF |  |

## NOTES:

*An "LSB", as used here, has a value of approximately 5 mV .

1. These values are expected for most parts at $25^{\circ} \mathrm{C}$ but are not tested or guaranteed.
2. DC to 100 KHz .
3. Multiplexer Break-Before-Make Guaranteed.
4. One state $=167 \mathrm{~ns}$ at $12 \mathrm{MHz}, 250 \mathrm{~ns}$ at 8 MHz .

## A/D GLOSSARY OF TERMS

ABSOLUTE ERROR-The maximum difference between corresponding actual and ideal code transitions. Absolute Error accounts for all deviations of an actual converter from an ideal converter.

ACTUAL CHARACTERISTIC—The characteristic of an actual converter. The characteristic of a given converter may vary over temperature, supply voltage, and frequency conditions. An actual characteristic rarely has ideal first and last transition locations or ideal code widths. It may even vary over multiple conversions under the same conditions.

BREAK-BEFORE-MAKE—The property of multiplexer which guarantees that a previously selected channel will be deselected before a new channel is selected (e.g., the converter will not short inputs together).

CHANNEL-TO-CHANNEL MATCHING—The difference between corresponding code transitions of actual characteristics taken from different channels under the same temperature, voltage and frequency conditions.

CHARACTERISTIC—A graph of input voltage versus the resultant output code for an A/D converter. It describes the transfer function of the A/D converter.

CODE-The digital value output by the converter.
CODE TRANSITION-The point at which the converter changes from an output code of $Q$, to a code of $Q+1$. The input voltage corresponding to a code transition is defined to be that voltage which is equally likely to produce either of two adjacent codes.

CODE WIDTH—The voltage corresponding to the difference between two adjacent code transitions.

DC INPUT LEAKAGE—Leakage current to ground from an analog input pin.

DIFFERENTIAL NON-LINEARITY—The difference between the ideal and actual code widths of the terminal based characteristic.

FEEDTHROUGH—Attenuation of a voltage applied on the selected channel of the A/D Converter after the sample window closes.

FULL SCALE ERROR—The difference between the expected and actual input voltage corresponding to the full scale code transition.

IDEAL CHARACTERISTIC—A characteristic with its first code transition at $\mathrm{V}_{\mathrm{IN}}=0.5$ LSB, its last code transition at $\mathrm{V}_{\mathrm{IN}}=\left(\mathrm{V}_{\mathrm{REF}}-1.5 \mathrm{LSB}\right)$ and all code widths equal to one LSB.

INPUT RESISTANCE—The effective series resistance from the analog input pin to the sample capacitor.

LSB—Least Significant Bit: The voltage corresponding to the full scale voltage divided by $2^{n}$, where n is the number of bits of resolution of the converter. For an 8-bit converter with a reference voltage of 5.12 V , one LSB is 20 mV . Note that this is different than digital LSBs, since an uncertainty of two LSB, when referring to an A/D converter, equals 40 mV . (This has been confused with an uncertainty of two digital bits, which would mean four counts, or 80 mV .)

NON-LINEARITY-The maximum deviation of code transitions of the terminal based characteristic from the corresponding code transitions of the ideal characteristic.

OFF-ISOLATION—Attenuation of a voltage applied on a deselected channel of the A/D converter. (Also referred to as Crosstalk.)

REPEATABILITY—The difference between corresponding code transitions from different actual characteristics taken from the same converter on the same channel at the same temperature, voltage and frequency conditions.

RESOLUTION—The number of input voltage levels that the converter can unambiguously distinguish between. Also defines the number of useful bits of information which the converter can return.

SAMPLE TIME-Begins when the sample capacitor is attached to a selected channel and ends when the sample capacitor is disconnected from the selected channel.

TEMPERATURE COEFFICIENTS—Change in the stated variable per degree centigrade temperature change. Temperature coefficients are added to the typical values of a specification to see the effect of temperature drift.

TERMINAL BASED CHARACTERISTIC—An actual characteristic which has been rotated and translated to remove zero offset and full scale error.
$\mathbf{V}_{\text {CC }}$ REJECTION—Attenuation of noise on the $\mathrm{V}_{\mathrm{CC}}$ line to the A/D converter.

ZERO OFFSET—The difference between the expected and actual input voltage corresponding to the first code transition.

## M80C196KB FUNCTIONAL DEVIATIONS

The M80C196KB has the following problems.

1. The DJNZW instruction is guaranteed to be functional. The DJNZ (byte instruction) work around is no longer needed.
2. The serial port only tolerates a $+1.25 \%,-7.5 \%$ baud rate error between Transmitter and Receiver. If the serial port fails on the receiver, increase the baud rate.
3. The HSI unit has two errata: one dealing with resolution and the other with first entries into the FIFO.
The HSI resolution is 9 states instead of 8 states. Events on the same line may be lost if they occur faster than once every 9 state times.
There is a mismatch between the 9 state time HSI resolution and the 8 state time timer. This causes one time value to be unused every 9 timer counts. Events may receive a time-tag one count later than expected because of this "skipped" time value.
If the first two events into an empty FIFO (not including the Holding Register) occur in the same internal phase, both are recorded with one timetag. Otherwise, if the second event occurs within 9 states after the first, its time-tag is one count later than the first's. If this is the "skipped" time value, the second event's time-tag is 2 counts later than the first's.
If the FIFO and Holding Register are empty, the first event will transfer into the Holding Register after 8 state times, leaving the FIFO empty again. If the second event occurs after this time, it will act as a new first event into an empty FIFO.
4. The serial port Framing Error flag that failed to indicate an error if the bit preceding the stop bit is a 1 has been fixed.

## CONVERTING FROM OTHER M8097 FAMILY PRODUCTS TO THE M80C196KB

The following list of suggestions for designing an M809XBH system will yield a design that is easily converted to the M80C196KB.

1. Do not base critical timing loops on instruction or peripheral execution times.
2. Use equate statements to set all timing parameters, including the baud rate.
3. Do not base hardware timings on CLKOUT or XTAL1. The timings of the M80C196KB are different than those of the M8X9XBH, but they will function with standard ROM/EPROM/Peripheral type memory systems.
4. Make sure all inputs are tied high or low and not left floating.
5. Indexed and indirect operations relative to the stack pointer (SP) work differently on the M80C196KB than on the M8097. On the M8097, the address is calculated based on the un-updated version of the stack pointer. The M80C196KB uses the updated version. The offset for PUSH[SP], POP[SP], PUSH nn[SP] and POP nn[SP] instructions may need to be changed by a count of 2.
