

## CS8221 NEW ENHANCED AT (NEAT™) DATA BOOK 82C211/82C212/82C215/82C206 (IPC) CHIPSet™

- 100% IBM<sup>™</sup> PC/AT Compatible New Enhanced CHIPSet<sup>™</sup> for 12MHz, 16MHz, and 20MHz systems.
- Supports 16MHz 80286 operation with only 0.7 wait states and 100ns DRAMs and 12MHz operation with 150ns DRAMs
- Separate CPU and AT Bus clocks
- Page Interleaved Memory Controller
- Integrated Lotus-Intel-Microsoft Expanded Memory Specification (LIM EMS) Memory Controller. Supports EMS 4.0.

The CS8221 PC/AT compatible NEAT CHIPSet<sup>™</sup> is an enhanced, high performance 4 chip VLSI implementation (including the 82C206 IPC) of the control logic used on the IBM<sup>™</sup> Personal Computer AT. The flexible architecture of the NEAT CHIPSet<sup>™</sup> allows it to be used in any 80286 based system.

- Software Configurable Command Delays, Wait states and Memory Organization
- Optimized for OS/2 operation
- Shadow RAM for BIOS to improve system performance
- Complete AT/286 requires only 24 components plus memory
- Targeted at Desktop PC/ATs, Laptops and CMOS Industrial Control Applications
- Available as four CMOS 84-pin PLCC or 100-pin PFP components.

The CS 8221 NEAT CHIPSet<sup>™</sup> provides a complete 286 PC/AT compatible system, requiring only 24 logic components plus memory devices.

The CS8221 NEAT CHIPSet<sup>™</sup> consists of the 82C211 CPU/Bus controller, the 82C212



Figure 1. NEAT System Block Diagram

# CHIPS.

Page/Interleave and EMS Memory controller, the 82C215 Data/Address buffer and the 82C206 Integrated Peripherals Controller (IPC).

The NEAT CHIPSet<sup>™</sup> supports the local CPU bus, a 16 bit system memory bus, and the AT buses as shown in the NEAT System Block Diagram. The 82C211 provides synchronization and control signals for all buses. The 82C211 also provides an independent AT bus clock and allows for dynamic selection between the processor clock and the user selectable AT bus clock. Command delays and wait states are software configurable, providing flexibility for slow or fast peripheral boards.

The 82C212 Page/Interleave and EMS Memory controller provides an interleaved memory sub-system design with page mode operation. It supports up to 8 MB of on-board DRAM with combinations of 256Kbit and 1Mbit DRAMs. The processor can operate at 16 MHz with 0.7 wait state memory accesses, using 100 nsec DRAMs. This is possible through the Page Interleaved memory scheme. The Shadow RAM feature allows faster execution of code stored in EPROM, by down loading code from EPROM to RAM. The RAM then shadows the EPROM for further code execution. In a DOS environment, memory above 1Mb can be treated as LIM EMS memory.

The 82C215 Data/Address buffer provides the buffering and latching between the local CPU address bus and the Peripheral address bus. It also provides buffering between the local CPU data bus and the memory data bus. The parity bit generation and error detection logic resides in the 82C215.

The 82C206 Integrated Peripherals Controller is an integral part of the NEAT CHIPSet<sup>™</sup>. It is described in the 82C206 Integrated Peripherals Controller data book.

#### **System Overview**

The CS8221 NEAT CHIPSet<sup>™</sup> is designed for use in 12 to 16 MHz 80286 based systems and provides complete support for the IBM PC/AT bus. There are four buses supported by the CS8221 NEAT CHIPSet<sup>™</sup> as shown in Figure 1: CPU local bus (A and D), system memory bus (MA and MD), I/O channel bus (SA and SD), and X bus (XA and XD). The system memory bus is used to interface the CPU to the DRAMs and EPROMs controlled by the 82C212. The I/O channel bus refers to the bus supporting the AT bus adapters which could be either 8 bit or 16 bit devices. The X bus refers to the peripheral bus to which the 82C206 IPC and other peripherals are attached in an IBM PC/AT.

#### **Notation and Glossary**

The following notations are used to refer to the configuration and diagnostics registers internal to the 82C211 and 82C212:

**REGnH** denotes the internal register of index n in hexadecimal notation.

**REGnH**<**x:y**> denotes the bit field from bits x to y of the internal register with index n in hexadecimal notation.







CHIPS

## 82C211 Pin Description

| Pin<br>No. | Pin<br>Type | Symbol                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clocks     |             |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5          | 1           | CLK2IN                                 | CLOCK 2 input from a TTL crystal oscillator having a maximum of twice the rated frequency of the 80286 processor clock.                                                                                                                                                                                                                                                                                             |
| 2          | 0           | PROCCLK                                | PROCESSOR CLOCK output for the 80286 and the 82C212.<br>It is derived from CLK2IN. It can also be programmed to<br>be derived from ATCLK.                                                                                                                                                                                                                                                                           |
| 76         | I           | ATCLK1                                 | AT Bus Clock 1 input source from crystal or oscillator.<br>This clock input is used for the AT bus operation and is<br>only required if the AT bus state machine clock, BCLK<br>(internal) will not be derived from CLK2IN. This clock<br>input should be tied low if not used. Its frequency should<br>be lower than CLK2IN. BCLK is the AT bus state machine<br>clock and can be programmed to be equal to ATCLK. |
| 81         | 0           | ATCLK2                                 | AT Bus Clock 2 output is connected to the crystal (if a crystal is used to generate AT bus clock). A series damping resistor of 10 ohms should be used to reduce amplitude of the resonant circuit. It should be left open if a TTL oscillator is used.                                                                                                                                                             |
| 83         | 0           | SYSCLK                                 | AT System Clock output is buffered to drive the SYSCLK<br>line on the AT bus I/O channel. It is half the frequency of<br>BCLK and should be between 6 and 8 MHz for maintaining<br>correct AT I/O bus timing compatibility with the IBM <sup>™</sup><br>PC/AT.                                                                                                                                                      |
| Control    |             | ······································ |                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13         | I           | RESET1                                 | RESET1 is an active low input generated by the power good signal of the power supply. When low, it activates RESET3 and RESET4. RESET1 is latched internally.                                                                                                                                                                                                                                                       |
| 51         | I           | RESET2                                 | RESET2 is an active low input generated from the keyboard controller (8042/8742) for a "warm reset" no requiring the system power to be shut off. It forces a CPU reset by activating RESET3.                                                                                                                                                                                                                       |
| 38         | 0           | RESET4                                 | RESET4 is an active high output used to reset the AT bus,<br>82C206 IPC, 8042 keyboard controller, 82C212 memory<br>controller. It is synchronized with the processor clock.                                                                                                                                                                                                                                        |
| 50         | 0           | RESET3                                 | RESET3 is an active high output to the 80286 when RESET1 or RESET2 is active. It is also activated when shut-down condition in the CPU is detected. RESET3 will stay active for at least 16 PROCLK cycles.                                                                                                                                                                                                          |

| Pin<br>No. | Pin<br>Type | Symbol        | Description                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU Inte   | erface      |               |                                                                                                                                                                                                                                                                                                                                                        |
| 71         | 1/0         | READY         | READY as an output, is driven low to terminate the current CPU cycle after IOCHRDY is high and $\overline{0WS}$ is high, or if "time out" condition is detected. During all other cycles, it is an input from the 82C212. It is an open collector output requiring an external pull-up resistor of $1K\Omega$ and is connected to the 80286 READY pin. |
| 79, 80     | l           | <u>50, 51</u> | STATUS is an active low inputs from the CPU. The status signals are used by the 82C211 to determine the state of the CPU. Pull up resistors of $10K\Omega$ each should be provided.                                                                                                                                                                    |
| 72         |             | M/IO          | MEMORY INPUT/OUTPUT is the signal from the CPU. When high, it indicates a memory access, when low it indicates an I/O access. It is used to generate memory and I/O signals for the system. A $10K\Omega$ pull up resistor is recommended.                                                                                                             |
| 55         | 0           | HOLD          | CPU HOLD REQUEST is an active high output to the CPU.<br>It is activated during DMA, Master or refresh cycles.                                                                                                                                                                                                                                         |
| 37         | I           | HLDA          | HOLD ACKNOWLEDGE is an acative high input generated<br>by the CPU to indicate to the requestering master that it<br>has relinquished the bus. When active, it forces all com-<br>mands (IOR, IOW, MEMR, MEMW, INTA) to be tri-stated.                                                                                                                  |
| 49         | I/O         | BHE           | BYTE HIGH ENABLE is an active low signal which indi-<br>cates the transfer of data on the upper byte of the data<br>bus. In conjunction with A0, it is input during CPU cycles<br>and in conjunction with XA0, it is output during DMA,<br>MASTER cycles. A pull up resistor of $10K\Omega$ is required.                                               |
| 39         | 0           | ΝΜΙ           | NON MASKABLE INTERRUPT is an active high output to<br>the NMI pin of the CPU and is generated by the 82C211 to<br>invoke a non-maskable interrupt.                                                                                                                                                                                                     |
| 41         | 0           | IALE          | ADDRESS LATCH ENABLE (INTERNAL) is an active high<br>output synchronized with PROCCLK and controls address<br>latches used to hold addresses during bus cycles. It is not<br>issued for halt bus cycles.                                                                                                                                               |

| Pin<br>No. | Pin<br>Type  | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|--------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O Cha    | nnel Interfa | ce      |                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31         | 1            | IOCHRDY | I/O CHANNEL READY is an active high input from the AT bus. When low it indicates a not ready condition and inserts wait states in AT-I/O or AT-memory cycles. When high it allows termination of the current AT-bus cycle. A series damping resistor of $53\Omega$ at the AT bus connector is recommended to limit the negative under shoot. A 1K $\Omega$ pull up resistor is required for this open collector line. |
| 30         | I            | IOCHCK  | I/O CHANNEL CHECK is an active low input from the AT bus causing an NMI to be generated if enabled. It is used to signal an I/O error condition from a device residing on the AT bus. A $10K\Omega$ pull up resistor is required.                                                                                                                                                                                     |
| 11         | I            | PARERR  | PARITY ERROR is an active low input from the 82C215 which causes an NMI if enabled. It indicates a parity error in local system memory.                                                                                                                                                                                                                                                                               |
| 44         | 0            | ALE     | ADDRESS LATCH ENABLE is an active high output to the<br>AT bus and is synchronized with the AT state machine<br>clock. It controls the address latches used to hold the<br>addresses during bus cycles. This signal should be buffered<br>to drive the AT bus.                                                                                                                                                        |
| 73         | 0            | EALE    | EXTERNAL ADDRESS LATCH ENABLE is an active low output used to latch the CPU A17-A23 address lines to the LA17-LA23 lines on the AT bus. This signal is used in the Delayed-Mode discussed in section 1.3.3.                                                                                                                                                                                                           |
| DMA In     | terface      |         |                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 40         | 0            | HLDA1   | HOLD ACKNOWLEDGE 1 is an active high output when a bus cycle is granted in response to HOLD REQUEST 1.                                                                                                                                                                                                                                                                                                                |
| 26         | I            | HRQ     | HOLD REQUEST is an active high input when DMA/Master<br>is requesting a bus cycle. For an AT compatible archi-<br>tecture, it should be connected to the HOLD REQUEST<br>signal from DMA1 and DMA2.                                                                                                                                                                                                                   |
| 27         | I            | AEN1    | ADDRESS ENABLE 1 is an active low input from one of<br>the two DMA controllers enabling the address latches for 8<br>bit DMA transfers.                                                                                                                                                                                                                                                                               |
| 28         | I            | AEN2    | ADDRESS ENABLE 2 is an active low input from one of<br>the two DMA controllers enabling the address latches for<br>16 bit DMA transfers.                                                                                                                                                                                                                                                                              |
| 48         | I            | ROMCS   | ROM CHIP-SELECT is an active low input from the 82C212.<br>It is used to disable parity checks for local ROM cycles.                                                                                                                                                                                                                                                                                                  |

