

WD60C40A

Peripheral Cache

Manager Device



# **TABLE OF CONTENTS**

| Section | Title |                                                                                                          | Page  |
|---------|-------|----------------------------------------------------------------------------------------------------------|-------|
| 1.0     | INTE  |                                                                                                          | 29-1  |
|         | 1.1   | Architectural Description                                                                                | 29-1  |
|         | 1.2   | Features                                                                                                 |       |
|         |       | 1.2.1 Longitudinal Redundancy Checking                                                                   | 29-3  |
|         |       | 1.2.2 Through Parity                                                                                     | 29-3  |
|         |       | 1.2.3 Western Digital Bus Mode                                                                           | 29-3  |
| 2.0     | PIN I | DESCRIPTION                                                                                              | 29-6  |
| 3.0     | NON   | J-CHANNEL REGISTERS                                                                                      | 29-8  |
|         | 3.1   | Option Register                                                                                          |       |
|         |       | 3.1.1 RRC3 thru RRC0 Refresh Rate Count Field                                                            |       |
|         |       | 3.1.2 SRAM Static RAM Mode (Bit 4)                                                                       |       |
|         |       | 3.1.3 CAW1, CAW0 Column Address Width Field (Bits 6,5)                                                   |       |
|         |       | 3.1.4 MPAR Memory Parity Enable (Bit 7)                                                                  | 29-9  |
|         | 3.2   | Option Register 2                                                                                        |       |
|         |       | 3.2.1 AINTE A Channel Interrupt Enable                                                                   | 29-10 |
|         |       | 3.2.2 BINTE B Channel Interrupt Enable                                                                   | 29-10 |
|         |       | 3.2.3 WAITE Wait Enable                                                                                  | 29-10 |
|         |       | 3.2.4 NOWAIT Non-Waitable Microprocessor Interface (Bit 5)                                               | 29-10 |
|         | 3.3   | Master Status Register                                                                                   | 29-11 |
|         |       | 3.3.1 AINTR Channel A Interrupt Request Read Only Bit<br>BINTR Channel B Interrupt Request Read Only Bit | 20-11 |
|         |       | 3.3.2 PPE Processor Parity Error                                                                         |       |
|         |       | 3.3.3 BANR Buffer Access Not Ready Read Only Bit                                                         |       |
|         |       | 3.3.4 PRNR Power Reset Not Ready (Bit 4) Read Only Bit                                                   |       |
|         |       | 3.3.5 DNR Device Not Ready (Bit 7) Read Only Bit                                                         |       |
|         | 3.4   | Buffer Data Latch                                                                                        |       |
|         | 3.5   | Microprocessor Address Pointer                                                                           |       |
|         | 3.6   | Test Address & Status Register                                                                           |       |
|         | 3.7   | Reset and Test Register                                                                                  |       |
|         | •     | 3.7.1 MTPAF Microprocessor to Port A FIFO Test (Bit 0)                                                   |       |
|         |       | 3.7.2 MTPBF Microprocessor to Port B FIFO Test (Bit 1)                                                   |       |
|         |       | 3.7.3 CNTRT Counter Test Mode (Bit 2)                                                                    |       |
|         |       | 3.7.4 TSMEM - Tri-State Memory Interface (Bit 3)                                                         |       |
|         |       | 3.7.5 ARST A Channel Reset (Bit 4)                                                                       |       |
|         |       | 3.7.6 BRST B Channel Reset (Bit 5)                                                                       |       |
|         |       | 3.7.7 SWRST Software Reset (Bit 7)                                                                       |       |
|         | 3.8   | Buffer Access Register                                                                                   |       |
|         | 3.9   | Autoincrement Access Register                                                                            |       |

| Section | Title |         |                                                      | Page    |
|---------|-------|---------|------------------------------------------------------|---------|
| 4.0     | DEVI  | CE CHAN |                                                      |         |
|         | 4.1   | Channel | Timing Register                                      |         |
|         |       | 4.1.1   | SC0(1)A (SC0(1)B) Channel Strobe Control Field       | . 29-17 |
|         |       | 4.1.2   | DLYA (DLYB) Delay Strobe Bit                         | . 29-17 |
|         |       | 4.1.3   | SDTCA (SDTCB) Strobe Deasserted Time Control Bit     | . 29-17 |
|         |       | 4.1.4   | RQPLA (RQPLB) DMA Request Polarity Bit               | . 29-17 |
|         |       | 4.1.5   | DKPLA (DKPLB) DMA Acknowledge Polarity Bit           | . 29-17 |
|         |       | 4.1.6   | PPEA (PPEB) Port Parity Enable Bit                   | . 29-17 |
|         |       | 4.1.7   | LPBMA (LPBMB) Loop Back Mode Enable                  | . 29-17 |
|         | 4.2   | Channel | Control Register                                     | . 29-19 |
|         |       | 4.2.1   | IBEA (IBEB) Interrupt on Busy Bit                    | . 29-19 |
|         |       | 4.2.2   | DIRA (DIRB) Channel Transfer Direction Bit           | . 29-19 |
|         |       | 4.2.3   | PAUSA (PAUSB) Channel Pause Control Bit (Bit 3)      | . 29-20 |
|         |       | 4.2.4   | EDACA (EDACB) EDAC Idle Enable (Bit 4)               | . 29-20 |
|         |       | 4.2.5   | DISKA (DISKB) Disk Type Device (Bit 5)               | . 29-20 |
|         |       |         | BRSTA (BRSTB) Burst Transfer Device (Bit 6)          | . 29-20 |
|         |       |         | SLAVA (SLAVB) Slave Mode Interface (Bit 7)           | . 29-20 |
|         |       | 4.2.6   | 000 DMA Single Cycle Master                          |         |
|         |       | 4.2.7   | 002 DMA Single Cycle Disk                            |         |
|         |       | 4.2.8   | 010 DMA Burst Cycle Master                           | . 29-21 |
|         |       | 4.2.9   | 011 Programmed I/O Mode                              | . 29-22 |
|         |       | 4.2.10  | 100 Single Cycle Slave Mode                          | . 29-22 |
|         |       | 4.2.11  | Unused & Reserved Mode                               | . 29-22 |
|         |       | 4.2.12  | 110 Burst Cycle Slave Mode                           |         |
|         |       | 4.2.13  | 111 Slave Burst Mode Disk                            | . 29-22 |
|         | 4.3   | Channel | Status Register                                      | . 29-23 |
|         |       | 4.3.1   | BSYA (BSYB) Channel Busy Status                      |         |
|         |       | 4.3.2   | VBSYA (VBSYB) Channel Very Busy Status               |         |
|         |       | 4.3.3   | FMTA (FMTB) Channel FIFO Empty Status (Bit 2)        |         |
|         |       | 4.3.4   | PNRA (PNRB) Port Not Ready Status (Bit 3)            |         |
|         |       | 4.3.5   | RQSTA (RQSTB) Channel DRQ Pin Status (Bit 4)         | . 29-23 |
|         |       | 4.3.6   | DKSTA (DKSTB) Channel DACK Pin Status (Bit 5)        |         |
|         | 4.4   | Channel | Interrupt Status Register                            | . 29-24 |
|         |       | 4.4.1   | BSYIA (BSYIB) Interrupt From Busy                    |         |
|         |       | 4.4.2   | VBIA (VBIB) Interrupt From Very Busy                 |         |
|         |       | 4.4.3   | PERRA (PERRB) Channel Parity Error Bit               |         |
|         |       | 4.4.4   | LATEA (LATEB) Channel Data Late Error Bit (Bit 3)    |         |
|         |       | 4.4.5   | REJA (REJB) Channel Command Reject Error Bit (Bit 4) |         |
|         |       | 4.4.6   | IOEA (IOEB) I/O Error Bit (Bit 5)                    |         |
|         |       | 4.4.7   | IOPEA (IOPEB) Programmed I/O Parity Error (Bit 6)    |         |
|         |       |         |                                                      |         |

| Section | Title P                                                                                                                                                                                                                                                                                                                        | age                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| Section | 4.4.8   AERRA (AERRB) Any Error Bit (Bit 7)   29     4.5   Channel Data Latch   29     4.6   Channel Buffer Pointer   29     4.7   Channel Transfer Counter   29     4.8   Channel Start Register   29     4.9   Channel Stop Register   29     4.10   Channel Pointer Capture Register   29     4.11   EDAC Idle Counter   29 | 9-25<br>9-26<br>9-27<br>9-28<br>9-29<br>9-30<br>9-30 |
|         | 4.12 Longitudinal Reduncy Checking Register                                                                                                                                                                                                                                                                                    | Э-31                                                 |
| 5.0     | MICROPROCESSOR INTERFACE                                                                                                                                                                                                                                                                                                       | <del>)</del> -32                                     |
| 6.0     | I/O MEMORY MAP                                                                                                                                                                                                                                                                                                                 | э-зз                                                 |
| 7.0     | INTERRUPTS                                                                                                                                                                                                                                                                                                                     | 9-33                                                 |
| 8.0     | RESET SEQUENCES                                                                                                                                                                                                                                                                                                                | 9-33                                                 |
| 9.0     | READY SEQUENCES AND LATENCIES                                                                                                                                                                                                                                                                                                  | э-34                                                 |
| 10.0    | NON-CHANNEL REGISTERS MAP                                                                                                                                                                                                                                                                                                      | э-35                                                 |
| 11.0    | CHANNEL REGISTERS MAP                                                                                                                                                                                                                                                                                                          | 9-36                                                 |
| 12.0    | ELECTRICAL CHARACTERISTICS                                                                                                                                                                                                                                                                                                     | 9-37                                                 |
| 13.0    | MISCELLANEOUS CHARACTERISTICS                                                                                                                                                                                                                                                                                                  | <del>9</del> -38                                     |
| 14.0    | TIMING SPECIFICATION                                                                                                                                                                                                                                                                                                           | 9-38                                                 |
| 15.0    | PACKAGE DIAGRAMS                                                                                                                                                                                                                                                                                                               | 9-58                                                 |

# LIST OF ILLUSTRATIONS

| Figure | Title                               | Page |
|--------|-------------------------------------|------|
| 1-1    | WD60C40 Block Diagram               |      |
| 1-2    | WD60C40 in 80188 Board Environment  |      |
| 2-1    | 84-Pin PLCC or PQFP Pin Assignments |      |
| 14-1   | Rise/Fall and Miscellaneous Timing  |      |
| 14-2   | PIO Read/Write of External Devices  |      |
| 14-3   | DMA Burst Mode Transfers            |      |
| 14-4   | DMA Single Cycle Mode               |      |
| 14-5   | Bus Master Disk Mode                |      |
| 14-6   | Slave Burst Mode Transfers          |      |
| 14-7   | Slave Single Cycle Transfer         |      |
| 14-8   | Slave Burst Disk Mode (Read)        |      |
| 14-9   | Slave Burst Disk Mode (Write)       |      |
| 14-10  | EDAC Mode (DMA Single Cycle)        |      |
| 14-11  | EDAC Mode (DMA Disk)                |      |
| 14-12  | Miicroprocessor Bus Timing          |      |
| 14-13  | RAS Only Refresh Timing             |      |
| 14-14  | Page Mode Write Timing              |      |
| 14-15  | Page Mode Read Timing               |      |
| 14-16  | Static RAM Write Timing             |      |
| 14-17  | Static RAM Read Timing              |      |
| 15-1   | 84-Pin PLCC Package Dimensions      |      |
| 15-2   | 84-Pin PQFP Package Dimensions      |      |

# LIST OF TABLES

| Table | Title                     | Page    |
|-------|---------------------------|---------|
| 2-1   | Pin Descriptions          | . 29-6  |
| 14-1  | Microprocessor Bus Timing | . 29-52 |

# 1.0 INTRODUCTION

## 1.1 ARCHITECTURAL DESCRIPTION

The WD60C40A peripheral cache manager (PCM) is a custom enhancement of the WD60C40, and is intended to be a drop-in replacement for the latter device. The WD60C40A is fully compatible with the WD60C40 as far as functional and timing requirements are concerned. In addition, the WD60C40A provides three new features: longitudinal redundancy checking (LRC), through parity, and an improved slave burst mode protocol (WD Bus Mode).

The WD60C40A peripheral cache manager (PCM) can control 1 Mbyte of dynamic RAM and the buffering required to allow seemingly simultaneous access of this buffer by three requestors. The three requestors are assumed to be two block-oriented devices and a microprocessor.

The two device interfaces to the dynamic RAM are designed to support block-oriented peripheral formatter chips, such as the WD10C00 Hard Disk Formatter, or block-oriented bus interface chips, such as the WD33C93A SCSI Bus Interface Chip. The implication of block-oriented devices is that the devices do not have the capability of randomly accessing data within the memory array. This restriction allows for the removal of the addressing pins that are normally associated with an interface. The 20-bit address counters that are required to select a byte within the array are now incorporated into the WD60C40A.

The buffer control logic interfaces with an external dynamic RAM array and arbitrates the access into this array from the three external sources. The internal arbitrator in the PCM also includes the refresh logic that is internal to the PCM into its arbitration mechanism.

The dynamic RAM memories do not have the random access bandwidth to sustain multiple highspeed devices. The dynamic RAM memories do incorporate a feature known as "page mode" that increases their bandwidth to the point that they can sustain multiple high-speed devices. The dynamic RAMs have a multiplexed address bus width the address into the array being divided into two parts, a row address and a column address. The dynamic RAMs allow a feature that if the next access into the array is in the same row (same page), then only the column address must be updated from the addressing logic. This scheme carries the penalty that a FIFO must be available to hold the data to/from the pcrt to ensure that it can transfer data in a continuous block when a port gains access to the RAM. The PCM incorporates 16 bytes of FIFO into each of the peripheral ports to support the page mode memory architecture. This scheme has the advantage that the memory bandwidth is increased by a factor of about 75% over the random access bandwidth, allowing a large buffer memory to be mechanized by inexpensive dynamic RAMs, but having the performance characteristics of a static RAM buffer.

The external dynamic RAM buffer may be eight bits or nine bits wide. The depth of the array and the organization of the devices that make up the array are as follows:

| SIZE   | OR | GANIZATION | J                    |
|--------|----|------------|----------------------|
| 16 KB  | 2  | 16Kb x 4   | (+ 64Kb x 1 parity)  |
| 64 KB  | 2  | 64Kb x 4   | (+ 64Kb x 1 parity)  |
| 64 KB  | 8  | 64Kb x 1   | (+ 64Kb x 1 parity)  |
| 256 KB | 2  | 256Kb x 4  | (+ 256Kb x 1 parity) |
| 256 KB | 8  | 256Kb x 1  | (+ 256Kb x 1 parity) |
| 1 MB   | 2  | 1Mb x 4    | (+ 1Mb x 1 parity)   |
| 1 MB   | 8  | 1Mb x 1    | (+ 1Mb x 1 parity)   |

Note: The use of static RAM is possible with additional logic.

In the following description, refer to Figure 1, the block diagram of the WD60C40A, and to the example board environment in Figure 2. A typical situation to use as an example of the actions within the part is that of a disk controller. In this example, port 'B' of the device is connected to a bus interface controller (ex. WD33C93A), and port 'A' of the device is connected to a disk interface controller (ex. WD10C00).

The example begins with the assumption that all devices are currently active, the refresh time has arrived, and the microprocessor is requesting a data item. The PCM is currently servicing the FIFO that is attached to the device port 'A'. The microprocessor is currently at a wait bus cycle because of the RDY signal from the PCM being inactive. The PCM moves data to/from the memory and the port 'A' FIFO until the FIFO is full/empty, or the transfer counter of port 'A' is exhausted. If during this sequence, the PCM detects that a dynamic RAM page boundary is

being crossed, the PCM will update the row address, and continue the page mode transfer. While this action is occuring, any byte transfers to/from the other device port are stored in that device port's FIFO. When port 'A' has finished its data transfers, the PCM first services the host data request, then the refresh request(s), both of which have priority over block transfers. The PCM then initiates transfer between the port 'B' FIFO, and the dynamic RAMs.