| Pin<br>No. | Pin<br>Type | Symbol  | Description                                                                                                                                                                                                                                    |
|------------|-------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bus Inpu   | uts         |         |                                                                                                                                                                                                                                                |
| 12         | I           | MEMCS16 | MEMORY CHIP SELECT 16 is an active low input from the AT bus indicating a 16 bit memory transfer. If high it implies an 8 bit memory transfer. A pull up resistor of $330\Omega$ is required.                                                  |
| 33         | I           | IOCS16  | I/O CHANNEL SELECT 16 is an active low input from the AT bus indicating a 16 bit I/O transfer. If high it implies an 8 bit I/O transfer. A pull up resistor of $330\Omega$ is required.                                                        |
| 69         | I           | OWS     | ZERO WAIT STATES is an active low input from the AT<br>bus, causing immediate termination of the current AT bus<br>cycle. Memories requiring zero wait states use this line to<br>speed up memory cycles. It requires a 330Ω pull up resistor. |
| Device [   | Decode      |         | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                          |
| 35         | 0           | 8042CS  | 8042 CHIP SELECT is an active low signal for the keyboard controller chip select.                                                                                                                                                              |
| 82         | 0           | ASRTC   | ADDRESS STROBE to Real Time Clock is an active high signal used on the 82C206.                                                                                                                                                                 |
| Refresh    |             |         |                                                                                                                                                                                                                                                |
| 52         | I           | REFREQ  | REFRESH REQUEST is an active high input initiating a DRAM refresh sequence. It is generated by the 8254 compatible timer controller #1 of the 82C206 IPC in a PC/AT implementation.                                                            |
| 58         | I/O         | REF     | REFRESH is an active low signal. As an open drain output, it initiates a refresh cycle for the DRAMs. As an input, it can be used to force a refresh cycle from an I/O device. An external pull up of $620\Omega$ is required.                 |
| X Bus In   | iterface    |         |                                                                                                                                                                                                                                                |
| 9          | I/O         | XMEMR   | X BUS MEMORY READ is an active low control strobe<br>directing memory to place data on the data bus. It is an<br>output if the CPU is controlling the bus and is an input if a<br>DMA controller is in control of the bus.                     |
| 10         | I/O         | XMEMW   | X BUS MEMORY WRITE is an active low control strobe<br>directing memory to accept data from the data bus. It is an<br>output if the CPU is controlling the bus and is an input if a<br>DMA controller is in control of the bus.                 |

| Pin<br>No.     | Pin<br>Type | Symbol             | Description                                                                                                                                                                                                                                                                                    |
|----------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 70             | I/O         | XIOR               | X BUS I/O READ is an active low strobe directing an I/O<br>port to place data on the data bus. It is an output if the<br>CPU is controlling the bus and is an input if a DMA<br>controller is in control of the bus.                                                                           |
| 56             | I/O         | XIOW               | X BUS I/O WRITE is an active low strobe directing an I/O port to accept data from the data bus. It is an output if the CPU is controlling the bus and is an input if a DMA controller is in control of the bus.                                                                                |
| 57             | I/O         | XBHE               | X BYTE HIGH ENABLE is an active low signal indicating<br>the high byte has valid data on the bus. It is an output<br>when the CPU is in control of the bus and is an input<br>when a DMA controller is in control of the bus. A $4.7$ K $\Omega$<br>pull-up resistor is required on this line. |
| 59-62<br>65-68 | I/O<br>I/O  | XD<7:4><br>XD<0:3> | X DATA BUS bits <7:0>                                                                                                                                                                                                                                                                          |
| 8              |             | NC                 | No Connect                                                                                                                                                                                                                                                                                     |
| 75             | 0           | TMRGATE            | TIMER GATE is an active high output that enables the timer on the 8254 compatible counter timer in the 82C206 to enable the tone signal for the speaker.                                                                                                                                       |
| 53             | I           | TMROUT2            | TIMER OUT 2 is an active high input from the 8254 compatible counter timer in the 82C206 that can be read from port B.                                                                                                                                                                         |
| 77             | 0           | SPKDATA            | SPEAKER DATA is an active high output used to gate the 8254 compatible tone signal of the 82C206 to the speaker.                                                                                                                                                                               |
| 54             | 0           | ĪNTĀ               | INTERRUPT ACKNOWLEDGE is an active low output to<br>the 82C206 interrupt controller. It is also used to direct<br>data from the X to S bus during an interrupt acknowledge<br>cycle.                                                                                                           |
| Buffer Co      | ontrol      |                    |                                                                                                                                                                                                                                                                                                |
| 34             | 0           | SDIR0              | SYSTEM BUS DIRECTION 0 for the low byte. A low sets the data path from the S bus to the M bus. A high sets the data path from the M bus to the S bus.                                                                                                                                          |
| 36             | 0           | SDIR1              | SYSTEM BUS DIRECTION 1 for the high byte. A low sets the data path from the S bus to the M bus. A high sets the data path from the M bus to the S bus                                                                                                                                          |
| 47             | 0           | ACEN               | ACTION CODE ENABLE is an active low output that validates the action code signals AC $<1$ , 0> that are used by the 82C215 address/data buffer.                                                                                                                                                |

| Pin<br>No.              | Pin<br>Type  | Symbol                     | Description                                                                                                                                                                                                                 |
|-------------------------|--------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 46, 45                  | 0            | AC<1, 0>                   | ACTION CODE is a two bit encoded output command for<br>bus size control and byte assembly operations performed<br>in the 82C215.                                                                                            |
| Memory                  | Control      |                            |                                                                                                                                                                                                                             |
| 78                      | I            | AF16                       | AF16 is an active low input indicating that the current cycle is a local bus cycle. A high indicates an AT bus cycle. A $10K\Omega$ pull up resistor is required.                                                           |
| 23–25<br>18–21<br>14–18 | I/O          | A<0:2><br>A<3:6><br>A<7:9> | ADDRESS lines A0-A9 are input from the CPU. These lines are output during refresh. A1 is used to detect shut down condition of the CPU. A0 is used to generate the enable signal for the data bus transceivers.             |
| 29                      | I/O          | XA0                        | ADDRESS line XA0 from the X bus. It is an output during CPU accesses on the X bus and is an input for 8 bit DMA cycles.                                                                                                     |
| CoProces                | ssor Interfa | се                         |                                                                                                                                                                                                                             |
| 6                       | 0            | NPCS                       | NUMERIC COPROCESSOR CHIP SELECT is an active<br>low output signal used to select the internal registers of<br>the 80287 NPX.                                                                                                |
| 7                       | 0            | BUSY                       | BUSY is an active low output to the CPU initiated by the 80287 NPX, indicatig that it is busy. A $4.7K\Omega$ pull up resistor is required.                                                                                 |
| 74                      | Ι            | NPBUSY                     | NUMERIC COPROCESSOR BUSY is an active low input from the NPX, indicating that it is currently executing a command. It is used to generate the BUSY signal to the CPU. A $4.7 \text{K}\Omega$ pull up resistor is required.  |
| 32                      | I            | ERROR                      | ERROR is an active low input from the NPX indicating that an unmasked error condition exists. A $4.7K\Omega$ pull up resistor is required.                                                                                  |
| 4                       | 0            | NPINT                      | NUMERIC COPROCESSOR INTERRUPT is an active high output . It is an interrupt request from the 80287 and is connected to the IRQ13 line of the 82C206 IPC in a PC/AT environment. A $10K\Omega$ pull up resistor is required. |

| Pin<br>No.          | Pin<br>Type | Symbol  | Description                                                                                                                                                                                                                |
|---------------------|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3                   | 0           | NPRESET | NUMERICAL PROCESSOR RESET is an active high reset<br>to the 80287. It is active when RESET4 is active or when a<br>write operation is made to Port 0F1H. In the later case, it is<br>active for the period of the command. |
| Power Sup           | plies       |         |                                                                                                                                                                                                                            |
| 42, 63, 84          |             | VDD     | POWER SUPPLY.                                                                                                                                                                                                              |
| 1, 17, 22<br>43, 64 |             | VSS     | GROUND.                                                                                                                                                                                                                    |

### 82C212 Pin Description

| Pin<br>No. | Pin<br>Type | Symbol   | Description                                                                                                                                                                                              |
|------------|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clocks and | I Control   |          |                                                                                                                                                                                                          |
| 83         | I           | PROCCLK  | PROCESSOR CLOCK input from the 82C211                                                                                                                                                                    |
| 23         | 1           | X1       | CRYSTAL 1 input from the 14.31818 MHz crystal.                                                                                                                                                           |
| 24         | 0           | X2       | CRYSTAL 2 output to the 14.31818 MHz crystal.                                                                                                                                                            |
| 18         | 0           | OSC      | OSCILLATOR output for the system clock at 14.31818 MHz and has a drive capability of 24mA.                                                                                                               |
| 21         | 0           | OSC/12   | OSCILLATOR divided by 12 is an output with a clock frequency equal to 1/12 of the crystal frequency across the X1, X2 pins.                                                                              |
| 12         | 1           | RESET4   | RESET 4 is the active high reset input from the 82C211. It resets the configuration registers to their default values. When active, RAS<0:3> and CAS<00:31> remain high, OSC and OSC/12 remain inactive. |
| 20         | I           | REF      | REFRESH is an active low input for DRAM refresh control from the 82C211. It initiates a refresh cycle for the DRAMs.                                                                                     |
| 65, 63     | I           | S<1, 0>  | STATUS input lines from the CPU are active low. These lines are monitored to detect the start of a cycle.                                                                                                |
| 54         | I           | M/IO     | MEMORY I/O signal from the CPU. If high it indicates a memory cycle. If low, it indicates an I/O cycle.                                                                                                  |
| 15         | 1           | XIOR     | I/O READ command, input active low.                                                                                                                                                                      |
| 14         | I           | XIOW     | I/O WRITE command, input active high.                                                                                                                                                                    |
| 17         | I           | XMEMR    | X BUS MEMORY READ command, input active low.                                                                                                                                                             |
| 16         | I           | XIOR     | X BUS MEMORY WRITE command, input active low.                                                                                                                                                            |
| 19         | I           | HLDA1    | HOLD ACKNOWLEDGE 1 is an active high input from the 82C211. It is used to generate RAS and CAS signals for DMA cycles, in response to a hold request.                                                    |
| 13         | 0           | ROMCS    | ROM CHIP SELECT is an active low chip select output to<br>the BIOS EPROM. It can be connected to the output<br>enable pin of the EPROM.                                                                  |
| 48, 74, 82 |             | A<0:2>   |                                                                                                                                                                                                          |
| 2-8        |             | A<3:9>   |                                                                                                                                                                                                          |
| 46         |             | A10      |                                                                                                                                                                                                          |
| 9-11       | I           | A<11:13> | ADDRESS input lines A<0:23> from the CPU local bus                                                                                                                                                       |
| 47         |             | A14      |                                                                                                                                                                                                          |
| 49-53      |             | A<15:19> |                                                                                                                                                                                                          |
| 55-58      |             | A<20:23> |                                                                                                                                                                                                          |

| Pin<br>No. | Pin<br>Type | Symbol   | Description                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 34         | I           | BHE      | BYTE HIGH ENABLE is an active low input from the CPU for transfer of data on the upper byte.                                                                                                                                                                                                                                          |
| 29         | 1/0         | READY    | READY is the system ready signal to the CPU. It is output<br>active low after requested memory or I/O data transfer is<br>completed. It is an input when the current bus cycle is an<br>AT bus cycle and is an output for local memory and I/O<br>cycles.                                                                             |
| 59         | 0           | AF16     | AF16 is an active low output asserted on local memory<br>(EPROM or DRAM) cycles. It is high for all other cycles.<br>This signal is sampled by the 82C211.                                                                                                                                                                            |
| DRAM In    | nterface    |          |                                                                                                                                                                                                                                                                                                                                       |
| 77-80      | 0           | RAS<3:0> | ROW ADDRESS STROBES 3 to 0 are active low outputs<br>used as RAS signals to the DRAMs for selecting different<br>banks. RAS3 selects the highest bank and RAS0 selects<br>the lowest bank. These signals should be buffered and line<br>terminated with 75 $\Omega$ resistors to reduce ringing before<br>driving the DRAM RAS lines. |
| 41         | 0           | CAS00    | COLUMN ADDRESS STROBE 00 is an active low output used to select the low byte DRAMs of bank 0. This signal should be line terminated with a $75\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                                    |
| 44         | 0           | CAS01    | COLUMN ADDRESS STROBE 01 is an active low output used to select the high byte DRAMs of bank 0. This signal should be line terminated with a $75\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                                   |
| 39         | 0           | CAS10    | COLUMN ADDRESS STROBE 10 is an active low output used to select the low byte DRAMs of bank 1. This signal should be line terminated with a $75\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                                    |
| 40         | 0           | CAS11    | COLUMN ADDRESS STROBE 11 is an active low output used to select the high byte DRAMs of bank 1. This signal should be line terminated with a $75\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                                   |
| 37         | 0           | CAS20    | COLUMN ADDRESS STROBE 20 is an active low output used to select the low byte DRAMs of bank 2. This signal should be line terminated with a $75\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                                    |

| Pin<br>No. | Pin<br>Type | Symbol   | Description                                                                                                                                                                                                                                                                                                            |
|------------|-------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38         | 0           | CAS21    | COLUMN ADDRESS STROBE 21 is an active low output used to select the high byte DRAMs of bank 2. This signal should be line terminated with a 75 $\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                   |
| 35         | 0           | CAS30    | COLUMN ADDRESS STROBE 30 is an active low output used to select the low byte DRAMs of bank 3. This signal should be line terminated with a 75 $\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                    |
| 36         | 0           | CAS31    | COLUMN ADDRESS STROBE 31 is an active low output used to select the high byte DRAMs of bank 3. This signal should be line terminated with a 75 $\Omega$ resistor to reduce ringing before driving the DRAM CAS line.                                                                                                   |
| 28         | 0           | MWE      | MEMORY WRITE ENABLE is an active low output for DRAM write enable.                                                                                                                                                                                                                                                     |
| 45         | 0           | DLE      | DATA LATCH ENABLE is an active high output used to<br>enable the local memory data buffer latch in the 82C215.                                                                                                                                                                                                         |
| 33         | 0           | DRD      | DATA READ is an active low output used to transfer data<br>from the memory bus to the local CPU bus in the 82C215.<br>If high it sets the data path from the local CPU bus to the<br>memory bus.                                                                                                                       |
| 81         | 0           | DLYOUT   | DELAY LINEOUT is an active high output to the delay line for generating the DRAM control signals.                                                                                                                                                                                                                      |
| 73, 75, 76 | 1           | DLY<0:2> | DELAY IN0, 1, 2 are active high inputs from the first, second and third tap on the delay line used to generate DRAM control signals.                                                                                                                                                                                   |
| 26         | 0           | XDEN     | X DATA BUFFER ENABLE is an active low output asserted<br>during I/O accesses to locations. 22H and 23H. These<br>locations contain the index and data registers for the<br>NEAT CHIPSet <sup>™</sup> . It is used to enable the buffers between<br>the XD and MA buses for accessing the 82C212 internal<br>registers. |
| 27         | 0           | XDIR     | X BUS DIRECTION is used to control the drivers between<br>the X and S buses. The drivers should <u>be used</u> such that<br>data flow is from the S to X bus when XDIR is low and in<br>the other direction when XDIR is high.                                                                                         |
| 71-72      | 0           | MA<8:9>  | MULTIPLEXED DRAM ADDRESS lines MA8, MA9. These lines should be buffered and line terminated with $75\Omega$ resistors before driving the DRAM address lines.                                                                                                                                                           |

| Pin<br>No.       | Pin<br>Type | Symbol             | Description                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 66-70<br>60-62   | I/O<br>I/O  | MA<3:7><br>MA<0:2> | MULTIPLEXED DRAM ADDRESS lines MA0 to MA7. Also<br>used as bi-directional lines to read/write to the internal<br>registers of the 82C212. An external 74LS245 buffer is<br>required to isolate this path during normal DRAM operation.<br>These lines should be buffered and line terminated with<br>$75\Omega$ resistors before driving the DRAM address lines. |
| Miscellane       | ous         |                    |                                                                                                                                                                                                                                                                                                                                                                  |
| 31               | I/O         | GA20               | ADDRESS line 20 is the gated A20 bit which is controlled by GATEA20.                                                                                                                                                                                                                                                                                             |
| 30               | 1           | GATEA20            | GATE ADDRESS 20 is an input used to force A20 low<br>when GATEA20 is low. When high it propagates CPUA20<br>onto the A20 line. It is used to keep address under 1Mb<br>during DOS operation.                                                                                                                                                                     |
| 25               | 0           | LMEGCS             | LOW MEG CHIP SELECT is an unlatched active low<br>output asserted when the low Meg memory address space<br>(0 to 1024 Kbytes) is accessed or during refresh cycles. It<br>is used to disable SMEMR and SMEMW signals on the AT<br>bus if accesses are made beyond the 1Mbyte address<br>space to maintain PC and PC/XT compatibility.                            |
| Power and        | Ground      |                    |                                                                                                                                                                                                                                                                                                                                                                  |
| 32, 42, 84       | -           | VDD                | POWER SUPPLY.                                                                                                                                                                                                                                                                                                                                                    |
| 1, 22, 43,<br>64 |             | VSS                | GROUND.                                                                                                                                                                                                                                                                                                                                                          |

## 82C215 Pin Description

| Pin<br>No.                                                            | Pin<br>Type | Symbol              | Description                                                                                                                                                                                      |
|-----------------------------------------------------------------------|-------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Controls                                                              |             |                     |                                                                                                                                                                                                  |
| 14                                                                    | I           | ACEN                | ACTION CODE ENABLE is an active low input from the 82C211 that validates the action codes.                                                                                                       |
| 12, 13                                                                | I           | AC<1:0>             | ACTION CODES input from the 82C211 are used for bus sizing and byte assembly operations. They are discussed in Section 1.2.4.                                                                    |
| 76                                                                    | I           | DLE                 | DATA LATCH ENABLE is an active high input from the 82C212 used to enable the local memory data buffer latch.                                                                                     |
| 74                                                                    | I           | DRD                 | DATA READ is an active low input from the 82C212 used<br>to transfer data from the M data bus to the CPU data bus.<br>If high, it sets the data path from the CPU data bus to the<br>M data bus. |
| 53                                                                    | I           | HLDA1               | HOLD ACKNOWLEDGE 1 is an active high input from the 82C211 used for address and data direction control during DMA cycles.                                                                        |
| 15                                                                    | I           | IALE                | ADDRESS LATCH ENABLE (INTERNAL) is an active high input from the 82C211 used to latch the CPU address lines on to the X address lines.                                                           |
| 11                                                                    | I           | BHE                 | BYTE HIGH ENABLE is an active low input from the CPU.<br>It is used to enable the high byte parity checking.                                                                                     |
| 10                                                                    | I           | A0                  | ADDRESS line A0 is input from the CPU. It is used to enable the low byte parity checking.                                                                                                        |
| Address                                                               |             |                     |                                                                                                                                                                                                  |
| 25-31<br>33-41                                                        | I/O<br>I/O  | A<1:7><br>A<8:16>   | ADDRESS lines A1-A16 from the CPU. They are input during CPU and refresh cycles and output during DMA/ Master cycles.                                                                            |
| 44-52<br>54-60                                                        | I/O<br>I/O  | XA<16:8><br>XA<7:1> | X ADDRESS lines XA16-XA1 (latched) are connected to the peripheral bus in the IBM™ PC/AT architecture.                                                                                           |
| Data                                                                  |             |                     |                                                                                                                                                                                                  |
| 2, 4, 6,<br>8, 16, 18,<br>20, 23, 3,<br>5, 7, 9,<br>17, 19,<br>21, 24 | I/O         | D<15:0>             | DATA lines D15-D0 from the CPU.                                                                                                                                                                  |
|                                                                       |             | 4                   |                                                                                                                                                                                                  |

| Pin<br>No.                                                                    | Pin<br>Type | Symbol    | Description                                                                                                                                                                                                                                                      |
|-------------------------------------------------------------------------------|-------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 82, 80,<br>73, 71, 69,<br>67, 65, 62,<br>81, 79, 72,<br>70, 68, 66,<br>63, 61 | I/O         | MD<15:0>  | MEMORY DATA lines MD15-MD0 from the memory bus.                                                                                                                                                                                                                  |
| Parity                                                                        |             | . <u></u> |                                                                                                                                                                                                                                                                  |
| 78, 77                                                                        | I/O         | MP1, MP0  | MEMORY PARITY bits MP1, MP0 are the parity bits for the<br>high and low order bytes of the system DRAMs. These<br>lines are input during memory operations for parity error<br>detection and are output during memory write operations<br>for parity generation. |
| 83                                                                            | 0           | PARERR    | PARITY ERROR is an active low output to the 82C211 which goes active upon detecting a parity error during a system memory read operation. It is used to generate a non-maskable interrupt to the CPU.                                                            |
| Power and                                                                     | Ground      |           |                                                                                                                                                                                                                                                                  |
| 32, 42, 84                                                                    | _           | VDD       | POWER                                                                                                                                                                                                                                                            |
| 1, 22, 43<br>64, 75                                                           |             | VSS       | GROUND                                                                                                                                                                                                                                                           |

#### 1. 82C211 BUS CONTROLLER

#### 1.1 Features

- Clock generation with software speed selection.
- Optional independent AT bus clock.
- CPU interface and bus control.
- Programmable command delays and wait state generation.
- Port B register.

#### **1.2 Functional Description**

The 82C211 Bus Controller consists of the following functional sub-modules as illustrated in figure 1.1:

- Reset and Shut down logic
- Clock generation and selection logic

- CPU state machine, AT bus state machine and bus arbitration logic
- Action Codes generation logic
- Port B register and NMI logic
- DMA and Refresh logic
- Numeric Coprocessor interface logic
- Configuration registers

#### 1.2.1 Reset and Shut Down Logic

Two reset inputs RESET1 and RESET2 are provided on the 82C211 bus controller. RESET1 is the Power Good signal from the power supply. When RESET1 is active, the 82C211 asserts RESET3 and RESET4 for a system reset. RESET2 is generated from the 8042 (or 8742) keyboard controller when a "warm reset" is required. The warm reset activates RESET3 to reset the 80286 CPU.







RESET3 is also activated by the 82C211 when a shut down condition is detected in the CPU. Additionally, a low to high transition in REG60<5> causes RESET3 to be active after the current I/O command goes inactive. RESET3 is asserted for at least 16 PROCCLK cycles and then deasserted. RESET4 is used to reset the AT bus, 82C206 IPC, 8042 keyboard controller and the 82C212 memory controller. It is synchronized with respect to PROCCLK and is asserted as long as the Power Good signal is held low.

After a shut down condition is detected, RESET3 is asserted and held high for at least 16 PROCCLK cycles and then deasserted. RESET3 resulting from a shut down condition is synchronous with PROCCLK, ensuring proper CPU operation. Both RESET3 and RESET4 meet the setup and hold timing requirements of the 80286 CPU.

#### 1.2.2 Clock Generation and Selection Logic

The 82C211 provides a flexible clock selection scheme as shown in Figure 1.2. It has two input clocks; CLK2IN and ATCLK. CLK2IN is driven from a TTL crystal oscillator, running at a maximum of twice the processor clock (PROCCLK) frequency. ATCLK is derived from a crystal. Typically, it should be of a lower frequency than CLK2IN. ATCLK and CLK2IN can be selected under program control. The 82C211 generates processor clock, PROCCLK, for driving the CPU state machine and interface. SCLK (internal) is PROCCLK/2 and is in phase with the internal states of the 80286. BCLK (internal) is the AT bus state machine clock and is used for the AT bus interface. SYSCLK is the AT bus system clock and is always BCLK/2.

PROCCLK can be derived from CLK2IN or from ATCLK. In the synchronous mode, both PROCCLK and BCLK are derived from CLK2IN, so that the processor state machine and the AT bus state machine run synchronous. In the asynchronous mode, BCLK is generated from the ATCLK and PROCCLK is generated from CLK2IN or the ATCLK. In this case, the processor and AT bus state machines run asynchronous to each other. The following clock selections are possible:

#### Synchronous mode

- 1. PROCCLK = BCLK = CLK2IN SYSCLK = BCLK/2 = CLK2IN/2
- 2. PROCCLK = CLK2IN BCLK = CLK2IN/2 SYSCLK = BCLK/2 = CLK2IN/4
- 3. PROCCLK = BCLK = CLK2IN/2 SYSCLK = BCLK/2 = CLK2IN/4



Figure 1.2 Clock Selection Block Diagram

## CHIP5

#### Asynchronous mode

- 1. PROCCLK = CLK2IN BCLK = ATCLK SYSCLK = BCLK/2 = ATCLK/2
- 2. PROCCLK = ATCLK BCLK = ATCLK SYSCLK = BCLK/2 = ATCLK/2.

Under normal operation, CLK2IN should be selected as the processor clock (PROCCLK) to allow the processor to run at full speed. BCLK can either be a sub-division of CLK2IN or the ATCLK. ATCLK may be selected to generate PROCCLK only when it is desired to slow down the processor for timing dependent code execution. Once the options for clock switching are set, the switching occurs with clean transition in the asynchronous or synchronous mode. During clock switching, no phases of PROCCLK are less than the minimum value or greater than the maximum value specified for the 80286 CPU. The clock source selection is made by writing to REG60H<4> and REG62H<0: 1>, which default to: PROCCLK = CLK2IN, SYSCLK = CLK2IN/4.

Figures 1.3 and 1.4 illustrate the sequence of events that switch PROCCLK from high to low speed and from low to high speed, upon receiving a request from the configuration register. In Figure 1.3, the falling edge (A) of PROCCLK is used to latch the command inactive condition (1). On the falling edge (B), CLK2IN is disabled on the PROCCLK line. This ensures that clock switching will occur when PROCCLK is low. Once PROCCLK has been disabled, the first rising edge (C) of BCLK latches this condition as denoted by sequence (2). BCLK then enables itself on the PROCCLK line on the falling edge









(D) as denoted by sequence (3). This ensures a glitch free transition between the two clocks. It also does not violate the min and max 80286 CPU clock specifications. If BCLK is asynchronous with respect to CLK2IN, it is possible that sequence (2) could violate setup time requirements with respect to edge (C). In this case, edge (D) will register the state of PROCCLK as still being high in sequence (3). Hence, edge (E) samples PROCCLK to be low and edge (F) enables BCLK on the PROCCLK line. This case also does not violate the min and max 80286 CPU clock specifications.

In Figure 1.4, the falling edge (A) of PROCCLK latches command inactive as denoted by sequence (1). Edge (B) disables BCLK on the PROCCLK line. In sequence (2), edge (C) of CLK2IN latches PROCCLK low. Edge (D) then enables CLK2IN on the PROCCLK line as denoted by sequence (3). If sequence (2) does not meet setup time requirements of edge (C), then the state of PROCCLK is sampled as being high in sequence (2). In this case, edge (D) samples PROCCLK low and edge (E) enables CLK2IN on the PROCCLK line. In this case also, PROCCLK does not violate the min and max 80286 CPU clock specifications.

## 1.2.3 CPU State Machine, Bus State Machine and Bus Arbitration

In order to extract maximum performance out of the 80286 on the system board, it is desirable to run the system board at the rated maximum CPU frequency. This frequency may be too fast for the slow AT bus. In order to overcome this problem, the 82C211 has two state machines: the CPU state machine which typically runs off CLK2IN, and the AT bus state machine which runs off BCLK. The two state machines maintain an asynchronous protocol under external mode operation.

#### **CPU State Machine**

Interface to the 80286 requires interpretation of the status lines S0, S1, M/IO during TS0 and the synchronization and generation of READY to the CPU upon completion of the requested operation. IALE is issued in response to the beginning of a new cycle in TS1 by the 82C211. If AF16 is detected as being inactive at the end of the processor TS state, control is handed over to the AT bus state machine. The CPU state machine then waits for READY to be active to terminate the current cycle. All local memory cycles are 16 bit cycles. If AF16 is asserted in response to a new CPU cycle and READY is not returned to the 82C211 within 128 clocks, and REG60H<2> is enabled, then an NMI is generated to signal bus time-out, if NMI has been enabled.

## AT Bus State Machine

The AT bus state machine gains control when AF16 is detected inactive by the CPU state machine. It uses BCLK which is twice the frequency of AT system clock SYSCLK. When ATCLK is selected as the source for BCLK, it also performs the necessary synchronization of control and status signals between the AT bus and the processor. The 82C211 supports 8 and 16 bit transfers between the processor and 8 or 16 bit memory or I/O devices located on the AT bus. The action codes AC0, AC1 qualified by ACEN are used for bus sizing and 8, 16 bit bus conversions by the 82C215. They are discussed in section 1.2.4.

The AT bus cycle is initiated by asserting <u>ALE in AT-TS1</u>. On the falling edge of ALE, <u>MEMCS16</u> is sampled for a memory cycle to determine the bus size. It then enters the command cycle AT-TC and provides the sequencing and timing signals for the AT bus cycle. For an I/O cycle, IOCS16 is sampled in the middle of the processor TC state. These control signals emulate the lower speed AT bus signals. The command cycle is terminated when IOCHRDY is active on the AT bus and all programmed wait states have been executed.

It is possible to provide software selectable wait states and command delays to the AT state machine. Providing command delays causes the commands (XMEMR XMEMW. XIOR or XIOW) to be delayed from going active in BCLK steps. Providing wait states causes READY to be delayed to the CPU in steps of the AT command cycles (AT-TC). The defaults and settings are discussed in section 1.4.



Figure 1.5 Refresh/DMA Sequence

#### **Bus Arbitration**

mu uumham

The 82C211 controls all bus activity and provides arbitration between the CPU, DMA/ Master devices, and DRAM refresh logic. It handles HRQ and REFREQ by generating HOLD request to the CPU and arbitrating among these requests in a non-preemptive manner. The CPU relinquishes the bus by issuing HLDA. The 82C211 responds by issuing REF or HLDA1 depending on the requesting device. During a refresh cycle, the refresh logic has control of the bus until REF goes inactive. XMEMR is asserted low during a refresh cycle and the refresh address is provided on the A0-A9 address lines by the 82C211 to be used by the 82C212 memory controller. During a DMA cycle, the DMA controller has control of the bus until HRQ goes inactive. The 82C211 puts out the action codes for bus sizing. ALE, EALE and ACEN are active during DMA cycle.

Figure 1.5 is a sequence diagram for Refresh/ DMA cycles. Upon receiving a refresh request

(REFREQ) it is internally latched by the 82C211. On the first rising edge of SYSCLK, HOLD is output to the processor in sequence 1. Depending on the current activity of the processor, a hold acknowledge (HLDA) is issued by the processor in sequence 2, after a DMA latency time. The 82C211 responds with REF active in sequence 3. LMEGCS from the 82C212 goes active in sequence 4. XMEMR is asserted low on the second rising edge of SYSCLK after REF is low in sequence 5. The 82C212 pulls all its RAS lines (RAS0-RAS3) high when REF goes low. The RAS lines go active in sequences 6 and 7 when the refresh address is active on the A0-A9 lines of the 82C211. The 82C212 uses the A0-A9 lines to generate the refresh address on the MA0-MA9 address lines. XMEMR goes inactive in sequence 8 followed by the RAS lines going inactive in sequences 9, 10. REF, LMEGCS and HOLD go inactive in sequence 11. Control is transferred to the CPU after HLDA goes inactive in sequence 12.

If a DMA device requests control of the bus,



the 82C211 receives HRQ1 active. After a DMA latency time, the CPU relinquishes the bus to the requesting device by issuing HLDA1 in sequence 14. HLDA1 is active as long as HRQ1 is active. Once the DMA device deasserts HRQ1, HLDA1 is deasserted by the 82C211 in sequence 15, to return control to the processor.

#### **1.2.4 Action Codes Generation Logic**

The AT state machine performs data conversion for CPU accesses to devices not on the CPU or Memory Bus.The AT bus conversions are performed for 16 to 8 bit read or write operations. Sixteen bit transfers to/from the CPU are broken into smaller 8 bit AT bus or peripheral bus reads or writes. The action codes are generated as shown in Table 1.1 to control the buffers in the 82C215. The action codes are in response to signals MEMCS16, IOCS16.



Action Codes Enable (ACEN) Generation

| Operation    | ACEN                                                                                  |
|--------------|---------------------------------------------------------------------------------------|
| DMA/MASTER   | 0                                                                                     |
| CPU (local)  | 1                                                                                     |
| CPU (AT bus) | 0 for write<br>0 qualified by command for<br>read and interrupt<br>acknowledge cycles |
| REFRESH      | 1 qualified by REF                                                                    |

#### AT-Bus CPU Cycles HLDA1 = 0

| AC | Operation                               |
|----|-----------------------------------------|
| 00 | 16 bit write and 8 bit write (low byte) |
| 01 | 16 bit read and 8 bit read (low byte)   |
| 10 | 8 bit write (high byte)                 |
| 11 | 8 bit read (high byte)                  |



Figure 1.6 Quick Mode Bus Conversion Cycle (0WS, 0CD)

#### DMA/MASTER Cycles, HLDA1 = 1

| AC | Operation                                                                                 |
|----|-------------------------------------------------------------------------------------------|
| 00 | MD bus tri-stated from the 82C215<br>for 16 bit and 8 (low byte) read/write<br>operations |
| 01 | Reserved                                                                                  |
| 10 | High memory write MD0-7 to MD8-15                                                         |
| 11 | High memory read MD8-15 to MD0-7                                                          |

Figure 1.6 shows a sequence diagram for a data conversion cycle in Quick mode with zero wait states (0 W.S.) and zero command delays (0 C.D.). Quick mode is discussed in section 1.3.2. In Quick mode ALE is issued on the AT bus as shown in sequences 1 and 2. MEMCS16 from an external device is sampled high by the 82C211 in sequence 3, initiating a bus conversion cycle. The first command also goes active in sequence 3 for the first byte operation and is terminated in sequence 4. In order to provide sufficient back to back time between the two 8 bit cycles, the second byte command is issued two PROCCLKs later in sequence 5 and is terminated in sequence 6. No second ALE is issued for the second byte operation since only address line XA0 changes from zero to one. READY is asserted low in sequence 7 and is sampled low by the processor in sequence 8, to terminate the current cycle. ACEN and AC0, AC1 are issued by the 82C211 for bus conversion as shown.

#### 1.2.5 Port B and NMI generation logic

The 82C211 provides access to Port B defined for the PC/AT as shown in Figure 1.7.



Figure 1.7 Port B

| Bits | Read/<br>Write | Function                                 |  |  |
|------|----------------|------------------------------------------|--|--|
| 7    | R              | PCK-System memory parity check           |  |  |
| 6    | R              | CHK-I/O channel check                    |  |  |
| 5    | R              | T20-Timer 2 out                          |  |  |
| 4    | R              | RFD-Refresh Detect                       |  |  |
| 3    | R/W            | EIC-Enable I/O channel<br>check          |  |  |
| 2    | R/W            | ERP-Enable system memory<br>parity check |  |  |
| 1    | R/W            | SPK-Speaker Data                         |  |  |
| 0    | R/W            | T2G-Timer 2 Gate (Speaker)               |  |  |
|      |                |                                          |  |  |

#### Table 1.2 Port B register definition

The NMI sub-module performs the latching and enabling of I/O and parity error conditions, which will generate a non-maskable interrupt to the CPU if NMI is enabled. Reading Port B will indicate the source of the error condition (IOCK and PCHK). Enabling and disabling of NMI is accomplished by writing to I/O address 070H. On the rising edge of XIOW, NMI will be enabled if data bit 7 (XD7) is equal to 1 and will be disabled if XD7 is equal to 0.

#### **Numeric Coprocessor Interface**

Incorporated in the 82C211 is the circuitary to interface an 80287 Numeric Coprocessor to 80286. The circuitary handles the decoding required for selecting and resetting the Numeric Coprocessor, handling NPBUSY and ERROR signals from the 80287 to the CPU, and generating interrupt signals for error handling.

The NPCS signal is active for I/O addresses 0F8H-0FFH, used to access the internal registers of the 80287. It is also active for I/O addresses 070H-NMI mask register, 0F0H-Reset Numeric Coprocessor BUSY signal, and 0F1H-Reset the Numeric Coprocessor and Numeric Coprocessor BUSY signal. While executing a task, the 80287 issues an NPBUSY



signal to the 82C211. Under normal operation, it is passed out to the CPU as  $\overline{BUSY}$ . If during this busy period, a numeric coprocessor error occurs, ERROR input to the 82C211 becomes active, resulting in latching of the BUSY\* output and assertion of NPINT. Both signals stay active until cleared by an I/O write cycle to address 0F0H or 0F1H. A system reset clears both NPINT and  $\overline{BUSY}$  latches in the 82C211. The 80287 is reset through the NPRESET output, which can be activated by a system reset or by performing a write operation to I/O port 0F1H.

#### **1.3 Modes of Operation of the 82C211**

The 82C211 has 4 modes of operation for different CPU and AT bus clock selections:

Normal mode Quick mode Delayed mode External mode

#### 1.3.1 Normal mode

This mode is enabled by default (without writing to the internal registers of the 82C211). Under Normal mode:

PROCCLK = CLK2IN BCLK = CLK2IN/2 SYSCLK = CLK2IN/4

Since the CPU state machine clock and the AT bus state machine clock are derived from CLK2IN, this is a synchronous mode. ALE and commands (XMEMR, XMEMW, XIOR, XIOW) are issued only for AT bus cycles and not for local cycles. If activated by default, I/O cycles will have one command delay, 8 bit AT memory cycles will have 4 wait states, 16 bit AT memory cycles will have 1 wait state.

Figure 1.8 shows the sequence diagram of a Normal mode local cycle followed by an AT bus cycle with zero wait states (0 W.S.) and







NOTE: TD = DELAYED HOLD TIME, TN = NORMAL HOLD TIME.

Figure 1.9 Normal Mode AT Bus Cycle with Additional Hold Time (0WS, 0CD)

zero command delays (0 C.D.). In sequences 1 and 2. IALE is generated from CLK2IN. AF16 is sampled to be low in sequence 2. ALE and AT buss commands (XIOR, XIOW, XMEMR, MEMW) are not generated since it is a local cycle. For a zero wait state cycle, ready is sampled low by the 80286 CPU in sequence 3 and the cycle is terminated. For the AT bus cycle, AF16 is sampled high in sequence 4. Control is transferred to the AT bus state machine. BCLK then generates the AT bus states. ALE is generated in sequences 5 and 6. The AT bus command is generated in sequences 6 and 7, for zero command delays programmed in the 82C211. For a zero wait state cycle, ready is asserted low as shown in sequences 8 and 9, to be sampled by the CPU in sequence 7. This terminates the AT bus cycle.

On the AT bus, certain slow peripherals require between 50 to 60 nanoseconds between command going inactive to the next ALE going active, to provide sufficient data recovery time. The sequence diagram in Figure 1.9 shows a Normal mode AT bus cycle with additional hold time. The dotted IALE signal would have been valid, if the additional hold time register had not been enabled in RA1<7>. Instead, IALE is delayed by <u>one T<sub>C</sub></u> state of the processor by asserting READY one T<sub>C</sub> cycle later. The 82C212 provides an extended DLE to the 82C215 in this mode, so that data is available to the CPU during write cycles. If this mode was not invoked, then READY would have been asserted earlier as shown by the dotted line. In Delayed mode, the 82C211 provides an extended data hold time. This additional hold time can only be programmed in the Normal mode.

#### 1.3.2 Quick mode

This mode is also a synchronous mode and is enabled by writing a zero to REG61<6> and the following clock selections have been made:

PROCCLK = BCLK = CLK2IN SYSCLK = CLK2IN/2

In Quick mode, an ALE signal is generated





Figure 1.10 Quick Mode Local Cycle Followed by AT Bus Cycle (0WS, 0CD)

on the AT bus for both AT bus and <u>local bus</u> cycles. However, the commands (XMEMR, XMEMW, XIOR, XIOW) are not issued for local bus cycles.

The sequence diagram for a Quick mode local cycle followed by an AT bus cycle is shown in Figure 1.10. In this mode, both IALE and ALE are generated in sequences 1 and 2 for the local cycle. Hence, an ALE is issued on the AT bus for AT or non-AT bus cycles. The local cycle is terminated when READY is sampled low by the 80286 in sequence 3. For the AT bus cycle, the command is issued after AF16 is sampled high in sequence 5. For write cycles, ACEN is activated in sequence 4. For read cycles, ACEN is activated in sequence 5. If the next cycle is not an AT bus write cycle, then ACEN is negated in sequence 6. READY is sampled low by the 80286 in sequence 6, to terminate the cycle. As seen in Figure 1.10, the AT bus states coincide with the CPU states for AT bus cycles. Hence, Quick mode is performance efficient when switching between local and AT bus cycles. This mode is useful for high speed add-on cards such as Lazer Printer interface cards.

#### 1.3.3 Delayed mode

This mode is another synchronous mode and is enabled when Quick mode is disabled and the following clock selections have been chosen made:

PROCCLK = CLK2IN BCLK = CLK2IN SYSCLK = CLK2IN/2

In Delayed mode, ALE and commands are issued only for AT bus cycles like in the Normal mode, except that BCLK = CLK2IN. ALE and commands are not issued for local cycles. Figure 1.11 shows a Delayed mode AT bus cycle. IALE is generated in sequences 1 and 2. ALE is asserted in sequence 3 after sampling AF16 high and it is deasserted in sequence 4. Hence the AT bus states, though synchronous, are delayed with respect to the processor states. Figure 1.11 is an example with two command delays and three wait states. The dotted lines A and B show command going active for 0 and 1 command delays. Sequence 5 shows command going active for programmed 2 command delays.



Figure 1.11 Delayed Mode AT Bus Cycle (3WS, 2CD)

Dotted lines D, E, F show command going inactive for 0, 1, 2 wait states. Sequence 6 shows command going inactive for programmed 3 wait states. READY is sampled by the 80286 in sequence 6 to terminate the current cycle. Since the AT bus states are delayed with respect to the processor states, the Local Address lines LA17-LA23 (typically un-latched) are not valid when ALE is active. In order to have the LA17-LA23 lines valid when ALE is active, they are latched by EALE as shown in sequence 7. Sequences 8. 9 show when ACEN is asserted for AT bus write (W) and read (R) cycles. ACEN is deasserted in sequence 10. This mode is useful for slow peripheral AT add-on cards.

#### 1.3.4 External mode

and de ante ante

This is an asynchronous mode and is enabled when ATCLK is selected as the source for BCLK. The following clock selections are required in this mode:

PROCCLK = CLK2IN BCLK = ATCLK SYSCLK = ATCLK/2

Since ATCLK is asynchronous to CLK2IN, the CPU state machine runs asynchronous to the AT bus state machine. ALE and commands (XMEMR, XMEMW, XIOR, XIOW) are issued only for AT bus cycles. These signals are inactive for local cycles. Figure 1.12 shows a sequence diagram for an External mode AT bus cycle. AF16 is sampled high in sequence 2 and is latched internally, using CLK2IN. The asynchronous BCLK samples this latched state on the next rising edge of BCLK. In the example shown, edge A samples the latched AF16 signal (internal) high. This causes the AT state machine to issue an ALE in sequences 3 and 4. For a zero command delay, zero wait states cycle, the command is issued on the AT bus in sequences 4 and 6, synchronized with BCLK. For write cycles, ACEN is asserted in sequence 1 and for read cycles. it is asserted in sequence 5. ACEN is deasserted in sequence 7. The command inactive state is sampled by CLK2IN on every rising edge. In this case, edge D of CLK2IN samples command high (sequence 8). It is followed by the assertion of READY in sequence 9, syn-



Figure 1.12 External Mode AT Bus Cycle (0WS, 0CD)

chronized with CLK2IN. The CPU samples READY low in sequence 10 and terminates the current cycle.

#### **1.4 Configuration Registers**

There are three bytes of configuration registers in the 82C211; RA0, RA1 and RA2. An indexing scheme is used to reduce the I/O ports required to access all the registers required for the NEAT CHIPSet. Port 22H is used as an indexing register and Port 23H is used as the data register. The index value is placed in port 22H to access a particular register and the data to be read from or written to that register is located in port 23H. Every access to port 23H must be preceded by a write of the index value to port 22H even if the same register data is being accessed again. All reserved bits are set to zero by default and when written to, must be set to zero. Table 1.3 lists the three registers:

#### Table 1.3

| Register<br>Number | Register<br>Name             | Index |
|--------------------|------------------------------|-------|
| RA0                | PROCCLK Selector             | 60H   |
| RA1                | Command Delay                | 61H   |
| RA2                | Wait State/<br>BCLK Selector | 62H   |

## CHIPS

#### 1.4.1 Register Description

## PROCCLK Register RA0

Index register port: 22H Data register port: 23H Index: 60H



| Bits | Function                                                                                                                                                                                          |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7, 6 | 82C211 revision number. 00 is the initial number.                                                                                                                                                 |
| 5    | Alternate CPU reset. A low to high<br>transition in this bit activates a CPU<br>reset. Once active, it remains active<br>for 16 PROCCLK cycles and then<br>goes low.                              |
| 4    | Processor clock select is by default<br>set to zero and selects PROCCLK =<br>CLK2IN. If high, it selects PROCCLK<br>= BCLK.                                                                       |
| 3    | Reserved.                                                                                                                                                                                         |
| 2    | Local bus READY timeout NMI en-<br>able. A one enables the NMI and a<br>zero disables it. Default is 0                                                                                            |
| 1    | Reserved.                                                                                                                                                                                         |
| 0    | Local bus READY timeout. A one<br>indicates that READY timeout has<br>occurred 128 PROCCLK cycles after<br>AF16 has been asserted. A zero in-<br>dicates that READY time out has not<br>occurred. |

## Command Delay Register RA1

Index register port: 22H Data register port: 23H Index: 61H



| Bits | Function                                                                                                                                   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 1, 0 | AT Bus I/O cycle command delay.<br>Specifies between 0 to 3 BCLK cycle<br>command delays for AT I/O cycles.<br>Default is 1.               |
| 3, 2 | AT Bus 8 bit memory command<br>delay. Specifies between 0 to 3<br>BCLK cycle command delays for 8<br>bit AT memory cycles. Default is 1.   |
| 5, 4 | AT Bus 16 bit memory command<br>delay. Specifies between 0 and 3<br>BCLK cycle command delays for 16<br>bit AT memory cycles. Default is 0 |
| 6    | Quick mode enable. A zero enables<br>Quick mode and a one disables it.<br>Default is 1.                                                    |
| 7    | Address hold time delay. A one en-<br>ables extra address bus hold time<br>and a zero disables it. Default is 0.                           |



## Wait States Register RA2

Index register port: 22H Data register port: 23H Index: 62H



| Bits | Function                                                |
|------|---------------------------------------------------------|
| 1, 0 | Bus clock (BCLK) source select.<br>Default is 00.       |
| 00   | BCLK = CLK2IN/2                                         |
| 01   | BCLK = CLK2IN                                           |
| 10   | BCLK = ATCLK                                            |
| 11   | Reserved                                                |
| 3, 2 | 8 bit AT cycle wait state generation.<br>Default is 5.  |
| 00   | 2 wait states                                           |
| 01   | 3 wait states                                           |
| 10   | 4 wait states                                           |
| 11   | 5 wait states                                           |
| 5, 4 | 16 bit AT cycle wait state generation.<br>Default is 3. |
| 00   | 0 wait states                                           |
| 01   | 1 wait state                                            |
| 10   | 2 wait states                                           |
| 11   | 3 wait states                                           |
| 7, 6 | Reserved                                                |

### **1.5 Absolute Maximum Ratings**

| Parameter             | Symbol           | Min. | Max. | Units |
|-----------------------|------------------|------|------|-------|
| Supply Voltage        | V <sub>cc</sub>  | -    | 7.0  | v     |
| Input Voltage         | VI               | -0.5 | 5.5  | v     |
| Output Voltage        | Vo               | -0.5 | 5.5  | v     |
| Operating Temperature | T <sub>OP</sub>  | -25° | 85°  | С     |
| Storage Temperature   | T <sub>STG</sub> | -40° | 125° | С     |

NOTE: Permanent device damage may occur if Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions described under Operating Conditions.

## 1.6 82C211 Operating Conditions

| Parameter           | Symbol          | Min. | Max. | Units |
|---------------------|-----------------|------|------|-------|
| Supply Voltage      | V <sub>cc</sub> | 4.75 | 5.25 | v     |
| Ambient Temperature | T <sub>A</sub>  | 0°   | 70°  | С     |

## 1.7 82C211 DC Characteristics

| Parameter                                                                 | Symbol           | Min. | Max. | Units |
|---------------------------------------------------------------------------|------------------|------|------|-------|
| Input Low Voltage                                                         | V <sub>IL</sub>  |      | 0.8  | V     |
| Input High Voltage                                                        | V <sub>IH</sub>  | 2.0  |      | V     |
| Output Low Voltage<br>I <sub>OL</sub> = TBD                               | V <sub>OL</sub>  |      | 0.45 | V     |
| Output High Voltage<br>I <sub>OH</sub> = TBD                              | V <sub>OH</sub>  | 2.4  | -    | V     |
| Input Current<br>0 <v<sub>IN<v<sub>CC</v<sub></v<sub>                     | I <sub>IL</sub>  | _    | ±10  | μA    |
| Input Clamp Voltage                                                       | V <sub>IC</sub>  |      | TBD  | V     |
| Power Supply Current @ 16MHz                                              | Icc              |      | TBD  | mA    |
| Output High-Z Leakage Current<br>0.45 <v<sub>OUT<v<sub>CC</v<sub></v<sub> | I <sub>OZ1</sub> |      | ±10  | μA    |
| PROCCLK Output Low Voltage<br>@ I <sub>OL</sub> = 5mA                     | V <sub>OLC</sub> |      | 0.45 | V     |
| PROCCLK Output High Voltage<br>@ I <sub>OH</sub> = -1mA                   | V <sub>OHC</sub> | 4.0  | _    | V     |

## 1.8 82C211-16 AC Characteristics

 $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%)$ 