The PCMs priority system when arbitrating is:

- microprocessor requests
- refresh requests
- the higher priority peripheral channel
- the lower priority peripheral channel

The control of the peripheral channel priority is under firmware control if the channels are peers in their capability of sustaining a pause in their transfers. If a channel is programmed as 'nonpausible', and the other channel is 'pausible' then this channel is given priority in the arbitration mechanism, regardless of the other firmware priority controls. If the channels are peers, such as both being 'pausible' or both being 'nonpausible', then the priority of the channels is controlled by firmware selecting one of the channels as higher priority through option register 2. See also the descriptions of the AHI bit in option register 2, and PAUS bits in the channel control register.

Note that arbitration does not occur until the requestor currently being serviced has completed its entire burst. This means that page mode bursts between the channels and memory are not interrupted by requests from higher priority requestors. There are two exceptions to this general rule. The first exception is a non-pausible device that is selected by firmware as having higher arbiter priority. This channel is then allowed an "urgent request", when its FIFO is almost exhausted. This "urgent request" will send a false end of transfer signal through the other port and cause arbitration to occur, and this channel will then win arbitration if the single cycle devices are not requesting. This is done to minimize the occurence of over/underrun errors in high priority non-pausible devices. The second exception that causes a burst to be halted is for a refresh burst. The refresh request occurs at regular intervals (see option register section for specific details), but if it is not serviced because of a channel burst, then the request is

queued into a counter. When four refresh cycles have been queued (about 60  $\mu$ sec.), then the "urgent request" mechanism will force arbitration, and a burst of four refresh cycles will be performed. This is done to maintain memory data integrity.

The programmable features of the internal logic allow the controller firmware to control and "tune" the actions of the PCM. The PCM needs know if the devices are capable of being throttled. Most devices that attach to peripherals have minimum data buffering, so the port logic must be programmed to look for overrun/underrun situations when the FIFO is full/empty. Some devices that attach to busses or other peripherals that have variable data rates, are capable of being 'stalled' when the FIFO is full/empty, and the port logic is capable of holding the port until the FIFO is ready.

The PCM also implements a "pipelined" pointer mechanism that allows the programmer to set the pointer (buffer address) of the current device transfer, and if required, set the pointer of the next transfer, while the current transfer is taking place. This address is held in the address pointer holding register to be automatically transferred to the address pointer at the end of the current transfer. If the next transfer's buffer is contiguous with the current transfer's buffer, then the address pointer "pipeline" need not be loaded, and when the next transfer begins the address pointer will continue from its current position. This address is therefore only necessary if the next transfer is at a memory address that is not contiguous with the end of the current transfer. The transfer counter is always loaded from the transfer counter holding register at the start of a new block transfer, but the transfer counter holding register need only be reloaded if the block size of a transfer needs to be changed. When the current transfer finishes, the firmware can be interrupted, while the hardware continues directly into the next transfer. With this mechanism, the firmware now has a block time to determine what is to be done when this transfer finishes, rather than doing this during the interblock gap times. If pipelined (ie. continuous) transfers are required, then microprocessor action is required whenever the pipeline becomes empty. If the next transfer is the same size as the current, and contiguous in address, then the firmware need only issue a new channel start command. Alternatively, the firmware can load new values into the "pipeline" registers before issuing the



start, and dynamically control the transfer size and buffer location. The firmware can poll the status or wait for an interrupt (if enabled) to indicate that the holding registers are available.

The device channels are mechanized with eight or nine data lines, and five control/handshake lines. Four control signals are programmable to allow interfaceing to multiple types of device controller chips. Features such as the master/slave relationships between the PCM and the external peripheral controller, the polarity and timing of the signals that do the handshake, input/output control direction, and the mode that the control lines emulate are all programmable.

## 1.2 FEATURES