| 1 ALE active delay from SYSCLKI   2 ALE inactive delay from SYSCLKI   3 COMMAND active delay from SYSCLKII   4 COMMAND inactive delay from SYSCLKI |   | 2<br>4<br>4<br>2<br>10 |          | ns<br>ns<br>ns |
|----------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------|----------|----------------|
| 3 COMMAND active delay from SYSCLK1                                                                                                                |   | 4<br>2                 |          | ns             |
|                                                                                                                                                    |   | 2                      |          |                |
| 4 COMMAND inactive delay from SYSCLKt                                                                                                              |   |                        |          |                |
|                                                                                                                                                    |   | 10                     |          | ns             |
| 5 EALE active delay from SYSCLK                                                                                                                    |   |                        |          | ns             |
| 6 MEMCS16 set-up time to SYSCLK1                                                                                                                   |   | 9                      |          | ns             |
| 7 MEMCS16 hold time to SYSCLK1                                                                                                                     | 0 |                        | <u></u>  | ns             |
| 8 IOCS16 set-up time to SYSCLK                                                                                                                     |   | 19                     |          | ns             |
| 9 IOCS16 hold time to SYSCLK                                                                                                                       | 0 |                        |          | ns             |
| 10 0WS set-up time to SYSCLK1                                                                                                                      |   | 19                     |          | ns             |
| 11 0WS hold time to SYSCLK1                                                                                                                        | 0 |                        |          | ns             |
| 12 IOCHRDY set-up time to SYSCLK1                                                                                                                  |   | 9                      |          | ns             |
| 13 IOCHRDY hold time to SYSCLK1                                                                                                                    | 0 |                        |          | ns             |
| 14 IALE active delay from PROCCLKI                                                                                                                 |   | 13                     | <u></u>  | ns             |
| 15 IALE inactive delay from PROCCLKI                                                                                                               |   | 14                     |          | ns             |
| AF16 set-up time to PROCCLK                                                                                                                        |   | 8                      |          | ns             |
| 17 AF16 hold time to PROCCLK                                                                                                                       |   | 10                     |          | ns             |
| 18 READY input set-up time to PROCCLK                                                                                                              |   | 7                      |          | ns             |
| 19 READY input hold time PROCCLK                                                                                                                   |   | 8                      |          | ns             |
| 20 RESET3 active delay from PROCCLK                                                                                                                |   | 9                      |          | ns             |
| 21 RESET3 inactive delay from PROCCLK                                                                                                              |   | 12                     |          | ns             |
| 22 RESET4 active delay from PROCCLKI                                                                                                               |   | 10                     |          | ns             |
| 23 RESET4 inactive delay from PROCCLK                                                                                                              |   | 12                     |          | ns             |
| 24 SDIR<1:0> active delay from SYSCLKI                                                                                                             |   | 6                      |          | ns             |
| SDIR<1:0> inactive delay from SYSCLKt                                                                                                              |   | 15                     |          | ns             |
| 26 ACEN active delay from SYSCLK                                                                                                                   |   | 8                      | 1.00.000 | ns             |
| ACEN inactive delay from SYSCLK1                                                                                                                   |   | 6                      |          | ns             |
| SDIR<1:0> active delay from PROCCLK                                                                                                                |   | 21                     |          | ns             |
| 29 SDIR<1:0> inactive delay from PROCCLK                                                                                                           | , | 25                     |          | ns             |
| 30 ACEN active delay from PROCCLKI                                                                                                                 |   | 25                     |          | ns             |