- 5 Volt only operational power.
- 1.25 micron CMOS for low power consumption.
- 84 pin PLCC or 84-pin PQFP packages.
- Supports dynamic memory configurations from 16 KB to 1 MB.
- · Supports static memory configurations.
- Supports parity on the memory array.
- · Supports parity on peripheral ports.
- Supports parity pass-through (parity is passed through a device with the data and not regenerated at the device's outputs).
- Supports longitudinal redundancy checking (LRC) on peripheral ports and FIFOs.
- Aggregate memory bandwidth of greater than 9.0 Mbytes/sec, using industry standard 100 ns. dynamic RAMs.
- · Supports two peripheral channels.
- High Speed Channels support peripheral data rates of:
  - 6.25 Mbytes/sec as bus master with 25 MHz input clock, the maximum data rate is input clock divided by 4.
  - 10.0 Mbytes/sec as bus slave, with 25 MHZ input clock, the maximum data rate is input clock divided by 2.5.
- Programmable configuration of device channel interface.
- Internal FIFOs on peripheral channels.

- Supports independant transfers on both peripheral ports and microprocessor simultaneously.
- Large memory allows peripheral controllers to be implemented that "decouple" the host and disk transfer rates, maintaining 1:1 disk interleave regardless of host transfer rate.
- Provides "minimum chip count" solution for mechanizing a peripheral cache controller.
- Supports high-speed microprocessor bus cycles, such as Intel\* 80186 or 80188 processors running at 12.5 MHz (no wait state required when accessing the PCM registers).

#### 1.2.1 Longitudinal Redundancy Checking

Both channels must operate as the bus master when using the LRC feature. LRC generation and checking takes place between the channel data bus input and output buffers and the channel FIFO. The LRC calculations do not include the parity bit. Refer to Section 4.12 for more information.

#### 1.2.2 Through Parity

Parity is passed through the chip with the data and not regenerated at the chip's output. This makes it possible to chain "send status" in the WD33C93A.

#### 1.2.3 Western Digital Bus Mode

The slave burst DMA protocol is modified in order to use the pipelining capability of the WD60C40A with the SBIC. As the WD60C40A nears the end of a burst, it switches to a single-byte transfer protocol to avoid over/under-flowing the FIFO. In the old implementation, the WD60C40 waits to deassert DRQ when both DACK and the \_RD or \_WR strobe is asserted. This may result in the SBIC sending two bytes instead of just one. The WD60C40 will be confused if the SBIC sends two bytes on the last request. The new implementation fixes this by having the WD60C40A deassert DRQ upon the assertion of DACK, thus guaranteeing that the SBIC sends only one byte.





INTRODUCTION

 $\otimes$ 

INTRODUCTION

WD60C40A



 $\otimes$ 

05/07/91

29-5

9

## 2.0 PIN DESCRIPTION

| PIN NUMBER                              | MNEMONIC                  | SIGNAL NAME                     | I/O              |
|-----------------------------------------|---------------------------|---------------------------------|------------------|
| 1,22,30,43,<br>56,64                    | Vcc                       | +5 Volt power supply connection | I                |
| 2,11,21,23,<br>29,42,44,57,<br>63,65,75 | GND                       | Ground power supply connection  | Ι                |
| 3 thru 10                               | AD0 thru AD7              | μP ADDRESS/DATA BUS             | I/O              |
| 12 thru 19                              | DBB0 thru<br>DBB7         | DEVICE BUS B DATA               | I/O              |
| 20                                      | DBBP                      | DEVICE BUS B PARITY BIT         | I/O              |
| 24                                      | CSB                       | CHANNEL SELECT B                | 0                |
| 25                                      | DRQB                      | DEVICE PORT B CYCLE REQUEST     | I/O <sup>1</sup> |
| 26                                      | DACKB                     | DEVICE PORT B CYCLE ACKNOWLEDGE | I/O <sup>2</sup> |
| 27                                      | BRD                       | DEVICE PORT B READ STROBE       | I/O              |
| 28                                      | BWR                       | DEVICE PORT B WRITE STROBE      | I/O              |
| 31 thru 38                              | RB7 thru RB0              | DYNAMIC RAM DATA BUS            | I/O              |
| 39                                      | RBP                       | DYNAMIC RAM PARITY BIT          | I/O              |
| 40                                      | W/WE                      | DYNAMIC RAM WRITE/STATIC RAM WE | 0                |
| 41                                      | CAS/OE                    | DYNAMIC RAM CAS/STATUS RAM OE   | 0                |
| 45                                      | RAS                       | RAM ROW ADDRESS STROBE          | 0                |
| 46 thru 55                              | BA0 <sup>3</sup> thru BA9 | RAM ADDRESS BUS <sup>3</sup>    | 0                |
| 58                                      | AWR                       | DEVICE PORT A WRITE STROBE      | I/O              |
| 59                                      | ARD                       | DEVICE PORT A READ STROBE       | I/O              |
| 60                                      | DACKA                     | DEVICE PORT A CYCLE ACKNOWLEGE  | I/O <sup>2</sup> |
| 61                                      | DRQA                      | DEVICE PORT A CYCLE REQUEST     | I/O <sup>1</sup> |
| 62                                      | CSA                       | CHANNEL SELECT A                | 0                |
| 66                                      | DBAP                      | DEVICE BUS A PARITY BIT         | I/O              |
| 67 thru 74                              | DBA7 thru<br>DBA0         | DEVICE BUS A DATA BUS           | I/O              |
| 76                                      | CLK                       | CLOCK                           | I                |
| 77                                      | RST                       | RESET                           | 1                |
| 78                                      | CS                        | up BUS CHIP SELECT              | I                |
| 79                                      | WR                        | μP BUS WRITE CYCLE STROBE       | <u> </u>         |
| 80                                      | RD                        | μΡ BUS READ CYCLE STROBE        | I                |
| 81                                      | ALE                       | μP ADDRESS STROBE               | I                |
| 82                                      | PINT                      | μP INTERRUPT REQUEST            | O <sup>4</sup>   |
| 83                                      | RDY                       | μΡ WAIT CONTROL                 | O <sup>4</sup>   |
| 84                                      | RBIAS <sup>5</sup>        | RESISTOR BIAS <sup>5</sup>      |                  |

#### NOTES:

1 I = WD60C40A bus master mode. O = WD60C40A bus slave mode

2 I = WD60C40A bus slave mode. O = WD60C40A bus master mode.

3 BA0 is the LSB.

4 Open drain output

## **TABLE 2-1. PIN DESCRIPTIONS**



FIGURE 2-1. 84-PIN PLCC OR PQFP PIN ASSIGNMENTS

29

## 3.0 NON-CHANNEL REGISTERS

The PCM was intended for use with the Intel 80186 processor and as such has been designed to interface easily with the 16-bit data bus of that processor. This is not to say that it cannot easily attach to other 8-bit or 16-bit microprocessors like Intel 8085, 8051, or 8096. The main requirement is that it be supplied with a multiplexed address/data bus with A7 to A0 multiplexed with D7 to D0 in that order.

As the PCM has only an eight bit data bus and it was decided not to handle the BHE signal, there are certain characteristics of the PCM that need explaining. First, all internal registers appear on even and the following odd byte address. This is because address signal A0 is not used inside of the PCM. The order of the registers was also arranged so that they appear in the order that they would normally be programmed. This allows the PCM to be attached to the 80186 and string move operations used to allow the fastest possible handling of loading the PCM.

Finally, the registers associated with the operation of the PCM itself do not decode the signal A7 so that they appear in both halves of the register map, facilitating an easier modulization of the driving firmware. Only the even addresses of the registers will be shown. Refer to pages 10 through 35 for a summary of all the non-channel registers.

#### 3.1.1 RRC3 Through RRC0 Refresh Rate Count Field

The refresh rate count field indicates to the PCM the prescale count to use for determing the refresh rate of the dynamic RAMs. The value of the refresh rate count field is effectively multiplied by 32, then subtracted from 512 to determine the number of clocks that will occur between refresh cycles. The value of this field is dependent upon the frequency of the PCMs clock. The following table shows the relationship of clock frequency, and refresh rate count field values, to produce 15.6 microsecond refresh cycles (for standard 128 cycle 2 ms. dynamic RAMs).

| Field<br>Value | Cycle<br>Count | Freq. Range <sup>1</sup><br>Low High |      | Refresh li<br>Low I | ntrvl <sup>2</sup><br>High |
|----------------|----------------|--------------------------------------|------|---------------------|----------------------------|
| 12             | 128            | 8.2                                  | 10.2 | 15.6                | 12.5                       |
| 11             | 160            | 10.4                                 | 12.2 | 15.4                | 13.1                       |
| 10             | 192            | 12.4                                 | 14.2 | 15.5                | 13.5                       |
| 9              | 224            | 14.4                                 | 16.4 | 15.6                | 13.7                       |
| 8              | 256            | 16.6                                 | 18.4 | 15.4                | 13.9                       |
| 7              | 288            | 18.6                                 | 20.4 | 15.5                | 14.1                       |
| 6              | 320            | 20.6                                 | 22.4 | 15.5                | 14.3                       |
| 5              | 352            | 22.6                                 | 24.4 | 15.6                | 14.4                       |

<sup>2</sup> Refresh intervals are in µs.

NOTE:

The other field values are valid but are unlikely to be useful to the customer

## 3.1 OPTION REGISTER

| ddress = 6<br>Read/write r |      |      |      |      |      |      |      |
|----------------------------|------|------|------|------|------|------|------|
| 7                          | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| MPAR                       | CAW1 | CAW0 | SRAM | RRC3 | RRC2 | RRC1 | RRC0 |

The option register is a read/write only register to the firmware. The bits represent settings of options that must be selected to match the board design. There is the facility to read option switches and allow the firmware to ascertain the hardware configuration in user 'adjustable' implementations. This register should be the first written after a reset sequence, and should not be written to thereafter unless another reset sequence has occurred.

## 3.1.2 SRAM Static Ram Mode (bit 4)

The Static Ram Mode bit informs the PCM that the memory array is composed of static RAMs. When the bit is set, the PCM is in static RAM mode. This changes the signals that the PCM uses to access the memory array. Because of the multiplexed address bus of dynamic RAMs, it will be necessary for an external latch to be added to demultiplex the address lines. In addition, external address decoding will be necessary to expand the

RAM to the full addressable capability. To assist in this, two of the RAM control signals change when the static RAM bit is set. First, the RAS signal is used to control the external latch that is to demultiplex the address, when a valid row address is available on BA8 to BA0. RAS is intended to drive the clock input of a 74F373 type octal D-type latch, there is a direct analogy to the operation of dynamic RAMs at this point, with the exception that the row address latch is external to the memory devices. Secondly, static RAMs also have different read and write characteristics to dynamic RAMs. In dynamic mode, the W signal, signals the RAMs that a write cycle is about to occur, with the actual write action being generated by the falling edge of the CAS signal. This is known as early write mode. A read would occur if the CAS signal went active (low) with the W signal inactive (high). In static mode, the W and CAS signals change to support the separate WE and OE signals of static RAMs. In static mode, the CAS becomes the OE signal, still being active low but it will only occur on RAM read cycles, having the same shape and timing as for dynamic RAM cycles. The W signal becomes the WE signal, still being active low and only occuring in write cycles, but of a shape and timing similar to the CAS/OE signal. Finally, the arbitration logic no longer receives refresh requests as the static RAMs require no refresh, of course. At this stage it should be noted that the static RAM configuration is still liable to the row change overhead, when a row boundary is crossed during a burst of data cycles between the peripheral port FIFO and the memorv.

The PCM is initialized to a special state at power up to ensure that there is no activity on the RAM control pins. This feature is used in the "power start" of the dynamic RAMs, which need to be left for a minimum time after power up. Please refer to the "Reset Sequences" section of this document for a description.

## 3.1.3 CAW1, CAW0 Column Address Width Field (bits 6,5)

The column address width field informs the PCM the type of RAM array that it is dealing with. The PCM uses the field to control the address multiplexer to the RAMs, and to determine the page mode boundaries of the RAMs. When a new page is detected, then the PCM executes a new RAS cycle, RAS goes inactive to precharge the RAS signal and then RAS goes active to latch the new row address and establish access in the new RAM page.

This field has no affect if the SRAM bit (bit 4) is set. When the SRAM mode is in effect, the PCM is forced to the ten bit column address mode.

00 = 10-bit column address (1meg DRAM). Bits 19 - 10 are the output on BA9 - BA0 during RAS time. Bits 9 - 0 are the output on BA9 - BA0 during CAS time.

01 = 9-bit column address (256K DRAM). Bits 18 - 9 are the output on BA9 - BA0 during RAS time. Bits 8 - 0 are the output on BA8 - BA0 during CAS time.

10 = 8-bit column address (64K DRAM). Bits 17 - 8 are the output on BA9 - BA0 during RAS time. Bits 7 - 0 are the output on BA7 - BA0 during CAS time.

11 = 6-bit column address (16K DRAM). Bits 15 - 6 are the output on BA9 - BA0 during RAS time. Bits 5 - 0 are the output on BA5 - BA0 during CAS time.

## 3.1.4 MPAR = Memory Parity Enable (bit 7)

The parity enable bit informs the PCM that the memory array has a parity bit attached. When the bit is set, the PCM generates odd parity (the sum of all one bits including the parity bit will be an odd number) on memory writes, and checks parity on memory reads. If there is even parity on a memory read, the PCM will cause a parity error interrupt in the appropriate status register. When the bit is reset, the PCM will not generate parity on a write, or check parity on a read. The microprocessor firmware can use this bit to test the parity logic of the PCM, when there is parity memory. When the parity enable bit is reset, the RBP pin of the PCM will be at a logic one level during a write cycle.

## 3.2 OPTION REGISTER 2

| ead/write re<br>he option re |   | initialized to zer | ro by the PCN | l reset sequ | ence |       |       |
|------------------------------|---|--------------------|---------------|--------------|------|-------|-------|
| 7                            | 6 | 5                  | 4             | 3            | 2    | 1     | 0     |
| •                            | 0 | NOWAIT             | WAITE         | AHI          | INTE | BINTE | AINTE |

#### 3.2.1 AINTE A Channel Interrupt Enable

The A channel interrupt enable bit allows interrupts from the "A" peripheral channel to exit the PCM by way of the PINT pin. This allows the programmer the capability to selectively disable interrupts from this channel while still allowing PCM interrupts from the other PCM resources. This bit only affects the transmission of the channels interrupt to the PINT pin, and does not affect the operation of any of the channels interrupt enables, or interrupt status flags.

| 'A' CHANNEL  | 'B' CHANNEL  |                  | AHI<br>PRIORITY |
|--------------|--------------|------------------|-----------------|
| Non-pausible | Pausible     | $\mathbf{X}^{j}$ | A Channel       |
| Pausible     | Non-pausible | х                | B Channel       |
| Non-pausible | Non-pausible | 1                | A Channel       |
| Non-pausible | Non-pausible | 0                | B Channel       |
| Pausible     | Pausible     | 1                | A Channel       |

#### 3.2.2 BINTE B Channel Interrupt Enable

This bit performs the same function as AINTE, but for the "B" channel.

## 3.2.3 WAITE Wait Enable

This bit is the master enable for any PCM wait condition to exit the PCM by the RDY pin. This allows the programmer the capability to selectively disable the RDY pin from the PCM. This bit only affects the transmission of the wait to the RDY pin, and does not affect the operation of any of the PCM wait sequences, or status.

#### 3.2.4 NOWAT Non-waitable Microprocessor Interface (bit 5)

The "non-waitable" bit is used to distinguish to the PCM that the microprocessor or board design does not support the RDY function to extend bus cycles. This bit controls how the PCM performs accesses to the data buffer and programmed I/O to the peripheral ports. This bit is reset by the PCM reset sequence.

When this bit is a zero, the PCM is to be used in a board with multiple devices sharing the microprocessor ready signal. The internal "ready" status of the PCM is gated with the CS signal, so only when the PCM is selected does it drive RDY. When the microprocessor accesses the data buffer or the peripherals for programmed I/O, the PCM asserts RDY low to halt the bus cycle until it can perform the access. The PCM uses the leading edge of the data strobe to trigger the access, and if the firmware is writing data, then there is a specified time from the leading edge of the strobe that write data must become available within. When the access is complete, the PCM deasserts the RDY signal and allows the bus cycle to finish.

When this bit is a one, the PCM is used in a configuration with a microprocessor that does not support wait states, and the RDY signal is normally used as a status signal to a microprocessor's PIO input pin and polled by the firmware, or the internal status of the RDY pin is polled through the PCM task file register. In this configuration, the PCM does not gate the CS signal with the internal RDY status, so the RDY status is available continuously. The PCM uses the trailing edge of the strobe to trigger the access, and as such there is no timing requirement on the write data from leading edge of strobe.

## 3.3 MASTER STATUS REGISTER

| Address = 64<br>Read/write re |   |   |      |      |     |       |       |
|-------------------------------|---|---|------|------|-----|-------|-------|
| 7                             | 6 | 5 | 4    | 3    | 2   | 1     | 0     |
| DNR                           | 0 | 0 | PRNR | BANR | PPE | BINTR | AINTR |

#### 3.3.1 AINTR Channel A Interrupt Request Read Only Bit BINTR Channel B Interrupt Request Read Only Bit

Setting AINTR (BINTR) indicates that the channel detected a situation requiring microprocessor action. The normal use of the interrupt is that the channel has completed an operation. The interrupt bit does not indicate if the operation was completed successfully, or if it terminated because of an error. The channel interrupt bit for each channel resets when the microprocessor clears all the interrupting states in the particular channel status register. This bit represents the 'or' function of all the interrupt conditions in the channel.

## 3.3.2 **PPE Processor Parity Error**

The processor parity error bit is set when a buffer read operation from the microprocessor interface resulted in a parity error. The bit is reset by the writing a one to the PPE bit. Writing a zero to PPE does not affect this bit.

#### 3.3.3 BANR Buffer Access Not Ready Read Only Bit

The PCM "buffer access not ready" status bit is used to signal the microprocessor that the PCM is currently performing an access of the buffer and the registers that are associated with the buffer are not available. When the access is complete, this bit will be reset. See also the "DNR" bit in the master status register.

#### 3.3.4 PRNR Power Reset Not Ready (bit 4) Read Only Bit

The PCM "power reset not ready" status bit is used to signal the microprocessor that the PCM is currently performing a power on reset sequence, or a programmed reset sequence, and all registers in the PCM except this register are not available. When the reset sequence is complete, this bit will be reset. See also the "DNR" bit in the master status register.

#### 3.3.5 DNR Device Not Ready (Bit 7) Read Only Bit

The PCM "device not ready" status bit is used to signal the microprocessor that the PCM is currently performing a task that does not allow access to some resource in the PCM. The bit is essentially a logical 'or' of four conditions in the device that require multiple clock times to resolve themselves. The conditions are:

- the buffer manager reset sequence
- the microprocessor access of the buffer memory
- the microprocessor access of either of the peripheral ports for programmed I/O.

When the power is applied to the PCM, or firmware issues a soft reset, the bit sets indicating that all internal registers except this registerare inaccessable. This bit will then reset when the PCM has completed its reset sequence. The "PRNR" bit in the master status register will also reflect this condition.

When the microprocessor accesses either of the peripheral ports for programmed I/O, or the microprocessor accesses the data buffer, the "device not ready" will reflect the status of the RDY pin of the PCM. This feature allows the firmware to 'poll' the PCM during these accesses when the board design or the microprocessor does not support the RDY function in hardware. The three accesses that cause this bit go to true are all independent, and can be occuring simultaneously. Because of the 'or' mechanism the bit will be false only when all accesses have completed.



When the microprocessor interface does support the RDY function, then there is no need to check this bit after the PCM has completed its reset sequence. When this bit is set because of RDY, the microprocessor is still in a wait state while the specific access is performed, and when the microprocessor is released from the wait state, then this bit is known to be reset.

## 3.4 BUFFER DATA LATCH

| Address = 68<br>Read/write re |      |      |      |      |      |      |      |
|-------------------------------|------|------|------|------|------|------|------|
| 7                             | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| BDL7                          | BDL6 | BDL5 | BDL4 | BDL3 | BDL2 | BDL1 | BDL0 |
| BUL/                          | BDLO | BDL5 | BDL4 | BDL3 | BULZ |      |      |

The buffer data latch register holds the data last transferred between the microprocessor and buffer. The register is in the task file address space, so access of the register does not cause RDY to go false (no wait states). Access of the buffer data latch not cause the triggering of a buffer access. The register is used when the board or microprocessor does not support the RDY function in hardware. Refer to the buffer access register description for specific details of the interaction of this register and the Buffer Access Register. The register is also useful for diagnostic purposes to test the PCM internal data path between the microprocessor and the internal task file.

## 3.5 MICROPROCESSOR ADDRESS POINTER

|           |      | r    |       |      |      |         | [    |
|-----------|------|------|-------|------|------|---------|------|
| 7         | 6    | 5    | 4     | 3    | 2    | 1       | 0    |
| _         | 0    | 0    | 0     | MP19 | MP18 | MP17    | MP16 |
| 0         | 0    | 0    | 0     |      |      | 1411 17 |      |
| 0<br>MP15 | MP14 | MP13 | MPM12 | MP11 | MP10 | MP09    | MP08 |

#### MP19 through MP00 Microprocessor Address Pointer

The Microprocessor Address Pointer is a 20-bit register/counter that supplies the address lines to the buffer memory when the microprocessor is requesting a buffer data access. These registers

may be read or written when the "BANR" bit in the master status register is reset, to show or set the current RAM window. If the microprocessor accesses the buffer through the Autoincrement Access Register, then this pointer will increment after the access has been performed.

## 3.6 TEST ADDRESS AND STATUS REGISTER

| ad/write r | 8H or F8H<br>egister |      |      |      |      |      |      |
|------------|----------------------|------|------|------|------|------|------|
| 7          | 6                    | 5    | 4    | 3    | 2    | 1    | 0    |
| TAS7       | TAS6                 | TAS5 | TAS4 | TAS3 | TAS2 | TAS1 | TAS0 |

The Test Address and Status register is a window into the internal logic of the PCM to allow greater visibility of the internal functioning of the device, and therefor greater test comprehensiveness.

The PMC contains an address register that can be loaded when a microprocessor write to the Test Address and Status Register occurs. This allows the selection of several internal registers and counters, and state machine registers, and the subsequent display of their content by reading this location.

This location also interacts with the Reset and Test register to invoke the test functions. Specifically there is an interlock so that test mode is more difficult to invoke, and less prone to be enabled accidently. The sequence to enable test mode is to write 80H to this register when all the test bits in the Reset and Test register are zero. This must be followed with a write to the Reset and Test register with the selected test mode (the soft reset bit must be zero). Then write F0H to this register. Once this procedure has been executed, then write the test address to this location, and read this location to view the desired internal status. When test mode is invoked, the only way to restore normal operation is to issue a soft reset, or assert the RST pin.

## 3.7 RESET AND TEST REGISTER

| Address = 7AI<br>Write only reg |   |      |      |       |       |       |       |
|---------------------------------|---|------|------|-------|-------|-------|-------|
| 7                               | 6 | 5    | 4    | 3     | 2     | 1     | 0     |
| SWRST                           | 0 | BRST | ARST | TSMEM | CNTRT | MTPBF | MTPAF |

The Reset and test register allows a software reset of the PCM device. It is important that, during the normal operation, the value written to this register is 80H. This register is also used for setting test modes and a value in this register other than 80H causes the PCM to behave unpredictably to the user. The actions that occur when the register is written with 80H are identical to those that occur during power up, and the reset sequences that are described in the reset sequences section. This register is register is initialized to 00H when either the reset input pin (RST) is asserted, or the software reset function is invoked.

#### 3.7.1 MTPAF Microprocessor to Port A FIFO Test (bit 0)

The microprocessor to port A FIFO test is used to verify the integrity of the internal data paths from/to the port FIFO, and to allow testing of the FIFO data cells. When this bit is set, the memory controller sets the data path from the memory side of the port FIFO to the buffer access register in the microprocessor section. The port should be in loopback mode, and when the microprocessor writes or reads the buffer access register the data will be transferred from/to the port FIFO instead of the external memory. Specifically, if the port has the DIR bit set so that data is to go from memory to the peripheral, then the microprocessor would write to the buffer access register, and the data would be read back from the FIFO through the channel data latch in loop back mode. The reverse direction has the microprocessor writing to the channel data latch, and reading the resultant data in the buffer access register.

#### 3.7.2 MTPBF Microprocessor to Port B FIFO Test (bit 1)

This is identical to bit 0 but uses the B channel.

## 3.7.3 CNTRT Counter Test Mode (bit 2)

When this bit is set, the 16 and 20 bit counters will be divided along 4 bit boundaries, and the carry input to these boundaries will be forced true. The example is of the Buffer Address Pointer, if it is initially set to 12345H, when an access through the autoincrement access register is made, the counter will contain as its next value 23456H. The counters affected by this bit are:

- port A address pointer
- port A transfer counter
- port A EDAC idle counter
- port B address pointer
- · port B transfer counter
- port B EDAC idle counter
- buffer address pointer
- refresh address counter.

# 3.7.4 TSMEM Tristate Memory Interface (bit 3)

When this bit is set the control signals to the memory interface are forced to a tristate mode, to allow testing of the memory devices by an external test machine.

## 3.7.5 ARST A Channel Reset (bit 4)

When written with a one causes the 'A' Channel to receive a reset. This reset does not affect the memory controller, or the other peripheral channel. The reset is removed when a zero is written into the bit, or a PCM reset sequence is initiated. When a channel is receiving a reset it will have its PNRA bit in its Channel Status Register set.

## 3.7.6 BRST B Channel Reset (bit 5)

This is identical to bit 4 but resets the 'B' Channel.

## 3.7.7 SWRST Software Reset (bit 7)

When written with a one causes initiation of the PCM reset sequence. This bit is self resetting when the PCM completes the reset sequence (denoted by the PRNR bit in the master status register being cleared), and initiates the PCM reset sequence on the trailing edge of the write strobe of this register.

#### 3.8 BUFFER ACCESS REGISTER

| ead/write r | egister |      |      |      |      |      |      |
|-------------|---------|------|------|------|------|------|------|
| 7           | 6       | 5    | 4    | 3    | 2    | 1    | 0    |
| BAR7        | BAR6    | BAR5 | BAR4 | BAR3 | BAR2 | BAR1 | BAR0 |

The Buffer Access Register is the window that the microprocessor uses to load/store data to/from the buffer memory. The microprocessor address pointer supplies the address to/from which the RAM transfer will be made.

When the microprocessor and board design support the RDY function in hardware, (the NOWAT bit is zero), then this register passes the data through to/from the microprocessor and buffer. The leading edge of the microprocessors read or write strobe causes a "not ready" signal to the microprocessor, holding this state until memory arbitration and the actual data transfer has been accomplished. When the transfer is complete by RDY going true, then the cycle will end and the task is complete. There is no need of the buffer data latch when using the PCM in this mode.

In the case where the RDY function is not supported in the hardware, (the NOWAT bit is one), then the firmware must perform a program sequence to complete a transfer. If the microprocessor is writing data to the buffer, then it will write to this register and data will be latched along with the fact it is a write. The trailing edge of the strobe will cause the PCM to request arbitration for the buffer. The firmware is free at this time to perform other tasks, or poll the "DNR" status bit or the "BANR" in the Master Status Register, or poll the PCM RDY pin. When the access is complete then "not ready" will go false, and the firmware is again allowed to access the buffer.

If the microprocessor desires to read the buffer, then it must first read this register and discard the data. This action is only used to initiate the arbiter request, and latch the fact it is a read access. The trailing edge of the strobe will cause the buffer access to initiate. When the "not ready" condition goes false, then the data that was fetched is available in this register, and also in the Buffer Data Latch. Note that reading the Buffer Data Latch does not cause a "not ready" condition, or perform another access of the buffer, where if data is read from this register then another access will be initiated.

#### 3.9 AUTOINCREMENT ACCESS REGISTER

| ad/write r | egister |      |      |      |      |      |      |
|------------|---------|------|------|------|------|------|------|
| 7          | 6       | 5    | 4    | 3    | 2    | 1    | 0    |
| BAR7       | BAR6    | BAR5 | BAR4 | BAR3 | BAR2 | BAR1 | BAR0 |

The autoincrement data register performs the identical function of the buffer access register with the added feature that at the end of the data transaction, the microprocessor address pointer increments to the next address.

If the firmware desires to read or write a small block of data in the buffer, then access through this register will simplify the programming sequence. When the PCM is in the "waitable" microprocessor mode, then firmware need only continuously read or write data through this register. The transfer of data to/from the buffer occurs while the microprocessor is in a wait state. and the incrementing of the Microprocessor Address Pointer occurs in the intervening time between consecutive microprocessor bus cycles. If the PCM is in the "non-waitable" microprocessor mode, then firmware must poll the "not ready" status between accesses of this register. In this mode when reading a string of bytes from the buffer, if the last byte is accessed from this register, then another buffer access will occur, and the address pointer will be incremented. If this is not desired, then the last byte read from the buffer should be read from the buffer data latch instead of from this register.

The autoincrement access register is intended for use when small blocks of data are to be moved to/from the buffer while both ports are transferring data. If a large amount of data is to be moved to/from the microprocessor it is suggested that one of the ports be used in loopback mode, to achieve the maximum data transfer rate.

# 4.0 DEVICE CHANNELS

|      | ddress = C0l<br>egister - not p |      |      |      |     |     |     |
|------|---------------------------------|------|------|------|-----|-----|-----|
| 7    | 6                               | 5    | 4    | 3    | 2   | 1   | 0   |
| LPBM | PPE                             | DKPI | ROPL | SDTC | DLY | SC1 | SC0 |

**NOTE** There is an A or B appended to each bit name corresponding to the appropriate channel.

There are two device channels that the PCM controls. The channel registers are independent and identical across the two channels. Within the PCM the channels appear as 64-byte memory spaces in the chips total address space of 256 bytes. The channels are referred to as A, and B, with channel A being the 64 bytes of address space from 00H to 3FH, channel B being the 64 bytes of address space from 80H to BFH. Because the devices attached to the channels get their address lines (if necessary) directly from the microprocessor bus the even only address characteristic of the internal registers does not apply.

The registers that control the channels, are in the 32 bytes of address space that immediately follow the respective channels address space. The registers for channel A are in the address space of 40H to 5FH. The registers for channel B are in the address space of C0H to DFH. As these registers are internal, the odd addresses in the channel's respective address blocks are just a ghost image of the registers at the even addresses.

When the controller firmware accesses a register that controls a channel, the microprocessor will not have to wait for access, because these registers are all within the PCM chip, and are always available for immediate access. When the controller firmware accesses a register in a device on a channel, the PCM must evaluate the state and mode of the channel to determine if access of the register is possible. If the PCM is the bus master, then it will arbitrate the access of the channel, and will insert wait states for the microprocessor. The number of wait states for this access is dependent upon both the strobe timing of the channel, and the arbitration time of the channel. If the PCM is in slave mode it will not attempt the access but cause an I/O error interrupt and status to occur.

The channels function is to allow access between a peripheral device and the data buffer. The characteristics of any transfer have both fixed and variable components. The fixed components are associated with the peripheral device and the hardware that will perform the transfer. These components are set at the beginning of the total transfer, and do not vary for the duration of the transfer. The variable components of the transfer are associated with the data buffer itself, and the arrangement of data, and the firmware control of the data. The fixed components are not 'pipelined', and are set by firmware at the start of a (group of) transfer(s).

The channel 'pipeline' mechanism allows firmware to control the data buffer on the fly. In applications where the firmware is attempting to either control a ring buffer or a cache, the mechanism allows the firmware to 'look ahead' to its next operation.

The registers have been organized in the order in which they would normally be programmed. It is especially important to ensure that the timing register is set up before the control register.

## 4.1 CHANNEL TIMING REGISTER

The channel timing register is used to control hardware actions that occur during a transfer to the external device. The action the register performs is that of controlling the pulse timing on the channel when the PCM is the bus master. This allows peripheral devices of various timing characteristics to be interfaced to the PCM. The register also defines to the channel logic specific characteristics of the external peripheral device, such as its handshake signal polarities, and parity capability. The firmware is only allowed to write to the channel timing register when the channel is idle. The channel state machine will set the I/O error bit in the channel interrupt status register if the channel timing register is written while the channel is busy.

All bits in the register are cleared by the reset sequence.

#### 4.1.1 SC0(1)A (SC0(1)B) Channel Strobe Control Field

The channel strobe control field is a two bit field that is used to control the width of the read and write strobes to the peripheral devices when the channel is in modes where the PCM is the bus master (DMA), or when doing PIO operations. The width of the strobes is programmable by setting the field. When the PCM is doing DMA cycles, for values of 0,1,2,3 the strobes will be 2,4,6,8 clocks wide respectively. When the PCM is doing PIO cycles, for values of 0,1,2,3 the strobes will be 4,6,8,10 clocks wide respectively.

## 4.1.2 DLYA (DLYB) Delay Strobe Bit

Normally, the  $\overline{CS}$  and  $\underline{DACK}$  signals go active two PCM clock before the RD or WR signals. When this bit is set, this period is extended by 2 PCM clocks. The primary use of this feature is for external decoding logic if multiple peripheral devices exist on the channel.

#### 4.1.3 SDTCA (SDTCB) Strobe Deasserted Time Control Bit

This bit is relevant when the PCM is the bus master and in burst data transfer mode, then this bit is used to control the time that the RD and WR signals are deasserted. When this bit is zero, the RD and WR strobes will be deasserted for two PCM clocks during a data burst. When this bit is one, the RD and WR signals will be deasserted for 4 PCM clocks during a data burst.

#### 4.1.4 RQPLA (RQPLB) DMA Request Polarity Bit

This bit controls the polarity of the PCM port DRQ pin. When this bit is set the PCM will consider the DRQ pin as active high. This is true whether this pin is receiving the request when the PCM is bus master or transmitting the request when the PCM is bus slave.

#### 4.1.5 DKPLA (DKPLB) DMA Acknowledge Polarity Bit

This bit controls the polarity of the PCM port DACK pin. When this bit is set, the PCM will consider the DACK pin as active high. This is true whether this pin is transmitting the acknowledge when the PCM is bus master or receiving the acknowledge when the PCM is bus slave. Note that both the above situations occur when EDAC redundancy byte counting is enabled.

## 4.1.6 PPEA (PPEB) Port Parity Enable Bit

The device port can be optionally set to check the parity on transfers to the PCM from the peripheral device. Odd parity is supported and is generated when this bit is set. When this bit is set, all reads (data going into PCM) of the device channel by the PCM (either as master or slave) will result in parity checking being done, and interrupts being generated if even parity is detected. It should be noted that **ALL** transfers, including programmed I/O, are checked if this bit is set. When the PPE bit is reset, the port parity bit will be at a logic one level when data is transferring from the PCM to the peripheral device.

#### 4.1.7 LPBMA (LPBMB) Loop Back Mode Enable

The purpose of this bit is to enable the microprocessor to use the FIFO to speed block transfers between the microprocessor and the buffer RAM. When set, this bit paths the channel data latch to the FIFO. It inactivates the outputs of the channel (CS, DACK, DRQ, WR, RD, and data bus). The microprocessor will appear to the channel as an external device and the channel will appear as if in slave mode. More explicitly the loopback mode sets the channel to a state of a non-pausible slave mode. In this state the microprocessor can transfer data to/from the FIFO at its maximum speed with the channel monitoring the FIFO for overrun/underrun conditions. The channel mode bits in the Channel Control Register need not be changed, but the Direction, and Interrupt Enable bits need to be programmed as if programming for an external transfer. In all other channel registers programming is as if for a normal external transfer, with the normal pipeline mechanisms in operation. Note the Direction bit in the Channel Control Register still needs to reflect the direction of transfer to/from an external device. As such the direction bit is SET for a transfer from the buffer to microprocessor (similar to a peripheral write command), though the microprocessor issues READ cycles to access the FIFO data.

## 4.2 CHANNEL CONTROL REGISTER

|   | Address = C2H<br>register - not p |   |   |   |   |   |   |
|---|-----------------------------------|---|---|---|---|---|---|
|   |                                   |   |   | • |   |   |   |
| 7 | 6                                 | 5 | 4 | 3 | 2 | 1 | 0 |

NOTE. There is an A or B appended to to each bit name corresponding to the appropriate channel

Where the Timing Control Register sets the physical environment of the interface with the external device, the Channel Control Register sets the logical environment of the interface. The register contains two types of parameters about the transfer being programmed. The high order five bits are used to identify the logical protocol that the PCM is going to use to interface to the external device. The low three bits are used to set a firmware environment to control the manbagement of the transfer direction and interrupts desired.

The firmware is only allowed to write to the channel control register when the channel is idle. The channel state machine will set the I/O error bit in the channel interrupt status register if the channel control register is written while the channel is busy.

Whenever the firmware writes to the channel control register, the PCM will take 10 PCM clocks to synchronize the action to the PCM clock, and advance the channels status. During this time the firmware can only access non-channel registers.

The register is initalized to A8H by the rest sequence.

## 4.2.1 IBEA (IBEB) Interrupt on Busy Bit

The busy interrupt bit indicates to the channel that the microprocessor desires an interrupt when the channel very busy status bit transitions from a one to a zero.

#### 4.2.2 DIRA (DIRB) Channel Transfer Direction Bit

The channel transfer direction bit is used to inform the PCM the direction of the transfer of this channel. The PCM uses this information to determine the read/write control of the buffer. When the transfer direction bit is a zero, the device is transferring data to the buffer (device read mode, buffer write mode). When the transfer direction bit is a one, the device is transferring data from the buffer (device write mode, buffer read mode).

The transfer direction bit is used by the channel logic to position the transfer counter, and the input of the FIFO to the source of the data. When the direction bit is a zero, (data transfer from the peripheral to the buffer), the transfer counter is monitoring the device handshake signals, and the count reflects the number of bytes that remain to be transferred from the peripheral device, to the input of the FIFO. When the transfer count exhausts and the FIFO goes empty, the logic will signal the end of this transfer if EDAC mode is not in effect. If EDAC mode is in effect, the channel will monitor the DACK pin to count EDAC trans fers, and when the EDAC idle counter exhausts and the FIFO is empty, it will signal the end of this transfer.

When the direction bit is a one, (data transfer from the buffer to the peripheral), the transfer counter is monitoring the buffer signals, and the count reflects the number of bytes that remain to be transferred from the buffer to the input of the

FIFO. When the transfer count exhausts and the FIFO goes empty, the logic will signal the end of this transfer if EDAC mode is not in effect. If EDAC mode is in effect when the FIFO goes empty, the channel will monitor the DACK pin to count EDAC transfers, and when the EDAC idle counter exhausts it will signal the end of this transfer.

#### 4.2.3 PAUSA (PAUSB) Channel Pause Control Bit (bit 3)

The bit is used by the memory arbiter. When this port is pausible (this bit set), and the other port is non-pausible (this bit reset), then the other port will have higher priority in the memory arbiter. If this bit is set the same in both channel control registers, then priority is determined by the "AHI" bit in the option 2 register.

This bit enables the "urgent request" logic. Because it controls priority, if the highest priority port's FIFO is near to overrun/underrun condition, then an "urgent request" is sent to the arbiter to stop the other port's burst and force arbitration.

# 4.2.4 EDACA (EDACB) EDAC Idle Enable (bit 4)

The EDAC Idle Enable bit is used to allow the port interface to share control of the peripheral bus with the WD60C80 EDAC device. The EDAC (Error Detection And Correction) is used in disk applications to append redundancy information to data blocks to allow error correction. The bit when set will allow the PCM to strip this information and not transfer it to the buffer on reads, and to allow the EDAC to append the information to the device data on writes. The EDAC bit is only relevant when the channel is programmed to be a bus master. The Channel EDAC Idle Counter contains a count of the number of redundancy bytes to ignore between data transfers. When this bit is set the transfer counter must be programmed for a single block size. When the transfer count exhausts the channel will tristate the DACK pin and begin to count DACK pulses until the EDAC idle counter exhausts. While the EDAC idle counter is enabled, no transfers are allowed between the port and the FIFO (the redundancy bytes transfer between peripheral and the EDAC device). When the EDAC idle count exhausts the channel will then continue normal pipeline operations if the firmware has programmed them.

#### 4.2.5 DISKA (DISKB) Disk Type Device (bit 5); BRSTA (BRSTB) Burst Transfer Device (bit 6); SLAVA (SLAVB) Slave Mode Interface (bit 7)

These three bits are used collectively to define to the port logic the type of peripheral device it will interface with, and the protocol to use with the interface signals. The signals will be described as per their individual significance, and then their collective significance. The names are derived from relationships they assume when the bit is set.

The SLAVE bit is used to instruct the channel that the external device is the bus master, and as such will control the WR and RD interface signals. When the bit is zero, the PCM is the bus master and controls the  $\overline{WR}$  and  $\overline{RD}$  signals. The master/slave relationship controls whether the PCM has the capability of performing programmed I/O on the external bus. When the microprocessor attempts to do programmed I/O and the channel is in a master and non-disk mode, the channel will arbitrate the external bus and interleave the programmed I/O with the DMA transfers the external device is requesting. When the channel is in slave mode, programmed I/O is rejected. If the microprocessor attempts programmed I/O an I/O error interrupt and status are asserted.

The BURST bit defines to the channel that the multiple bytes may be transferred between the external device and the FIFO with a single iteration of the protocol pins (DRQ and DACK). When the bit is a zero then SINGLE cycle mode, where an iteration of the protocol pins result in a single byte being transferred. The DISK bit defines to the channel that the external device is a disk formatter device, and causes the protocol pins to maintain a different protocol than the normal REQUEST and ACKNOW-LEDGE. When the bit is a zero then the normal DRQ and DACK protocol is enforced. Programmed I/O is inhibited when in a disk mode.

In the following text the three bits are grouped with the ordering of SLAVA (SLAVB), BRSTA (BRSTB), and DISKA (DISKB).

## 4.2.6 000 DMA Single Cycle Master

In this mode, the DRQ pin is the data request and is an input, the DACK pin is the data acknowledge and an output. In this mode, the PCM is con sidered to be the bus master, and the peripheral chip is the bus slave. The peripheral device uses the DACK signal to gualify the data strobes from the PCM. The WR pin is a low true output pin from the PCM, and is active when the PCM is programmed with a channel transfer direction bit set, and the peripheral device has requested service. The WR signal is used to clock data from the PCM to the peripheral device. The RD pin is a low true output pin from the PCM, and is active when the PCM is programmed with a channel transfer direction bit cleared, and the peripheral device has requested service. The RD signal is used to clock data from the peripheral device to the PCM. The PCM will also use the WR and RD signals when the microprocessor requests programmed input/output of the peripheral device. At this time, the PCM will output the chip select signal to the peripheral device. The timing of the WR and RD signals is programmed in the timing control register of the channel.

In the Single Cycle DMA mode, the PCM will cycle the DACK signal for each byte transferred. The peripheral device can use the DACK signal to deassert its DRQ. This mode is designed to interface with older DMA style peripherals that interfaced with the Intel 8237 DMA chip. This mode will only transfer a byte when the channel FIFO is capable, therefore it is implied that overrun/underrun detection is the responsibility of the peripheral device. The channel will continue to transfer data if a parity error is detected, with the channel counters being captured at the time the error is detected. This mode is compatible with the EDAC device, and supports interleave of programmed I/O through the port and the DMA transfers.

#### 4.2.7 001 DMA Single Cycle Disk

This mode is specifically for the ADS10C00 Disk Formatter Chip. The interface is the same as the DMA Single Cycle Master mode, in that the peripheral device requests service with the DRQ signal, and the PCM which is the bus master acknowledges the request with the DACK signal. The timing of the DACK signal is modified for the ADS10C00 requirements, with the leading edge of the DACK being returned asynchronously in response to the DRQ, and the data and trailing edge occuring synchronous to the PCM clock. In the DMA single cycle disk mode the WR and RD signals are not used. Instead the direction of data transfer is known to both the external device, and the PCM device, so the direction strobes are not required. In this mode the DACK signal is all that is required, as it acts both as an acknowledgement of data transfer, but also as the timing strobe. In this mode the PCM will attempt to transfer a byte on demand from the external device. If the channel FIFO becomes empty or full when another byte transfer is to take place, the channel will latch the data late occurance, and capture the channel counters for the firmware. The transfer will continue until the current transfer count is exhausted. If a parity error is detected during the transfer, the parity error status is latched along with the channel counters, and the transfer continues until the transfer counter exhausts. Since the ADS10C00 device supplies a seperate port for programmed I/O, then programmed I/O through the PCM port is not allowed in this mode. This mode is compatible with the EDAC device.

## 4.2.8 010 DMA Burst Cycle Master

This mode, tuned for the WD33C93 device, is the same as the DMA Single Cycle Master with the exception that at the end of the data strobe (either WR or RD) the DRQ signal is sampled, and if it is still active and the channel FIFO is capable of transferring another byte, the channel logic will keep the DACK signal asserted, and proceed to transfer another byte of data. This burst sequence will continue until either the external device deasserts DRQ, or the channel FIFO becomes unable to transfer another byte, or the microprocessor has requested a programmed I/O cycle on the external bus. The channel will continue to transfer data if a parity error is detected. This mode allows the highest data rate of the PCM bus master modes, but also requires the bus slave to deassert the DRQ in the shortest amount of time.

When the PCM is programmed for strobe timing of 2 PCM clocks (SC1A(B), SC0A(B) = 00), and strobe deassert time of 2 PCM clocks (SDTCA(B) = 0) then the PCM is capable of transferring data at 1/4 the PCM clock rate. This yields a transfer rate of 6.25 Mbytes per second with a 25 MHz clock to the PCM. (**DRQ deassertion time needs** to be strictly followed to guarantee reliable operation.) Since the DACK signal does not change for multiple byte bursts, this mode is incompatible with the EDAC device.

## 4.2.9 011 Programmed I/O Mode

This mode is used to allow programmed I/O to occur to slave devices. Since it is a master mode then programmed I/O is enabled, but since it does not specify one of the specified interface protocols of bus masters, then it will not perform any peripheral transfers, and the DACK output will remain inactive at all times. When programmed I/O is to occur in a slave such as the WD50C1X configuration, then the firmware will set this mode while programmed I/O is to occur, and set the slave mode again after the programmed I/O is complete. Note that for DMA Single Cycle Master mode, and DMA Burst Cycle Master mode, that programmed I/O requests are interleaved with the data transfers, and there is no need to set Programmed I/O mode to do programmed I/O.

## 4.2.10 100 Single Cycle Slave Mode

The Single Cycle Slave Mode is similar to the DMA Single Cycle Master Mode, with the sense of the master/slave relationship reversed. In this mode the PCM is assumed to be attached to a host system bus as a DMA slave device. In this mode the sense of the DRQ and the DACK pins are reversed, in that the PCM makes the DRQ pin an output, and requests data from the bus master, and the DACK pin is used by the bus master to signal the PCM that the data transaction is to take place. In this mode it is the responsibility of the bus master to drive the data strobe lines during a data transaction. This configuration is targeted for the XT\* environment, and the interface is consistent with the protocol of the Intel 8237 DMA chip. when programmed as it is in that environment.

## 4.2.11 101 Unused and Reserved Mode

#### 4.2.12 110 Burst Cycle Slave Mode

This mode is similar to the Single Cycle Slave Mode, with the exception that the PCM will not deassert the DRQ output signal unless the FIFO does not have the capability of accepting another byte of data.

#### 4.2.13 111 Slave Burst Mode Disk

In this mode, the connotation of the DRQ pin and the DACK pin change. The PCM is considered to be the bus slave, and the peripheral device is considered to be the bus master. The DRQ pin in this mode becomes an input, and monitors the BDRQ of the peripheral device. The DACK pin in this mode becomes an output, and signals the peripheral device when the peripheral device can continue with its next burst of data. For this discussion, the DACK pin will be referred to as BRDY. The WR pin and the RD pin in this mode are driven by the external bus master, the disk formatter. The protocol of the DRQ and BRDY signals is meant to accomodate the WD50C1X series of disk formatter devices. If the disk formatter is reading the disk then it will transfer a sectors worth data to the FIFO and set DRQ active. It will then wait for the PCM to assert BRDY to indicate that it can proceed with the next sector transfer. If the PCM exhausts its transfer count, and the pipeline register is empty, the PCM will not assert BRDY until the channel pointers have been set for the next transfer. If the PCM has not exhausted its transfer count, or continues in a pipeline operation, then it will send BRDY to the disk formatter to let it proceed with its transfer. If the disk formatter is writing to the disk, it will assert DRQ at the start of the transfer, and wait for BRDY. The PCM will assert BRDY when the channel is started and data is available in the FIFO. At the end of the sector transfer the disk formatter will again signal with DRQ if it desires to continue. If the PCM has the proper conditions to allow the next transfer it will again send BRDY. When programmed I/O is to occur to the WD50C1X device, the firmware must first set the channels mode to master for programmed I/O, then perform the programmed I/O, then return to this mode before starting the channel. If an error occurs (either parity error or data late error) during the transfer of data, the PCM will latch the errorstatus, and the channel counters. When the disk formatter again sends BDRQ the PCM will not send the BRDY signal, effectively halting the disk formatter from proceeding. The user can



handle the error condition in one of two ways. The user can issue a stop to the channel, and clear the error, then restart the channel which will then allow the disk formatter to proceed when it sees BRDY. The user can supply external hardware to allow the firmware to reset the disk formatter, as the formatter chip is known to be in a state where write gate is not being asserted.

## 4.3 CHANNEL STATUS REGISTER

|            | ddress = C4 | ιH   |      |     |     |      |     |
|------------|-------------|------|------|-----|-----|------|-----|
| ad only re | egister     |      |      |     |     |      |     |
| 7          | 6           | 5    | 4    | 3   | 2   | 1    | 0   |
| 0          | 0           | DKST | RQST | PNR | FMT | VBSY | BSY |

NOTE: There is an A or B appended to each bit name corresponding to the appropriate channel.

## 4.3.1 BSYA (BSYB) Channel Busy Status

The channel is currently engaged in a transfer.

# 4.3.2 VBSYA (VBSYB) Channel Very Busy Status

Specifically, this status bit indicates that the pipeline registers cannot be written into. One reason these registers are not available is because the channel is currently engaged in a transfer, and the pipeline registers of the transfer counter and the buffer pointers are currently loaded with the values of the next transfer. The two status bits inform the firmware the state of the channel. When the two bits are both false, then the channel is currently idle, and the firmware can load the buffer pointer and transfer counter, and initiate an operation on the device. When the busy status is set, but the very busy status is false, the channel is in the busy state. In this state the pipeline registers are available for the firmware to load the values of the next transfer. When the firmware loads the pipeline registers and issues the start channel pulse, the channel will show very busy status. This status is the very busy state and indicates to the firmware that the channel is not available for any new pointers.

#### 4.3.3 FMTA (FMTB) Channel FIFO Empty Status (Bit 2)

Indicates the current status of the channel FIFO.

# 4.3.4 PNRA (PNRB) Port Not Ready Status (Bit 3)

The PCM "port not ready" status bit is used to signal the microprocessor that the PCM is currently performing a programmed I/O access of the peripheral, and the registers that are associated with the channels programmed I/O are not available. When the access is complete, this bit will be reset. See also the "DNR" bit in the master status register. This bit is also set if the channel is currently receiving a reset.

#### 4.3.5 RQSTA (RQSTB) Channel DRQ Pin Status (Bit 4)

In order to allow the firmware to poll the state of devices while the channel is in slave mode, the state of the channel's DRQ pin is available on this bit. The DRQ is an input which has programmable polarity. This bit DOES NOT show the actual level of the DRQ pin but rather the logical state; set if DRQ is active, and reset if DRQ is inactive.

#### 4.3.6 DKSTA (DKSTB) Channel DACK Pin Status (bit 5)

Indicates the logical state of the channel DACK pin.

## 4.4 CHANNEL INTERRUPT STATUS REGISTER

|   | Address = C6H<br>vrite/clear bits |     |     |      |      |     |      |
|---|-----------------------------------|-----|-----|------|------|-----|------|
| 7 | 6                                 | 5   | 4   | 3    | 2    | 1   | 0    |
|   | IOPE                              | IOE | REJ | LATE | PERR | VBI | BSYI |

## 4.4.1 BSYIA (BSYIB) Interrupt From Busy

This status bit will be set when the busy interrupt bit in the channels control register (bit 0) is set, and the channel busy status bit transi tions from a one to a zero (the channel state transitions from busy to idle). This bit is cleared when a one is written to it.

## 4.4.2 VBIA (VBIB) Interrupt From Very Busy

This status bit will be set when the very busy interrupt bit in the channels control register (bit 1) is set, and the channel very busy status bit transitions from a one to a zero (the channel state transitions from very busy to busy). This bit is cleared when a one is written to it.

#### 4.4.3 PERRA (PERRB) Channel Parity Error Bit

The channel parity error bit indicates to the firmware that the channel detected a parity error during a read of data either from the dynamic RAMs, or from the peripheral device. When the channel detects a parity error, it will interrupt the microprocessor, set the channel parity error flag. The transfer will continue until the end of the current block, at which time the PCM will wait for the firmware to clear the error and restart transfers.

When the transfer direction is from the buffer to the peripheral then the error occurred in the memory, and the firmware can determine the location of the parity error by reading the current value of the channel pointer, which was captured at the time of the error. When the transfer direction is from the peripheral device to the buffer, then the error occurred on the channel external interface, and the transfer counter will determine the exact byte in error. This bit is cleared when a one is written to it.

#### 4.4.4 LATEA (LATEB) Channel Data Late Error Bit (bit 3)

The channel data late error bit indicates to the firmware that the channel detected a data overrun/underrun error during a transfer of data to/from the channel FIFO. When the channel detects a data late error, it will interrupt the microprocessor, set the channel data late error status. The detection of the overrun/underrun condition is disabled by the channels pause bit being set. This bit is cleared when a one is written to it.

#### 4.4.5 REJA (REJB) Channel Command Reject Error Bit (bit 4)

The channel command reject error bit indicates to the firmware that there was an attempt to start a transfer when the channel had very busy status bit set, or without clearing the channel after an error. When the channel detects this condition it will interrupt the microprocessor, and set the command reject status. The transfer will not be affected. When the current transfer finishes the channel will not perform the next transfer in the pipeline because it is assumed that the pipeline register was corrupted previous to the erroneous start. No transfer will be initiated by the erroneous start command. This bit is cleared when a one is written to it.

#### 4.4.6 IOEA (IOEB) I/O Error Bit (bit 5)

The channel I/O error bit indicates to the firmware that there was an attempt to do a programmed I/O cycle to a channel that was in slave mode, or the channel control register was written while the channel was busy. The I/O error does not halt a transfer in progress, or corrupt an external transfer. The status indicates to the microprocessor that the previous programmed I/O transaction did not transfer valid data, or the load of the channel control register did not take place. This bit is cleared when a one is written to it.

#### 4.4.7 IOPEA (IOPEB) Programmed I/O Parity Error (bit 6)

The channel programmed I/O parity error bit indicates to the firmware that a parity error occurred during a programmed I/O read of the peripheral device. The detection of a programmed I/O parity error does not affect a transfer in progress if the programmed I/O cycle was interleaved with device data transfers in either the DMA Single Cycle Master mode, or the DMA Burst Cycle Master mode. This bit is cleared when a one is written to it.

## 4.4.8 AERRA (AERRB) Any Error Bit (bit 7)

The Any Error status bit is a read only bit, and is the logical 'or' of the five error status bits. It is provided for convenience to the firmware to easily determine if the previous operation was successful.

#### 4.5 CHANNEL DATA LATCH

| Channel B A | ddress = C8H |      | ,    |      |      |      | Channel A Address = 48H<br>Channel B Address = C8H<br>Read / write register |  |  |  |  |  |  |  |  |  |
|-------------|--------------|------|------|------|------|------|-----------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 7           | 6            | 5    | 4    | 3    | 2    | 1    | 0                                                                           |  |  |  |  |  |  |  |  |  |
| CDL7        | CDL6         | CDL5 | CDL4 | CDL3 | CDL2 | CDL1 | CDL0                                                                        |  |  |  |  |  |  |  |  |  |

**NOTE** There is an A or B appended to each bit name corresponding to the appropriate channel

The Channel Data Latch holds the data associated with 3 different functions performed on the channel. The access of the register does not cause a wait condition.

The first function is that of the "Reset Status Latch." When the PCM is reset either by power being applied, or by writing into the PCM reset register, the PCM samples the channel bus and saves the data in the channel data latch for the firmware. The intent is that the board designer will install passive resistor networks that allow option jumper status to be reflected on the channel bus at reset time. There is an assumption here that the external device will tristate the channel data bus bits during the power reset condition. With the PCM and the external device both tristate, a resistor through an option jumper to either V<sub>CC</sub> or GND will passively pull the data line to the desired signal level. The PCM will latch the state of the data bus lines at the end of its reset sequence, so there is a minimum of 5  $\mu$ s plus 16 PCM clocks for the resistor to pull the signal to an acceptable level. The value of the resistor is dereived from the reset sequence time, and the capacitance of the data lines. The maximum resistor value should be used to reduce the DC and AC loading of the data lines. Since the channel data latch is used for other functions, it is a requirement of the firmware that if the reset status is to be savbed, that the firmware must read the channel data latch and save it in its local memory before attempting either programmed I/O to/from the external device, or to put the channel in loopback mode.

The second function of the channel data latch is for the loopback mode of the channel. In the loopback mode the microprocessor will read data from this latch, and write data to the latch without wait states. The channel logic will transfer the data between the latch and the FIFO, and check for overrun conditions. See also the "LPBMA" ("LPBMB") bit in the Channel Timing Register.

The third function is that of the port programmed I/O data latch. When the "RDY" function is supported in hardware, then programmed I/O proceeds through the normal address space reserved for external peripheral I/O. The leading edge of the microprocessors read or write strobe causes a "not ready" signal to the microprocessor, holding this state until arbitration for the peripheral port and the actual data transfer has been accomplished. When the transfer is complete by RDY going true, then the cycle will end and the task is complete. In this case this register is not used, though it still performs its intended function of capturing the programmed I/O data to/from the peripheral.

In the case where the RDY function is not supported in the hardware, then the firmware must perform a program sequence to complete a transfer. If the microprocessor is writing data to the port, then it will write to the programmed I/O data space, and data will be latched along with the fact it is a write. The trailing edge of the strobe will cause the PCM to request arbitration for the channel. The firmware is free at this time to perform other tasks, or poll the "DNR" status bit or the "PNRA" ("PNRB") in the Channel Status Register, or poll the PCM RDY pin. When the access is complete then "not ready" will go false, and the firmware is again allowed to access the channel for programmed I/O.

If the microprocessor desires to read the channel, then it must first read from the programmed I/O data space, and discard the data. This action is only used to initiate the arbiter request, and latch the fact it is a read access. The trailing edge of the strobe will cause the buffer access to initiate. When the "not ready" condition goes false, then the data that was fetched is available in this register, and also in the programmed I/O data space. If the data is then read from the programmed I/O data space, then another

programmed I/O cycle will be initiated, while if the data is read from this register, another programmed I/O access will not take place.

#### CHANNEL BUFFER POINTER 4.6

| Channel A A<br>Channel A A<br>Channel B A<br>Channel B A | ddress = 4CH<br>ddress = 4AH<br>ddress = CE<br>ddress = CC<br>ddress = CA | H (BP19 - BP <sup>-</sup><br>H (BP15 - BP(<br>H (BP07 - BP(<br>H (BP19 - BP<br>H (BP19 - BP<br>H (BP15 - BP<br>H (BP07 - BP<br>H (BP07 - BP | 08)<br>00)<br>16)<br>08) |      |      |      |      |
|----------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------|------|------|------|
| 7                                                        | 6                                                                         | 5                                                                                                                                           | 4                        | 3    | 2    | 1    | 0    |
| 0                                                        | 0                                                                         | 0                                                                                                                                           | 0                        | BP19 | BP18 | BP17 | BP16 |
| BP15                                                     | BP14                                                                      | BP13                                                                                                                                        | BP12                     | BP11 | BP10 | BP09 | BP08 |
| BP07                                                     | BP06                                                                      | BP05                                                                                                                                        | BP04                     | BP03 | BP02 | BP01 | BP00 |
|                                                          |                                                                           |                                                                                                                                             |                          |      |      |      |      |

NOTE. There is an A or B appended to each bit name corresponding to the appropriate channel

## BP19A (BP19B) through BP00A (BP00B) Buffer Pointer Address Bits

The channel buffer pointer is composed of three registers that contain the 20-bit memory address of the data. The actual hardware that mechanizes the buffer pointer is a presettable 20-bit counter. which is the actual pointer, a 20-bit holding register connected to the preset inputs of the counter (the pipeline register), and a 20-bit latch connected to the outputs of the counter for reading the counter. The microprocessor can actually only load the pipeline register from its data bus. When the firmware writes to any of the bytes in the buffer address pointer, a flag in the PCM is set to remember that the pipeline register was written. The channel state machine will use this flag to indicate that the buffer address pointer is to be loaded with a new value. When the channel state machine enters the "busy" state it will test and clear the flag, and load the counter from the holding register if the flag was set. See also the description of channel "states" in the Channel Start Register.

If the channel enters the "busy" state and the flag is cleared, indicating that firmware did not load the pipeline register, then the counter continues from its current position. The firmware then can mechanize a ring buffer system with only the firmware overhead of writing the starting address at the initial transfer, and then only issuing start commands for succeeding transfers. The data will then appear as a single large contiguous block. If data is to be transferred from discontiguous areas of the data buffer as in a cache buffer system, then the firmware has the added overhead of writing the next address to the pipeline register for each transfer segment that is not contiguous.

If the microprocessor desires to read the counter while it is active, the firmware must first write to the capture pointer register, which will make a copy of the counter at the time, and the microprocessor can then read the 3 bytes of address without any sampling errors. When the channel detects an error during a transfer it will copy the counter to the capture latch register for reading. When the channel transitions to the idle state, and the previous operation had no error, the address pointer is automatically copied to the capture latch register for reading.

#### 4.7 CHANNEL TRANSFER COUNTER

| Channel A Ad<br>Channel B Ad | ldress = 50⊢<br>ldress = D2ł<br>ldress = D0ł | I (TC15 - TC0<br>I (TC07 - TC0<br>H (TC15 - TC<br>H (TC07 - TC<br>ers | 00)<br>08) |      |      |      |      |
|------------------------------|----------------------------------------------|-----------------------------------------------------------------------|------------|------|------|------|------|
| 7                            | 6                                            | 5                                                                     | 4          | 3    | 2    | 1    | 0    |
| TC15                         | TC14                                         | TC13                                                                  | TC12       | TC11 | TC10 | TC09 | TC08 |
| TC07                         | TC06                                         | TC05                                                                  | TC04       | TC03 | TC02 | TC01 | TC00 |

#### TC15 through TC00 Transfer Counter Bits

The channel transfer counter appears as a read/write register, but in fact it is a write only register, and a read only counter. When the firmware writes to the transfer counter it is writing to a pipeline register. When the transfer counter is read, it is reading a capture latch that is loaded from the actual counter. The reason for this mechanization is that the pipeline register needs to hold the byte count of the transfer, and to load this value into the counter each time the channel begins an operation. This value only need change when the firmware requires a different granularity of data. When the channel detects an error, both the address pointer and the transfer counter are captured. The data that the firmware requires is how far into the transfer the operation proceeded before the error was detected. When the firmware reads the actual counter, the value is the residual count of the number of bytes that are left in the transfer, and from this information the firmware can deduce the number of bytes that transferred sucessfully. The firmware can also sample the current transfer counter by writing to the Channel Pointer Capture Register.

The channel transfer counter is composed of two registers that contain the 16 bit value that is the number of data bytes of the current transfer. The actual hardware that mechanizes the transfer counter is a presettable 16 bit down counter, which is the actual counter, and a 16 bit holding register which is the pipeline. The counter is unidirectional going from number of bytes that is desired to be transferred, to zero. The microprocessor can actually only load the pipeline register from its data bus. When the Channel Start Register is set, and the channel is currently idle, then the channel state machine will load the transfer counter from the pipeline register, and start the operation. At this time the pipeline register is now free, and the firmware can load the transfer count of the next transfer into the pipeline register.

It should be noted here that for most devices that are envisioned, the block size that will be entered into the transfer counter, will be the sector (frame, etc.) size of the attached block oriented device and from that time the firmware will probably not load the transfer counter pipeline register. Hence if the firmware starts the channel again, the transfer counter will continually be updated with the block size of the device, without the firmware repeatedly loading the value on each transfer. The transfer count can be multiples of the device block size, if the firmware desires to cluster blocks together and view them as larger data items. A special case exists when EDAC Idle Enable control bit is set in the Channel Control register, in that the transfer counter is used to count the number of bytes between redundancy fields, and therefore can not be multiples of the block size.

## 4.8 CHANNEL START REGISTER

| Channel A Ad<br>Channel B Ad<br>Write onlyreg |   |   |   |   |   |   |   |
|-----------------------------------------------|---|---|---|---|---|---|---|
| 7                                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0                                             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Whenever the firmware writes to the channel start register, the PCM will take ten PCM clocks to synchronize the action to the PCM clock, and advance the channels status. During this time the firmware can only access non-channel registers.

Under normal conditions the PCM will have the channel enabled before the device is armed for a transfer. The exception to this is likely to be a programmable device that requires the PCM to be the bus slave (eq. WD501X type devices). In that case the mode will have to be changed to slave after the firmware has set up the device, as there is no programmed I/O facility in slave mode. It should be noted that once the operation of the peripheral device has been started, it may assume master status at any time, and as such, can fight the PCM if the firmware does not enter slave mode before this happens. Also, delay in starting the transfer by writing to this register, may result in over/underrun errors in the peripheral device. Writing into the channel start register will produce varied responses from the channel, depending upon the current mode and state of the channel.

When the channel is in the idle state (busy and very busy status are both cleared), and the firmware writes into the channel start register, this indicates to the channel that the firmware desires the channel to begin operations. The channel state machine will load the transfer counter from the transfer counter pipeline register, and if the channel buffer address pointer pipeline has been written into, it will load the buffer pointer from the pipeline register, the flag for the address pointer will be reset, and channel busy status will set. When the busy status is set the pipeline registers are now available for the firmware to write the parameters of the next transfer. When the channel is in the busy state (busy status set, and very busy status cleared), and the firmware writes into the channel start register, this indicates to the channel that the firmware desires the channel to continue operations when the current operation finishes. The channel very busy status will set. When the very busy status is set the pipeline registers are not available for the firmware to write. The channel is now considered to be in the very busy state. The channel will clear the very busy status and exit the very busy state when the current transfer completes. When the transfer completes the channel state machine will advance to the busy state and perform the same sequences that are described going from idle to busy. The channel counters are now set with values for the new transfer and the pipeline registers are again available for the firmware to queue the parameters of another transfer and issue another start.

When the channel is in the very busy state (busy and very busy status are both set), and the firmware writes into the channel start register, this will cause the channel to set the command rejected status and terminate operations on the channel when the current transfer completes. The channel state machine assumes that the firmware has corrupted the values in the pipeline when it issued the last start command. When the current operation completes the channel state machine will stay in the command reject error state until a channel stop is issued, which will then bring the state machine back to idle.

Finally, any attempt to start a channel with an uncleared error will result in a command reject error.



#### 4.9 CHANNEL STOP REGISTER

| hannel B /<br>/riteonly re | Address = D6ł<br>egister | 4 |   |   |   |   |   |
|----------------------------|--------------------------|---|---|---|---|---|---|
| 7                          | 6                        | 5 | 4 | 3 | 2 | 1 | 0 |
|                            |                          |   | _ |   |   | • | - |

Whenever the firmware writes to the channel stop register, the PCM will take ten PCM clocks to synchronize the action to the PCM clock, and advance the channels status. During this time the firmware can only access non-channel registers.

## 4.10 CHANNEL POINTER CAPTURE REGISTER

|   | ddress = 58H<br>ddress = D8H<br>egister |   |   |   |   |   |   |
|---|-----------------------------------------|---|---|---|---|---|---|
| 7 | 6                                       | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 0                                       | 0 | 0 | 0 | 0 | 0 | 0 |

Whenever the firmware writes to the channel pointer capture register, the PCM will take ten PCM clocks to synchronize the action to the PCM clock, and advance the channels status. During this time the firmware can only access non-channel registers.

When channel pointer capture register is written into, the capture latches for the channel pointer and channel transfer counter will sample the current state of the counters. This allows the microprocessor to detect the current position of the pointer and counter while they are active.

## 4.11 EDAC IDLE COUNTER

| Channel B A | ddress = 5AH<br>ddress = DA<br>d/write registe | Н    |      |      |      |      |      |
|-------------|------------------------------------------------|------|------|------|------|------|------|
| 7           | 6                                              | 5    | 4    | 3    | 2    | 1    | 0    |
| EC07        | EC06                                           | EC05 | EC04 | EC03 | EC02 | EC01 | EC00 |

In order for the PCM to function with an external Error Detection and Correction device (EDAC), it is necessary for the PCM to be able to ignore (or "idle") while data transfers intended for or generated by the EDAC device transpire. To this end, each channel has an 8 bit down counter called the EDAC idle counter. It is mechanized by an 8-bit holding register that is loaded by the microprocessor with the number of bytes that should be ignored at the end of each block transferred, and an 8-bit down counter, decremented on the trailing edge of DACK once the PCM has finished its transfer. This counter is not latched like the address pointers and transfer counters, so any attempt to read this counter while it is running may result in synchronization errors. This value need only be set, to suit the EDAC device being used, after a reset condition. Thereafter the EDAC mode can be enabled and disabled using the EDAC Idle Enable Bit in the Channel Control Register.

## 4.12 LONGITUDINAL REDUNDANCY CHECKING REGISTER

|            | ddress = DCl | H |   |   |   |   |   |
|------------|--------------|---|---|---|---|---|---|
| ad/write r | egister      |   |   |   |   |   |   |
| 7          | 6            | 5 | 4 | 3 | 2 | 1 | 0 |
| 0          | 0            | 0 | 0 | 0 | 0 | 0 | 0 |

Both A and B channels must operate as the bus master when using the LRC feature. LRC generation and checking takes place between the channel data bus input and output buffers and the channel FIFO. The LRC calculations do not include the parity bit.

An LRC error on a transfer from the buffer memory to the peripheral causes the WD60C40A to force a parity error on the last data byte to the peripheral. Because of the timings required for this feature, the LRC byte does not go through the FIFO on these transfers.

Enabling the LRC option splits the existing 16-bit transfer counters into 12-bit block counters and 4-bit modulo counters. The WD60C40A effectively breaks up a transfer into several blocks, and each block has its associated LRC byte. The programmed value of the block counter specifies

the length of these blocks, and the value in the modulo counter plus one indicates the number of blocks which make up the entire transfer, allowing up to 16 blocks per Channel Start.

The host has both read and write access to the LRC register to facilitate aborting transfers and subsequently resuming them. Since the LRC is calculated as the data enters the WD60C40A channel, the LRC byte after a Channel Stop includes the calculations for any data left in the WD60C40A FIFO. The host assumes responsibility for adjusting the LRC register to account for any data left in the peripheral device FIFO to ensure a correct LRC byte for the entire data block. Writing to the LRC register disables the normal zeroing of this register by the Channel Start command, enabling the host to resume the aborted transfer.

## 5.0 MICROPROCESSOR INTERFACE

The PCM interface to the controller microprocessor is designed to be compatible with microprocessors of the multiplexed address/data bus design. It is specifically targeted to interface to the Intel 80186 microprocessor with no external logic, but with some external logic the PCM can interface to other microprocessors that have multiplexed buses, or to non-multiplexed bus microprocessors. Speed penalties will exist for these implementations.

The PCM appears to the microprocessor as a contiguous address space of 256 bytes. The 8 bit address that decodes the unique location within the PCM is supplied by 8 multiplexed address/data pins. The address bit 0 is however ignored as all internal registers are mechanised to appear on even byte boundaries to suit the 80186. The PCM latches the address during the ADDRESS LATCH ENABLE signal. The 8 bits are used as both address information at ALE time. and data information at all other times. The PCM latches the bus address on all microprocessor cycles, but only responds to those cycles that are accompanied by the chip select signal. This signal is derived by the controller designer by doing a decode of the address information above bit A07, or using the already decoded outputs of the 80186. The controller designer has the flexibility to map the PCM's address space into the microprocessors memory space, or the I/O space, or a combination of both.

The PCM's interface includes a general interrupt signal to inform the microprocessor of changes of states of status within the PCM, and two signals to control the direction and timing of microprocessor bus cycles that involve the PCM. There are also two signals that allow the PCM to synchronize resource sharing for the microprocessor. When the PCM detects a bus cycle within its address range (chip select asserted), it decodes the address that it has latched, and determines the resource that is to be accessed. The PCM has control of four general resources (internal registers, buffer memory, channel A, and channel B), and maps these resources into the address space. The microprocessor interface deviates at this point depending upon the microprocessor that is interfaced, and the microprocessor and board design to support the READY/WAIT signal. In the case where the microprocessor and board design support the RDY function, the PCM uses the microprocessor RDY line to hold the microprocessor in a wait condition if the resource is not ready for immediate access. The internal register set of the PCM does not insert any wait states. The access of the other resources may or may not insert wait states.

If the microprocessor is accessing a device on one of the peripheral device channels, the local bus arbitrator for that channel will deassert RDY to the microprocessor until the channel is free for the microprocessor access to proceed. When the channel has been acquired the PCM will assert CSA or CSB (peripheral chip select) to select the peripheral device. When the access of the peripheral device is finished, the PCM will assert RDY, which will allow the microprocessor to proceed. If the access of the peripheral channel results in an I/O error, there will be no wait states inserted. If the microprocessor is accessing the buffer RAM, the memory arbiter will deassert RDY to the microprocessor until the buffer access has been done.

In the case where the microprocessor or the board design does not support the RDY function, the previously described actions to initiate the PCM function are identical. The difference is when the PCM deasserts the RDY function. In this case the microprocessor will not go into a wait condition, and is free to continue executing code. Internally, the PCM latches the access initiated, and the direction of the access, and proceeds to complete the access without holding the microprocessor. Data latches in each port and the buffer area will hold the data for the microprocessor while the access is in the arbitration queue. The microprocessor now has the responsibility of testing status (either in a PCM internal register, or the RDY signal), and when the access is complete, and to fetch the accessed data if the access was a read.

# 6.0 I/O MEMORY MAP

The PCM has within it four resources that the controller's firmware can access. The first resource is the PCM's register file. This consists of various registers that the firmware can read and write to both control the operation of the PCM, and sense the status of operations. The registers that are associated with a particular channel, are in an address space that is adjacent to the channel, and registers that are not associated with a particular channel use a partial decode of addressing so they are made to appear in both channels address space. Since these registers are dedicated to the microprocessor, there is no arbitration required to access these registers, and bus cycles to these registers involve no wait states.

The second resource that the PCM controls is the memory array. The memory array is made to appear to the firmware as a single memory location. The access to the actual memory location must be arbitrated along with accesses from the two peripheral channels, so access to the buffer memory may encounter some significant delays when there is heavy buffer traffic. The addressing of the memory array can either be static by loading the microprocessor page register, or can be made to autoincrement when searching through the data buffer.

The other two resources that the PCM controls are the device buses. The two device buses are made to appear as 64 byte spaces. Channel A devices appear in the offset range of 00H to 3FH. Channel B devices appear in the offset range of 80H to BFH. The actual registers that can be accessed through the channel, and the locations that they are made to appear at are under control of the board designer.

| FCH | DATA BUFFER           |
|-----|-----------------------|
| E0H | BUFFER MGR. REGISTERS |
| COH | CHANNEL B REGISTERS   |
| 80H | CHANNEL B             |
|     |                       |
| 7CH | DATA BUFFER           |
| 60H | BUFFER MGR. REGISTERS |
| 40H | CHANNEL A REGISTERS   |
| 00H | CHANNELA              |

# 7.0 INTERRUPTS

All interrupt conditions within the PCM are grouped into a single interrupt line going out of the WD60C40A. Individual interrupt conditions can be enabled/disabled within the PCM, but there is no prioritization of interrupts within the device. Interrupt conditions are reset when the firmware writes a one to the bit to clear the particular interrupt condition.

# 8.0 RESET SEQUENCES

The PCM chip will be initialized when the RST pin is asserted, or the firmware writes a one into the soft reset bit of the PCM reset register. When the PCM is reset, it aborts all transfers, sets channel control registers to 00 and tristates the port's control lines (RD, WR, DRQ, DACK), disables refresh by resetting the RAM control logic to a special state, and clears all interrupts. The firmware is responsible for setting up refresh and initializing the RAM to suit the dynamic RAM requirements. Resetting the PCM terminates access of the dynamic RAM array, allowing the idle time reguirement of dynamic RAMs at power on. When the PCM option register is written to, this signals the PCM that the idle time requirement of the dynamic RAM array has passed, and the PCM will begin refresh cycles if refresh is enabled, it is the requirement of the controller firmware to delay the required idle time interval from power on condition before writing into the PCM's option register, to delay the required time interval from enabling refresh until the dynamic RAMs are ready for operation, and to initialize the memory array to proper parity. The PCM is initialized to static RAM mode by master reset. When the PCM is reset, the memory signals will be deasserted, and the channel control signals will all be tristate. The memory signals will return to normal operation when the firmware writes into the option register. The channel signals will return to normal operation when the firmware writes into the channel control register. It should be noted that programmed I/O to the peripheral port can not be performed until the channel control register is written as master mode after a reset.

## 9.0 READY SEQUENCES AND LATENCIES

The RDY (ready) signal will be asserted low when the PCM has an internal resource that is unavailable to the firmware. Then time that the signal will be asserted depends upon the mode that the microprocessor interface is in, and the resource that is being accessed. When the PCM is in the 'waitable' microprocessor mode, the RDY signal will assert low when the internal address decode with CS selects a resource. The resource will start its access three PCM clocks after the microprocessor's data strobe asserts. When the PCM is in the 'non-waitable' mode, the RDY signal will assert low 30 ns after the microprocessor's data strobe ends. The resource will start its access after the three PCM clocks for synchronization. These times are in addition to the following discussion which describes the components that determine the time of the particular access.

When the firmware accesses the buffer, the time the access takes is dependant upon the microprocessor's placement in the memory arbitration scheme, and any latency associated with its request occuring while a port data burst is in progress. The microprocessor is the highest priority device in the memory arbitration scheme, since it is a single cycle device, and its request period can be controlled by the firmware. The latency associated with a port data burst is found from the equation:

TBRST = 2 (N) + 4 (P+1) expressed in PCM clocks

N = number of bytes in the ports burst

P = number of RAS cycles occuring during the burst, or # of page boundaries crossed during burst.

Example: If the port transfers 22 bytes during the burst, and crosses a page boundary, then the total burst will require 52 PCM clocks. For a PCM clock frequency of 16 Mhz. this will be a time of 3.25 microseconds.

The N factor in the above equation depends upon the number of bytes in the FIFO when the burst begins, and the memory transfer rate, and the peripheral transfer rate. The value of N should be determined by simulation but an estimation can be made from the equation:

N = MTR (IFBC) / (MTR - PTR)

MTR = memory transfer rate, 1/2 PCM clock frequency

PTR = peripheral transfer rate, (in MHz)

IFBC = initial FIFO byte count at start of burst

#### NOTE:

IFBC is in the range of 0 to 15 for WD60C40.

The memory transfer rate when the port is in a burst is two PCM clocks per byte. If the PCM is supplied with a 16 MHz clock, then the memory trans fer rate will be 8 MHz (8 Mbytes/second). The peripheral transfer rate is supplied in the same terms as the memory transfer rate. As an example the WD33C93A SCSI interface peripheral is capable of a transfer rate of 4 Mbytes/second, or 4 MHz. The FIFO size in the PCM is 15 bytes. If these values are applied to the equation, and use the value of 14 bytes for the initial FIFO condition, the result is 29 bytes for the expected burst. At the memory transfer rate of 8 Mbytes per second, this would yield a burst time of 3.625 microseconds.

It can be seen that as the peripheral transfer rate approaches the memory transfer rate, the denominator of the equation approaches zero, and the size of the burst increases rapidly. Therefore if the PCM is designed into a system with the peripheral transfer rate very close to the memory transfer rate, large microprocessor buffer access times can be expected. The size of burst is limited by the refresh mechanism of the PCM. The PCM will queue up to four refreshes, and then force an arbitration, which the microprocessor will win because it is highest priority. In a system that has refreshes programmed at the normal rate of 15.6 microseconds, this effectively limits the maximum burst and the maximum latency to about 62 microseconds.

## 10.0 NON-CHANNEL REGISTERS MAP

| 7     | 6    | 5      | 4     | 3     | 2     | 1     | 0     | REGISTER/<br>ADDRESS           |
|-------|------|--------|-------|-------|-------|-------|-------|--------------------------------|
| MPAR  | CAW1 | CAW0   | SRAM  | RRC3  | RRC2  | RRC   | RRC0  | OPT<br>60H or E0H              |
| 0     | 0    | NOWAIT | WAITE | AHI   | INTE  | BINTE | AINTE | OP2<br>62H or E2H              |
| DNR   | 0    | 0      | PRNR  | BANR  | PPE   | BINTR | AINTR | MSR<br>64H or E4H              |
| 0     | 0    | 0      | 0     | 0     | 0     | 0     | 0     | 66H or E6H                     |
| BDL7  | BDL6 | BDL5   | BDL4  | BDL3  | BDL2  | BDL1  | BDL0  | BDL<br>68H or E8H              |
| MP07  | MP06 | MP05   | MP04  | MP03  | MP02  | MP01  | MP00  | MAP<br>6AH or EAH              |
| MP15  | MP14 | MP13   | MP12  | MP11  | MP10  | MP09  | MP08  | 6CH or ECH                     |
| 0     | 0    | 0      | 0     | MP19  | MP18  | MP17  | MP16  | 6EH or EEH                     |
| TAS7  | TAS6 | TAS5   | TAS4  | TAS3  | TAS2  | TAS1  | TAS0  | TAS<br>78H or F8H <sup>1</sup> |
| SWRST | 0    | BRST   | ARST  | TSMEM | CNTRT | MTPBF | MTPAF | RTR<br>7AH or FAH              |
| BAR7  | BAR6 | BAR5   | BAR4  | BAR3  | BAR2  | BAR1  | BAR0  | BAR<br>7CH or FCH              |
| BAR7  | BAR6 | BAR5   | BAR4  | BAR3  | BAR2  | BAR1  | BAR0  | AAR<br>7EH or FEH              |
| NOTES |      |        |       |       |       |       |       |                                |

All "odd" addresses will access the "even" address that is one lower

<sup>1</sup>Contents of addresses 70H (or F0H) through 76H (or F6H) must be written as 00 and read as 00

# **11.0 CHANNEL REGISTERS MAP**

| 7     | 6              | 5    | 4    | 3    | 2                  | 1    | 0    | REGISTER/<br>ADDRESS   |
|-------|----------------|------|------|------|--------------------|------|------|------------------------|
| LPBM  | PPE            | DKPL | RQPL | SDTC | DLY                | SC1  | SC0  | CTR<br>40H or C0H      |
| SLAV  | BRST           | DISK | EDAC | PAUS | DIR                | IVE  | IBE  | CCR<br>42H or C2H      |
| 0     | 0              | DKST | RQST | PNR  | FMT                | VBSY | BSY  | CSR<br>44H or C4H      |
| AERR  | IOPE           | IOE  | REJ  | LATE | PERR               | VB1  | BSY1 | ISR<br>46H or C6H      |
| CDL7  | CDL6           | CDL5 | CDL4 | CDL3 | CDL2               | CDL1 | CDL0 | CDL<br>4BH or C8H      |
| BP07  | BP06           | BP05 | BP04 | BP03 | BP02               | BP01 | BP00 | CBP<br>4AH or CAH      |
| BP15  | BP14           | BP13 | BP12 | BP11 | BP10               | BP09 | BP08 | 4CH or CCH             |
| 0     | <sup>•</sup> 0 | 0    | 0    | BP19 | BP18               | BP17 | BP16 | 4EH or CEH             |
| TC07  | TC06           | TC05 | TC04 | TC03 | TC02               | TC01 | TC00 | CTC<br>50H or D0H      |
| TC15  | TC14           | TC13 | TC12 | TC11 | TC10               | TC09 | TC08 | 52H or D2H             |
| 0     | 0              | 0    | 0    | 0    | 0                  | 0    | 0    | CST<br>54H or D4H      |
| 0     | 0              | 0    | 0    | 0    | 0                  | 0    | 0    | CSP<br>56H or D6H      |
| 0     | 0              | 0    | 0    | 0    | 0                  | 0    | 0    | CCP<br>58H or D8H      |
| EC07  | EC06           | EC05 | EC04 | EC03 | EC02               | EC01 | EC00 | CEC<br>5AH or DAH      |
| 0     | 0              | 0    | 0    | 0    | 0                  | 0    | 0    | Reserved<br>5CH or DCH |
| 0     | 0              | 0    | 0    | 0    | 0                  | 0    | 0    | Reserved<br>5EH or DEH |
| NOTE: |                |      |      |      | 0<br>appropriate c |      | 0    |                        |

# 12.0 DC ELECTRICAL CHARACTERISTICS

| PARAMETER                                      | SYMBOL          | MIN | MAX | UNIT |
|------------------------------------------------|-----------------|-----|-----|------|
| Power Supply                                   | V <sub>CC</sub> | 4.5 | 5.5 | V    |
| Input Low Voltage                              | VIL             |     | 0.8 | V    |
| Input High Voltage                             | VIH             | 2.0 |     | V    |
| Ouptut Low Voltage<br>I <sub>OL</sub> = 2.0 mA | V <sub>OL</sub> |     | 0.4 | V    |
| Output High Voltage,<br>IOH = 400 μA           | V <sub>OH</sub> | 2.8 |     | V    |
| Leakage Current Low                            | ILL             |     | 10  | μΑ   |
| Leakage Current High                           | Іцн             |     | -10 | μΑ   |
| Supply Current                                 | Icc             |     | 100 | mA   |
| Power Dissipation                              | PD              |     | 500 | mW   |

The output loading depends on the pin function and are as follows:

| IOL  | IOH     | SIGNAL NAME                                                                                                                                                |
|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 mA | -2.5mA  | AD7 to AD0                                                                                                                                                 |
| 2 mA | -1.0 mA | CSA, CSB<br>DRQA, DRQB<br>DACKA, DACKB<br>ARD, BRD<br>AWR, BWR<br>DBA7 to DBA0, DBAP<br>DBB7 to DBB0, DBBP<br>RB7 to RB0, RBP<br>BA9 to BA0<br>RAS, CAS, W |
| 6 mA | O.D.    | RDY<br>PINT                                                                                                                                                |

# 13.0 MISCELLANEOUS CHARACTERISTICS

| Operating Temperature    | 0° to 70° C                         |
|--------------------------|-------------------------------------|
| Absolute Maximum Ratings | All voltages referenced to $V_{SS}$ |
| Vcc                      | 7.0 Volts                           |
| Voltage to any pin       | -0.3 to $V_{CC}$ + 0.3 Volts        |
| Storage Temperature      | -40° to +125° C                     |

#### NOTE:

Maximum limits indicate the point where permanent device damage occurs. Continuous operation at these limits is not intended, and should be limited to those conditions specified in Electrical Characteristics sections.

# 14.0 TIMING SPECIFICATION

In these timing diagrams the following assumptions have been made:

- (1) As port B is identical to port A, only port A timings need be shown.
- (2) The DRQA signal has been programmed as active HIGH.
- (3) The DACKA signal has been programmed as active LOW.
- (4) The timing specifications assume the following loading on each pin.

| MAX LOADING | PIN NAMES                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------|
| 120 PF MAX  | BA9 to BA0<br>RB7 to RB0, <u>RB</u> P<br>RAS, CAS, W                                                        |
| 100 PF MAX. | AD7 to AD0                                                                                                  |
| 50 PF MAX.  | CSA, CSB<br>DACKA, DACKB<br>ARD, BRD<br>AWR, BWR<br>DBA7 to DBA0, DBAP<br>DBB7 to DBB0, DBBP<br>RDY<br>PINT |

The timing diagrams use the following nomenclature:

#### REF

The Reference number on the timing waveform diagram.

#### NAME

Abbreviated Symbol by which the timing is referred.

#### DESCRIPTION

Description of the timing referred.

#### REFERENCE

The reference edge to which the timing is specified.

- LE = Leading edge
- TE = Trailing edge
- RE = Rising edge
- FE = Falling edge
- IC = Initial Condition

# Classification of requirement/specification.

R/S

R = Requirement of the external circuit.

S = WD60C40 output timing specification.

#### TIMING

Value, unit, and characteristic of timing.



FIGURE 14-1. RISE/FALL AND MISC. TIMING



\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC

#### FIGURE 14-2. PIO READ/WRITE OF EXTERNAL DEVICES



\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC.

\*\*\* Based on SC and SDTC set to zero. Add 2 TCYC for each programmed state.

#### FIGURE 14-3. DMA BURST MODE TRANSFERS



| NAME                                                           | REF | R/S | MINIMUM           | MAXIMUM            |
|----------------------------------------------------------------|-----|-----|-------------------|--------------------|
| TACS = Time of DACK to Chip Select                             | TE  | S   | 2 TCYC - 15 NS ** |                    |
| TCSA = Time of Chip Select to DACK                             | TE  | S   | 2 TCYC - 15 NS ** |                    |
| TDAW = Time DACK to Write Strobe<br>(See DLY in Section 4.1)   | LE  | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |
| TWWR = Width of Write Strobe<br>(See SC in Section 4.1)        |     | S   | 2 TCYC - 15 NS    | 8 TCYC + 15 NS     |
| TWOE = Time to Output Enable in Write                          | LE  | S   | 0 NS              |                    |
| TSUW = Data Setup Time to Write                                | TE  | S   | 2 TCYC - 40 NS    | 8 TCYC + 15 NS     |
| TWDH = Time of Data Hold in Write                              | TE  | S   | TCKH - 5 NS       |                    |
| TWRZ = Time of Write Strobe to High Z                          | TE  | S   | TCKH - 5 NS       | TCKH + 20 NS       |
| TDAR = Time DACK to Read Strobe<br>(See DLY in Section 4.1)    | LE  | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |
| TWRD = Width of Read Strobe<br>(See SC in Section 4.1)         |     | S   | 2 TCYC - 15 NS    | 8 TCYC + 15 NS     |
| TSUR = Data Setup Time of Read Data                            | TE  | R   | 30 NS             |                    |
| TDHR = Data Hold Time of Read Data                             | TE  | R   | 0 NS              |                    |
| TROZ = Time of Read Strobe to High Z                           | TE  | R   |                   | 2 TCYC **          |
| TDQD = Time to DRQ Deasserted<br>(to stop Burst)               | LE  | R   |                   | 2 TCYC - 20 NS *** |
| TSDA = Time of Strobe Deactivated<br>(See SDTC in Section 4.1) |     | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |

\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC.

\*\*\* Based on SC and SDTC set to zero. Add 2 TCYC for each programmed state.

#### FIGURE 14-4. DMA SINGLE CYCLE MODE

29



| NAME                                 | REF | R/S | MINIMUM        | MAXIMUM          |
|--------------------------------------|-----|-----|----------------|------------------|
| TDAK = Time DRQ to Acknowledge       | LE  | S   |                | 35 NS            |
| TDQD = Time to DRQ Deasserted        | LE  | R   |                | 3 TCYC           |
| TRQP = Time of Request Period        |     | R   | 6.5 TCYC       |                  |
| TWDK = Width of DACK Signal          |     | S   | 3 5 TCYC       | 5.5 TCYC + 15 NS |
| TSUW = Data Setup Time of Write Data | TE  | S   | 2 TCYC - 40 NS |                  |
| TWDH = Data Hold Time of Write Data  | TE  | S   | TCKH - 5 NS    |                  |
| TSUR = Data Setup Time of Read Data  | TE  | R   | 30 NS          |                  |
| TDHR = Data Hold Time of Read Data   | TE  | R   | 0 NS           |                  |

\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC

\*\*\* Based on SC and SDTC set to zero. Add 2 TCYC for each programmed state

#### FIGURE 14-5. BUS MASTER DISK MODE



| NAME                                                            | REF | R/S | MINIMUM  | MAXIMUM |
|-----------------------------------------------------------------|-----|-----|----------|---------|
| TWWR - Width of Write Strobe                                    |     | R   | 50 NS    |         |
| TSDA = Time of Strobe Deactivated                               |     | R   | 50 NS    |         |
| TDQD = Time to DRQ Deasserted                                   | LE  | S   |          | 35 NS   |
| TDSP = Time of Data Strobe Period                               |     | R   | 2.5 TCYC |         |
| TDAH = Time of DACK Hold                                        | TE  | R   | 0 NS     |         |
| TSUW = Data Setup Time to Write                                 | TE  | R   | 20 NS    |         |
| TWDH = Time of Data Hold in Write                               | TE  | R   | 10 NS    |         |
| TRON = Time Read Output Enable from<br>DACK (If DIR bit is set) | LE  | S   | 0 NS     | 50 NS   |
| TWRD = Width of Read Strobe                                     |     | R   | 50 NS    |         |
| TRAC = Data Access Time                                         | LE  | S   |          | 45 NS   |
| TDHR = Data Hold Time of Read Data                              |     | S   | 10 NS    | 45 NS   |
| TROZ = Time of Read Strobe to High Z                            |     | S   |          | 50 NS   |

#### FIGURE 14-6. SLAVE BURST MODE TRANSFERS



| TWDH = Time of Data Hold in Write                               | TE | R | 10 NS          |       |
|-----------------------------------------------------------------|----|---|----------------|-------|
| TRON = Time Read Output Enable from<br>DACK (If DIR bit is set) | LE | S | 0 NS           | 50 NS |
| TWRD = Width of Read Strobe                                     |    | R | 50 NS          |       |
| TRAC = Data Access Time                                         | LE | S |                | 45 NS |
| TDHR = Data Hold Time of Read Data                              | TE | S | 10 NS          | 45 NS |
| TROZ = Time of Read Strobe to High Z                            | TE | S |                | 50 NS |
| TRWA = Time of R/W to DACK Inactive                             | LE | S | 2 TCYC + 15 NS |       |

## FIGURE 14-7. SLAVE SINGLE CYCLE TRANSFER



FIGURE 14-8. SLAVE BURST DISK MODE (READ)







| NAME                                                           | REF | R/S | MINIMUM           | MAXIMUM            |
|----------------------------------------------------------------|-----|-----|-------------------|--------------------|
| TACS = Time of DACK to Chip Select                             | TE  | S   | 2 TCYC - 15 NS ** |                    |
| TCSA = Time of Chip Select to DACK                             | TE  | S   | 2 TCYC - 15 NS ** |                    |
| TDAW = Time DACK to Write Strobe<br>(See DLY in Section 4.1)   | LE  | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |
| TWWR = Width of Write Strobe<br>(See SC in Section 4.1)        |     | S   | 2 TCYC - 15 NS    | 8 TCYC + 15 NS     |
| TWOE = Time to Output Enable in Write                          | LE  | S   | 0 NS              |                    |
| TSUW = Data Setup Time to Write                                | TE  | S   | 2 TCYC - 40 NS    | 8 TCYC + 15 NS     |
| TWDH = Time of Data Hold in Write                              | TE  | S   | TCKH - 5 NS       |                    |
| TWRZ = Time of Write Strobe to High Z                          | TE  | S   | TCKH - 5 NS       | 6.5 TCYC           |
| TDAR = Time DACK to Read Strobe<br>(See DLY in Section 4 1)    | LE  | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |
| TWRD = Width of Read Strobe<br>(See SC in Section 4.1)         |     | S   | 2 TCYC - 15 NS    | 8 TCYC + 15 NS     |
| TSUR = Data Setup Time of Read Data                            | TE  | R   | 30 NS             | dist               |
| TDHR = Data Hold Time of Read Data                             | TE  | R   | 0 NS              |                    |
| TROZ = Time of Read Strobe to High Z                           | TE  | R   |                   | 2 TCYC **          |
| TDQD = Time to DRQ Deasserted<br>(to stop Burst)               | LE  | R   |                   | 2 TCYC - 20 NS *** |
| TSDA = Time of Strobe Deactivated<br>(See SDTC in Section 4.1) |     | S   | 2 TCYC - 15 NS    | 4 TCYC + 15 NS     |
| TDAZ = Time to Dack High Z                                     | TE  | S   |                   | 6 TCYC             |

\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC.

\*\*\* Based on SC and SDTC set to zero. Add 2 TCYC for each programmed state.

## FIGURE 14-10. EDAC MODE (DMA SINGLE CYCLE)



| NAME                                 | REF | R/S | MINIMUM        | MAXIMUM          |
|--------------------------------------|-----|-----|----------------|------------------|
| TDAK = Time DRQ to Acknowledge       | LE  | S   |                | 35 NS            |
| TDQD = Time to DRQ Deasserted        | LE  | R   |                | 3 TCYC           |
| TRQP = Time of Request Period        |     | R   | 6.5 TCYC       |                  |
| TWDK = Width of DACK Signal          |     | S   | 3.5 TCYC       | 5.5 TCYC + 15 NS |
| TSUW = Data Setup Time of Write Data | TE  | S   | 2 TCYC - 40 NS |                  |
| TWDH = Data Hold Time of Write Data  | TE  | S   | TCKH - 5 NS    |                  |
| TSUR = Data Setup Time of Read Data  | TE  | R   | 30 NS          |                  |
| TDHR = Data Hold Time of Read Data   | TE  | R   | 0 NS           |                  |
| TDAZ = Time to DACK High Z           | TE  | S   |                | 6 TCYC           |

\*\* If SDTC in Section 4.1 is set, then value is 4 TCYC

\*\*\* Based on SC and SDTC set to zero. Add 2 TCYC for each programmed state

FIGURE 14-11. EDAC MODE (DMA DISK)



FIGURE 14-12. MICROPROCESSOR BUS TIMING

29

| NAME                                                 | REF.               | R/S | TIMING      |
|------------------------------------------------------|--------------------|-----|-------------|
| TALEH = ALE High Pulse Width                         |                    | R   | 35 NS MIN.  |
| TSVALE = Address Setup Before T.E. ALE               | TE                 | R   | 15 NS MIN.  |
| TAHALE = Address Hold after T.E. ALE                 | TE                 | R   | 15 NS MIN.  |
| TALQDS = ALE T.E. to Qualified Data Strobe           | TE                 | R   | 30 NS MIN.  |
| TWORD = Pulse Width Qualified Read Strobe            |                    | R   | 110 NS MIN. |
| TQROE = Qualified Read Strobe to Output Enabled      | LE                 | S   | 40 NS MAX.  |
| TQRDV = Qualified Read Strobe to Data Valid          | LE                 | S   | 95 NS MAX.  |
| TQRDH = Data Hold from Qualified Read Strobe         | TE                 | S   | 0 NS MIN.   |
| TQROZ = T.E. Qualified Read Strobe to High Impedance | TE                 | S   | 60 NS MAX.  |
| TQRREC = Recovery Time after Qualified Read Strobe   | TE                 | R   | 120 NS MIN. |
| TWQWR = Pulse Width Qualified Write Strobe           |                    | R   | 110 NS MIN. |
| TDVQWR = Data Valid from L.E. Qualified Write        | *                  | R   | 3 CLK MAX.  |
| TSUQWR = Data Setup to T.E. Qualified Write          | TE                 | R   | 30 NS MIN.  |
| TDHQWR = Data Hold from T.E. Qualified Write         | TE                 | R   | 10 NS MIN.  |
| TQWREC = Recovery Time after Qualified Write Strobe  | TE                 | R   | 120 NS MIN. |
| Waitable Micro                                       | processor Interfac | е   |             |
| TAURDY = Address Valid to Ready Valid                | LE                 | S   | 50 NS MAX.  |
| TCSRDY = Chip Select to Readh Valid                  | LE                 | S   | 35 NS MAX.  |
| Non-Waitable Mic                                     | roprocessor Interf | ace |             |
| TQDSRY = T.E. Qualified Data Strobe to Not Ready     | TE                 | S   | 60 NS MAX.  |
| Either Microp                                        | rocessor Interface |     |             |
| TNRDY = Time Not Ready                               | **                 | S   | 6 CLK MIN.  |

Required in Waitable Mode Only
\*\* See Section 5.0 for maximum

## **TABLE 14-1. MICROPROCESSOR BUS TIMING**



| NAME                                        | REF | R/S | MINIMUM          | MAXIMUM      |
|---------------------------------------------|-----|-----|------------------|--------------|
| TCYC = Input CLock Period                   |     | R   | 40 NS            |              |
| TCKL = Input Clock Low                      |     | R   | 17 NS            |              |
| TCKH = Input Clock High                     |     | R   | 17 NS            |              |
| TCKR = Input Clock Rise                     |     | R   |                  | 5 NS         |
| TCKF = Input Clock Fall                     |     | R   |                  | 5 NS         |
| TRAS = Time of RAS Low                      |     | S   | 3.5 TCYC - 15 NS |              |
| TRPC = Time of RAS Precharge<br>(RAS High)  |     | S   | 2.5 TCYC - 5 NS  | TRFC         |
| TASR = Address Setup to L.E. RAS            | FE  | S   | TCYC - 20 NS     | TCYC         |
| TRAH = Address Hold from L.E. RAS           | FE  | S   | TCYC - 15 NS     |              |
| TRCY = RAS Cycle Time                       |     | S   | 6 TCYC           | TRFC **      |
| TRFC = Refresh Cycle Time<br>(Programmable) |     | S   | 32 TCYC          | 512 TCYC *** |
| TT = Transition Time All Outputs            |     | S   | 3 NS             | 20 NS        |

\*\* This specification assumes no other memory requests other than Refresh.

\*\*\* This is the maximum programmable value. The programmed value is based on DRAM specification.

#### FIGURE 14-13. RAS ONLY REFRESH TIMING



| NAME                                       | REF | R/S | MINIMUM          | MAXIMUM |
|--------------------------------------------|-----|-----|------------------|---------|
| TRAS = Time of RAS Asserted                |     | S   | 3.5 TCYC - 15 NS |         |
| TRPC = Time of RAS Precharge<br>(RAS High) |     | S   | 2.5 TCYC - 5 NS  | TRFC    |
| TASR = Address Setup to L.E. RAS           | FE  | S   | TCYC - 20 NS     | TCYC    |
| TRAH = Address Hold from L.E. RAS          | FE  | S   | TCYC - 15 NS     |         |
| TRCY = RAS Cycle Time                      |     | S   | 6 TCYC           |         |
| TT = Transition Time All Outputs           |     | S   | 3 NS             | 20 NS   |
| TRCD = L.E. RAS to L.E. CAS Delay          | LE  | S   | 2 TCYC - 25 NS   |         |
| TCAS = Time of CAS Asserted                |     | S   | TCYC             |         |
| TCP = Time of CAS Precharge (CAS<br>High)  |     | S   | TCYC - 20 NS     |         |
| TWP = Time of Write Asserted               |     | S   | 2 TCYC           |         |
| TASC = Address Setup to L.E. CAS           | LE  | S   | TCKH - 15 NS     |         |
| TCAH = Address Hold from L.E. CAS          | LE  | S   | 1.5 TCYC - 15 NS |         |
| TDS = Data Setup to L.E. CAS               | LE  | S   | TCKH - 15 NS     |         |
| TDH = Data Hold from L.E. CAS              | LE  | S   | 1.5 TCYC - 15 NS |         |
| TRSH = RAS Hold from L.E. CAS              | LE  | S   | TCYC             |         |
| TWCS = Write Setup to L.E. CAS             | LE  | S   | TCYC             |         |
| TWCH = Write Hold from L.E. CAS            | LE  | S   | TCYC             |         |

FIGURE 14-14. PAGE MODE WRITE TIMING



| NAME                                       | REF | R/S | MINIMUM          | MAXIMUM |
|--------------------------------------------|-----|-----|------------------|---------|
| TRAS = Time of RAS Asserted                |     | S   | 3.5 TCYC - 15 NS |         |
| TRPC = Time of RAS Precharge<br>(RAS High) |     | S   | 2.5 TCYC - 5 NS  | TRFC    |
| TASR = Address Setup to L.E. RAS           | FE  | S   | TCYC - 20 NS     | TCYC    |
| TRAH = Address Hold from L.E. RAS          | FE  | S   | TCYC - 15 NS     |         |
| TRCY = RAS Cycle Time                      |     | S   | 6 TCYC           |         |
| TT = Transition Time All Outputs           |     | S   | 3 NS             | 20 NS   |
| TRCD = L.E. RAS to L.E. CAS Delay          | LE  | S   | 1.5 TCYC - 5 NS  |         |
| TCAS = Time of CAS Asserted                |     | S   | TCYC             |         |
| TCP = Time of CAS Precharge (CAS<br>High)  |     | S   | TCYC - 20 NS     |         |
| TASC = Address Setup to L.E. CAS           | LE  | S   | TCKH - 15 NS     |         |
| TCAH = Address Hold from L.E. CAS          | LE  | S   | 1.5 TCYC - 15 NS |         |
| TRSH = RAS Hold from L.E. CAS              | LE  | S   | TCYC             |         |
| TCAC = CAS Access Time                     | LE  | R   |                  | тсус    |
| TOFF = Data High-Z Delay                   | TE  | R   | 0 NS             | 30 NS   |

## FIGURE 14-15. PAGE MODE READ TIMING



#### FIGURE 14-16. STATIC RAM WRITE TIMING

ΤE

ΤE

ΤE

ΤE

ΤE

s

s

s

s

s

s

s

TCYC - 20 NS

1.5 TCYC - 15 NS

1.5 TCYC - 15 NS

TCYC

5 NS

5 NS

0 NS

TWPC = Time of Write Precharge

TASW = Address Setup to T.E. Write

TWAH = Address Hold from T.E. Write

TRWH = RAS Hold Time from T.E. Write

(Write High) TWP = Time of Write Asserted

TDS = Data Setup to T.E. Write

TDH = Data Hold from T.E. Write



### FIGURE 14-17. STATIC RAM READ TIMING

# **15.0 PACKAGE DIAGRAMS**



FIGURE 15-1. 84-PIN PLCC PACKAGE DIMENSIONS



FIGURE 15-2. 84-PIN PQFP PACKAGE DIMENSIONS