# 1.8 82C211-16 AC Characteristics (Continued) (T\_A = 0°C to 70°C, V\_{CC} = 5V $\pm$ 5%)

| Sym | Description                                   | Min. | Тур. | Max. | Units |
|-----|-----------------------------------------------|------|------|------|-------|
| t31 | ACEN inactive delay from PROCCLKI             |      | 22   |      | ns    |
| t32 | AC0 active delay from PROCCLK                 |      | 25   |      | ns    |
| t33 | AC0 inactive delay from PROCCLKI              |      | 25   |      | ns    |
| t34 | AC1 active delay from MEMCS16 active (memory) |      |      |      | ns    |
| t35 | AC1 active delay from IOCS16 active (IO)      |      |      |      | ns    |
| t36 | REFREQ set-up to SYSCLKI                      | 24   |      |      | ns    |
| t37 | REFREQ width                                  | 25   |      |      | ns    |
| t38 | Hold active delay from SYSCLKI                |      |      | 25   | ns    |
| t39 | Hold inactive delay from SYSCLK1              |      |      | 25   | ns    |
| t40 | REF delay from HLDA                           |      |      | 25   | ns    |
| t41 | REF delay from SYSCLK1                        |      |      | 25   | ns    |
| t42 | REFDET delay from REF                         |      |      | 25   | ns    |
| t43 | REF inactive delay from SYSCLK1               |      |      | 25   | ns    |
| t44 | XMEMR active delay from SYSCLK1               |      |      |      | ns    |
| t45 | XMEMR inactive delay from SYSCLK1             |      |      |      | ns    |
| t46 | HRQ1 set-up to SYSCLK1                        | 15   |      |      | ns    |
| t47 | HRQ1 hold time to SYSCLK1                     | 1    |      |      | ns    |
| t48 | HLDA1 active delay from SYSCLK1               |      |      | 30   | ns    |
| t49 | HLDA1 active delay from HLDA1                 |      |      | 30   | ns    |
| t50 | HLDA1 inactive delay from SYSCLK1             |      |      | 32   | ns    |
| t51 | HLDA1 inactive delay from HLDA                |      |      |      | ns    |
| t52 | NPCS active delay from PROCCLKI               |      |      |      | ns    |
| t53 | Overlap of NPBUSY & ERROR (both low)          | 10   |      |      | ns    |
| t54 | CPINT delay from NPBUSY, ERROR low            |      |      | 30   | ns    |
| t55 | CPINT inactive delay from ERROR1              |      |      | 31   | ns    |
| t56 | NPBUSY active pulse width                     | 15   |      |      | ns    |
| t57 | ERROR hold time with respect to NPBUSY1       | 0    |      |      | ns    |
| t58 | ERROR set up time to NPBUSY                   | 5    |      |      | ns    |
| t59 | ERROR min low pulse                           | 10   |      |      | ns    |

## 1.8 82C211-16 AC Characteristics (Continued)

 $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%)$ 

| Sym | Description                     | Min. | Тур. | Max. | Units |
|-----|---------------------------------|------|------|------|-------|
| t60 | BUSY active delay from NPBUSY   |      |      | 32   | ns    |
| t61 | BUSY inactive delay from NPBUSY |      |      | 32   | ns    |
| t62 | BUSY delay from IOW             |      |      | 30   | ns    |
| t63 | NPRST active delay from IOW     |      |      | 33   | ns    |
| t64 | NPRST inactive delay from IOW   |      |      | 37   | ns    |

## 1.9 82C211 Timing Diagrams



## 1.9 82C211 Timing Diagrams (Continued)















### 2 82C212 PAGE/INTERLEAVE AND EMS MEMORY CONTROLLER

## 2.1 Features

- Page mode access with interleaved memory banks, providing higher performance over conventional DRAM accessing schemes
- Supports 100ns DRAMs at 16MHz using page interleaved operation
- Supports upto 8Mbytes of on board memory
- Provides automatic remapping of RAM resident in 640K to 1Mbyte area to the top of the 1Mbyte address space.
- Supports Lotus Intel Microsoft-Expanded Memory System (LIM-EMS 4.0) address translation logic

- Shadow RAM feature for efficient Basic Input/Output System (BIOS) execution
- OS/2 optimization feature allows fast switching between protected and real mode
- Staggered refresh to reduce power supply noise

## 2.2 Overview

The 82C212 performs the memory control functions in the NEAT system, utilizing page mode access DRAMs. The various memory array configurations possible and Page/ Interleaved mode operation are discussed in this section. Figure 2.1 is a block diagram of the 82C212 chip.

### 2.2.1 Array Configuration

The 82C212 organizes memory as banks of 18 bit modules, consisting of 16 bits of data



Figure 2.1 82C212 Block Diagram



and 2 bits of parity information. The 16 bits of data are split into high and low order bytes. with one parity bit for each byte. This configuration can be implemented by using eighteen 1-bit wide DRAMs or by using four 4-bit wide DRAMs for data with two 1-bit wide DRAMs for parity. The minimum configuration can be a single bank operating in non-interleaved mode or can be a pair of DRAM banks operating in two way interleaved mode. Since the 82C212 uses a two way interleaving scheme, the DRAMs within a pair of banks must be identical. However, each bank of DRAM pairs can be different from other pairs. For example, Banks 0, 1 may have 256K by 1 bit DRAMs and Banks 2 and 3 could have 1M by 1bit DRAMs. A typical system may be shipped with one or two banks of smaller DRAM types (eq. 256K by 1 bit DRAMs) and later upgraded with additional pairs of banks of larger DRAMs (eq. 1M by 1 bit DRAMs).

## 2.2.2 Page/Interleaved Operation

The 82C212 uses a page/interleaved design that is different from most interleaved memory

designs. Typical two way interleaving schemes use two banks of DRAMs with even word addresses on one bank and odd word addresses on the other bank. If memory accesses are sequential, the RAS\* precharge time of one bank overlaps the access time of the other bank. Typically, programs consist of instruction fetches interspersed with operand accesses. The instruction fetches tend to be sequential and the operand accesses tend to be random.

Figure 2.2 is a sequence diagram for a memory interleaved scheme using two banks 0 and 1. The RAS signals of the two banks are interleaved so that the RAS precharge time ( $T_{rp}$ ) of one bank is used for the RAS active time in the other bank. This requires sequential accesses to be alternating between the two banks. For non-sequential accesses, it is possible to get wait states due to a 'miss'. Typically, this results in a 50% hit ratio (possible zero wait state accesses).

Figure 2.3 is a sequence diagram of a paged







mode DRAM operation. In paged mode DRAMs, once a row access has been made, it is possible to access subsequent column addresses within that row, without the RAS precharge penalty. However, after a RAS active timeout, there is a RAS precharge period which typically occurs every 10 microseconds. Since the CAS precharge time T<sub>cp</sub> is small, it is possible to make fast random accesses within a selected row. Typically, page mode access times are half the normal DRAM access times. For 256K × 1 DRAMs, each row has 512 bits. If eighteen 256K × 1 bit DRAMs are used to implement a bank, a page would have 512 × 2 bytes (excluding 2 bits for parity) = 1 Kbytes. Thus paged mode DRAMs could be interleaved at 1 Kbyte boundaries rather than 2 byte boundaries as in the regular interleaved mode operation. Any access to the currently active RAS page would occur in a short page access time and any subsequent access could be anywhere in the same 1Kbyte boundary, without incurring any penalty due to RAS precharge. If memory is configured to take advantage of this DRAM organization, significantly better performance can be achieved over normal interleaving because:

- Page mode access time is shorter than normal DRAM access time. This allows more time in the DRAM critical paths, to achieve penalty free accesses or 'hits'.
- The possibility of the next access being fast is significantly higher than in a regular interleaving scheme. This is because instructions and data tend to cluster together by principle of locality of reference.

Figure 2.4 is a sequence diagram of a two way Page/Interleaved scheme using page mode DRAMs. As seen, it is possible to make zero wait state accesses between the two banks 0 and 1, by overlapping CAS precharge time of one bank with CAS active time of the other bank. The DRAM RAS lines for both banks can be held active till the RAS active time out period, at which time a RAS precharge for that bank is required. Typical hit ratios higher then 80% are possible using this scheme. With the 82C212 memory controller, using the page/interleaved scheme, 150 nanosecond access time DRAMs can be used at 12MHz and 100 nano second access time DRAMs at 16MHz.

### **OS/2** Optimization

The NEAT architecture features OS/2 optimization using REG67<1> of the 82C212 in conjunction with REG60<5> of the 82C211. OS/2 makes frequent DOS calls while operating in protected mode of the 80286 CPU. In order to service these DOS calls, the 80286 CPU has to switch from protected to real mode quickly. Typical PC/AT architectures require the processor to issue two commands to the 8042 (or 8742) keyboard controller in order to reset the processor (to switch it into protected mode) and to activate GATEA20.

REG60<5> of the 82C211 is to used to invoke a software reset to the 80286 processor and REG67<1> is used to activate GATEA20. Since this involves two I/O writes, it is possible to execute a "Fast GATEA20". In an OS/2 environment, where frequent DOS calls are made, this feature provides significant performance improvement.







**nir** 

L

Figure 2.5 DRAM Organization

## 2.3 Functional Description

Figure 2.1 is a block diagram of the 82C212 memory controller. It consists of the following sub-modules:

- EPROM and DRAM control logic
- System Control logic
- Memory Mapping and Refresh logic
- Oscillator clock generation logic
- Configuration registers

## 2.3.1 EPROM and DRAM Control Logic

The EPROM and DRAM control logic in the 82C212 is responsible for the generation of the RAS, CAS and MWE signals for DRAM accesses and the generation of ROMCS for EPROM accesses. This sub-module also generates READY to the CPU upon completion of the desired local memory operation. The appropriate number of wait states are inserted, as programmed by software (or by default) in the wait state register of the 82C212. Figure 2.5 is a block diagram of the DRAM organization for the NEAT architecture. As seen, each RAS line drives each 256K × 18 bit bank (or 1M × 18 bit bank). The CAS lines are used to drive individual bytes within each bank. MWE is connected to each DRAM bank write enable input.

## 2.3.2 System Control Logic

This sub-module of the 82C212 generates XDEN, DLE, DRD, AF16 for system control. XDEN is issued for I/O accesses to the internal registers of the 82C212. It is used to enable the XD0-7 lines onto the MA0-7 lines from an external buffer, for accessing the internal registers of the 82C212. The DLE and DRD signals are generated for enabling and controlling the direction of data between the CPU data bus and the memory data bus (MD bus). AF16 is issued by the 82C212 state machine. It is active for local memory accesses and meets the set up and hold times with respect to PROCCLK for the 82C211.

## 2.3.3 Memory Mapping and Refresh logic

The 82C212 has an extensive set of memory mapping registers for various memory organizations. The registers are discussed in section 2.3.5. Through the memory mapping logic, for up to 1 Mbyte of system RAM, it is possible to map RAM that overlaps the EPROM area (640Kbyte-1Mbyte) above the 1Mbyte area, as shown in Figure 2.6. Hence, for 1Mbyte of on board RAM, the software can address it from 0 to 640 Kbytes and from 1 Mbyte to 1.384 Mbytes. The EPROM can be addressed from the 640 Kbyte area to the 1 Mbyte area.



Figure 2.6 System RAM/ROM Mapping for 1MB System RAM

For normal mode of operation, only one bank of DRAMs may be used. However, for the page/interleaved mode of operation, RAM bank pairs must be used.

## Shadow RAM Feature

For efficient execution of BIOS, it is preferable to execute BIOS code through RAM rather than through slower EPROMs. The 82C212 provides the shadow RAM feature which if enabled allows the BIOS code to be executed from system RAM resident at the same physical address as the BIOS EPROM. The software should transfer code stored in the BIOS EPROMs to the system RAM, before enabling the shadow RAM feature. This feature significantly improves the performance in BIOS-call intensive applications. Performance improvements as high as 300 to 400% have been observed in benckmark tests on the shadow RAM. The shadow RAM feature is invoked by enabling the corresponding bits in the ROM enable register and the RAM mapping register.

If more than 1 Mbyte of system RAM exists, it is mapped as shown in Figure 2.7, if the shadow RAM feature is not invoked. This means that RAM in the 640 Kbyte to 1 Mbyte area cannot be accessed. If the shadow RAM feature is used, then the RAM is mapped as



Figure 2.7 RAM/ROM Mapping Without Shadow RAM (More Than 1MB of RAM)

shown in Figure 2.8, overlapping or Shadowing the EPROM area. In both cases, for accesses beyond the 1 Mbyte address range, the processor is switched from real to protected mode from BIOS.



RAM (More Than 1MB of RAM)

## **EMS Address Translation Logic**

Expanded Memory System or EMS is a memory mapping scheme used to map a 64 Kbyte block of memory in the EPROM area D0000H-DFFFFH to anywhere in the 1 Mbyte-8 Mbyte area. This 64 Kbyte memory block is segmented into four 16 Kbyte pages. Through atranslation table, each 16Kbyte segment can be mapped any where in the 1 Mbyte to 8 Mbyte area. Since the 82C212 uses the translation table in the EMS mode, address lines A14 to A22 are translated by the appropriate EMS mapping register. Hence, this scheme does not require switching between user and protected mode. Figure 2.9 shows the EMS organization with a possible translation scheme. It is possible for the 82C212 to map this 64 Kbyte block to anywhere in the 0 to 8 Mbyte area. However, it is desirable to map this block above the 1 Mbyte area in order to not use the RAM space in the 0 to 640 Kbyte area. Although the EMS scheme translates the 64 Kbyte block in the D0000H-DFFFFH





Figure 2.9 EMS Mapping

area, it is possible to select a 64 Kbyte block from any other area.

## **Refresh Logic**

During a refresh cycle, the 82C211 puts out the refresh address on the A0-A9 address lines and asserts the REF signal low to the 82C212. The 82C212 uses these signals to generate the refresh address on the MA0-MA9 address lines, the RAS signals and LMEGCS. Figure 1.5 is a sequence diagram for a refresh cycle. As seen, the 82C212 performs as taggered mode refresh to reduce the power supply noise generated during RAS switching. Prior to a refresh, all RAS lines are pulled high to ensure RAS precharge. Following this, RAS0 and RAS3 are asserted low. RAS1 and RAS2 are staggered by one delay unit using an external delay line, with respect to RAS0 and RAS3. The RAS0-RAS3, RAS1-RAS2 bundling is provided so that staggering is effective for a minimal 2 bank or a full 4 bank configuration.

## **Memory Configurations**

It is possible to use 1Mbit or 256K bit (and in one case, 64K bit) DRAMs for system memory using the NEAT CHIPSet<sup>TM</sup>. Each memory bank can be implemented with eighteen 1 bit wide DRAMs or four 4 bit wide DRAMs with two 1 bit wide DRAMs. Possible configurations for onboard memory are listed in Table 2.1. Each bank is 16 bits wide plus two bits for parity. Table 2.1

|    | DRAM Type  |            |            |       | Total   | EMS               |
|----|------------|------------|------------|-------|---------|-------------------|
|    | Bank0      | Bank1      | Bank2      | Bank3 | Memory  | Range             |
| 1  | 0          | 0          | 0          | 0     | disable | 0                 |
| 2  | 256K       | 0          | 0          | 0     | 512Kb   | 0                 |
| 3  | 1 <b>M</b> | 0          | 0          | 0     | 2Mb     | 1Mb to<br>2Mb     |
| 4  | 256K       | 64K        | 0          | 0     | 640Kb   | 0                 |
| 5  | 256K       | 256K       | 0          | 0     | 1Mb     | 1Mb to<br>1.384Mb |
| 6  | 1M         | 1 <b>M</b> | 0          | 0     | 4Mb     | 1Mb to<br>4Mb     |
| 7  | 256K       | 256K       | 256K       | 0     | 1.5Mb   | 1Mb to<br>1.5Mb   |
| 8  | 256K       | 256K       | 1 <b>M</b> | 0     | ЗМЬ     | 1Mb to<br>3Mb     |
| 9  | 1 <b>M</b> | 1 <b>M</b> | 1 <b>M</b> | 0     | 6Mb     | 1Mb to<br>6Mb     |
| 10 | 256K       | 64K        | 256K       | 256K  | 1.64Mb  | 1Mb to<br>1.64Mb  |
| 11 | 256K       | 256K       | 256K       | 256K  | 2Mb     | 1Mb to<br>2Mb     |
| 12 | 256K       | 64K        | 1M         | 1M    | 4.64Mb  | 1Mb to<br>4.64Mb  |
| 13 | 256K       | 256K       | 1M         | 1M    | 5Mb     | 1Mb to<br>5Mb     |
| 14 | 1M         | 1M         | 1 <b>M</b> | 1M    | 8Mb     | 1Mb to<br>8Mb     |

Page/interleaving is possible for only those combinations with similar pairs of DRAMs. In table 2.1, page/interleaving is possible with combinations 5, 6, 11, 13 and 14.

## 2.4 Clock Generation Logic

The 82C212 has an oscillator circuit which uses a 14.31818 MHz crystal to generate the OSC and OSC/12 clocks. The 1.19381 MHz OSC/12 clock is used internally to generate the RAS timeout clocks, one for each bank. RAS is deasserted for each bank when its RAS time out counter times out after about 10 microseconds.

## **2.5 Configuration Registers**

There are twelve configuration and diagnostics registers in the 82C212, RB0-RB11. These are accessed through IO ports 22H and 23H normally found in the interrupt controller module of the 82C206 IPC. An indexing scheme is used to reduce the number of I/O addresses required to access all of the registers needed to configure and control the memory controller. Port 22H is used as an index register that points to the required data value accessed through port 23H. A write of the index value for the required data is performed to location 22H. This is then decoded and controls the multiplexers gating the appropriate register to the output bus. Every access to port 23H must be preceded by a write of the index value to port 22H even if the same data register is being accessed again. All bits marked as Reserved are set to zero by default and must be maintained that way during write operations. Table 2.2 lists these registers.

| Register<br>Number | Register<br>Name      | Index |
|--------------------|-----------------------|-------|
| RB0                | Version               | 64H   |
| RB1                | ROM Configuration     | 65H   |
| RB2                | Memory Enable-1       | 66H   |
| RB3                | Memory Enable-2       | 67H   |
| RB4                | Memory Enable-3       | 68H   |
| RB5                | Memory Enable-4       | 69H   |
| RB6                | Bank 0/1 Enable       | 6AH   |
| RB7                | DRAM Configuration    | 6BH   |
| RB8                | Bank 2/3 Enable       | 6CH   |
| RB9                | EMS Base Address      | 6DH   |
| RB10               | EMS Address Extension | 6EH   |
| RB11               | Miscellaneous         | 6FH   |

### Table 2.2



## 2.5.1 Register Description

## Version Register RB0

Index register port: 22H Data register port: 23H Index: 64H



| Bits | Function                                             |
|------|------------------------------------------------------|
| 7    | NEAT memory controller identifier.<br>0 = 82C212     |
| 6, 5 | 82C212 revision number. 00 = initial revision number |
| 4-0  | Reserved                                             |

## **ROM Configuration Register RB1**

Index register port: 22H Data register port: 23H Index: 65H



| Bits | Function                                                                                                                              |
|------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0    | ROM at F0000H-FFFFFH (BIOS).<br>Default = 0 = ROM enabled. ROMCS<br>is generated.                                                     |
| 1    | ROM at E0000H-EFFFFH. Default =<br>1 = ROM disabled, Shadow RAM<br>enabled. ROMCS is not generated<br>unless bit is set to 0.         |
| 2    | ROM at D0000H-DFFFFH. Default =<br>1 = ROM disabled, Shadow RAM<br>enabled. ROMCS is not generated<br>unless bit is set to 0.         |
| 3    | ROM at C0000H-CFFFFH (EGA).<br>Default = 1 = ROM disabled, Shadow<br>RAM enabled. ROMCS is not gener-<br>ated unless bit is set to 0. |
| 4    | Shadow RAM at F0000H-FFFFFH in<br>Read/Write mode, 0 = Read/Write<br>(default), 1 = Read only (Write pro-<br>tected).                 |
| 5    | Shadow RAM at E0000H-EFFFFH<br>in Read/Write mode. 0 = Read/Write<br>(default), 1 = Read only (Write pro-<br>tected).                 |
| 6    | Shadow RAM at D0000H-DFFFFH<br>in Read/Write mode. 0 = Read/Write<br>(default), 1 = Read only (Write pro-<br>tected).                 |
| 7    | Shadow RAM at C0000H-CFFFFH<br>in Read/Write mode. 0 = Read/Write<br>(default), 1 = Read only (Write pro-<br>tected).                 |



### Memory Enable-1 Register RB2

Index register port: 22H Data register port: 23H Index: 66H



| Bits | Function                                                                                                                                                                         |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0-6  | Reserved                                                                                                                                                                         |  |
| 7    | Address map RAM on system board<br>in 80000H-9FFFFH area. 0 = Address<br>is on the I/O channel (Default), 1 =<br>Address is on the system board and<br>is put out by the 82C212. |  |

#### Memory Enable Register-2 RB3

Index register port: 22H Data register port: 23H (R/W) Index: 67H



| Bits | Function                                                             |
|------|----------------------------------------------------------------------|
| 0    | Enable Shadow RAM in A0000H-<br>A3FFFH area. Disable = 0 Enable = 1. |
| 1    | Enable Shadow RAM in A4000H-<br>A7FFFH rea. Disable = 0 Enable = 1.  |
| 2    | Enable Shadow RAM in A8000H-<br>ABFFFH area. Disable = 0 Enable = 1. |
| 3    | Enable Shadow RAM in AC000H-<br>AFFFFH area. Disable = 0 Enable = 1. |
| 4    | Enable Shadow RAM in B0000H-<br>B3FFFH area. Disable = 0 Enable = 1. |
| 5    | Enable Shadow RAM in B4000H-<br>B7FFFH area. Disable = 0 Enable = 1. |
| 6    | Enable Shadow RAM in B8000H-<br>BBFFFH area. Disable = 0 Enable = 1. |
| 7    | Enable Shadow RAM in BC000H-<br>BFFFFH area. Disable = 0 Enable = 1. |

## Memory Enable-3 Register RB4

Index register port: 22H Data register port: 23H (R/W) Index: 68H



| Bits | Function                                                             |
|------|----------------------------------------------------------------------|
| 0    | Enable Shadow RAM in C0000H-<br>C3FFFH area. Disable = 0 Enable = 1. |
| 1    | Enable Shadow RAM in C4000H-<br>C7FFFH area. Disable = 0 Enable = 1. |

| 2 | Enable Shadow RAM in C8000H-<br>CBFFFH area. Disable = 0 Enable = 1. |
|---|----------------------------------------------------------------------|
| 3 | Enable Shadow RAM in CC000H-<br>CFFFFH area. Disable = 0 Enable = 1. |
| 4 | Enable Shadow RAM in D0000H-<br>D3FFFH area. Disable = 0 Enable = 1. |
| 5 | Enable Shadow RAM in D4000H-<br>D7FFFH area. Disable = 0 Enable = 1. |
| 6 | Enable Shadow RAM in D8000H-<br>DBFFFH area. Disable = 0 Enable = 1. |
| 7 | Enable Shadow RAM in DC000H-<br>DFFFFH area. Disable = 0 Enable = 1. |

## Memory Enable-4 Register (RB5)

Index register port: 22H Data register port: 23H (R/W) Index: 69H



| Bits | Function                                                             |
|------|----------------------------------------------------------------------|
| 0    | Enable Shadow RAM in E0000H-<br>E3FFFH area. Disable = 0 Enable = 1. |
| 1    | Enable Shadow RAM in E4000H-<br>E7FFFH area. Disable = 0 Enable = 1. |
| 2    | Enable Shadow RAM in E8000H-<br>EBFFFH area. Disable = 0 Enable = 1. |
| 3    | Enable Shadow RAM in EC000H-<br>EFFFFH area. Disable = 0 Enable = 1. |
| 4    | Enable Shadow RAM in F0000H-<br>F3FFFH area. Disable = 0 Enable = 1. |

| 5 | Enable Shadow RAM in F4000H-<br>F7FFFH area. Disable = 0 Enable = 1. |
|---|----------------------------------------------------------------------|
| 6 | Enable Shadow RAM in F8000H-<br>FBFFFH area. Disable = 0 Enable = 1. |
| 7 | Enable Shadow RAM in FC000H-<br>FFFFFH area. Disable = 0 Enable = 1. |

## Bank0/1 Enable Register RB6

Index register port: 22H Data register port: 23H Index: 6AH



| Bits | Function                                                                                  |                        |                                                                                                  |
|------|-------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------|
| 0-4  | Reserved                                                                                  |                        |                                                                                                  |
| 5    | Number of RAM banks used. 0 = 1<br>bank, non-interleaved mode (De-<br>fault), 1 = 2 banks |                        |                                                                                                  |
| 7, 6 | for<br>sys                                                                                | the<br>stem            | bits contain the information<br>DRAM types used on the<br>board. POST/BIOS should                |
|      | sto                                                                                       | ored                   | DRAM configuration data<br>in the CMOS RAM of the<br>IPC.                                        |
|      | sto                                                                                       | ored                   | in the CMOS RAM of the                                                                           |
|      | stc<br>82                                                                                 | ored<br>C206           | in the CMOS RAM of the<br>IPC.                                                                   |
|      | sto<br>82<br>7                                                                            | ored<br>C206<br>6      | in the CMOS RAM of the<br>IPC.<br>Disabled<br>256K and 64K bit DRAMs<br>used (for 640 Kbyte com- |
|      | sto<br>82<br>7<br>0                                                                       | ored<br>C206<br>6<br>0 | in the CMOS RAM of the<br>IPC.<br>DRAM Types<br>Disabled<br>256K and 64K bit DRAMs               |



## **DRAM Configuration Register RB7**

Index register port: 22H Data register port: 23H (R/W) Index: 6BH



| Bits | Function                                                                            |        |                                                                                                            |
|------|-------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------|
| 1, 0 | ROM access wait states control.                                                     |        |                                                                                                            |
|      | 1                                                                                   | 0      | Wait States                                                                                                |
|      | 0                                                                                   | 0      | 0                                                                                                          |
|      | 0                                                                                   | 1      | 1                                                                                                          |
|      | 1<br>1                                                                              | 0<br>1 | 2<br>3 (Default)                                                                                           |
| 3, 2 | EN                                                                                  | IS m   | emory access wait states.                                                                                  |
|      | 3                                                                                   | 2      | Wait States                                                                                                |
|      | 0                                                                                   | 0      | 0                                                                                                          |
|      | 0                                                                                   | 1      | 1                                                                                                          |
|      | 1                                                                                   | 0      | 2 (Default)                                                                                                |
|      | 1                                                                                   | 1      | Reserved                                                                                                   |
| 4    | EMS enable bit.If set to 0, EMS is disabled (Default). If set to 1, EMS is enabled. |        |                                                                                                            |
| 5    | ace<br>1                                                                            | cesse  | ccess wait states. If set to 0,<br>es have 0 wait states. If set to<br>ault), accesses will have 1<br>ite. |

| _ |                                                                                                                                                                                                                  |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | 640Kbyte to 1Mbyte RAM relocation<br>bit. A zero does not relocate local<br>RAM. A one (Default) relocates local<br>RAM from 080000H-09FFFFH to<br>100000H-11FFFFH, provided total<br>local RAM is 1 Mbyte only. |
| 7 | Page/Interleaved mode enable. A0<br>disables the page/interleaved mode,<br>allowing useage of normal mode<br>for the DRAMs (Default). A 1 en-<br>ables page/interleaved mode for the<br>DRAMs.                   |

## Bank 2/3 Enable Register RB8

Index register port: 22H Data register port: 23H Index: 6CH



| Bits | Function                                                                                                        |                  |                                                  |  |  |  |  |  |  |
|------|-----------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------|--|--|--|--|--|--|
| 0-4  | Re                                                                                                              | Reserved         |                                                  |  |  |  |  |  |  |
| 5    | Number of local RAM Banks used<br>0 = 1 Bank used, non-interleaved<br>mode only (Default). 1 = 2 Banks<br>used. |                  |                                                  |  |  |  |  |  |  |
| 7, 6 |                                                                                                                 |                  | pits indicate the local DRAM listed:             |  |  |  |  |  |  |
|      | 7                                                                                                               | 6                | DRAM Type                                        |  |  |  |  |  |  |
|      | 0<br>0<br>1<br>1                                                                                                | 0<br>1<br>0<br>1 | none (Default)<br>Reserved<br>256 Kbit<br>1 Mbit |  |  |  |  |  |  |



## **EMS Base Address Register RB9**

Index register port: 22H Data register port: 23H (R/W) Index: 6DH



| Bits | Fu             | Inc                                                                                                                                                             | lion       |            |                                                                                                         |  |  |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|---------------------------------------------------------------------------------------------------------|--|--|
| 0-3  | pa<br>bi       | ige<br>ts a                                                                                                                                                     | reg<br>are | iste<br>en | are used for the EMS<br>er I/O base address. The<br>coded as follows, with<br>binations being reserved: |  |  |
|      | 3              | 2                                                                                                                                                               | 1          | 0          | I/O Base                                                                                                |  |  |
|      | 0              | 0                                                                                                                                                               | 0          | 0          | 208H/209H                                                                                               |  |  |
|      | 0              | -                                                                                                                                                               | 0          | 1          | 218H/219H                                                                                               |  |  |
|      | 0              | 1                                                                                                                                                               | 0          | 1          | 258H/259H                                                                                               |  |  |
|      | 0              | 1<br>0                                                                                                                                                          | 1          | 0<br>0     | 268H/269H<br>2A8H/2A9H                                                                                  |  |  |
|      | 1              | -                                                                                                                                                               | 1          | 1          | 2B8H/2B9H                                                                                               |  |  |
|      | 1              | 1                                                                                                                                                               | 1          | ò          | 2E8H/2E9H                                                                                               |  |  |
| 7-4  | th<br>dr<br>Io | These bits are used for selecting<br>the expanded memory base ad-<br>dresses. They are encoded as fol-<br>lows, with all unused combinations<br>being reserved: |            |            |                                                                                                         |  |  |
|      | 7              | 6                                                                                                                                                               | 5          | 4          | EMS Base Addresses                                                                                      |  |  |
|      | 0              | 0                                                                                                                                                               | 0          | 0          | C0000H, C4000H,<br>C8000H, CC000H                                                                       |  |  |
|      | 0              | 0                                                                                                                                                               | 0          | 1          | C4000H, C8000H,<br>CC000H, D0000H                                                                       |  |  |
|      | 0              | 0                                                                                                                                                               | 1          | 0          | C8000H, CC000H,<br>D0000H, D4000H                                                                       |  |  |
|      | 0              | 0                                                                                                                                                               | 1          | 1          | CC000H, D0000H,                                                                                         |  |  |

|   |   |   | 1 | D4000H, D8000H                                      |
|---|---|---|---|-----------------------------------------------------|
| 0 | 1 | 0 | 0 | D4000H, D8000H<br>D0000H, D4000H,<br>D8000H, DC000H |
|   |   |   | 1 | D8000H, DC000H                                      |
| 0 | 1 | 0 | 1 | D4000H, D8000H,                                     |
|   |   |   |   | DC000H, E0000H                                      |
| 0 | 1 | 1 | 0 | D8000H, DC000H,                                     |
|   |   |   |   | E0000H, E4000H                                      |
| 0 | 1 | 1 | 1 | DC000H, E0000H,                                     |
|   |   |   |   | E4000H, E8000H                                      |
| 1 | 0 | 0 | 0 | E0000H, E4000H,<br>E8000H, EC000H                   |
|   |   |   |   | E8000H, EC000H                                      |
|   |   |   |   |                                                     |

### **EMS Address Extention Register RB10**

Index register port: 22H Data register port: 23H Index: 6EH



| Bits | Function |                                   |                              |  |  |  |  |
|------|----------|-----------------------------------|------------------------------|--|--|--|--|
| 1, 0 | EN       | IS Pa                             | ge 3 address extension bits. |  |  |  |  |
|      | 1        | 0                                 | Block of EMS Memory          |  |  |  |  |
|      | 0        | 0                                 | 1 Mbyte to 2 Mbyte           |  |  |  |  |
|      | 0        | 1                                 | 2 Mbyte to 4 Mbyte           |  |  |  |  |
|      | 1        | 0                                 | 4 Mbyte to 6 Mbyte           |  |  |  |  |
|      | 1        | 1                                 | 6 Mbyte to 8 Mbyte           |  |  |  |  |
| 3, 2 | EN       | EMS Page 2 address extension bits |                              |  |  |  |  |
|      | 3        | 2                                 | Block of EMS Memory          |  |  |  |  |
|      | 0        | 0                                 | 1 Mbyte to 2 Mbyte           |  |  |  |  |
|      | 0        | 1                                 | 2 Mbyte to 4 Mbyte           |  |  |  |  |
|      | 1        | 0                                 | 4 Mbyte to 6 Mbyte           |  |  |  |  |
|      | 1        | 1                                 | 6 Mbyte to 8 Mbyte           |  |  |  |  |

# CHIPS

|      | 5  | 4     | Block of EMS Memory          |
|------|----|-------|------------------------------|
|      | 0  | 0     | 1 Mbyte to 2 Mbyte           |
|      | 0  | 1     | 2 Mbyte to 4 Mbyte           |
|      | 1  | 0     | 4 Mbyte to 6 Mbyte           |
|      | 1  | 1     | 6 Mbyte to 8 Mbyte           |
| 7, 6 | EN | IS Pa | ge 0 address extension bits. |
|      | 7  | 6     | Block of EMS Memory          |
|      | 0  | 0     | 1 Mbyte to 2 Mbyte           |
| - 1  | 0  | 1     | 2 Mbyte to 4 Mbyte           |
|      | 0  |       |                              |
|      | 1  | 0     | 4 Mbyte to 6 Mbyte           |

## **Miscellaneous Register RB12**

Index register port: 22H Data register port: 23H Index: 6FH



| Bits | Function                                                                                                                                                                                                                           |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Reserved                                                                                                                                                                                                                           |
| 1    | This bit is used for Address line<br>A20 control and provides OS/2<br>optimization while switching bet-<br>ween user and protected modes.<br>The bit defaults to 0 and enables<br>CPUA20 onto A20. If set to 1, it sets<br>A20 = 0 |

| 2    | This bit is used to enable the RAS<br>time-out counter for page mode<br>operation. The counter is disabled<br>if set to 0 (Default) and is enabled if<br>set to 1. |          |     |                                                                     |  |  |  |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|---------------------------------------------------------------------|--|--|--|--|--|
| 3, 4 | Re                                                                                                                                                                 | Reserved |     |                                                                     |  |  |  |  |  |
| 7-5  | m                                                                                                                                                                  | em       | ory | ts are used to set the EMS<br>space according to the fol-<br>oding: |  |  |  |  |  |
|      | 7                                                                                                                                                                  | 6        | 5   | EMS Memory Size                                                     |  |  |  |  |  |
|      | 0                                                                                                                                                                  | 0        | 0   | 1 Mbyte to 1.5 Mbytes<br>(0.5 Mbytes)                               |  |  |  |  |  |
|      | 0                                                                                                                                                                  | 0        | 1   | 1 Mbyte to 2 Mbytes<br>(1 Mbyte)                                    |  |  |  |  |  |
|      | 0                                                                                                                                                                  | 1        | 0   | 1 Mbyte to 3 Mbytes<br>(2 Mbytes)                                   |  |  |  |  |  |
|      | 0                                                                                                                                                                  | 1        | 1   | 1 Mbyte to 4 Mbytes<br>(3 Mbytes)                                   |  |  |  |  |  |
|      | 1                                                                                                                                                                  | 0        | 0   | 1 Mbyte to 5 Mbytes<br>(4 Mbytes)                                   |  |  |  |  |  |
|      | 1                                                                                                                                                                  | 0        | 1   | 1 Mbyte to 6 Mbytes<br>(5 Mbytes)                                   |  |  |  |  |  |
|      | 1                                                                                                                                                                  | 1        | 0   | 1 Mbyte to 7 Mbytes                                                 |  |  |  |  |  |
|      | 1                                                                                                                                                                  | 1        | 1   | (6 Mbytes)<br>1 Mbyte to 8 Mbytes<br>(7 Mbytes)                     |  |  |  |  |  |

## 2.6 Absolute Maximum Ratings

| Parameter             | Symbol           | Min. | Max. | Units |
|-----------------------|------------------|------|------|-------|
| Supply Voltage        | V <sub>cc</sub>  | _    | 7.0  | V     |
| Input Voltage         | V                | -0.5 | 5.5  | V     |
| Output Voltage        | Vo               | -0.5 | 5.5  | V     |
| Operating Temperature | T <sub>OP</sub>  | -25° | 85°  | С     |
| Storage Temperature   | T <sub>STG</sub> | -40° | 125° | С     |

NOTE: Permanent device damage may occur if Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions described under Operating Conditions.

## 2.7 82C212 Operating Conditions

| Parameter           | Symbol          | Min. | Max. | Units |
|---------------------|-----------------|------|------|-------|
| Supply Voltage      | V <sub>CC</sub> | 4.75 | 5.25 | V     |
| Ambient Temperature | Τ <sub>Α</sub>  | 0°   | 70°  | С     |

## 2.8 82C212 DC Characteristics

| Parameter                                                                 | Symbol           | Min. | Max. | Units |
|---------------------------------------------------------------------------|------------------|------|------|-------|
| Input Low Voltage                                                         | V <sub>IL</sub>  | _    | 0.8  | V     |
| Input High Voltage                                                        | V <sub>IH</sub>  | 2.0  |      | V     |
| Output Low Voltage<br>I <sub>OL</sub> = TBD                               | V <sub>OL</sub>  | _    | 0.45 | V     |
| Output High Voltage<br>I <sub>OH</sub> = TBD                              | V <sub>OH</sub>  | 2.4  | -    | V     |
| Input Low Current<br>0 <v<sub>IN<v<sub>CC</v<sub></v<sub>                 | I <sub>IL</sub>  |      | +10  | μA    |
| Input Clamp Voltage                                                       | V <sub>IC</sub>  |      | TBD  | V     |
| Power Supply Current @ 16MHz                                              | l <sub>CC</sub>  |      | TBD  | mA    |
| Output High-Z Leakage Current<br>0.45 <v<sub>OUT<v<sub>CC</v<sub></v<sub> | I <sub>OZ1</sub> |      | +10  | μA    |

## 2.9 82C212-16 AC Characteristics

 $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%)$ 

| Sym | Description                                     | Min. | Тур. | Max. | Units |
|-----|-------------------------------------------------|------|------|------|-------|
| t1  | RAS, active delay from CLK2                     |      | 14   |      | ns    |
| t2  | RAS <sub>i</sub> inactive delay from CLK24      |      | 16   |      | ns    |
| t3  | DLYIN active delay from RAS <sub>i</sub> 1      |      | 3    |      | ns    |
| t4  | DLYIN inactive delay from RAS <sub>i</sub> t    |      | 3    |      | ns    |
| t5  | Column address stable from DLYINt               |      | 15   |      | ns    |
| t6  | Column address hold from DLYINI                 |      | 15   |      | ns    |
| t7  | CAS <sub>i</sub> active delay from DLYINt       |      | 15   |      | ns    |
| t8  | CAS <sub>i</sub> hold from DLYINI               |      | 15   |      | ns    |
| t9  | AF16 active delay from CLK2                     |      | 9    |      | ns    |
| t10 | AF16 inactive delay from CLK2                   |      | 11   |      | ns    |
| t11 | READY active delay from CLK21                   |      | 20   |      | ns    |
| t12 | READY inactive delay from CLK2                  |      | 15   |      | ns    |
| t13 | DRD active delay from CLK2                      |      |      |      | ns    |
| t14 | DRD hold from DLE                               |      |      |      | ns    |
| t15 | DLE active delay from CAS <sub>i</sub>          |      |      |      | ns    |
| t16 | DLE inactive delay from CLK2                    |      |      |      | ns    |
| t17 | LMEGCS active from CLK24                        |      | 15   |      | ns    |
| t18 | LMEGCS inactive from CLK21                      |      | 15   |      | ns    |
| t19 | GA20 valid delay from CPU <a20> valid</a20>     |      | 15   |      | ns    |
| t20 | GA20 invalid delay from CPU <a20> invalid</a20> |      | 15   |      | ns    |
| t21 | DLE inactive delay from CLK21                   |      |      |      | ns    |
| t22 | MWE active delay from CLK2                      |      | 17   |      | ns    |
| t23 | MWE inactive delay from CLK21                   |      | 17   |      | ns    |
| t24 | RAS <sub>i</sub> active delay from CLK2         |      | 17   |      | ns    |
| t25 | RAS <sub>i</sub> inactive delay from CLK2       |      |      |      | ns    |
| t26 | CAS <sub>i</sub> active delay from CLK21        |      | 11   |      | ns    |
| t27 | CAS <sub>i</sub> inactive delay from CLK21      |      | 13   |      | ns    |
| t28 | DRD inactive delay from CLK2                    |      |      |      | ns    |
| t29 | DLE inactive delay from CLK2                    |      |      |      | ns    |
| t30 | RAS <sub>i</sub> active delay from CLK21        | 14   |      |      | ns    |
| t31 | Row address set up time to RAS <sub>i</sub> I   |      | 10   |      | ns    |

# 2.9 82C212-16 AC Characteristics (Continued)

(T\_A = 0°C to 70°C, V\_{CC} = 5V  $\pm$  5%)

| Sym | Description                                                       | Min.                    | Тур. | Max. | Units |
|-----|-------------------------------------------------------------------|-------------------------|------|------|-------|
| t32 | Row address hold time from CLK21                                  |                         | 10   |      | ns    |
| t33 | RAS <sub>i</sub> inactive delay from CLK2                         |                         | 18   |      | ns    |
| t34 | RAS <sub>i</sub> precharge time                                   | 4 × CLK2                |      |      | ns    |
| t35 | ROMCS active from CLK21                                           |                         | 18   |      | ns    |
| t36 | ROMCS inactive from CLK21                                         |                         |      |      | ns    |
| 137 | DLE hold time from DRD                                            |                         |      |      | ns    |
| t38 | RAS <sub>0~3</sub> inactive from REF                              |                         |      |      | ns    |
| t39 | RAS <sub>0,3</sub> active from XMEMR                              |                         | 20   |      | ns    |
| t40 | RAS <sub>0,3</sub> inactive from XMEMR                            | 20                      |      |      | ns    |
| 41  | RAS <sub>1,2</sub> active from RAS <sub>0,3</sub>                 | 10 + 1st delay line tap |      |      | ns    |
| t42 | RAS <sub>1,2</sub> inactive from RAS <sub>0,3</sub> t             | 10 + 1st delay line tap |      |      | ns    |
| t43 | Address setup time from XMEMRI                                    | 50                      |      |      | ns    |
| t44 | Address hold time from REFt                                       |                         | 0    |      |       |
| 45  | Refresh address delay                                             | 20                      |      |      | ns    |
| 46  |                                                                   |                         |      |      | ns    |
| 47  | LMEGCS delay from REF                                             | 10                      |      | ns   |       |
| 48  | LMEGCS delay from REFt                                            |                         |      |      | ns    |
| 49  | RAS <sub>0~3</sub> inactive from HLDA11                           | 15                      |      | ns   |       |
| :50 | RAS <sub>i</sub> active from command active                       | 15                      |      | ns   |       |
| :51 | RAS <sub>i</sub> inactive from command inactive                   |                         |      |      | ns    |
| 52  |                                                                   |                         |      |      | ns    |
| :53 |                                                                   |                         |      |      | ns    |
| :54 | Column address stable from DLYIN1                                 | 10 + 1st delay line tap |      |      | ns    |
| 55  | CAS <sub>i</sub> active delay from DLYINt<br>(while XMEMW active) | 10 + 2nd delay line tap |      |      | ns    |
| 56  | CAS <sub>i</sub> active delay from DLYINt<br>(while XMEMR active) | 10 + 3rd delay line tap |      |      | ns    |
| 57  | AF16 active from command active                                   | 15                      |      | ns   |       |
| 58  | AF16 inactive from command inactive                               |                         |      |      | ns    |
| 59  | Address setup time from command                                   |                         | 50   |      | ns    |
| 60  |                                                                   |                         |      |      | ns    |
| 61  | Address setup time from command (EMS)                             |                         | 70   |      | ns    |





## 2.10 82C212 Timing Diagrams





Non-Interleave Mode-Write Followed by Read, 0WS







Interleave Mode-Write Cycle with RAS Being Inactive, 0WS







Interleave Mode-Write, 0WS (RAS active)



Interleave Mode-Read After Write, 0WS (RAS active)



Interlevae Mode—Read, 0WS (RAS active)



Non-Interleave Mode-0WS, Write





Interleave Mode—Read Miss Cycle



**ROM Read Cycle** 





**Refresh Cycle** 





**DMA Cycle** 



Interleave Mode—Write Cycle, 1WS (RAS active)





Interleave Mode-Read Cycle, 1WS (RAS active)





EMS, Non-Interleave Mode, Read

## 3 82C215 DATA/ADDRESS BUFFER

### **3.1 Features**

- Bus Conversion logic for 16 bit to 8 bit transfers
- Parity generation/detection logic

## **3.2 Functional Description**

Figure 3.1 is a block diagram of the 82C215 Data/Address buffer. It consists of four modules:

- Address buffers and latches
- Data buffers and latches
- Bus conversion logic
- Parity generation/detection logic

### 3.2.1 Address Buffers and Latches

The 82C215 provides the address buffering between the CPU address lines A1-A16 and the XA1-XA16 lines. These buffers drive 4 mA output low currents ( $I_{OL}$ ). The CPU address lines are latched by IALE to generate the X-Address lines when HLDA is inactive.

### 3.2.2 Data Buffers and Latches

The 82C215 provides the buffering between the CPU data bus (D0-D15) and the memory data bus (MD0-MD15). The D0-D15 lines drive 4 mA output low currents ( $I_{OL}$ ). The MD0-MD15 lines drive 8 mA  $I_{OL}$ . The enable signal for the latch between the Memory Data bus and the CPU Data bus is controlled by DRD, HLDA and the action codes. This allows 16 bit reads from 8 bit peripherals controlled by the 82C211.









Figure 3.2 Bus Conversion Data Paths

## 3.3.3 Bus Conversion Logic

The 82C215 provides data bus conversion when the 16 bit CPU reads from or writes to 8 bit devices. It also provides bus conversion for Master/DMA cycles. There are six possible cases, as seen in Table 3.1 in conjunction with Figure 3.2. These conversions are controlled by the action codes which are qualified by ACEN from the 82C211.

## 3.3.4 Parity Generation/Detection Logic

For local RAM write cycles, the 82C215 generates even parity for each of the two bytes of the data word. These valid even parity bits are written to the parity bits MP0, MP1 in the local DRAMs. During a local memory read cycle, the 82C215 checks for even parity for each MD byte read. If the parity is detected as being odd, the 82C215 flags a parity error on the PARERR output line to the 82C211. The 82C211 distinguishes between local ROM and RAM cycles before sampling PARERR.

# CHIP5

| AC1 | AC0 Cycle |            | Operation      | Data Path                                                                                                        |  |  |
|-----|-----------|------------|----------------|------------------------------------------------------------------------------------------------------------------|--|--|
| 0   | 0         | CPU        | 16 bit write   | A-B-D-E-F-G and H-J-L-M-N-P                                                                                      |  |  |
| 0   | 0         | CPU        | 8 bit LO write | H-J-L-M-N-P                                                                                                      |  |  |
| 0   | 1         | CPU        | 16 bit read    | G-F-E-D-B-A and P-N-M-L-J-H                                                                                      |  |  |
| 0   | 1         | CPU        | 8 bit LO read  | P-N-M-L-J-H                                                                                                      |  |  |
| 1   | 0         | CPU        | 8 bit HI write | A-B-C-K-L-M-N-P                                                                                                  |  |  |
| 1   | 1         | CPU        | 8 bit HI read  | P-N-M-L-K-C-B-A                                                                                                  |  |  |
| 1   | 0         | DMA/MASTER | 8 bit HI write | P-N-M-L-K-C-D-E-F-G                                                                                              |  |  |
| 1   | 1         | DMA/MASTER | 8 bit HI read  | G-F-E-D-C-K-L-M-N-P                                                                                              |  |  |
|     |           |            |                | and the second |  |  |

## Table 3.1

# 3.4 Absolute Maximum Ratings

| Parameter             | Symbol           | Min. | Max. | Units |  |
|-----------------------|------------------|------|------|-------|--|
| Supply Voltage        | V <sub>cc</sub>  | _    | 7.0  | ٧     |  |
| Input Voltage         | VI               | -0.5 | 5.5  | V     |  |
| Output Voltage        | Vo               | -0.5 | 5.5  | v     |  |
| Operating Temperature | T <sub>OP</sub>  | -25° | 85°  | С     |  |
| Storage Temperature   | T <sub>STG</sub> | -40° | 125° | С     |  |

NOTE: Permanent device damage may occur if Absolute Maximum Ratings are exceeded. Functional operation should be restricted to the conditions described under Operating Conditions.

# 3.5 82C215 Operating Conditions

| Parameter           | Symbol          | Min. | Max. | Units |  |
|---------------------|-----------------|------|------|-------|--|
| Supply Voltage      | V <sub>cc</sub> | 4.75 | 5.25 | V     |  |
| Ambient Temperature | T <sub>A</sub>  | 0°   | 70°  | С     |  |

# 3.6 82C215 DC Characteristics

| Parameter                                                                 | Symbol           | Min. | Max.  | Units |  |
|---------------------------------------------------------------------------|------------------|------|-------|-------|--|
| Input Low Voltage                                                         | V <sub>IL</sub>  | _    | 0.8   | v     |  |
| Input High Voltage                                                        | V <sub>IH</sub>  | 2.0  |       | v     |  |
| Output Low Voltage<br>I <sub>OL</sub> =                                   | V <sub>OL</sub>  | _    | 0.45  | V     |  |
| Output High Voltage<br>I <sub>OH</sub> =                                  | V <sub>OH</sub>  | 2.4  | _     | v     |  |
| Input Current<br>0 <v<sub>IN<v<sub>CC</v<sub></v<sub>                     | I <sub>IL</sub>  | —    | ±10µA |       |  |
| Output Short Circuit Current<br>V <sub>O</sub> = 0V                       | I <sub>OS</sub>  |      |       | mA    |  |
| Input Clamp Voltage                                                       | V <sub>IC</sub>  |      |       | v     |  |
| Power Supply Current @ 16MHz                                              | I <sub>CC</sub>  | _    |       | mA    |  |
| Output High-Z Leakage Current<br>0.45 <v<sub>OUT<v<sub>CC</v<sub></v<sub> | I <sub>OZ1</sub> |      | ±10µA |       |  |

# 3.7 82C215-16 AC Characteristics

 $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%)$ 

| Sym | Description                              | Min. | Typ. | Max. | Units |
|-----|------------------------------------------|------|------|------|-------|
| t1  | MD bus 3-stated after DRD active         | 7.3  |      | 24.9 | ns    |
| t2  | MD bus valid to D bus valid              | 6.3  |      | 15   | ns    |
| t3a | MD bus being driven after DRD inactive   | 7.7  |      | 28.4 | ns    |
| t3b | MP0, MP1 being driven after DRD inactive | 6.3  |      | 23.6 | ns    |
| t4  | D bus invalid after DRD inactive         | 6.0  |      | 21.6 | ns    |
| t5  | D bus 3-stated after DRD inactive        | 6.4  |      | 22.8 | ns    |
| t6  | D bus valid to MD bus valid              | 4.4  |      | 15.3 | ns    |
| t7  | D bus valid to MP1, MP0 valid            | 6.7  |      | 31.4 | ns    |
| t8  | ACEN active to D bus valid               | 8.2  |      | 29.3 | ns    |
| t9  | AC code valid to MD bus valid            | 6.9  |      | 23.5 | ns    |
| t10 | AC code invalid to MD bus invalid        | 3.9  |      | 13.6 | ns    |
| t11 | DLE inactive to PARERR enabled           | 10.8 |      | 38.2 | ns    |
| t12 | DRD inactive to PARERR disabled          | 13.1 |      | 47.7 | ns    |
| t13 | IALE active to XA bus valid              | 6.0  |      | 21.3 | ns    |

# 3.7 82C215-16 AC Characteristics (Continued) (T\_A = 0°C to 70°C, V\_{CC} = 5V $\pm$ 5%)

| Sym | Description                                                                 | Min. | Тур. | Max. | Units |
|-----|-----------------------------------------------------------------------------|------|------|------|-------|
| t14 | XA bus valid to A bus valid                                                 | 4.6  |      | 16.1 | ns    |
| t15 | MD, MP setup time to DLE trailing edge                                      | 0.0  |      |      | ns    |
| t16 | MD, MP hold time from DLE trailing edge                                     | 6.0  |      |      | ns    |
| t17 | DRD setup time to DLE trailing edge                                         | 6.0  |      |      | ns    |
| t18 | DRD hold time from DLE trailing edge                                        | 8.0  |      |      | ns    |
| t19 | MD bus hold time from ACEN trailing edge                                    | 7.0  |      |      | ns    |
| t20 | MD bus valid to MP valid during DMA write during DMA high memory read cycle | 8.8  |      | 31.1 | ns    |
| t21 | MD high byte valid to MD low byte valid during DMA high memory read cycle   | 4.4  |      | 15.3 | ns    |
| t22 | AC code valid to MD high byte valid during DMA high memory write cycle      | 6.4  |      | 22.6 | ns    |
| t23 | AC code valid to MP valid during DMA high<br>memory write cycle             | 10.6 |      | 37.3 | ns    |

# 3.8 82C215 Timing Diagrams



# 3.8 82C215 Timing Diagrams (Continued)



# 3.8 82C215 Timing Diagrams (Continued)





## Load Circuit Measurement Conditions

| Parameter                 | Output Type                     | Symbol                               | C <sub>L</sub> (pF) | <b>R<sub>1</sub> (</b> Ω) | <b>R<sub>L</sub> (Ω)</b> | SW1       | SW2      |
|---------------------------|---------------------------------|--------------------------------------|---------------------|---------------------------|--------------------------|-----------|----------|
| Propagation<br>Delay      | Totem pole<br>3-state           | t <sub>PLH</sub><br>t <sub>PHL</sub> | 50                  |                           | 1.0K                     | OFF       | ON       |
| Time                      | Bidirectional                   | PHL                                  | 00                  |                           | 1.010                    | 011       | 0        |
| Propagation<br>Delay Time | Open drain or<br>Open Collector | t <sub>PLH</sub><br>t <sub>PHL</sub> | 50                  | 0.5K                      |                          | ON        | OFF      |
| Disable Time              | 3-state<br>Bidirectional        | t <sub>PLZ</sub><br>t <sub>PHZ</sub> | 5                   | 0.5K                      | 1.0K                     | ON<br>OFF | ON       |
| Enable Time               | 3-state<br>Bidirectional        | t <sub>PZL</sub><br>t <sub>PZH</sub> | 50                  | 0.5K                      | 1.0K                     | ON<br>OFF | ON<br>ON |







# **100-PIN PLASTIC FLAT PACKAGE**





ALL DIMENSIONS IN MILLIMETERS (INCHES).



# 84-PIN PLASTIC LEADED CHIP CARRIER



# **Ordering Information**

| Order Number        | Package Type |
|---------------------|--------------|
| P82C211/212/215/206 | PLCC-84 pins |
| F82C211/212/215/206 | PFP-100 pins |

#### Note:

1. PLCC = Plastic Leaded Chip Carrier PFP = Plastic Flat Pack

# CHIP5

# CANADA DISTRIBUTORS

Electro Source Inc.

39 Robertson Rd., Ste. 233 The Bell Mews Mall Nepean, Ontario Canada K2H 8R2 Phone: 613-726-1452 Fax: 613-726-8834

## **Electro Source Inc.**

215 Carlingview Drive Suite 303 Rexdale, Ontario Canada M9W 5X8 Phone: 416-675-4490 Telex: 6-989271

## **Electro Source Inc.**

6600 TransCanada Hwy. Suite 510 Pointe Claire, Quebec Canada H9R 4S2 Phone: 514-694-0404 Fax: 514-694-8501

# **U.S. DISTRIBUTORS**

# ALABAMA

## **Quality Components**

4900 University Square Suite 20 Huntsville, AL 35816 Phone: 205-830-1881

## Hall-Mark

4900 Bradford Drive Huntsville, AL 35816 Phone: 205-837-8700

## ARIZONA

## Anthem

1727 East Webber Drive Tempe, AZ 85281 Phone: 602-966-6600

## Hall-Mark

4040 E. Raymond Phoenix, AZ 85040 Phone: 602-437-1200

# CALIFORNIA

Anthem 20640 Bahama Street Chatsworth, CA 91311 Phone: 818-700-1000

#### Anthem

One Oldfield Drive Irvine, CA 92718-2809 Phone: 714-768-4444

#### Anthem

4700 Northgate Boulevard Sacramento, CA 95834 Phone: 916-922-6800

## Anthem

9369 Carroll Park Drive San Diego, CA 92121 Phone: 619-453-9005

## Anthem

10400 East Brokaw San Jose, CA 95131 Phone: 408-295-4200

#### Hall-Mark

8130 Remmet Avenue Canoga Park, CA 91304 Phone: 818-716-7300

#### Hall-Mark

6341 Auburn Blvd., Suite D Citrus Heights, CA 95610 Phone: 916-722-8600

## Hall-Mark

3878 Ruffin Rd., Suite B San Diego, CA 92123 Phone: 619-268-1201

## Hall-Mark

1110 Ringwood Ct. San Jose, CA 95131 Phone: 408-946-0900

Hall-Mark 19220 S. Normandie Avenue Torrance, CA 90502 Phone: 213-217-8400

## Hall-Mark 14831 Franklin Avenue Tustin, CA 92680 Phone: 714-669-4700

## COLORADO

Anthem 8200 South Akron Street Englewood, CO 80112 Phone: 303-790-4500

## Hall-Mark 6950 S. Tucson Way Englewood, CO 80112 Phone: 303-790-1662

#### CONNECTICUT

#### Lionex

170 Research Parkway Meriden, CT 06450 Phone: 203-237-2282

## Hall-Mark

33 Village Lane Wallingford, CT 06492 Phone: 203-269-0100

# FLORIDA

Hall-Mark 15302 Roosevelt Blvd. Suite 303 Clearwater, FL 33520 Phone: 813-530-4543

Hall-Mark 7648 Southland Blvd. Suite 100 Orlando, FL 32809 Phone: 305-855-4020

Hall-Mark 3161 S.W. 15th Street Pompano Beach, FL 33069-4806 Phone: 305-971-9280

Quality Components Florida Phone: 800-241-0037

# GEORGIA

Hall-Mark 6410 Atlantic Blvd. Suite 115 Norcross, GA 30071 Phone: 404-447-8000

Quality Components 6350-F McDonough Drive Norcross, GA 30093 Phone: 404-449-9508

## ILLINOIS

Hall-Mark/N.C. Regional Systems Warehouse 210 Mittel Drive WoodDale, IL 60191 Phone: 312-680-3800

# INDIANA

Hall-Mark 4275 W. 96th Street Indianapolis, IN 46268 Phone: 317-872-8875 800-423-6638 (INDIANA) 800-772-0112 (KENTUCKY)

# CHIP5

## KANSAS

Hall-Mark/Kansas City 10809 Lakeview Drive Lenexa, KS 66215 Phone: 913-888-4747

## MASSACHUSETTS

Hall-Mark

6 Cook Street Bilerica, MA 01821 Boston 617-935-9777 Phone: 617-667-0902

## Lionex

36 Jonspin Road Wilmington, MA 01887 Phone: 617-657-5170

## MARYLAND

Hall-Mark/Baltimore 10240 Old Columbia Road Columbia, MD 21046 Phone: 301-988-9800

## Lionex

9020A Mendenhall Court Columbia, MD 21045 Phone: 301-964-0040

## MINNESOTA

Hall-Mark 10300 Valley View Eden Prairie, MN 55344 Phone: 612-941-2600

## MISSOURI

Hall-Mark/St. Louis 13750 Shoreline Drive Earth City, MO 63045 Phone: 314-291-5350

# NORTH CAROLINA

Hall-Mark 5237 N. Blvd. Raleigh, NC 27604 Phone: 919-872-0712

# **Quality Components**

2940-15 Trawick Road Raleigh, NC 27604 Phone: 919-876-7767

## **NEW JERSEY**

## Lionex

311 Route 46 West Fairfield, NJ 07006 Phone: 201-227-7960 Lionex

311 Route 46 West Fairfield, NJ 07006 Phone: 201-227-7960

Hall-Mark

107 Fairfield Road Ste. 1B Fairfield, NJ 07006 Phone: 201-575-4415

Hall-Mark 1000 Midlantic Drive Mt. Laurel, NJ 08054 Phone: 609-235-1900

Hall-Mark 10 Old Bloomfield Ave. Pinebrook, NJ 07058 Phone: 201-882-9773

## **NEW YORK**

Hall-Mark 101 Comac Loop RonKonKoma, NY 11779 Phone: 516-737-0600

Lionex 400 Oser Avenue Hauppauge, NY 11787 Phone: 516-273-1660

# OHIO

Hall-Mark 5821 Harper Road Solon, OH 44139 Phone: 216-349-4632

Hall-Mark 400 E. Wilson Bridge Road Suite 5 Worthington, OH 43085 Phone: 614-888-3313

## OKLAHOMA

Quality Components 9934 E. 21st Street South Tulsa, OK 74129 Phone: 918-664-8812

# OREGON

Anthem 15812 S.W. Uppert Boones Ferry Road Lake Oswego, OR 97034 Phone: 503-684-2661

## PENNSYLVANIA

Lionex 101 Rock Road Horsham, PA 19044 Phone: 215-443-5150

## TEXAS

Hall-Mark 12211 Technology Blvd. Austin, TX 78727 Phone: 512-258-8848

Hall-Mark 11420 Page Mill Road Dallas, TX 75243 Phone: 214-553-4300

Hall-Mark 8000 Westglen Houston, TX 77063 Phone: 713-781-6100

Quality Components 4257 Kellway Circle Addison, TX 75001 Phone: 214-733-4300

Quality Components 2120-M Braker Lane Austin, TX 78758 Phone: 512-835-0220

Quality Components 1005 Industrial Boulevard Sugar Land, TX 77478 Phone: 713-240-2255

# UTAH

Anthem 1615 West 2200 South Salt Lake City, UT 84119 Phone: 801-973-8555

Hall-Mark 2265 S. 1300 West West Valley, UT 84119 Phone: 801-972-1008

## WASHINGTON

Anthem 5020 148th Avenue N.E. Redmond, WA 98052 Phone: 206-881-0850

## WISCONSIN

Hall-Mark 16255 W. Lincoln Avenue New Berlin, WI 53151 Phone: 414-797-7844

# CHIPS.

# FAR EAST DISTRIBUTORS

# American MITAC

Corporation 3385 Viso Court Santa Clara, CA 95054 U.S.A. Phone: 408-988-0258 Telex: 9103382201 MECTEL Fax: 408-980-9742

## AUSTRALIA

# **R&D Electronics**

4 Florence Street Burwood, Victoria Australia 3125 Phone: 61-3-288 8911 Fax: 61-3-2889168

# HONG KONG

Wong's Kong King Ltd. 8/F Sime Darby Ind. Bldg. 420 Kwun Tong Road Kwun Tong, Hong Kong Phone: 852 3-450121 Telex: 36810 WKKL HX Fax: 852 3-7551128

## ISRAEL

Hitek Ltd. 45, Basel St. TEL-AVIV, ISRAEL Phone: 972 03/457917 Telex: 922361701HTK1

# JAPAN

# ASCII Corporation

SAT-I Bldg., 3F 2-20-4, Minami Aoyama Minato-ku Tokyo 107 Japan Phone: 03-470-0486 Telex: J28764ASCII Fax: 03-470-0522

# KOREA

# Kortronics Enterprises

Rm. 307 9-Dong B-Block #604-1 Guro-Dong, Guro-Gu Seoul, Korea Phone: 82 2 635-1043 Fax: 82 2 675-0514

## SINGAPORE

#### Computer Engineering Systems PTE, Ltd.

73 Ayer Rajah Crescent #02-14/21 Ayer Rajah Industrial Estate Singapore 0513 Phone: 7797377 Telex: RS25223 CESPL Fax: 657787142

## TAIWAN, R.O.C.

Micro Electronic Inc. (Head Office) 8th Fl., 585 Ming Sheng E. Rd. Taipei, Taiwan R.O.C. Phone: 886(02)5018231 Telex: 11942 TAIAUTO Fax: 886-2-5014265

# EUROPEAN DISTRIBUTORS

## BELGIUM

Auriema Belgium S.A./N.V. Rue Brogniezstraat 172-A B-1070 Bruxelles Brussels Phone: (02) 523-62-95 Telex: 21646

## FINLAND

OY Fintronic AB Melkonkatu 24A SF-00210 Helsinki, Finland Phone: 358 06926022 Telex: 857124224 FTRON SF Fax: 358 0 674886

# FRANCE

## A2M

6. Av. du General de Gaulle 78150 Le Chesnay France Phone: 33 39.54.91.13 Telex: 842698376 F Fax: 331 39.54.30.61

## GERMANY

Rein Elektronik GmbH Loetscher Weg 66 Postfach 5160 D-4054 Nettetal 1 West Germany Phone: 49 (02153) 733-0 Telex: 841854203B REIN D (or 854251B REIN D) Fax: 49 02153-733110

## ITALY

## Eledra S.p.A.

Via G. Watt 37 20143 Milano Viale Elvezia 18 Italy Phone: 39 (02) 81.82.1 Telex: 843332332 Fax: 39 (02) 81.82.211

# NETHERLANDS

Auriema Nederland B.V. Doornakkersweg 26 5642 MP Eindhoven Netherlands Phone: 31 (0) 40-816565 Telex: 84451992 Fax: 31 (0) 40-811815

## SPAIN

Compania Electronica de Tecnicas Aplicadas, S.A. (Comelta) (Main Branch) Emilio Munoz, num. 41 nave 1-1-2 28037 Madrid, Spain Phone: 34 754 30 01 Telex: 83142007 CETA E

Compania Electronica de Tecnicas Aplicadas, S.A. (Comelta)

Pedro IV, num. 84-5 planta 08005 Barcelona, Spain Phone: 300 77 12 (8 lineas) Telex: 83151934 CETA E

# CHIPS.

# **SWEDEN (Nordic Countries)**

#### Nordisk Elektronik A.B. (Main Branch) Box 1409

Box 1409 S-171 27 Solna Sweden Phone: 46 08-734 97 70 Fax: 46 08-27 22 04 Telex: 85410547 NORTRON S

## Nordisk Elektronik A/S

P.O. Box 123 Smedsvingen 4 1364 Hvalstad Norway Phone: 47 02 84 62 10 Fax: 47 02 84 65 45 Telex: 85677546 NENASN

## Nordisk Elektronik A/S

Transformervej 17 DK-2730 Herlev Denmark Telex: 85535200 NORDEL DK

## SWITZERLAND

## DataComp

Silbernstrasse 10 CH-9853 Dietikon Switzerland Phone: 41 01 740 51 40 Telex: 827750 DACO Fax: 41 1-7413423

## UNITED KINGDOM

Katakana Limited

Manhattan House Bridge Road Maidenhead, Berkshire SL6 8DB United Kingdom Phone: Maidenhead 44 (0628) 75641 Telex: 846775 KATKAN Fax: 44 (0628) 782812

# CANADA SALES REPRESENTATIVES

## Electro Source Inc.

39 Robertson Rd., Ste. 233 The Bell Mews Mall Nepean, Ontario Canada K2H 8R2 Phone: 613-726-1452 Fax: 613-726-8834

## Electro Source Inc.

215 Carlingview Drive Suite 303 Rexdale, Ontario, Canada M9W 5X8 Phone: 416-675-4490

#### Electro Source Inc.

6600 TransCanada Hwy. Suite 510 Pointe Claire, Quebec Canada H9R 4S2 Phone: 514-694-0404 Fax: 514-694-8501

# REGIONAL SALES OFFICES

#### NORTHEAST REGION: SALES OFFICE

Chips & Technologies, Inc. One Wall Street Burlington Office Park Burlington, MA 01803 Phone: 617-273-3500 Fax: 617-273-5394

## MID-AMERICA REGION: SALES OFFICE

## Chips & Technologies, Inc. 15415 Katy Freeway Suite 209 Houston, TX 77094 Phone: 713-579-9633 Fax: 713-579-9557

## WESTERN REGION: SALES OFFICE

#### Chips & Technologies, Inc. 2055 Gateway Place #220 San Jose, CA 95110 Phone: 408-437-8877

408-437-8877 408-437-0959

## Chips & Technologies, Inc.

18201 Von Karman Ave. Suite 310 Irvine, CA 92715 Phone: 714-852-8721 Fax: 714-852-8912

# CHIP5.

# U.S. SALES REPRESENTATIVES

## ALABAMA

The Novus Group, Inc. 2905 Westcorp Blvd. Suite 120 Huntsville, AL 35805 Phone: 205-534-0044

## ARIZONA

Reptronix 1729 E. McLellan Road Mesa, AZ 85203 Phone: 602-964-2362

Reptronix 450 W. Cool Dr. #325 Tucson, AZ 85704 Phone: 602-297-7569

# CALIFORNIA

Magna Sales 3333 Bowers Avenue Suite 251 Santa Clara, CA 95054 Phone: 408-727-8753

## S.C. Cubed

468 Pensfield Place Suite 101A Thousand Oaks, CA 91360 Phone: 805-496-7307

**S.C. Cubed** 17862 17th St. East Building Suite 207 Tustin, CA 92680 Phone: 714-731-9206

## COLORADO

Wescom Marketing, Inc. 4851 Independence Street Suite 159 Wheat Ridge, CO 80033 Phone: 303-422-8957

## FLORIDA

## **Dyne-A-Mark Corporation**

573 South Duncan Avenue Clearwater, FL 33516 Phone: 813-441-4702 Tampa: 813-223-7969

Dyne-A-Mark Corporation 1001 Northwest 62nd Street Suite 108 Ft. Lauderdale, FL 33309 Phone: 305-771-6501

# GEORGIA

The Novus Group, Inc. 4556 Canda Drive Lilburn, GA 30247 Phone: 404-381-1015

## ILLINOIS

Micro-Tex, Inc. 2400 West Central Road Hoffman Estates, IL 60196 Phone: 312-382-3001

## INDIANA

Giesting & Associates 101 East Carmel Drive Suite 210 Carmel, IN 46032 Phone: 317-844-5222

Giesting & Associates 4407 DeRome Drive Fort Wayne, IN 46815 Phone: 219-486-1912

# MARYLAND

**Micro-Comp, Inc.** 1421 South Caton Ave. Baltimore, MD 21227-1082 Phone: 301-644-5700

## MASSACHUSETTS

Mill-Bern Associates, Inc. 2 Mack Road Woburn, MA 01801 Phone: 617-932-3311

## MICHIGAN

Giesting & Associates 5654 Wendzell Drive Coloma, MI 49038 Phone: 616-468-4200

## **Giesting & Associates**

21999 Farmington Road Suite 400 Farmington Hills, MI 48024 Phone: 313-478-8106

## MINNESOTA

# High Technology Sales Assoc.

11415 Valley View Road Eden Prairie, MN 55344 Phone: 612-944-7274

# **NEW JERSEY**

## T.A.I.

12 South Blackhorse Pike Bellmawr, New Jersey 08031 Phone: NJ: 609-933-2600 PA: 215-627-6615

## NEW MEXICO

## Reptronix

237-C Eubank Blvd. NE Albuquerque, NM 87123 Phone: 505-292-1718

## **NEW YORK**

## ERA, Incorporated

351 Veterans Memorial Hwy. Commack, NY 11725 Phone: 516-543-0510

## L-Mar Associates

349 W. Commercial St. Suite 2285 E. Rochester, NY 14445 Phone: 716-381-9100

## NORTH CAROLINA

The Novus Group, Inc. 5337 Trestlewood Lane Raleigh, NC 27610 Phone: 919-833-7771

# CHIPS.

# ΟΗΙΟ

Giesting & Associates 2854 Blue Rock Road P.O. Box 39398 Cincinnati. OH 45239

# Phone: 513-385-1105 Giesting & Associates 26250 Euclid Avenue Suite 525

Cleveland, OH 44132 Phone: 216-261-9705

# Giesting & Associates

8843 Washington Colony Drive Dayton, OH 45459 Phone: 513-433-5832

## OREGON

L-Squared Limited 15234 NW Greenbrier Pkwy. Beaverton, OR 97006 Phone: 503-629-8555

## PENNSYLVANIA

**Giesting & Associates** 471 Walnut Street Pittsburgh, PA 15238 Phone: 412-963-5832

# TEXAS

OM Sales 13915 Burnet Road Suite 301 Austin, TX 78728 Phone: 512-388-1151

#### **OM Sales**

10500 Richmond Ave. Suite 115 Houston, TX 77042 Phone: 713-789-4426

## **OM** Sales

2323 N. Central Expwy. Suite 150 Richardson, TX 76080 Phone: 214-690-6746

## UTAH

Wescom Marketing, Inc. 3499 S. Main Salt Lake City, UT 84115 Phone: 801-269-0419

#### WASHINGTON

L-Squared Limited 105 Central Way Suite 203 Kirkland, WA 98033 Phone: 206-827-8555

## WISCONSIN

Micro-Tex, Inc. 22660 Broadway Suite 3B Waukesha, WI 53186 Phone: 414-542-5352





# Chips and Technologies, Incorporated

3050 Zanker Road, San Jose, CA 95134 408-434-0600 Telex 272929 CHIP UR

IBM, AT, XT, PS/2, Enhanced Graphics Adapter, Color Graphics Adapter, Monochrome Adapter, IBM Color Display, IBM Monochrome Display are trademarks of International Business Machines. Intel, iAPX 386 are trademarks of Intel Corporation.

MOTOROLA is a trademark of Motorola.

Hercules Graphics is a trademark of Hercules Computer Technology.

Lotus is a trademark of Lotus Corporation.

Microsoft is a trademark of Microsoft.

CHIPSet, CHIPSpak, CHIPSport, SharpScan EGA are trademarks of Chips and Technologies, Inc.

Copyright© 1985, 1986, 1987 Chips and Technologies, Inc.

Chips and Technologies, Inc. makes no warranty for the use of its products and bears no responsibility for any errors which may appear in this document.

Chips and Techonologies, Inc. retains the right to make changes to these specifications at any time without notice.