## 82380 HIGH PERFORMANCE 32-BIT DMA CONTROLLER WITH INTEGRATED SYSTEM SUPPORT PERIPHERALS - High Performance 32-Bit DMA Controller - 50 MBytes/sec Maximum Data Transfer Rate at 25 MHz - -8 Independently Programmable Channels - 20-Source Interrupt Controller - Individually Programmable Interrupt **Vectors** - 15 External, 5 Internal Interrupts - 82C59A Superset - Four 16-Bit Programmable Interval **Timers** - 82C54 Compatible - Programmable Wait State Generator - -0 to 15 Wait States Pipelined - 1 to 16 Wait States Non-Pipelined - DRAM Refresh Controller - 80386 Shutdown Detect and Reset Control - Software/Hardware Reset - High Speed CHMOS III Technology - 132-Pin PGA Package (See Packaging Handbook Order 240800-001, Package Type A) - Optimized for use with the 80386 Microprocessor - Resides on Local Bus for Maximum **Bus Bandwidth** - 16, 20, and 25 MHz Clock The 82380 is a multi-function support peripheral that integrates system functions necessary in an 80386 environment. It has eight channels of high performance 32-bit DMA with the most efficient transfer rates possible on the 80386 bus. System support peripherals integrated into the 82380 provide Interrupt Control, Timers, Wait State generation, DRAM Refresh Control, and System Reset logic. The 82380's DMA Controller can transfer data between devices of different data path widths using a single channel. Each DMA channel operates independently in any of several modes. Each channel has a temporary data storage register for handling non-aligned data without the need for external alignment logic. 290128-1 November 1991 Order Number: 290128-006 # intel. ## **TABLE OF CONTENTS** | CONTENTS | PAGE | |---------------------------------------------------------------|------------------| | 1.0 FUNCTIONAL OVERVIEW | . 1-468 | | 1.1 82380 Architecture | . 1-468 | | 1.1.1 DMA Controller | . 1-469 | | 1.1.2 Programmable Interval Timers | . 1-470 | | 1.1.3 Interrupt Controller | . 1-471 | | 1.1.4 Wait State Generator | . 1-472 | | 1.1.5 DRAM Refresh Controller | | | 1.1.6 CPU Reset Function | | | 1.1.7 Register Map Relocation | . 1-473 | | 1.2 Host Interface | . 1-473 | | 1.3 IBM-PC System Compatibility | . 1-474 | | 2.0 80386 HOST INTERFACE | . 1-474 | | 2.1 Master and Slave Modes | . 1-475 | | 2.2 80386 Interface Signals | . 1-475 | | 2.2.1 Clock (CLK2) | . 1-475 | | 2.2.2 Data Bus (D0-D31) | . 1-475 | | 2.2.3 Address Bus (A31-A2) | . 1-476 | | 2.2.4 Byte Enable (BE3#-BE0#) | . 1-476 | | 2.2.5 Bus Cycle Definition Signals (D/C#, W/R#, M/IO#) | . 1-477 | | 2.2.6 Address Status (ADS#) | . 1-477 | | 2.2.7 Transfer Acknowledge (READY#) | . 1-477 | | 2.2.8 Next Address Request (NA#) | . 1-477 | | 2.2.9 Reset (RESET, CPURST) | . 1-477 | | 2.2.10 Interrupt Out (INT) | . 1-4/8 | | 2.3 82380 Bus Timing | 1-4/8 | | 2.3.1 Address Pipelining | 1-4/8<br>1 470 | | 2.3.2 Master Mode Bus Timing | 1 495 | | | | | 3.0 DMA CONTROLLER | 1-483 | | 3.1 Functional Description | 1-484 | | 3.2 Interface Signals | . 1-485 | | 3.2.1 DREQn and EDACK (0-2) | . 1-486 | | 3.2.2 HOLD and HLDA | 1-486 | | 3.2.3 EOP# | . 1-480 | | 3.3 Modes of Operation | . 1*400<br>1 400 | | 3.3.2 Buffer Transfer Processes | . 1-407<br>1-497 | | 3.3.3 Data Transfer Modes | . 1-407<br>1-486 | | 3.3.4 Channel Priority Arbitration | 1-492 | | 3.3.5 Combining Priority Modes | 1-494 | | 3.3.6 Bus Operation | . 1-495 | | 3.3.6.1 Fly-By Transfers | 1-495 | | 3.3.6.2 Two-Cycle Transfers | 1-495 | | 3.3.6.3 Data Path Width and Data Transfer Rate Considerations | 1-496 | | 3.3.6.4 Read, Write, and Verify Cycles | 1-496 | | 3.4 Bus Arbitration and Handshaking | 1-49€ | | 3.4.1 Synchronous and Asynchronous Sampling of DREQn and EOP# | 1-499 | | 3.4.2 Arbitration of Cascaded Master Requests | 1-501 | | 3.4.3 Arbitration of Refresh Requests | 1-500 | | CONTENTS | | |-------------------------------------------------------------------------------------|-------| | | PAGE | | 3.0 DMA CONTROLLER (Continued) | | | 3.5 DMA Controller Register Overview | 1-503 | | 5.5.1 Control/Status Registers | 4 500 | | 0.0.2 Ondinier registers | 4 504 | | 3.3.3 Temporary Registers | | | 5.5 Biti/ Controller Flogramming | 4 500 | | 0.0.1 Duilet 1 10Ce33e3 | 4 500 | | 5.0.1.1 Single buller Process | 4 500 | | 3.0.1.2 Builei Auto-initialize Process | 1 500 | | o.o. r.o baner channing riocess | 4 500 | | 3.6.2 Data Transfer Modes | 4 507 | | 0.0.0 Cascaded bus Masters | 4 507 | | 3.6.4 Software Commands | 1-50/ | | 3.7 Register Definitions | 1-507 | | 3.8 8237A Compatibility | 1-508 | | 4.0. DD0.00 1.11.1 | 1-514 | | 4.1 Supplies Description | 1-515 | | 4.1 Functional Description | 4 545 | | Title internal block bladfaff | 4 545 | | 4.1.2 Interrupt Controller Banks | 4 546 | | 4.2 interface Signals | 4 547 | | 4.2.1 interrupt inputs | 4 547 | | 4.2.2 III. ET UDI (OUDIA IIIVI) | | | 4.3 Bus runctional Description | 4 540 | | THE WINDLES OF OPERAUOIT | 4 540 | | 4.4.1 End-Oi-interrupt | 1 510 | | 4.4.2 Interrupt Priorities | 4.500 | | 4.4.2.1 Fully Nested Mode | 4 500 | | 4.4.4.4 AUIOMAIIC HOIAIION—Eduai Priority Devices | 4 504 | | 4.4.2.3 Specific Rotation—Specific Priority 4.4.2.4 Interrupt Priority Mode Suppose | 1-521 | | 4.4.2.4 Interrupt Priority Mode Summary | 1-522 | | 4.4.3 IDEUDO MASODO | | | 4.4.4 Edge Or Level Interrupt Triggering | 1-523 | | 4.4.5 Interrupt Cascading | 1-523 | | 4.4.5.1 Special Fully Nested Mode 4.4.5.1 Special Fully Nested Mode | | | 4.4.6 Reading Interrupt Status | 1-524 | | 4.4.6 Reading Interrupt Status | 1-524 | | 4.4.6.1 Poll Command | 1-524 | | 4.4.6.2 Reading Interrupt Registers | 1-524 | | 4.5 Register Set Overview | 1-524 | | 4.5.1 Initialization Command Words (ICW) | 1-526 | | 4.5.2 Operation Control Words (OCW) | 1-526 | | 4.5.5 FUII/ IIILEITUDI REQUEST/ III-SERVICE Status Register | 4 507 | | 4.5.4 interrupt wask nedister (IMH) | 4 507 | | T.O.O VOCIOI riegister (VII) | 4 507 | | TO Frogramming | 4 503 | | 4.6.1 initialization (ICVV) | 1 507 | | TIOLE VECTOI I TECHSICIS I VITI | 4 500 | | 4.0.3 Operation Control Worlds (OCW) | 4 500 | | 7.9.5.1 Deau Status Anu Foli Commande (Cicwy) | 4 = | | 7.7 Hegister Dit Dennition | 4 500 | | 4.8 Register Operational Summary | 1-532 | | | | 1-465 | CONTENTS | PAGE | |-------------------------------------------------|-------| | 5.0 PROGRAMMABLE INTERVAL TIMER | 1-533 | | 5.1 Functional Description | | | 5.1.1 Internal Architecture | | | 5.2 Interface Signals | | | 5.2.1 CLKIN | | | 5.2.2 TOUT1, TOUT2#, TOUT3# | 1-535 | | 5.2.3 GATE | | | 5.3 Modes of Operation | 1-536 | | 5.3.1 Mode 0—Interrupt On Terminal Count | 1-536 | | 5.3.2 Mode 1—GATE Retriggerable One-Shot | | | 5.3.3 Mode 2—Rate Generator | 1-538 | | 5.3.4 Mode 3—Square Wave Generator | 1-539 | | 5.3.5 Mode 4—Initial Count Triggered Strobe | 1-541 | | 5.3.6 Mode 5—GATE Retriggerable Strobe | | | 5.3.7 Operation Common to All Modes | | | 5.3.7.1 GATE | 1-543 | | 5.3.7.2 Counter | | | 5.4 Register Set Overview | | | 5.4.1 Counter 0, 1, 2, 3 Registers | | | 5.4.2 Control Word Register I & II | 1 544 | | 5.5 Programming | | | 5.5.1 Initialization | | | 5.5.2 Read Operation | | | 5.6 Register Bit Definitions | | | • | • | | 6.0 WAIT STATE GENERATOR | | | 6.1 Functional Description | 1-548 | | 6.2 Interface Signals | 1-549 | | 6.2.1 READY# | 1-549 | | 6.2.2 READYO# | 1-549 | | 6.2.3 WSC(0-1) | 1-549 | | 6.3 Bus Function | | | 6.3.1 Wait States in Non-Pipelined Cycle | 1-550 | | 6.3.2 Wait States in Pipelined Cycle | 1-551 | | 6.3.3 Extending and Early Terminating Bus Cycle | 1-552 | | 6.4 Register Set Overview | 1-553 | | 6.5 Programming | 1-554 | | 6.6 Register Bit Definition | | | 6.7 Application Issues | 1-554 | | 6.7.1 External 'READY' Control Logic | | | • | | | 7.0 DRAM REFRESH CONTROLLER | | | 7.1 Functional Description | | | 7.2 Interface Signals | | | 7.2.1 TOUT1/REF# | | | 7.3 Bus Function | | | 7.3.1 Arbitration | | | 7.4 Modes of Operation | | | 7.4.1 Word Size and Refresh Address Counter | | | 7.5 Register Set Overview | | | 7.6 Programming | | | 7.7 Register Bit Definition | 1-558 | | intel. | 82380 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | CONTENTS | PAGE | | 8.0 RELOCATION REGISTER AND ADDRESS DECODE 8.1 Relocation Register 8.1.1 I/O-Mapped 82380 8.1.2 Memory-Mapped 82380 8.2 Address Decoding | | | 9.0 CPU RESET AND SHUTDOWN DETECT 9.1 Hardware Reset 9.2 Software Reset 9.3 Shutdown Detect | | | 10.0 INTERNAL CONTROL AND DIAGNOSTIC PORTS 10.1 Internal Control Port 10.2 Diagnostic Ports | 1,560 | | 11.0 INTEL RESERVED I/O PORTS | | | 12.0 MECHANICAL DATA 12.1 Introduction 12.2 Pin Assignment 12.3 Package Dimensions and Mounting 12.4 Package Thermal Specification | | | 13.0 ELECTRICAL DATA 13.1 Power and Grounding 13.2 Power Decoupling 13.3 Unused Pin Recommendations 13.4 ICE-386 Support 13.5 Maximum Ratings 13.6 D.C. Specifications 13.7 A.C. Specifications | | | APPENDIX A—Ports Listed by Address | | | APPENDIX B—Ports Listed by Function | 1-583 | | APPENDIX C—Pin Descriptions | | | APPENDIX D—System Notes | 1-590 | ## intel. ## 1.0 FUNCTIONAL OVERVIEW The 82380 contains several independent functional modules. The following is a brief discussion of the components and features of the 82380. Each module has a corresponding detailed section later in this data sheet. Those sections should be referred to for design and programming information. ### 1.1 82380 Architecture The 82380 is comprised of several computer system functions that are normally found in separate LSI and VLSI components. These include: a high-performance, eight-channel, 32-bit Direct Memory Access Controller; a 20-level Programmable Interrupt Controller which is a superset of the 82C59A; four 16-bit Programmable Interval Timers which are functionally equivalent to the 82C54 timers; a DRAM Refresh Controller; a Programmable Wait State Generator; and system reset logic. The interface to the 82380 is optimized for high-performance operation with the 80386 microprocessor. The 82380 operates directly on the 80386 bus. In the Slave mode, it monitors the state of the proces- sor at all times and acts or idles according to the commands of the host. It monitors the address pipeline status and generates the programmed number of wait states for the device being accessed. The 82380 also has logic to reset the 80386 via hardware or software reset requests and processor shutdown status. After a system reset, the 82380 is in the Slave mode. It appears to the system as an I/O device. It becomes a bus master when it is performing DMA transfers. To maintain compatibility with existing software, the registers within the 82380 are accessed as bytes. If the internal logic of the 82380 requires a delay before another access by the processor, wait states are automatically inserted into the access cycle. This allows the programmer to write initialization routines, etc. without regard to hardware recovery times. Figure 1-1 shows the basic architectural components of the 82380. The following sections briefly discuss the architecture and function of each of the distinct sections of the 82380. Figure 1-1. Architecture of the 82380 ## int<sub>el</sub>, #### 1.1.1 DMA CONTROLLER The 82380 contains a high-performance, 8-channel, 32-bit DMA controller. It is capable of transferring any combination of bytes, words, and double words. The addresses of both source and distination can be independently incremented, decremented or held constant, and cover the entire 32-bit physical address space of the 80386. It can disassemble and assemble misaligned data via a 32-bit internal temporary data storage register. Data transferred between devices of different data path widths can also be assembled and disassembled using the internal temporary data storage register. The DMA Controller can also transfer aligned data between I/O and memory on the fly, allowing data transfer rates up to 32 megabytes per second for an 82380 operating at 16 MHz. Figure 1-2 illustrates the functional components of the DMA Controller. There are twenty-four general status and command registers in the 82380 DMA Controller. Through these registers any of the channels may be programmed into any of the possible modes. The operating modes of any one channel are independent of the operation of the other channels. Each channel has three programmable registers which determine the location and amount of data to be transferred: 82380 Byte Count Register—Number of bytes to transfer. (24-bits) Requester Register—Address of memory or peripheral which is requesting DMA service. (32-bits) Target Register—Address of peripheral or memory which will be accessed. (32-bits) There are also port addresses which, when accessed, cause the 82380 to perform specific functions. The actual data written does not matter, the act of writing to the specific address causes the command to be executed. The commands which operate in this mode are: Master Clear, Clear Terminal Count Interrupt Request, Clear Mask Register, and Clear Byte Pointer Flip-Flop. DMA transfers can be done between all combinations of memory and I/O; memory-to-memory, memory-to-I/O, I/O-to-memory, and I/O-to-I/O. DMA service can be requested through software and/or hardware. Hardware DMA acknowledge signals are available for all channels (except channel 4) through an encoded 3-bit DMA acknowledge bus (EDACK0-2). Figure 1-2. 82380 DMA Controller The 82380 DMA controller transfers blocks of data (buffers) in three modes: Single Buffer, Buffer Auto-Initialize, and Buffer Chaining. In the Single Buffer Process, the 82380 DMA Controller is programmed to transfer one particular block of data. Successive transfers then require reprogramming of the DMA channel. Single Buffer transfers are useful in systems where it is known at the time the transfer begins what quantity of data is to be transferred, and there is a contiguous block of data area available. The Buffer Auto-Initialize Process allows the same data area to be used for successive DMA transfers without having to reprogram the channel. The Buffer Chaining Process allows a program to specify a list of buffer transfers to be executed. The 82380 DMA Controller, through interrupt routines, is reprogrammed from the list. The channel is reprogrammed for a new buffer before the current buffer transfer is complete. This pipelining of the channel programming process allows the system to allocate non-contiguous blocks of data storage space, and transfer all of the data with one DMA process. The buffers that make up the chain do not have to be in contiguous locations. Channel priority can be fixed or rotating. Fixed priority allows the programmer to define the priority of DMA channels based on hardware or other fixed parameters. Rotating priority is used to provide peripherals access to the bus on a shared basis. With fixed priority, the programmer can set any channel to have the current lowest priority. This al- lows the user to reset or manually rotate the priority schedule without reprogramming the command registers. ## 1.1.2 PROGRAMMABLE INTERVAL TIMERS Four 16-bit programmable interval timers reside within the 82380. These timers are identical in function to the timers in the 82C54 Programmable Interval Timer. All four of the timers share a common clock input which can be independent of the system clock. The timers are capable of operating in six different modes. In all of the modes, the current count can be latched and read by the 80386 at any time, making these very versatile event timers. Figure 1-3 shows the functional components of the Programmable Interval Timers. The outputs of the timers are directed to key system functions, making system design simpler. Timer 0 is routed directly to an interrupt input and is not available externally. This timer would typically be used to generate time-keeping interrupts. Timers 1 and 2 have outputs which are available for general timer/counter purposes as well as special functions. Timer 1 is routed to the refresh control logic to provide refresh timing. Timer 2 is connected to an interrupt request input to provide other timer functions. Timer 3 is a general purpose timer/counter whose output is available to external hardware. It is also connected internally to the interrupt request which defaults to the highest priority (IRQQ). Figure 1-3. Programmable Interval Timers—Block Diagram ## 82380 ### 1.1.3 INTERRUPT CONTROLLER The 82380 has the equivalent of three enhanced 82C59A Programmable Interrupt Controllers. These controllers can all be operated in the Master mode, but the priority is always as if they were cascaded. There are 15 interrupt request inputs provided for the user, all of which can be inputs from external slave interrupt controllers. Cascading 82C59As to these request inputs allows a possible total of 120 external interrupt requests. Figure 1-4 is a block diagram of the 82380 Interrupt Controller. Each of the interrupt request inputs can be individually programmed with its own interrupt vector, allowing more flexibility in interrupt vector mapping than was available with the 82C59A. An interrupt is provided to alert the system that an attempt is being made to program the vectors in the method of the 82C59A. This provides compatibility of existing software that used the 82C59A or 8259A with new designs using the 82380. In the event of an unrequested or otherwise erroneous interrupt acknowledge cycle, the 82380 Interrupt Controller issues a default vector. This vector, programmed by the system software, will alert the system of unsolicited interrupts of the 80386. The functions of the 82380 Interrupt Controller are identical to the 82C59A, except in regards to programming the interrupt vectors as mentioned above. Interrupt request inputs are programmable as either edge or level triggered and are software maskable. Priority can be either fixed or rotating and interrupt requests can be nested. Figure 1-4. 82380 Interrupt Controller-Block Diagram intel. Enhancements are added to the 82380 for cascading external interrupt controllers. Master to Slave handshaking takes place on the data bus, instead of dedicated cascade lines. #### 1.1.4 WAIT STATE GENERATOR The Wait State Generator is a programmable READY generation circuit for the 80386 bus. A peripheral requiring wait states can request the Wait State Generator to hold the processor's READY input inactive for a predetermined number of bus states. Six different wait state counts can be programmed into the Wait State Generator by software; three for memory accesses and three for I/O accesses. A block diagram of the 82380 Wait State Generator is shown in Figure 1-5. The peripheral being accessed selects the required wait state count by placing a code on a 2-bit wait state select bus. This code along with the M/IO# signal from the bus master is used to select one of six internal 4-bit wait state registers which has been programmed with the desired number of wait states. From zero to fifteen wait states can be programmed into the wait state registers. The Wait State Generator tracks the state of the processor or current bus master at all times, regardless of which device is the current bus master and regardless of whether or not the Wait State Generator is currently active. The 82380 Wait State Generator is disabled by making the select inputs both high. This allows hardware which is intelligent enough to generate its own ready signal to be accessed without penalty. As previously mentioned, deselecting the Wait State Generator does not disable its ability to determine the proper number of wait states due to pipeline status in subsequent bus cycles. The number of wait states inserted into a pipelined bus cycle is the value in the selected wait state register. If the bus master is operating in the non-pipelined mode, the Wait State Generator will increase the number of wait states inserted into the bus cycle by one. On reset, the Wait State Generator's registers are loaded with the value FFH, giving the maximum number of wait states for any access in which the wait state select inputs are active. #### 1.1.5 DRAM REFRESH CONTROLLER The 82380 DRAM Refresh Controller consists of a 24-bit refresh address counter and bus arbitration logic. The output of Timer 1 is used to periodically request a refresh cycle. When the controller receives the request, it requests access to the system bus through the HOLD signal. When bus control is acknowledged by the processor or current bus master, the refresh controller executes a memory read operation at the address currently in the Refresh Address Register. At the same time, it activates a refresh signal (REF#) that the memory uses to force a refresh instead of a normal read. Control of the bus is transferred to the processor at the completion of this cycle. Typically a refresh cycle will take six clock cycles to execute on an 80386 bus. Figure 1-5. 82380 Wait State Generator—Block Diagram The 82380 DRAM Refresh Controller has the highest priority when requesting bus access and will interrupt any active DMA process. This allows large blocks of data to be moved by the DMA controller without affecting the refresh function. Also the DMA controller is not required to completely relinquish the bus, the refresh controller simply steals a bus cycle between DMA accesses. The amount by which the refresh address is incremented is programmable to allow for different bus widths and memory bank arrangements. ### 1.1.6 CPU RESET FUNCTION The 82380 contains a special reset function which can respond to hardware reset signals from the 82384, as well as a software reset command. The circuit will hold the 80386's RESET line active while an external hardware reset signal is present at its RESET input. It can also reset the 80386 processor as the result of a software command. The software reset command causes the 82380 to hold the processor's RESET line active for a minimum of 62 CLK2 cycles; enough time to allow an 80386 to re-initialize. The 82380 can be programmed to sense the shutdown detect code on the status lines from the 80386. If the Shutdown Detect function is enabled, the 82380 will automatically reset the processor. A diagnostic register is available which can be used to determine the cause of reset. ### 1.1.7 REGISTER MAP RELOCATION After a hardware reset, the internal registers of the 82380 are located in I/O space beginning at port address 0000H. The map of the 82380's registers is relocatable via a software command. The default mapping places the 82380 between I/O addresses 0000H and 00DBH. The relocation register allows this map to be moved to any even 256-byte boundary in the processor's 16-bit I/O address space or any even 16-Mbyte boundary in the 32-bit memory address space. ### 1.2 Host Interface The 82380 is designed to operate efficiently on the local bus of an 80386 microprocessor. The control signals of the 82380 are identical in function to those of the 80386. As a slave, the 82380 operates with all of the features available on the 80386 bus. When the 82380 is in the Master mode, it looks identical to the 80386 to the connected devices. The 82380 monitors the bus at all times, and determines whether the current bus cycle is a pipelined or non-pipelined access. All of the status signals of the processor are monitored. The control, status, and data registers within the 82380 are located at fixed addresses relative to each other, but the group can be relocated to either memory or I/O space and to different locations within those spaces. As a Slave device, the 82380 monitors the control/status lines of the CPU. The 82380 will generate all of the wait states it needs whenever it is accessed. This allows the programmer the freedom of accessing 82380 registers without having to insert NOPs in the program to wait for slower 82380 internal registers. The 82380 can determine if a current bus cycle is a pipelined or a non-pipelined cycle. It does this by monitoring the ADS# and READY# signals and thereby keeping track of the current state of the 80386. As a bus master, the 82380 looks like an 80386 to the rest of the system. This enables the designer greater flexibility in systems which include the 82380. The designer does not have to alter the interfaces of any peripherals designed to operate with the 80386 to accommodate the 82380. The 82380 will access any peripherals on the bus in the same manner as the 80386, including recognizing pipelined bus cycles. The 82380 is accessed as an 8-bit peripheral. This is done to maintain compatibility with existing system architectures and software. The 80386 places the data of all 8-bit accesses either on D (0-7) or D (8-15). The 82380 will only accept data on these lines when in the Slave mode. When in the Master mode, the 82380 is a full 32-bit machine, sending and receiving data in the same manner as the 80386. ## intel. ## 1.3 IBM PC\* System Compatibility The 82380 is an 80386 companion device designed to provide an enhancement of the system functions common to most small computer systems. It is modeled after and is a superset of the Intel peripheral products found in the IBM PC, PC-AT, and other popular small computers. ### 2.0 80386 HOST INTERFACE The 82380 contains a set of interface signals to operate efficiently with the 80386 host processor. These signals were designed so that minimal hardware is needed to connect the 82380 to the 80386. Figure 2-1 depicts a typical system configuration with the 80386 processor. As shown in the diagram, the 82380 is designed to interface directly with the 80386 bus. \*IBM PC and IBM PC-AT are registered trademarks of International Business Machines Inc. Since the 82380 is residing on the opposite side of the data bus transceiver (with respect to the rest of the peripherals in the system), it is important to note that the transceiver should be controlled so that contention between the data bus transceiver and the 82380 will not occur. In order to do this, port address decoding logic should be included in the direction and enable control logic of the transceiver. When any of the 82380 internal registers is read, the data bus transceiver should be disabled so that only the 82380 will drive the local bus. This section describes the basic bus functions of the 82380 to show how this device interacts with the 80386 processor. Other signals which are not directly related to the host interface will be discussed in their associated functional block description. Figure 2-1. 80386/82380 System Configuration ## 2.1 Master and Slave Modes At any time, the 82380 acts as either a Slave device or a Master device in the system. Upon reset, the 82380 will be in the Slave Mode. In this mode, the 80386 processor can read/write into the 82380 internal registers. Initialization information may be programmed into the 82380 during Slave Mode. INTEL CORP {UP/PRPHLS} When DMA service (including DRAM Refresh Cycles generated by the 82380) is requested, the 82380 will request and subsequently get control of the 80386 local bus. This is done through the HOLD and HLDA (Hold Acknowledge) signals. When the 80386 processor responds by asserting the HLDA signal, the 82380 will switch into Master Mode and perform DMA transfers. In this mode, the 82380 is the bus master of the system. It can read/write data from/to memory and peripheral devices. The 82380 will return to the Slave Mode upon completion of DMA transfers, or when HLDA is negated. ## 2.2 80386 Interface Signals As mentioned in the Architecture section, the Bus Interface module of the 82380 (see Figure 1-1) contains signals that are directly connected to the 80386 host processor. This module has separate 32-bit Data and Address busses. Also, it has additional control signals to support different bus operations on the system. By residing on the 80386 local bus, the 82380 shares the same address, data and control lines with the processor. The following subsections discuss the signals which interface to the 80386 host processor. ### 2.2.1 CLOCK (CLK2) 67E D The CLK2 input provides fundamental timing for the 82380. It is divided by two internally to generate the 82380 internal clock. Therefore, CLK2 should be driven with twice the 80386's frequency. In order to maintain synchronization with the 80386 host processor, the 82380 and the 80386 should share a common clock source. The internal clock consists of two phases: PHI1 and PHI2. Each CLK2 period is a phase of the internal clock. PHI2 is usually used to sample input and set up internal signals and PHI1 is for latching internal data. Figure 2-2 illustrates the relationship of CLK2 and the 82380 internal clock signals. The CPURST signal generated by the 82380 guarantees that the 80386 will wake up in phase with PHI1. ## 2.2.2 DATA BUS (D0-D31) This 32-bit three-state bidirectional bus provides a general purpose data path between the 82380 and the system. These pins are tied directly to the corresponding Data Bus pins of the 80386 local bus. The Data Bus is also used for interrupt vectors generated by the 82380 in the Interrupt Acknowledge cycle. During Slave I/O operations, the 82380 expects a single byte to be written or read. When the 80386 host processor writes into the 82380, either D0-D7 or D8-D15 will be latched into the 82380, depending upon how the Byte Enable (BE0#-BE#3) signals are driven. The 82380 does not need to look at D16-D31 since the 80386 duplicates the single byte Figure 2-2. CLK2 and 82380 Internal Clock data on both halves of the bus. When the 80386 host processor reads from the 82380, the single byte data will be duplicated four times on the Data Bus; i.e., on D0-D7, D8-D15, D16-D23 and D24- During Master Mode, the 82380 can transfer 32-, 16-, and 8-bit data between memory (or I/O devices) and I/O devices (or memory) via the Data Bus. ## 2.2.3 ADDRESS BUS (A31-A2) These three-state bidirectional signals are connected directly to the 80386 Address Bus. In the Slave Mode, they are used as input signals so that the processor can address the 82380 internal ports/registers. In the Master Mode, they are used as output signals by the 82380 to address memory and peripheral devices. The Address Bus is capable of addressing 4 G-bytes of physical memory space (00000000H to FFFFFFFFH), and 64 K-bytes of I/O addresses (00000000H to 0000FFFFH). ### 2.2.4 BYTE ENABLE (BE3#-BE0#) These bidirectional pins select specific byte(s) in the double word addressed by A31-A2. Similar to the Address Bus function, these signals are used as inputs to address internal 82380 registers during Slave Mode operation. During Master Mode operation, they are used as outputs by the 82380 to address memory and I/O locations. #### NOTE: In addition to the above function, BE3# is used to enable a production test mode and must be LOW during reset. The 80386 processor will automatically hold BE3# LOW during RESET. The definitions of the Byte Enable signals depend upon whether the 82380 is in the Master or Slave Mode. These definitions are depicted in Table 2-1. Table 2-1. Byte Enable Signals ### As INPUTS (Slave Mode): | BE3#-BE0# | Implied A1, A0 | Data Bits Written<br>to 82380* | | |-----------|----------------|--------------------------------|--| | XXX0 | 00 | D0-D7 | | | XX01 | 01 | D8-D15 | | | X011 | 10 | D0-D7 | | | X111 | 11 | D8-D15 | | X-DON'T CARE ## As OUTPUTS (Master Mode): | BE3#-BE0# | Byte to be Accessed<br>Relative to A31-A2 | Logical Byte Presented On<br>Data Bus During WRITE Only*<br>D24-31 D16-23 D8-15 D0-7 | | | | |-----------|-------------------------------------------|--------------------------------------------------------------------------------------|---|----|---| | 1110 | 0 | U | U | U | A | | 1101 | 1 | U | u | Ā | Ä | | 1011 | 2 | Ü | Ā | ii | A | | 0111 | 3 | Ā | Ü | Ā | Â | | 1001 | 1, 2 | Ü | B | A | Â | | 1100 | 0, 1 | Ü | ū | В | Â | | 0011 | 2, 3 | В | Ā | 8 | Â | | 1000 | 0, 1, 2 | Ū | Ĉ | В | Â | | 0001 | 1, 2, 3 | Č | В | Ā | Â | | 0000 | 0, 1, 2, 3 | Ď | c | B | Â | U = Undefined <sup>\*</sup>During READ, data will be duplicated on D0-D7, D8-D15, D16-D23, and D24-D31. During WRITE, the 80386 host processor duplicates data on D0-D15, and D16-D31, so that the 82380 is concerned only with the lower half of the Data Bus. A = Logical D0-D7 B = Logical D8-D15 C = Logical D16-D23 <sup>\*</sup>Actual number of bytes accessed depends upon the programmed data path width. #### 82380 ## 2.2.5 BUS CYCLE DEFINITION SIGNALS (D/C#, W/R#, M/IO#) These three-state bidirectional signals define the type of bus cycle being performed. W/R# distinguishes between write and read cycles. D/C# distinguishes between processor data and control cycles. M/IO# distinguishes between memory and I/O cycles. During Slave Mode, these signals are driven by the 80386 host processor; during Master Mode, they are driven by the 82380. In either mode, these signals will be valid when the Address Status (ADS#) is driven LOW. Exact bus cycle definitions are given in Table 2-2. Note that some combinations are recognized as inputs, but not generated as outputs. In the Master Mode, D/C# is always HIGH. ### 2.2.6 ADDRESS STATUS (ADS#) This bidirectional signal indicates that a valid address (A2-A31, BE0#-BE3#) and bus cycle definition (W/R#, D/C#, M/IO#) is being driven on the bus. In the Master Mode, it is driven by the 82380 as an output. In the Slave Mode, this signal is monitored as an input by the 82380. By the current and past status of ADS# and the READY# input, the 82380 is able to determine, during Slave Mode, if the next bus cycle is a pipelined address cycle. ADS# is asserted during T1 and T2P bus states (see Bus State Definition). Note that during the idle states at the beginning and the end of a DMA process, neither the 80386 nor the 82380 is driving the ADS# signal; i.e., the signal is left floated. Therefore, it is important to use a pull-up resistor (approximately 10 K $\Omega$ ) on the ADS# signal. ## 2.2.7 TRANSFER ACKNOWLEDGE (READY#) This input indicates that the current bus cycle is complete. In the Master Mode, assertion of this signal indicates the end of a DMA bus cycle. In the Slave Mode, the 82380 monitors this input and ADS# to detect a pipelined address cycles. This signal should be tied directly to the READY# input of the 80386 host processor. ### 2.2.8 NEXT ADDRESS REQUEST (NA#) This input is used to indicate to the 82380 in the Master Mode that the system is requesting address pipelining. When driven LOW by either memory or peripheral devices during Master Mode, it indicates that the system is prepared to accept a new address and bus cycle definition signals from the 82380 before the end of the current bus cycle. If this input is active when sampled by the 82380, the next address is driven onto the bus, provided a bus request is already pending internally. This input pin is monitored only in the Master Mode. In the Slave Mode, the 82380 uses the ADS# and READY# signals to determine address pipelining cycles, and NA# will be ignored. #### 2.2.9 RESET (RESET, CPURST) #### RESET This synchronous input suspends any operation in progress and places the 82380 in a known initial state. Upon reset, the 82380 will be in the Slave Mode waiting to be initialized by the 80386 host processor. The 82380 is reset by asserting RESET for 15 or more CLK2 periods. When RESET is asserted, all other input pins are ignored, and all other bus pins are driven to an idle bus state as shown in Table 2-3. The 82380 will determine the phase of its internal clock following RESET going inactive. #### Table 2-2. Bus Cycle Definition | Table 2-2. Due Cycle Delitition | | | | | | | |---------------------------------|------------|-----|-------------------|---------------|--|--| | M/IO# | As OUTPUTS | | | | | | | 0 | 0 | 0 | Interrupt | NOT GENERATED | | | | | | | Acknowledge | | | | | 0 | 0 | ] 1 | UNDEFINED | NOT GENERATED | | | | 0 | 1 | 0 | I/O Read | I/O Read | | | | 0 | 1 | 1 | I/O Write | I/O Write | | | | 1 | 0 | 0 | UNDEFINED | NOT GENERATED | | | | 1 | 0 | 1 | HALTIF | NOT GENERATED | | | | | | | BE(3-0) # = X011 | | | | | | | İ | SHUTDOWN if | | | | | | | | BE (3-0) # = XXX0 | | | | | 1 | 1 | 0 | Memory Read | Memory Read | | | | 1 | 1 | 1 | Memory Write | Memory Write | | | ## intel. Table 2-3. Output Signals Following RESET | Signal | Level | | | |----------------------------------|--------------------|--|--| | A2-A31, D0-D31, BE0#-BE3# | Float | | | | D/C#, W/R#, M/IO#, ADS# | Float | | | | READYO# | '1' | | | | EOP# | '1' (Weak Pull-UP) | | | | EDACK2-EDACK0 | '100' | | | | HOLD | <b>'0'</b> | | | | INT | UNDEFINED* | | | | TOUT1/REF#, TOUT2#/IRQ3#, TOUT3# | UNDEFINED* | | | | CPURST | ·0' | | | <sup>\*</sup>The Interrupt Controller and Programmable Interval Timer are initialized by software commands. RESET is level-sensitive and must be synchronous to the CLK2 signal. Therefore, this RESET input should be tied to the RESET output of the Clock Generator. The RESET setup and hold time requirements are shown in Figure 2.3. #### **CPURST** This output signal is used to reset the 80386 host processor. It will go active (HIGH) whenever one of the following events occurs: a) 82380's RESET input is active; b) a software RESET command is issued to the 82380; or c) when the 82380 detects a processor Shutdown cycle and when this detection feature is enabled (see CPU Reset and Shutdown Detect). When activated, CPURST will be held active for 62 CLK2 periods. The timing of CPURST is such that the 80386 processor will be in synchronization with the 82380. This timing is shown in Figure 2-4. ### 2.2.10 INTERRUPT OUT (INT) This output pin is used to signal the 80386 host processor that one or more interrupt requests (either internal or external) are pending. The processor is expected to respond with an Interrupt Acknowledge cycle. This signal should be connected directly to the Maskable Interrupt Request (INTR) input of the 80386 host processor. ## 2.3 82380 Bus Timing The 82380 internally divides the CLK2 signal by two to generate its internal clock. Figure 2-2 shows the relationship of CLK2 and the internal clock. The internal clock consists of two phases: PHI1 and PHI2. Each CLK2 period is a phase of the internal clock. In Figure 2-2, both PHI1 and PHI2 of the 82380 internal clock are shown. Figure 2-3. RESET Timing Figure 2-4. CPURST Timing # int<sub>e</sub>l. 82380 In the 82380, whether it is in the Master or Slave Mode, the shortest time unit of bus activity is a bus state. A bus state, which is also referred as a 'T-state', is defined as one 82380 PHI2 clock period (i.e., two CLK2 periods). Recall in Table 2-2, there are six different types of bus cycles in the 82380 as defined by the M/IO#, D/C# and W/R# signals. Each of these bus cycles is composed of two or more bus states. The length of a bus cycle depends on when the READY# input is asserted (i.e., driven LOW). ### 2.3.1 ADDRESS PIPELINING The 82380 supports Address Pipelining as an option in both the Master and Slave Mode. This feature typically allows a memory or peripheral device to operate with one less wait state than would otherwise be required. This is possible because during a pipelined cycle, the address and bus cycle definition of the next cycle will be generated by the bus master while waiting for the end of the current cycle to be acknowledged. The pipelined bus is especially well suited for interleaved memory environment. For 16 MHz interleaved memory designs with 100 ns access time DRAMs, zero wait state memory accesses can be achieved when pipelined addressing is selected. In the Master Mode, the 82380 is capable of initiating, on a cycle-by-cycle basis, either a pipelined or non-pipelined access depending upon the state of the NA# input. If a pipelined cycle is requested (indicated by NA# being driven LOW), the 82380 will drive the address and bus cycle definition of the next cycle as soon as there is an internal bus request pending. In the Slave Mode, the 82380 is constantly monitoring the ADS# and READY# signals on the processor local bus to determine if the current bus cycle is a pipelined cycle. If a pipelined cycle is detected, the 82380 will request one less wait state from the processor if the Wait State Generator feature is selected. On the other hand, during an 82380 internal register access in a pipelined cycle, it will make use of the advance address and bus cycle information. In all cases, Address Pipelining will result in a savings of one wait state. #### 2.3.2 MASTER MODE BUS TIMING When the 82380 is in the Master Mode, it will be in one of six bus states. Figure 2-5 shows the complete bus state diagram of the Master Mode, including pipelined address states. As seen in the figure, the 82380 state diagram is very similar to that of the 80386. The major difference is that in the 82380, there is no Hold state. Also, in the 82380, the conditions for some state transitions depend upon whether it is the end of a DMA process\*. #### NOTE: \*The term 'end of a DMA process' is loosely defined here. It depends on the DMA modes of operation as well as the state of the EOP# and DREQ inputs. This is explained in detail in section 3—DMA Controller. intel. The 82380 will enter the idle state, Ti, upon RESET and whenever the internal address is not available at the end of a DMA cycle or at the end of a DMA process. When address pipelining is not used (NA# is not asserted), a new bus cycle always begins with state T1. During T1, address and bus cycle definition signals will be driven on the bus. T1 is always followed by T2. If a bus cycle is not acknowledged (with READY\*) during T2 and NA\* is negated, T2 will be repeated. When the end of the bus cycle is acknowledged during T2, the following state will be T1 of the next bus cycle (if the internal address latch is loaded and if this is not the end of the DMA process). Otherwise, the Ti state will be entered. Therefore, if the memory or peripheral accessed is fast enough to respond within the first T2, the fastest non-pipelined cycle will take one T1 and one T2 state. Use of the address pipelining feature allows the 82380 to enter three additional bus states: T1P, T2P, and T2i. T1P is the first bus state of a pipelined bus cycle. T2P follows T1P (or T2) if NA# is asserted when sampled. The 82380 will drive the bus with the address and bus cycle definition signals of the next cycle during T2P. From the state diagram, it can be seen that after an idle state Ti, the first bus cycle must begin with T1, and is therefore a non-pipelined bus cycle. The next bus cycle can be pipelined if NA# is asserted and the previous bus cycle ended in a T2P state. Once the 82380 is in a pipelined cycle and provided that NA# is asserted in subsequent cycles, the 82380 will be switching between T1P and T2P states. If the end of the current bus cycle is not acknowledged by the READY# input, the 82380 will extend the cycle by adding T2P states. The fastest pipelined cycle will consist of one T1P and one T2P state. NOTE: ADAV—Internal Address Available Figure 2-5. Master Mode State Diagram 82380 The 82380 will enter state T2i when NA# is asserted and when one of the following two conditions occurs. The first condition is when the 82380 is in state T2. T2i will be entered if READY# is not asserted and there is no next address available. This situation is similar to a wait state. The 82380 will stay in T2i for as long as this condition exists. The second condition which will cause the 82380 enter T2i is when the 82380 is in state T1P. Before going to state T2P, the 82380 needs to wait in state T2i until the next address is available. Also, in both cases, if the DMA process is complete, the 82380 will enter the T2i state in order to finish the current DMA cycle. Figure 2-6 is a timing diagram showing non-pipelined bus accesses in the Master Mode. Figure 2-7 shows the timing of pipelined accesses in the Master Mode. Figure 2-6. Non-Pipelined Bus Cycles Figure 2-7. Pipelined Bus Cycles ## intel. ## 2.3.3 SLAVE MODE BUS TIMING Figure 2-8 shows the Slave Mode bus timing in both pipelined and non-pipelined cycles when the 82380 is being accessed. Recall that during Slave Mode, the 82380 will constantly monitor the ADS# and READY# signals to determine if the next cycle is pipelined. In Figure 2-8, the first cycle is non-pipelined and the second cycle is pipelined. In the pipelined cycle, the 82380 will start decoding the ad- dress and bus cycle signals one bus state earlier than in a non-pipelined cycle. The READY# input signal is sampled by the 80386 host processor to determine the completion of a bus cycle. This occurs during the end of every T2 and T2P state. Normally, the output of the 82380 Wait State Generator, READYO#, is directly connected to the READY# input of the 80386 host processor and the 82380. In such case, READYO# and READY# will be identical (see Wait State Generator). Figure 2-8. Slave Read/Write Timing ## 82380 ### 3.0 DMA CONTROLLER The 82380 DMA Controller is capable of transferring data between any combination of memory and/or I/O, with any combination (8-, 16-, or 32-bits) of data path widths. Bus bandwidth is optimized through the use of an internal temporary register which can disassemble or assemble data to or from either an aligned or a non-aligned destination or source. Fig- ure 3-1 is a block diagram of the 82380 DMA Controller. The 82380 has eight channels of DMA. Each channel operates independently of the others. Within the operation of the individual channels, there are many different modes of data transfer available. Many of the operating modes can be intermixed to provide a very versatile DMA controller. Figure 3-1. 82380 DMA Controller Block Diagram ## 3.1 Functional Description In describing the operation of the 82380's DMA Controller, close attention to terminology is required. Before entering the discussion of the function of the 82380 DMA Controller, the following explanations of some of the terminology used herein may be of benefit. First, a few terms for clarification: DMA PROCESS—A DMA process is the execution of a programmed DMA task from beginning to end. Each DMA process requires initial programming by the host 80386 microprocessor. BUFFER-A contiguous block of data. BUFFER TRANSFER—The action required by the DMA to transfer an entire buffer. DATA TRANSFER—The DMA action in which a group of bytes, words, or double words are moved between devices by the DMA Controller. A data transfer operation may involve movement of one or many bytes. BUS CYCLE—Access by the DMA to a single byte, word, or double word. Each DMA channel consists of three major components. These components are identified by the contents of programmable registers which define the memory or I/O devices being serviced by the DMA. They are the Target, the Requester, and the Byte Count. They will be defined generically here and in greater detail in the DMA register definition section. The Requester is the device which requires service by the 82380 DMA Controller, and makes the request for service. All of the control signals which the DMA monitors or generates for specific channels are logically related to the Requester. Only the Requester is considered capable of initiating or terminating a DMA process. The Target is the device with which the Requester wishes to communicate. As far as the DMA process is concerned, the Target is a slave which is incapable of control over the process. The direction of data transfer can be either from Requester to Target or from Target to Requester; i.e., each can be either a source or a destination. The Requester and Target may each be either I/O or memory. Each has an address associated with it that can be incremented, decremented, or held constant. The addresses are stored in the Requester Address Registers and Target Address Registers, respectively. These registers have two parts: one which contains the current address being used in the DMA process (Current Address Register), and one which holds the programmed base address (Base Address Register). The contents of the Base Registers are never changed by the 82380 DMA Controller. The Current Registers are incremented or decremented according to the progress of the DMA process. The Byte Count is the component of the DMA process which dictates the amount of data which must be transferred. Current and Base Byte Count Registers are provided. The Current Byte Count Register is decremented once for each byte transferred by the DMA process. When the register is decremented past zero, the Byte Count is considered 'expired' and the process is terminated or restarted, depending on the mode of operation of the channel. The point at which the Byte Count expires is called 'Terminal Count' and several status signals are dependent on this event. Each channel of the 82380 DMA Controller also contains a 32-bit Temporary Register for use in assembling and disassembling non-aligned data. The operation of this register is transparent to the user, although the contents of it may affect the timing of some DMA handshake sequences. Since there is data storage available for each channel, the DMA Controller can be interrupted without loss of data. The 82380 DMA Controller is a slave on the bus until a request for DMA service is received via either a software request command or a hardware request signal. The host processor may access any of the control/status or channel registers at any time the 82380 is a bus slave. Figure 3-2 shows the flow of operations that the DMA Controller performs. At the time a DMA service request is received, the DMA Controller issues a bus hold request to the host processor. The 82380 becomes the bus master when the host relinquishes the bus by asserting a hold acknowledge signal. The channel to be serviced will be the one with the highest priority at the time the DMA Controller becomes the bus master. The DMA Controller will remain in control of the bus until the hold acknowledge signal is removed, or until the current DMA transfer is complete. While the 82380 DMA Controller has control of the bus, it will perform the required data transfer(s). The type of transfer, source and destination addresses, and amount of data to transfer are programmed in the control registers of the DMA channel which received the request for service. Figure 3-2. Flow of DMA Controller Operation At completion of the DMA process, the 82380 will remove the bus hold request. At this time the 82380 becomes a slave again, and the host returns to being a master. If there are other DMA channels with requests pending, the controller will again assert the hold request signal and restart the bus arbitration and switching process. ## 3.2 Interface Signals There are fourteen control signals dedicated to the DMA process. They include eight DMA Channel Requests (DREQn), three Encoded DMA Acknowledge signals (EDACKn), Processor Hold and Hold Acknowledge (HOLD, HLDA), and End-Of-Process (EOP#). The DREQn inputs and EDACK(0-2) outputs are handshake signals to the devices requiring DMA service. The HOLD output and HLDA input are handshake signals to the host processor. Figure 3-3 shows these signals and how they interconnect between the 82380 DMA Controller, and the Requester and Target devices. Figure 3-3. Requester, Target, and DMA Controller Interconnection (2-Cycle Configuration) ## 3.2.1 DREQn and EDACK(0-2) These signals are the handshake signals between the peripheral and the 82380. When the peripheral requires DMA service, it asserts the DREQn signal of the channel which is programmed to perform the service. The 82380 arbitrates the DREQn against other pending requests and begins the DMA process after finishing other higher priority processes. When the DMA service for the requested channel is in progress, the EDACK(0-2) signals represent the DMA channel which is accessing the Requester. The 3-bit code on the EDACK(0-2) lines indicates the number of the channel presently being serviced. Table 3-2 shows the encoding of these signals. Note that Channel 4 does not have a corresponding hardware acknowledge. The DMA acknowledge (EDACK) signals indicate the active channel only during DMA accesses to the Requester. During accesses to the Target, EDACK(0-2) has the idle code (100). EDACK(0-2) can thus be used to select a Requester device during a transfer. Table 3-2. EDACK Encoding During a DMA Transfer | EDACK2 | EDACK1 | EDACK0 | Active Channel | |--------|--------|--------|----------------| | 0 | 0 | 0 | 0 | | 0 | 0 | 1 | 1 | | 0 | 1 | 0 | 2 | | 0 | 1 | 1 | 3 | | 1 | 0 | 0 | Target Access | | 1 | 0 | 1 | 5 | | 1 | 1 | 0 | 6 | | _ 1 | 1 | 1 | 7 | DREQn can be programmed as either an Asynchronous or Synchronous input. See section 3.4.1 for details on synchronous versus asynchronous operation of this pin. The EDACKn signals are always active. They either indicate 'no acknowledge' or they indicate a bus access to the requester. The acknowledge code is either 100, for an idle DMA or during a DMA access to the Target, or 'n' during a Requester access, where n is the binary value representing the channel. A simple 3-line to 8-line decoder can be used to provide discrete acknowledge signals for the peripherals. ## 3.2.2 HOLD and HLDA The Hold Request (HOLD) and Hold Acknowledge (HLDA) signals are the handshake signals between the DMA Controller and the host processor. HOLD is an output from the 82380 and HLDA is an input. HOLD is asserted by the DMA Controller when there is a pending DMA request, thus requesting the processor to give up control of the bus so the DMA process can take place. The 80386 responds by asserting HLDA when it is ready to relinquish control of the bus. The 82380 will begin operations on the bus one clock cycle after the HLDA signal goes active. For this reason, other devices on the bus should be in the slave mode when HLDA is active. HOLD and HLDA should not be used to gate or select peripherals requesting DMA service. This is because of the use of DMA-like operations by the DRAM Refresh Controller. The Refresh Controller is arbitrated with the DMA Controller for control of the bus, and refresh cycles have the highest priority. A refresh cycle will take place between DMA cycles without relinquishing bus control. See section 3.4.3 for a more detailed discussion of the interaction between the DMA Controller and the DRAM Refresh Controller. #### 3.2.3 EQP# EOP# is a bi-directional signal used to indicate the end of a DMA process. The 82380 activates this as an output during the T2 states of the last Requester bus cycle for which a channel is programmed to execute. The Requester should respond by either withdrawing its DMA request, or interrupting the host processor to indicate that the channel needs to be programmed with a new buffer. As an input, this signal is used to tell the DMA Controller that the peripheral being serviced does not require any more data to be transferred. This indicates that the current buffer is to be terminated. EOP# can be programmed as either an Asynchronous or a Synchronous input. See section 3.4.1 for details on synchronous versus asynchronous operation of this pin. ## 3.3 Modes of Operation The 82380 DMA Controller has many independent operating functions. When designing peripheral interfaces for the 82380 DMA Controller, all of the functions or modes must be considered. All of the channels are independent of each other (except in priority of operation) and can operate in any of the modes. Many of the operating modes, though independently programmable, affect the operation of other modes. Because of the large number of com- ## intطِ. binations possible, each programmable mode is discussed here with its affects on the operation of other modes. The entire list of possible combinations will not be presented. Table 3-1 shows the categories of DMA features available in the 82380. Each of the five major categories is independent of the others. The sub-categories are the available modes within the major function or mode category. The following sections explain each mode or function and its relation to other features. ### Table 3-1. DMA Operating Modes ## I. Target/Requester Definition - a. Data Transfer Direction - b. Device Type - c. Increment/Decrement/Hold #### II. Buffer Processes - a. Single Buffer Process - b. Buffer Auto-Initialize Process - c. Buffer Chaining Process #### III. Data Transfer/Handshake Modes - a. Single Transfer Mode - b. Demand Transfer Mode - c. Block Transfer Mode - d. Cascade Mode #### IV. Priority Arbitration - a. Fixed - b. Rotating - c. Programmable Fixed ## V. Bus Operation - a. Fly-By (Single-Cycle)/Two-Cycle - b. Data Path Width - c. Read, Write, or Verify Cycles ## 3.3.1 TARGET/REQUESTER DEFINITION All DMA transfers involve three devices: the DMA Controller, the Requester, and the Target. Since the devices to be accessed by the DMA Controller vary widely, the operating characteristics of the DMA Controller must be tailored to the Requester and Target devices. The Requester can be defined as either the source or the destination of the data to be transferred. This is done by specifying a Write or a Read transfer, respectively. In a Read transfer, the Target is the data source and the Requester is the destination for 82380 the data. In a Write transfer, the Requester is the source and the Target in the destination. The Requester and Target addresses can each be independently programmed to be incremented, decremented, or held constant. As an example, the 82380 is capable of reversing a string or data by having a Requester address increment and the Target address decrement in a memory-to-memory transfer. #### 3.3.2 BUFFER TRANSFER PROCESSES ## Single Buffer Process The Single Buffer Process allows the DMA channel to transfer only one buffer of data. When the buffer has been completely transferred (Current Byte Count decremented past zero or EOP# input active), the DMA process ends and the channel becomes idle. In order for that channel to be used again, it must be reprogrammed. The single Buffer Process is usually used when the amount of data to be transferred is known exactly, and it is also known that there is not likely to be any data to follow before the operating system can reprogram the channel. ## **Buffer Auto-Initialize Process** The Buffer Auto-Initialize Process allows multiple groups of data to be transferred to or from a single buffer. This process does not require reprogramming. The Current Registers are automatically reprogrammed from the Base Registers when the current process is terminated, either by an expired Byte Count or by an external EOP# signal. The data transferred will always be between the same Target and Requester. The auto-initialization/process-execution cycle is repeated, with a HOLD/HLDA re-arbitration, until the channel is either disabled or re-programmed. # intel. ## **Buffer Chaining Process** The Buffer Chaining Process is useful for transferring large quantities of data into non-contiguous buffer areas. In this process, a single channel is used to process data from several buffers, while having to program the channel only once. Each new buffer is programmed in a pipelined operation that provides the new buffer information while the old buffer is being processed. The chain is created by loading new buffer information while the 82380 DMA Controller is processing the Current Buffer. When the Current Buffer expires, the 82380 DMA Controller automatically restarts the channel using the new buffer information. Loading the new buffer information is done by an interrupt routine which is requested by the 82380. Interrupt Request 1 (IRQ1) is tied internally to the 82380 DMA Controller for this purpose. IRQ1 is generated by the 82380 when the new buffer information is loaded into the channel's Current Registers, leaving the Base Registers 'empty'. The interrupt service routine loads new buffer information into the Base Registers. The host processor is required to load the information for another buffer before the current Byte Count expires The process repeats until the host programs the channel back to single buffer operation, or until the channel runs out of buffers. The channel runs out of buffers when the Current Buffer expires and the Base Registers have not yet been loaded with new buffer information. When this occurs, the channel must be reprogrammed. If an external EOP# is encountered while executing a Buffer Chaining Process, the current buffer is considered expired and the new buffer information is loaded into the Current Registers. If the Base Registers are 'empty', the chain is terminated. The channel uses the Base Target Address Register as an indicator of whether or not the Base Registers are full. When the most significant byte of the Base Target Register is loaded, the channel considers all of the Base Registers loaded, and removes the interrupt request. This requires that the other Base Registers (Base Requester Address, Last Byte Count) must be loaded before the Base Target Address Register. The reason for implementing the re- loading process this way is that, for most applications, the Byte Count and the Requester will not change from one buffer to the next, and therefore do not need to be reprogrammed. The details of programming the channel for the Buffer Chaining Process can be found in the section of DMA programming. ### 3.3.3 DATA TRANSFER MODES Three Data Transfer modes are available in the 82380 DMA Controller. They are the Single Transfer, Block Transfer, and Demand Transfer Modes. These transfer modes can be used in conjunction with any one of three Buffer Transfer modes: Single Buffer, Auto-Initialized Buffer, and Buffer Chaining. Any Data Transfer Modes can be used under any of the Buffer Transfer Modes These modes are independently available for all DMA channels. Different devices being serviced by the DMA Controller require different handshaking sequences for data transfers to take place. Three handshaking modes are available on the 82380, giving the designer the opportunity to use the DMA Controller as efficiently as possible. The speed at which data can be presented or read by a device can affect the way a DMA controller uses the host's bus, thereby affecting not only data throughput during the DMA process, but also affecting the host's performance by limiting its access to the bus. ## Single Transfer Mode In the Single Transfer Mode, one data transfer to or from the Requester is performed by the DMA Controller at a time. The DREQn input is arbitrated and the HOLD/HLDA sequence is executed for each transfer. Transfers continue in this manner until the Byte Count expires, or until EOP # is sampled active. If the DREQn input is held active continuously, the entire DREQ-HOLD-HLDA-DACK sequence is repeated over and over until the programmed number of bytes has been transferred. Bus control is released to the host between each transfer. Figure 3-4 shows the logical flow of events which make up a buffer transfer using the Single Transfer Mode. Refer to section 3.4 for an explanation of the bus control arbitration procedure. Figure 3-4. Buffer Transfer in Single Transfer Mode ## 82380 The Single Transfer Mode is used for devices which require complete handshake cycles with each data access. Data is transferred to or from the Requester only when the Requester is ready to perform the transfer. Each transfer requires the entire DREQ-HOLD-HLDA-DACK handshake cycle. Figure 3-5 shows the timing of the Single Transfer Mode cy- ## **Block Transfer Mode** In the Block Transfer Mode, the DMA process is initiated by a DMA request and continues until the Byte count expires, or until EOP# is activated by the Requester. The DREQn signal need only be held active until the first Requester access. Only a refresh cycle will interrupt the block transfer process. Figure 3-6 illustrates the operation of the DMA during the Block Transfer Mode. Figure 3-7 shows the timing of the handshake signals during Block Mode Transfers. Figure 3-5. DMA Single Transfer Mode Figure 3-6. Buffer Transfer in **Block Transfer Mode** ## **Demand Transfer Mode** The Demand Transfer Mode provides the most flexible handshaking procedures during the DMA pro-cess. A Demand Transfer is initiated by a DMA request. The process continues until the Byte Count expires, or an external EOP# is encountered. If the device being serviced (Requester) desires, it can interrupt the DMA process by de-activating the DREQn line. Action is taken on the condition of DREQn during Requester accesses only. The access during which DREQn is sampled inactive is the last Requester access which will be performed during the current transfer. Figure 3-8 shows the flow of events during the transfer of a buffer in the Demand Mode. Figure 3-7. Block Mode Transfers Figure 3-8. Buffer Transfer in Demand Transfer Mode When the DREQn line goes inactive, the DMA controller will complete the current transfer, including any necessary accesses to the Target, and relinquish control of the bus to the host. The current process information is saved (byte count, Requester and Target addresses, and Temporary Register). The Requester can restart the transfer process by reasserting DREQn. The 82380 will arbitrate the request with other pending requests and begin the process where it left off. Figure 3-9 shows the timing of handshake signals during Demand Transfer Mode operation. Using the Demand Transfer Mode allows peripherals to access memory in small, irregular bursts without wasting bus control time. The 82380 is designed to give the best possible bus control latency in the Demand Transfer Mode. Bus control latency is defined here as the time from the last active bus cycle of the previous bus master to the first active bus cycle of the new bus master. The 82380 DMA Controller will perform its first bus access cycle two bus states after HLDA goes active. In the typical configuration, bus control is returned to the host one bus state after the DREQn goes inactive. There are two cases where there may be more than one bus state of bus control latency at the end of a transfer. The first is at the end of an Auto-Initialize process, and the second is at the end of a process where the source is the Requester and Two-Cycle transfers are used. When a Buffer Auto-Initialize Process is complete, the 82380 requires seven bus states to reload the Figure 3-9. Demand Mode Transfers Current Registers from the Base Registers of the Auto-Initialized channel. The reloading is done while the 82380 is still the bus master so that it is prepared to service the channel immediately after relinquishing the bus, if necessary. In the case where the Requester is the source, and Two-Cycle transfers are being used, there are two extra idle states at the end of the transfer process. This occurs due to housekeeping in the DMA's internal pipeline. These two idle states are present only after the very last Requester access, before the DMA Controller de-activates the HOLD signal. ## 3.3.4 CHANNEL PRIORITY ARBITRATION DMA channel priority can be programmed into one of two arbitration methods: Fixed or Rotating. The four lower DMA channels and the four upper DMA channels operate as if they were two separate DMA controllers operating in cascade. The lower group of four channels (0–3) is always prioritized between channels 7 and 4 of the upper group of channels (4–7). Figure 3-10 shows a pictorial representation of the priority grouping. The priority can thus be set up as rotating for one group of channels and fixed for the other, or any other combination. While in Fixed Priority, the programmer can also specify which channel has the lowest priority. Figure 3-10. DMA Priority Grouping The 82380 DMA Controller defaults to Fixed Priority. Channel 0 has the highest priority, then 1, 2, 3, 4, 5, 6, 7. Channel 7 has the lowest priority. Any time the DMA Controller arbitrates DMA requests, the requesting channel with the highest priority will be serviced next. Fixed Priority can be entered into at any time by a software command. The priority levels in effect intel. after the mode switch are determined by the current setting of the Programmable Priority. Programmable Priority is available for fixing the priority of the DMA channels within a group to levels other than the default. Through a software command, the channel to have the lowest priority in a group can be specified. Each of the two groups of four channels can have the priority fixed in this way. The other channels in the group will follow the natural Fixed Priority sequence. This mode affects only the priority levels while operating with Fixed Priority. For example, if channel 2 is programmed to have the lowest priority in its group, channel 3 has the highest priority. In descending order, the other channels would have the following priority: (3, 0, 1, 2), 4, 5, 6, 7 (channel 2 lowest, channel 3 highest). If the upper group were programmed to have channel 5 as the lowest priority channel, the priority would be (again, highest to lowest): 6, 7, (3, 0, 1, 2), 4, 5. Figure 3-11 shows this example pictorially. The lower group is always prioritized as a fifth channel of the upper group (between channels 4 and 7). Figure 3-11. Example of Programmed Priority The DMA Controller will only accept Programmable Priority commands while the addressed group is operating in Fixed Priority. Switching from Fixed to Rotating Priority preserves the current priority levels. Switching from Rotating to Fixed Priority returns the priority levels to those which were last programmed by use of Programmable Priority. Rotating Priority allows the devices using DMA to share the system bus more evenly. An individual channel does not retain highest priority after being serviced, priority is passed to the next highest priority channel in the group. The channel which was most recently serviced inherits the lowest priority. This rotation occurs each time a channel is serviced. Figure 3-12 shows the sequence of events as priority is passed between channels. Note that the lower group rotates within the upper group, and that servicing a channel within the lower group causes rotation within the group as well as rotation of the upper group. 82380 Figure 3-12. Rotating Channel Priority. Lower and Upper groups are programmed for the Rotating Priority Mode. # intel. ## 3.3.5 COMBINING PRIORITY MODES Since the DMA Controller operates as two fourchannel controllers in cascade, the overall priority scheme of all eight channels can take on a variety of forms. There are four possible combinations of priority modes between the two groups of channels: Fixed Priority only (default), Fixed Priority upper group/Rotating Priority lower group, Rotating Priority upper group/Fixed Priority lower group, and Rotating Priority only. Figure 3-13 illustrates the operation of the two combined priority methods. Figure 3-13. Combining Priority Modes ### 3.3.6 BUS OPERATION Data may be transferred by the DMA Controller using two different bus cycle operations: Fly-By (onecycle) and Two-Cycle. These bus handshake methods are selectable independently for each channel through a command register. Device data path widths are independently programmable for both Target and Requester. Also selectable through software is the direction of data transfer. All of these parameters affect the operation of the 82380 on a bus-cycle by bus-cycle basis. ### 3.3.6.1 Fly-By Transfers The Fly-By Transfer Mode is the fastest and most efficient way to use the 82380 DMA Controller to transfer data. In this method of transfer, the data is written to the destination device at the same time it is read from the source. Only one bus cycle is used to accomplish the transfer. In the Fly-By Mode, the DMA acknowledge signal is used to select the Requester. The DMA Controller simultaneously places the address of the Target on the address bus. The state of M/IO# and W/R# during the Fly-By transfer cycle indicate the type of Target and whether the target is being written to or read from. The Target's Bus Size is used as an incrementer for the Byte Count. The Requester address registers are ignored during Fly-By transfers. Note that memory-to-memory transfers cannot be done using the Fly-By Mode. Only one memory or I/O address is generated by the DMA Controller at a time during Fly-By transfers. Only one of the devices being accessed can be selected by an address. Also, the Fly-By method of data transfer limits the hardware to accesses of devices with the same data bus width. The Temporary Registers are not affected in the Fly-By Mode. Fly-By transfers also require that the data paths of the Target and Requester be directly connected. This requires that successive Fly-By accesses be to doubleword boundaries, or that the Requester be capable of switching its connections to the data bus. ## 3.3.6.2 Two-Cycle Transfers Two-Cycle transfers can also be performed by the 82380 DMA Controller. These transfers require at least two bus cycles to execute. The data being transferred is read into the DMA Controller's Temporary Register during the first bus cycle(s). The second bus cycle is used to write the data from the Temporary Register to the destination. If the addresses of the data being transferred are not word or doubleword aligned, the 82380 will recognize the situation and read and write the data in groups of bytes, placing them always at the proper destination. This process of collecting the desired bytes and putting them together is called 'byte assembly'. The reverse process (reading from aligned locations and writing to non-aligned locations) is called 'byte disassembly'. The assembly/disassembly process takes place transparent to the software, but can only be done while using the Two-Cycle transfer method. The 82380 will always perform the assembly/disassembly process as necessary for the current data transfer. Any data path widths for either the Requester or Target can be used in the Two-Cycle Mode. This is very convenient for interfacing existing 8- and 16-bit peripherals to the 80386's 32-bit bus. The 82380 DMA Controller always attempts to fill the Temporary Register from the source before writing any data to the destination. If the process is terminated before the Temporary Register is filled (TC or EOP#), the 82380 will write the partial data to the destination. If a process is temporarily suspended (such as when DREQn is de-activated during a demand transfer), the contents of a partially filled Temporary Register will be stored within the 82380 until the process is restarted. For example, if the source is specified as an 8-bit device and the destination as a 32-bit device, there will be four reads as necessary from the 8-bit source to fill the Temporary Register. Then the 82380 will write the 32-bit contents to the destination. This cycle will repeat until the process is terminated or sus- Note that for a Single-Cycle transfer mode of operation (see section 3.3.3), the internal circuitry of the DMA Controller actually executes single transfers by removing the DREQ from the internal arbitration. Thus single transfers from an 8-bit requester to a 32bit target will consist of four complete and independent 8-bit requester cycles, between which bus control is released and re-requested. Finally, the 32-bit data will be transferred to the target device from the temporary register before the fifth requester cycle. With Two-Cycle transfers, the devices that the 82380 accesses can reside at any address within I/O or memory space. The device must be able to decode the byte-enables (BEn#). Also, if the device cannot accept data in byte quantities, the programmer must take care not to allow the DMA Controller to access the device on any address other than the device boundary. ## 3.3.6.3 Data Path Width and Data Transfer Rate Considerations The number of bus cycles used to transfer a single 'word' of data is affected by whether the Two-Cycle or the Fly-By (Single-Cycle) transfer method is used. The number of bus cycles used to transfer data directly affects the data transfer rate. Inefficient use of bus cycles will decrease the effective data transfer rate that can be obtained. Generally, the data transfer rate is halved by using Two-Cycle transfers instead of Fly-By transfers. The choice of data path widths of both Target and Requester affects the data transfer rate also. During each bus cycle, the largest pieces of data possible should be transferred. The data path width of the devices to be accessed must be programmed into the DMA controller. The 82380 defaults after reset to 8-bit-to-8-bit data transfers, but the Target and Requester can have different data path widths, independent of each other and independent of the other channels. Since this is a software programmable function, more discussion of the uses of this feature are found in the section on programming. ### 3.3.6.4 Read, Write, and Verify Cycles Three different bus cycle types may be used in a data transfer. They are the Read, Write, and Verify cycles. These cycle types dictate the way in which the 82380 operates on the data to be transferred. A Read Cycle transfers data from the Target to the Requester. A Write Cycle transfers data from the Requester to the target. In a Fly-By transfer, the address and bus status signals indicate the access (read or write) to the Target; the access to the Requester is assumed to be the opposite. The Verify Cycle is used to perform a data read only. No write access is indicated or assumed in a Verify Cycle. The Verify Cycle is useful for validating block fill operations. An external comparator must be provided to do any comparisons on the data read. ### 3.4 Bus Arbitration and Handshaking Figure 3-14 shows the flow of events in the DMA request arbitration process. The arbitration se- quence starts when the Requester asserts a DREQn (or DMA service is requested by software). Figure 3-15 shows the timing of the sequence of events following a DMA request. This sequence is executed for each channel that is activated. The DREQn signal can be replaced by a software DMA channel request with no change in the sequence. Figure 3-14. Bus Arbitration and DMA Sequence After the Requester asserts the service request, the 82380 will request control of the bus via the HOLD signal. The 82380 will always assert the HOLD signal one bus state after the service request is asserted. The 80386 responds by asserting the HLDA signal, thus releasing control of the bus to the 82380 DMA Controller. Priority of pending DMA service requests is arbitrated during the first state after HLDA is asserted by the 80386. The next state will be the beginning of the first transfer access of the highest priority process. # int<sub>e</sub>l. 82380 When the 82380 DMA Controller is finished with its current bus activity, it returns control of the bus to the host processor. This is done by driving the HOLD signal inactive. The 82380 does not drive any address or data bus signals after HOLD goes low. It enters the Slave Mode until another DMA process is requested. The processor acknowledges that it has regained control of the bus by forcing the HLDA signal inactive. Note that the 82380's DMA Controller will not re-request control of the bus until the entire HOLD/HLDA handshake sequence is complete. The 82380 DMA Controller will terminate a current DMA process for one of three reasons: expired byte count, end-of-process command (EOP# activated) from a peripheral, or de-activated DMA request signal. In each case, the controller will de-assert HOLD immediately after completing the data transfer in progress. These three methods of process termination are illustrated in Figures 3-16, 3-19, and 3-18, respectively. An expired byte count indicates that the current process is complete as programmed and the channel has no further transfers to process. The channel must be restarted according to the currently programmed Buffer Transfer Mode, or reprogrammed completely, including a new Buffer Transfer Mode. If the peripheral activates the EOP # signal, it is indicating that it will not accept or deliver any more data for the current buffer. The 82380 DMA Controller considers this as a completion of the channel's current process and interprets the condition the same way as if the byte count expired. The action taken by the 82380 DMA Controller in response to a de-activated DREQn signal depends on the Data Transfer Mode of the channel. In the Demand Mode, data transfers will take place as long as the DREQn is active and the byte count has not expired. In the Block Mode, the controller will complete the entire block transfer without relinquishing Figure 3-15. Beginning of a DMA process intel. the bus, even if DREQn goes inactive before the transfer is complete. In the Single Mode, the controller will execute single data transfers, relinquishing the bus between each transfer, as long as DREQn is active. Normal termination of a DMA process due to expiration of the byte count (Terminal Count-TC) is shown in Figure 3-16. The condition of DREQn is ignored until after the process is terminated. If the channel is programmed to auto-initialize, HOLD will be held active for an additional seven clock cycles while the auto-initialization takes place. Table 3-3 shows the DMA channel activity due to EOP# or Byte Count expiring (Terminal Count). | Buffer Process: | Single<br>or Chaining-<br>Base Empty | | Auto-<br>Initialize | | Chaining-<br>Base Loaded | | |-----------------------|--------------------------------------|-----|---------------------|------|--------------------------|------| | Event | | | | | | | | Terminal Count | True | X | True | X | True | X | | EOP# Input | × | 0 | X | 0 | X | 0 | | Results | | | | | | | | Current Registers | - | _ | Load | Load | Load | Load | | Channel Mask | Set | Set | - | _ | | _ | | EOP# Output | 0 | X | 0 | X | 1 | X | | Terminal Count Status | Set | Set | Set | Set | _ | _ | | Software Request | CLR | CLR | CLR | CLR | _ | | Table 3-3, DMA Channel Activity Due to Terminal Count or External EOP# Figure 3-16. Termination of a DMA Process Due to Expiration of Current Byte Count 82380 The 82380 always relinquishes control of the bus between channel services. This allows the hardware designer the flexibility to externally arbitrate bus hold requests, if desired. If another DMA request is pending when a higher priority channel service is completed, the 82380 will relinquish the bus until the hold acknowledge is inactive. One bus state after the HLDA signal goes inactive, the 82380 will assert HOLD again. This is illustrated in Figure 3-17. ### 3.4.1 SYNCHRONOUS AND ASYNCHRONOUS SAMPLING OF DREQ! AND EOP# As an indicator that a DMA service is to be started, DREQn is always sampled asynchronously. It is sampled at the beginning of a bus state and acted upon at the end of the state. Figure 3-15 illustrates the start of a DMA process due to a DREQn input. The DREQn and EOP # inputs can be programmed to be sampled either synchronously or asynchronously to signal the end of a transfer. The synchronous mode affords the Requester one bus state of extra time to react to an access. This means the Requester can terminate a process on the current access, without losing any data. The asynchronous mode requires that the input signal be presented prior to the beginning of the last state of the Requester access. The timing relationships of the DREQn and EOP# signals to the termination of a DMA transfer are shown in Figures 3-18 and 3-19. Figure 3-18 shows the termination of a DMA transfer due to inactive DREQn. Figure 3-19 shows the termination of a DMA process due to an active EOP# input. In the Synchronous Mode, DREQn and EOP# are sampled at the end of the last state of every Requester data transfer cycle. If EOP# is active or DREQn is inactive at this time, the 82380 recognizes this access to the Requester as the last transfer. At this point, the 82380 completes the transfer in progress, if necessary, and returns bus control to the host. In the asynchronous mode, the inputs are sampled at the beginning of every state of a Requester access. The 82380 waits until the end of the state to act on the input. DREQn and EOP# are sampled at the latest possible time when the 82380 can determine if another transfer is required. In the Synchronous Mode, DREQn and EOP# are sampled on the trailing edge of the last bus state before another data access cycle begins. The Asynchronous Mode requires that the signals be valid one clock cycle earlier. Figure 3-17. Switching between Active DMA Channels intel. Figure 3-18. Termination of a DMA Process Due to De-Asserting DREQn Figure 3-19. Termination of a DMA Process Due to an External EOP# 82380 While in the Pipeline Mode, if the NA# signal is sampled active during a transfer, the end of the state where NA# was sampled active is when the 82380 decides whether to commit to another transfer. The device must de-assert DREQn or assert EOP# before NA# is asserted, otherwise the 82380 will commit to another, possibly undesired, transfer. Synchronous DREQn and EOP# sampling allows the peripheral to prevent the next transfer from occurring by de-activating DREQn or asserting EOP# during the current Requester access, before the 82380 DMA Controller commits itself to another transfer. The DMA Controller will not perform the next transfer if it has not already begun the bus cycle. Asynchronous sampling allows less stringent timing requirements than the Synchronous Mode, but requires that the DREQn signal be valid at the beginning of the next to last bus state of the current Requester access. Using the Asynchronous Mode with zero wait states can be very difficult. Since the addresses and control signals are driven by the 82380 near half-way through the first bus state of a transfer, and the Asynchronous Mode requires that DREQn be active before the end of the state, the peripheral being accessed is required to present DREQn only a few nanoseconds after the control information is available. This means that the peripheral's control logic must be extremely fast (practically non-causal). An alternative is the Synchronous Mode. ### 3.4.2 ARBITRATION OF CASCADED MASTER REQUESTS The Cascade Mode allows another DMA-type device to share the bus by arbitrating its bus accesses with the 82380's. Seven of the eight DMA channels (0–3 and 5–7) can be connected to a cascaded device. The cascaded device requests bus control through the DREQn line of the channel which is programmed to operate in Cascade Mode. Bus hold acknowledge is signaled to the cascaded device through the EDACK lines. When the EDACK lines are active with the code for the requested cascade channel, the bus is available to the cascaded master device. Figure 3-20. Cascaded Bus Master A Cascade cycle begins the same way a regular DMA cycle begins. The requesting bus master asserts the DREQn line on the 82380. This bus control request arbitrated as any other DMA request would be. If any channel receives a DMA request, the 82380 requests control of the bus. When the host acknowledges that it has released bus control, the 82380 acknowledges to the requesting master that it may access the bus. The 82380 enters an idle state until the new master relinquishes control. A cascade cycle will be terminated by one of two events: DREQn going inactive, or HLDA going inactive. The normal way to terminate the cascade cycle is for the cascaded master to drop the DREQn signal. Figure 3-21 shows the two cascade cycle termination sequences. The Refresh Controller may interrupt the cascaded master to perform a refresh cycle. If this occurs, the 82380 DMA Controller will de-assert the EDACK signal (hold acknowledge to cascaded master) and wait for the cascaded master to remove its hold request. When the 82380 regains bus control, it will perform the refresh cycle in its normal fashion. After the refresh cycle has been completed, and if the cascaded device has re-asserted its request, the 82380 will return control to the cascaded master which was interrupted. Figure 3-21. Cascade Cycle Termination The 82380 assumes that it is the only device monitoring the HLDA signal. If the system designer wishes to place other devices on the bus as bus masters, the HLDA from the processor must be intercepted before presenting it to the 82380. Using the Cascade capability of the 82380 DMA Controller offers a much better solution. #### 3.4.3 ARBITRATION OF REFRESH REQUESTS The arbitration of refresh requests by the DRAM Refresh Controller is slightly different from normal DMA channel request arbitration. The 82380 DRAM Refresh Controller always has the highest priority of any DMA process. It also can interrupt a process in progress. Two types of processes in progress may be encountered: normal DMA, and bus master cascade. In the event of a refresh request during a normal DMA process, the DMA Controller will complete the data transfer in progress and then execute the refresh cycle before continuing with the current DMA process. The priority of the interrupted process is not lost. If the data transfer cycle interrupted by the Refresh Controller is the last of a DMA process, the refresh cycle will always be executed before control of the bus is transferred back to the host. When the Refresh Controller request occurs during a cascade cycle, the Refresh Controller must be assured that the cascaded master device has relinquished control of the bus before it can execute the refresh cycle. To do this, the DMA Controller drops the EDACK signal to the cascaded master and waits for the corresponding DREQn input to go inactive. By dropping the DREQn signal, the cascaded master relinquishes the bus. The Refresh Controller then performs the refresh cycle. Control of the bus is returned to the cascaded master if DREQn returns to an active state before the end of the refresh cycle, otherwise control is passed to the processor and the cascaded master loses its priority. #### 3.5 DMA Controller Register Overview The 82380 DMA Controller contains 44 registers which are accessable to the host processor. Twenty-four of these registers contain the device addresses and data counts for the individual DMA channels (three per channel). The remaining registers are control and status registers for initiating and monitoring the operation of the 82380 DMA Controller. Table 3-4 lists the DMA Controller's registers and their accessability. | Register Name | Access | |------------------------------------|---------------| | Control/Status Register—C<br>Group | ne Each Per | | Command Register I | Write Only | | Command Register II | Write Only | | Mode Register I | Write Only | | Mode Register II | Write Only | | Software Request Register | Read/Write | | Mask Set-Reset Register | Write Only | | Mask Read-Write Register | Read/Write | | Status Register | Read Only | | Bus Size Register | Write Only | | Chaining Register | Read/Write | | Channel Registers—One Eac | h Per Channel | | Base Target Address | Write Only | | Current Target Address | Read Only | | Base Requester Address | Write Only | | Current Requester Address | Read Only | | Base Byte Count | Write Only | | Current Byte Count | Read Only | **Table 3-4. DMA Controller Registers** #### 3.5.1 CONTROL/STATUS REGISTERS The following registers are available to the host processor for programming the 82380 DMA Controller into its various modes and for checking the operating status of the DMA processes. Each set of four DMA channels has one of each of these registers associated with it. #### Command Register I Enables or disables the DMA channels as a group. Sets the Priority Mode (Fixed or Rotating) of the group. This write-only register is cleared by a hardware reset, defaulting to all channels enabled and Fixed Priority Mode. #### Command Register II Sets the sampling mode of the DREQn and EOP# inputs. Also sets the lowest priority channel for the group in the Fixed Priority Mode. The functions programmed through Command Register II default after a hardware reset to: asynchronous DREQn and EOP#, and channels 3 and 7 lowest priority. #### Mode Register I Mode Register I is identical in function to the Mode register of the 8237A. It programs the following functions for an individually selected channel: Type of Transfer—read, write, verify Auto—Initialize—enable or disable Target Address Count—increment or decrement Data Transfer Mode—demand, single, block, cascade Mode Register I functions default to the following after reset: verify transfer, Auto-Initialize disabled, Increment Target address, Demand Mode. #### Mode Register II Programs the following functions for an individually selected channel: Target Address Hold—enable or disable Requester Address Count—increment or decrement Requester Address Hold—enable or disable Target Device Type—I/O or Memory Requester Device Type—I/O or Memory Transfer Cycles—Two-Cycle or Fly-By Mode Register II functions are defined as follows after a hardware reset: Disable Target Address Hold, Increment Requester Address, Target (and Requester) in memory, Fly-By Transfer Cycles. Note: Requester Device Type ignored in Fly-By Transfers. #### Software Request Register The DMA Controller can respond to service requests which are initiated by software. Each channel has an internal request status bit associated with it. The host processor can write to this register to set or reset the request bit of a selected channel. The status of the group's software DMA service requests can be read from this register as well. Each request bit is cleared upon Terminal Count or external EOP#. The software DMA requests are non-maskable and subject to priority arbitration with all other software and hardware requests. The entire register is cleared by a hardware reset. #### Mask Registers Each channel has associated with it a mask bit which can be set/reset to disable/enable that channel. Two methods are available for setting and clearing the mask bits. The Mask Set/Reset Register is a write-only register which allows the host to select an individual channel and either set or reset the mask bit for that channel only. The Mask Read/Write Register is available for reading the mask bit status and for writing mask bits in groups of four. The mask bits of a group may be cleared in one step by executing the Clear Mask Command. See the DMA Programming section for details. A hardware reset sets all of the channel mask bits, disabling all channels #### **Status Register** The Status register is a read-only register which contains the Terminal Count (TC) and Service Request status for a group. Four bits indicate the TC status and four bits indicate the hardware request status for the four channels in the group. The TC bits are set when the Byte Count expires, or when an external EOP# is asserted. These bits are cleared by reading from the Status Register. The Service Request bit for a channel indicates when there is a hardware DMA request (DREQn) asserted for that channel. When the request has been removed, the bit is cleared. #### **Bus Size Register** This write-only register is used to define the bus size of the Target and Requester of a selected channel. The bus sizes programmed will be used to dictate the sizes of the data paths accessed when the DMA channel is active. The values programmed into this register affect the operation of the Temporary Register. Any byte-assembly required to make the transfers using the specified data path widths will be done in the Temporary Register. The Bus Size register of the Target is used as an increment/decrement value for the Byte Counter and Target Address when in the Fly-By Mode. Upon reset, all channels default to 8-bit Targets and 8-bit Requesters. #### **Chaining Register** As a command or write register, the Chaining register is used to enable or disable the Chaining Mode for a selected channel. Chaining can either be disabled or enabled for an individual channel, independently of the Chaining Mode status of other channels. After a hardware reset, all channels default to Chaining disabled. When read by the host, the Chaining Register provides the status of the Chaining Interrupt of each of the channels. These interrupt status bits are cleared when the new buffer information has been loaded. #### 3.5.2 CHANNEL REGISTERS Each channel has three individually programmable registers necessary for the DMA process; they are the Base Byte Count, Base Target Address, and Base Requester Address registers. The 24-bit Base 82380 Byte Count register contains the number of bytes to be transferred by the channel. The 32-bit Base Target Address Register contains the beginning address (memory or I/O) of the Target device. The 32bit Base Requester Address register contains the base address (memory or I/O) of the device which is to request DMA service. Three more registers for each DMA channel exist within the DMA Controller which are directly related to the registers mentioned above. These registers contain the current status of the DMA process. They are the Current Byte Count register, the Current Target Address, and the Current Requester Address. It is these registers which are manipulated (incremented, decremented, or held constant) by the 82380 DMA Controller during the DMA process. The Current registers are loaded from the Base registers. The Base registers are loaded when the host processor writes to the respective channel register addresses. Depending on the mode in which the channel is operating, the Current registers are typically loaded in the same operation. Reading from the channel register addresses yields the contents of the corresponding Current register. To maintain compatibility with software which accesses an 8237A, a Byte Pointer Flip-Flop is used to control access to the upper and lower bytes of some words of the Channel Registers. These words are accessed as byte pairs at single port addresses. The Byte Pointer Flip-Flop acts as a one-bit pointer which is toggled each time a qualifying Channel Register byte is accessed. It always points to the next logical byte to be accessed of a pair of bytes. The Channel registers are arranged as pairs of words, each pair with its own port address. Addressing the port with the Byte Pointer Flip-Flop reset accesses the least significant byte of the pair. The most significant byte is accessed when the Byte Pointer is set. For compatibility with existing 8237A designs, there is one exception to the above statements about the Byte Pointer Flip-Flop. The third byte (bits 16–23) of the Target Address is accessed through its own port address. The Byte Pointer Flip-Flop is not affected by any accesses to this byte. The upper eight bits of the Byte Count Register are cleared when the least significant byte of the register is loaded. This provides compatibility with software which accesses an 8237A. The 8237A has 16-bit Byte Count Registers. #### 3.5.3 TEMPORARY REGISTERS Each channel has a 32-bit Temporary Register used for temporary data storage during two-cycle DMA transfers. It is this register in which any necessary byte assembly and disassembly of non-aligned data is performed. Figure 3-22 shows how a block of data will be moved between memory locations with different boundaries. Note that the order of the data does not change. | SOU | RCE | DESTINATION | | |-----|-----|-------------|---| | 20H | Α | 50H | | | 21H | В | 51H | | | 22H | С | 52H | | | 23H | D | 53H | Α | | 24H | E | 54H | В | | 25H | F | 55H | C | | 26H | G | 56H | D | | 27H | | 57H | E | | | | 58H | F | | | | 59H | G | | | | 5AH | | Figure 3-22. Transfer of Data between Memory Locations with Different Boundaries. This will be the result, independent of data path width. If the destination is the Requester and an early process termination has been indicated by the EOP# signal or DREQn inactive in the Demand Mode, the Temporary Register is not affected. If data remains in the Temporary Register due to differences in data path widths of the Target and Requester, it will not be transferred or otherwise lost, but will be stored for later transfer. If the destination is the Target and the EOP# signal is sensed active during the Requester access of a transfer, the DMA Controller will complete the transfer by sending to the Target whatever information is in the Temporary Register at the time of process termination. This implies that the Target could be accessed with partial data. For this reason it is advisable to have an I/O device designated as a Requester, unless it is capable of handling partial data transfers. ### 3.6 DMA Controller Programming Programming a DMA Channel to perform a needed DMA function is in general a four step process. First the global attributes of the DMA Controller are programmed via the two Command Registers. These global attributes include: priority levels, channel group enables, priority mode, and DREQn/EOP# input sampling. The second step involves setting the operating modes of the particular channel. The Mode Registers are used to define the type of transfer and the handshaking modes. The Bus Size Register and Chaining Register may also need to be programmed in this step. The third step is setting up the channel is to load the Base Registers in accordance with the needs of the operating modes chosen in step two. The Current Registers are automatically loaded from the Base Registers, if required by the Buffer Transfer Mode in effect. The information loaded and the order in which it is loaded depends on the operating mode. A channel used for cascading, for example, needs no buffer information and this step can be skipped entirely. The last step is to enable the newly programmed channel using one of the Mask Registers. The channel is then available to perform the desired data transfer. The status of the channel can be observed at any time through the Status Register, Mask Register, Chaining Register, and Software Request register. Once the channel is programmed and enabled, the DMA process may be initiated in one of two ways, either by a hardware DMA request (DREQn) or a software request (Software Request Register). Once programmed to a particular Process/Mode configuration, the channel will operate in that configuration until programmed otherwise. For this reason, restarting a channel after the current buffer expires does not require complete reprogramming of the channel. Only those parameters which have changed need to be reprogrammed. The Byte Count Register is always changed and must be reprogrammed. A Target or Requester Address Register which is incremented or decremented should be reprogrammed also. #### 3.6.1 BUFFER PROCESSES The Buffer Process is determined by the Auto-Initialize bit of Mode Register I and the Chaining Register. If Auto-Initialize is enabled, Chaining should not be used. #### 3.6.1.1 Single Buffer Process The Single Buffer Process is programmed by disabling Chaining via the Chaining Register and programming Mode Register I for non-Auto-Initialize. #### 3.6.1.2 Buffer Auto-Initialize Process Setting the Auto-Initialize bit in Mode Register I is all that is necessary to place the channel in this mode. Buffer Auto-Initialize must not be enabled simultaneous to enabling the Buffer Chaining Mode as this will have unpredictable results. Once the Base Registers are loaded, the channel is ready to be enabled. The channel will reload its Current Registers from the Base Registers each time the Current Buffer expires, either by an expired Byte Count or an external EOP#. #### 3.6.1.3 Buffer Chaining Process The Buffer Chaining Process is entered into from the Single Buffer Process. The Mode Registers should be programmed first, with all of the Transfer Modes defined as if the channel were to operate in the Single Buffer Process. The channel's Base and Current Registers are then loaded. When the channel has been set up in this way, and the chaining interrupt service routine is in place, the Chaining Process can be entered by programming the Chaining Register. Figure 3.23 illustrates the Buffer Chaining Process. An interrupt (IRQ1) will be generated immediately after the Chaining Process is entered, as the channel then perceives the Base Registers as empty and in need of reloading. It is important to have the interrupt service routine in place at the time the Chaining Process is entered into. The interrupt request is removed when the most significant byte of the Base Target Address is loaded. The interrupt will occur again when the first buffer expires and the Current Registers are loaded from the Base Registers. The cycle continues until the Chaining Process is disabled, or the host fails to respond to IRQ1 before the Current Buffer expires. Figure 3-23. Flow of Events in the **Buffer Chaining Process** Exiting the Chaining Process can be done by resetting the Chaining Mode Register. If an interrupt is pending for the channel when the Chaining Register is reset, the interrupt request will be removed. The Chaining Process can be temporarily disabled by setting the channel's Mask bit in the Mask Register. The interrupt service routine for IRQ1 has the responsibility of reloading the Base Register as necessary. It should check the status of the channel to determine the cause of channel expiration, etc. It should also have access to operating system information regarding the channel, if any exists. The IRQ1 service routine should be capable of determining whether the chain should be continued or terminated and act on that information. #### 3.6.2 DATA TRANSFER MODES The Data Transfer Modes are selected via Mode Register I. The Demand, Single, and Block Modes are selected by bits D6 and D7. The individual transfer type (Fly-By vs Two-Cycle, Read-Write-Verify, and I/O vs Memory) is programmed through both of the Mode registers. #### 3.6.3 CASCADED BUS MASTERS The Cascade Mode is set by writing ones to D7 and D6 of Mode Register I. When a channel is programmed to operate in the Cascade Mode, all of the other modes associated with Mode Registers I and II are ignored. The priority and DREQn/EOP# definitions of the Command Registers will have the same effect on the channel's operation as any other mode. #### 3.6.4 SOFTWARE COMMANDS There are five port addresses which, when written to, command certain operations to be performed by the 82380 DMA Controller. The data written to these locations is not of consequence, writing to the location is all that is necessary to command the 82380 to perform the indicated function. Following are descriptions of the command function. Clear Byte Pointer Flip-Flop-location 000CH Resets the Byte Pointer Flip-Flop. This command should be performed at the beginning of any access to the channel registers in order to be assured of beginning at a predictable place in the register programming sequence. Master Clear-location 000DH All DMA functions are set to their default states. This command is the equivalent of a hardware reset to the DMA Controller. Functions other than those in the DMA Controller section of the 82380 are not affected by this command. Clear Mask ---Channels 0-3---location 000EH Channels 4-7---location 00CEH Register This command simultaneously clears the Mask Bits of all channels in the addressed group, enabling all of the channels in the group. Clear TC Interrupt Request—location 001EH This command resets the Terminal Count Interrupt Request Flip-Flop. It is provided to allow the program which made a software DMA request to acknowledge that it has responded to the expiration of the requested channel(s). ### 3.7 Register Definitions The following diagrams outline the bit definitions and functions of the 82380 DMA Controller's Status and Control Registers. The function and programming of the registers is covered in the previous section on DMA Controller Programming. An entry of 'X' as a bit value indicates "don't care." | Channel Registers | | (Read Current, Wr | ite Base) | | |-------------------|-------------------|-------------------|-----------------|------------------| | Channel | Register Name | Address<br>(Hex) | Byte<br>Pointer | Bits<br>Accessed | | Channel 0 | Target Address | 00 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 87 | × | 16-23 | | | | 10 | 0 | 24-31 | | | Byte Count | 01 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 11 | 0 | 16-23 | | | Requester Address | 90 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 91 | 0 | 16-23 | | | | | 1 | 24-31 | | Channel 1 | Target Address | 02 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 83 | x | 16-23 | | | | 12 | 0 | 24-31 | | | Byte Count | 03 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 13 | 0 | 16-23 | | | Requester Address | 92 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 93 | 0 | 16-23 | | | | | 1 | 24-31 | 82380 | Channel Registers | | (Read Current, Write Base) | | | |-------------------|-------------------|----------------------------|---------|----------| | Channel Channel | Register Name | Address | Byte | Bits | | Channel | • | (Hex) | Pointer | Accessed | | Channel 2 | Target Address | 04 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 81 | × | 16-23 | | | | 14 | 0 | . 24-31 | | | Byte Count | 05 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 15 | 0 | 16-23 | | | Requester Address | 94 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 95 | 0 | 16-23 | | | | | 1 | 24-31 | | Channel 3 | Target Address | 06 | 0 | 0-7 | | | · · | | 1 | 8-15 | | | | 82 | x | 16-23 | | | | 16 | Ö | 24-31 | | | Byte Count | 07 | 0 | 0-7 | | | • | | 1 | 8-15 | | | | 17 | 0 | 16-23 | | | Requester Address | 96 | Ö | 0-7 | | | • | | 1 | 8-15 | | | , | 97 | ò | 16-23 | | | | • | 1 | 24-31 | | Channel 4 | Target Address | CO | 0 | 0-7 | | | . • | | 1 | 8-15 | | | | 8F | × | 16-23 | | | | D0 | Ö | 24-31 | | | Byte Count | C1 | , 0 | 0-7 | | | | | 1 | 8-15 | | | , | D1 | Ö | 16-23 | | | Requester Address | 98 | ŏ | 0-7 | | | • | - <del>-</del> | 1 | 8–15 | | | | 99 | Ó | 16-23 | | | | | 1 | 24-31 | | Channel 5 | Target Address | C2 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 8B | x | 16-23 | | | | D2 | Ö | 24-31 | | | Byte Count | C3 | Ö | 0-7 | | | • | | 1 | 8-15 | | | | D3 | Ó | 16-23 | | | Requester Address | 9A | Ō | 0-7 | | | • | | 1 | 8-15 | | | | 9B | Ó | 16-23 | | | | | 1 | 24-31 | | Channel Registers | | (Read Current, Wr | ite Base) | | |-------------------|-------------------|-------------------|-----------------|------------------| | Channel | Register Name | Address (Hex) | Byte<br>Pointer | Bits<br>Accessed | | Channel 6 | Target Address | C4 | 0 | 0-7 | | | | | 1 | 8-15 | | | | 89 | x | 16-23 | | | | D4 | 0 | 24-31 | | • | Byte Count | C5 | 0 | 0-7 | | | | | 1 | 8-15 | | | | D5 | 0 | 16-23 | | | Requester Address | 9C | 0 | 0-7 | | | | | 1 | 8-15 | | | | 9D | 0 | 16-23 | | | | | 1 | 24-31 | | Channel 7 | Target Address | C6 | 0 | 0-7 | | | | | 1 | 8-15 | | , | | 8 <b>A</b> | x | 16-23 | | | | D6 | 0 | 24-31 | | | Byte Count | C7 | 0 | 0-7 | | | | | 1 | 8-15 | | | | D7 | 0 | 16-23 | | | Requester Address | 9E | 0 | 0-7 | | | | | 1 | 8-15 | | | | 9F | 0 | 16-23 | | | | | 1 | 24-31 | Command Register I (Write Only) Port Address—Channels 0-3—0008H Channels 4-7—00C8H Command Register II (Write Only) Port Addresses—Channels 0-3—001AH Channels 4-7—00DAH Mode Register I (Write Only) Port Addresses—Channels 0-3—000BH Channels 4-7—00CBH Target and Requester DECREMENT is allowed only for byte transfers. Mode Register II (Write Only) Port Addresses—Channels 0-3—001BH Channels 4-7—00DBH Target and Requester DECREMENT is allowed only for byte transfers. intel. Software Request Register (Read/Write) Port Addresses—Channels 0-3-0009H Channels 4-7-00C9H Write Format: Software DMA Service Request Read Format: Software Requests Pending Mask Set/Reset Register Individual Channel Mask (Write Only) Port Addresses—Channels 0-3—000AH Channels 4-7—00CAH Mask Read/Write Register Group Channel Mask (Read/Write) Port Addresses-Channels 0-3-000FH Channels 4-7-00CFH Status Register Channel Process Status (Read Only) Port Addresses---Channels 0-3--0008H Channels 4-7-00C8H **Bus Size Register** Set Data Path Width (Write Only) Port Addresses—Channels 0-3-0018H Channels 4-7-00D8H Bus Size Encoding: 00 = Reserved by Intel 01 = 32-bit Bus 10 = 16-bit Bus 11 = 8-bit Bus Chaining Register (Read/Write) Port Addresses---Channels 0-3--0019H Channels 4-7-00D9H Write Format: Set Chaining Mode Read Format: Channel Interrupt Status ### 3.8 8237A Compatibility The register arrangement of the 82380 DMA Controller is a superset of the 8237A DMA Controller. Functionally the 82380 DMA Controller is very different from the 8237A. Most of the functions of the 8237A are performed also by the 82380. The following discussion points out the differences between the 8237A and the 82380. The 8237A is limited to transfers between I/O and memory only (except in one special case, where two channels can be used to perform memory-to-memory transfers). The 82380 DMA Controller can transfer between any combination of memory and I/O. Several other features of the 8237A are enhanced or expanded in the 82380 and other features are added. The 8237A is an 8-bit only DMA device. For programming compatibility, all of the 8-bit registers are preserved in the 82380. The 82380 is programmed via 8-bit registers. The address registers in the 82380 are 32-bit registers in order to support the 80386's 32-bit bus. The Byte Count Registers are 24-bit registers, allowing support of larger data blocks than possible with the 8237A. All of the 8237A's operating modes are supported by the 82380 (except the cumbersome two-channel memory-to-memory transfer). The 82380 performs memory-to-memory transfers using only one channel. The 82380 has the added features of buffer pipelining (Buffer Chaining Process), programmable priority levels, and Byte Assembly. The 82380 also adds the feature of address registers for both destination and source. These addresses may be incremented, decremented, or held constant, as required by the application of the individual channel. This allows any combination of destination and source device. Each DMA channel has associated with it a Target and a Requester. In the 8237A, the Target is the device which can be accessed by the address register, the Requester is the device which is accessed by the DMA Acknowledge signals and must be an I/O device. #### 82380 ### 4.0 PROGRAMMABLE INTERRUPT CONTROLLER (PIC) #### 4.1 Functional Description The 82380 Programmable Interrupt Controller (PIC) consists of three enhanced 82C59A Interrupt Contollers. These three controllers together provide 15 external and 5 internal interrupt request inputs. Each external request input can be cascaded with an additional 82C59A slave collector. This scheme allows the 82380 to support a maximum of 120 (15 x 8) external interrupt request inputs. Following one or more interrupt requests, the 82380 PIC issues an interrupt signal to the 80386. When the 80386 host processor responds with an interrupt acknowledge signal, the PIC will arbitrate between the pending interrupt requests and place the interrupt vector associated with the highest priority pending request on the data bus. The major enhancement in the 82380 PIC over the 82C59A is that each of the interrupt request inputs can be individually programmed with its own interrupt vector, allowing more flexibility in interrupt vector mapping. #### 4.1.1 INTERNAL BLOCK DIAGRAM The block diagram of the 82380 Programmable Interrupt Controller is shown in Figure 4-1. Internally, the PIC consists of three 82C59A banks: A, B and C. The three banks are cascaded to one another: C is cascaded to B, B is cascaded to A. The INT output of Bank A is used externally to interrupt the 80386. Bank A has nine interrupt request inputs (two are unused), and Banks B and C have eight interrupt request inputs. Of the fifteen external interrupt request inputs, two are shared by other functions. Specifically, the Interrupt Request 3 input (IRQ3#) can be used as the Timer 2 output (TOUT2#). This pin can be used in three different ways: IRQ3# input only, TOUT2# output only, or using TOUT2# to generate an IRQ3# interrupt request. Also, the Interrupt Request 9 input (IRQ 9#) can be used as DMA Request 4 input (DREQ4). Typically, only IRQ9# or DREQ4 can be used at a time. Figure 4-1. Interrupt Controller Block Diagram ### intel. ### 4.1.2 INTERRUPT CONTROLLER BANKS All three banks are identical, with the exception of the IRQ1.5 on Bank A. Therefore, only one bank will be discussed. In the 82380 PIC, all external requests can be cascaded into and each interrupt controller bank behaves like a master. As compared to the 82C59A, the enhancements in the banks are: All interrupt vectors are individually programmable. (In the 82C59A, the vectors must be programmed in eight consecutive interrupt vector locations.) The cascade address is provided on the Data Bus (D0-D7). (In the 82C59A, three dedicated control signals (CAS0, CAS1, CAS2) are used for master/slave cascading.) The block diagram of a bank is shown in Figure 4-2. As can be seen from this figure, the bank consists of six major blocks: the Interrupt Request Register (IRR), the In-Service Register (ISR), the Interrupt Mask Register (IMR), the Priority Resolver (PR), the Vector Register (VR), and the Control Logic. The functional description of each block follows. Figure 4-2. Interrupt Bank Block Diagram INTERRUPT REQUEST (IRR) AND IN-SERVICE REGISTER (ISR) The interrupts at the Interrupt Request (IRQ) input lines are handled by two registers in cascade, the Interrupt Request Register (IRR) and the In-Service Register (ISR). The IRR is used to store all interrupt levels which are requesting service; and the ISR is used to store all interrupt levels which are being serviced. #### PRIORITY RESOLVER (PR) This logic block determines the priorities of the bits set in the IRR. The highest priority is selected and strobed into the corresponding bit of the ISR during an Interrupt Acknowledge cycle. #### INTERRUPT MASK REGISTER (IMR) The IMR stores the bits which mask the interrupt lines to be masked (disabled). The IMR operates on the IRR. Masking of a higher priority input will not affect the interrupt request lines of lower priority. #### **VECTOR REGISTERS (VR)** This block contains a set of Vector Registers, one for each interrupt request line, to store the pre-programmed interrupt vector number. The corresponding vector number will be driven onto the Data Bus of the 82380 during the interrupt Acknowledge cycle. #### CONTROL LOGIC The Control Logic coordinates the overall operations of the other internal blocks within the same bank. This logic will drive the Interrupt Output signal (INT) HIGH when one or more unmasked interrupt inputs are active (LOW). The INT output signal goes directly to the 80386 (in Bank A) or to another bank to which this bank is cascaded (see Figure 4-1). Also, this logic will recognize an Interrupt Acknowledge cycle (via M/IO#, D/C# and W/R# signals). During this bus cycle, the Control Logic will enable the corresponding Vector Register to drive the interrupt vector onto the Data Bus. In Bank A, the Control Logic is also responsible for handling the special ICW2 interrupt request input (IRQ1.5#). #### 4.2 Interface Signals #### **4.2.1 INTERRUPT INPUTS** There are 15 external Interrupt Request inputs and 5 internal Interrupt Requests. The external request inputs are: IRQ3#, IRQ9#, IRQ11# to IRQ23#. They are shown in bold arrows in Figure 4-1. All IRQ inputs are active LOW and they can be programmed (via a control bit in the Initialization Command Word 1 (ICW1)) to be either edge-triggered or level-triggered. In order to be recognized as a valid interrupt request, the interrupt input must be active (LOW) until the first INTA# cycle (see Bus Functional Description). Note that all 15 external Interrupt Request inputs have weak internal pull-up resistors. As mentioned earlier, an 82C59A can be cascaded to each external interrupt input to expand the interrupt capacity to a maximum of 120 levels. Also, two of the interrupt inputs are dual functions: IRQ3# can be used as Timer 2 output (TOUT2#) and IRQ9# can be used as DREQ4 input. IRQ3# is a bidirectional dual function pin. This interrupt request input is wired-OR with the output of Timer 2 (TOUT2#). If only IRQ3# function is to be used, Timer 2 should be programmed so that OUT2 is LOW. Note that TOUT2# can also be used to generate an interrupt request to IRQ3# input. The five internal interrupt requests serve special system functions. They are shown in Table 4-1. The following paragraphs describe these interrupts. Table 4-1, 82380 Internal Interrupt Requests | Interrupt Request | Interrupt Source | |-------------------|-------------------------| | IRQ0# | Timer 3 Output (TOUT3#) | | IRQ8# | Timer 0 Output (TOUT0#) | | IRQ1# | DMA Chaining Request | | IRQ4# | DMA Terminal Count | | IRQ1.5# | ICW2 Written | TIMER 0 AND TIMER 3 INTERRUPT REQUESTS [IRQ0#] IRQ8# and IRQ0# interrupt requests are initiated by the output of Timers 0 and 3, respectively. Each of these requests is generated by an edge-detector flip-flop. The flip-flops are activated by the following conditions: Set— Rising edge of timer output (TOUT); Clear— Interrupt acknowledge for this request; OR Request is masked (disabled); OR Hardware Reset. intel. ### CHAINING AND TERMINAL COUNT INTERRUPTS [IRQ1 #] These interrupt requests are generated by the 82380 DMA Controller. The chaining request (IRQ1#) indicates that the DMA Base Register is not loaded. The Terminal Count request (IRQ4#) indicates that a software DMA request was cleared. #### ICW2 INTERRUPT REQUEST [IRO1.5#] Whenever an Initialization Control Word 2 (ICW2) is written to a Bank, a special ICW2 interrupt request is generated. The interrupt will be cleared when the newly programmed ICW2 Register is read. This interrupt request is in Bank A at level 1.5. This interrupt request is internally ORed with the Cascaded Request from Bank B and is always assigned a higher priority than the Cascaded Request. This special interrupt is provided to support compatibility with the original 82C59A. A detailed description of this interrupt is discussed in the Programming section. #### DEFAULT INTERRUPT [IRQ7#] During an Interrupt Acknowledge cycle, if there is no active pending request, the PIC will automatically generate a default vector. This vector corresponds to the IRQ7 # vector in Bank A. #### 4.2.2 INTERRUPT OUTPUT (INT) The INT output pin is taken directly from bank A. This signal should be tied to the Maskable Interrupt Request (INTR) of the 80386. When this signal is active (HIGH), it indicates that one or more internal/external interrupt requests are pending. The 80386 is expected to respond with an interrupt acknowledge cycle. #### 4.3 Bus Functional Description The INT output of bank A will be activated as a result of any unmasked interrupt request. This may be a non-cascaded or cascaded request. After the PIC has driven the INT signal HIGH, 80386 will respond by performing two interrupt acknowledge cycles. The timing diagram in Figure 4-3 shows a typical interrupt acknowledge process between the 82380 and the 80386 CPU. Figure 4-3. Interrupt Acknowledge Cycle After activating the INT signal, the 82380 monitors the status lines (M/IO#, D/C#, W/R#) and waits for the 80386 to initiate the first interrupt acknowledge cycle. In the 80386 environment, two successive interrupt acknowledge cycles (INTA) marked by M/IO# = LOW, D/C# = LOW, and W/R#LOW are performed. During the first INTA cycle, the PIC will determine the highest priority request. Assuming this interrupt input has no external Slave Controller cascaded to it, the 82380 will drive the Data Bus with 00H in the first INTA cycle. During the second INTA cycle, the 92380 PIC will drive the Data Bus with the corresponding preprogrammed interrupt vector. If the PIC determines (from the ICW3) that this interrupt input has an external Slave Controller cascaded to it, it will drive the Data Bus with the specific Slave Cascade Address (instead of 00H) during the first INTA cycle. This Slave Cascade Address is the preprogrammed content in the corresponding Vector Register. This means that no Slave Address should be chosen to be 00H. Note that the Slave Address and Interrupt Vector are different interpretations of the same thing. They are both the contents of the programmable Vector Register. During the second INTA cycle, the Data Bus will be floated so that the external Slave Controller can drive its interrupt vector on the bus. Since the Slave Interrupt Controller resides on the system bus, bus transceiver enable and direction control logic must take this into consideration. In order to have a successful interrupt service, the interrupt request input must be held active (LOW) until the beginning of the first interrupt acknowledge cycle. If there is no pending interrupt request when the first INTA cycle is generated, the PIC will generate a default vector, which is the IRQ7 vector (bank A level 7). According to the Bus Cycle definition of the 80386, there will be four Bus Idle States between the two interrupt acknowledge cycles. These idle bus cycles will be initiated by the 80386. Also, during each interrupt acknowledge cycle, the internal Wait State Generator of the 82380 will automatically generate the required number of wait states for internal delays. #### 4.4 Mode of Operation A variety of modes and commands are available for controlling the 82380 PIC. All of them are programmable; that is, they may be changed dynamically under software control. In fact, each bank can be programmed individually to operate in different modes. With these modes and commands, many possible configurations are conceivable, giving the user enough versatility for almost any interrupt controlled application. This section is not intended to show how the 82380 PIC can be programmed. Rather, it describes the operation in different modes. #### 4.4.1 END-OF-INTERRUPT Upon completion of an interrupt service routine, the interrupted bank needs to be notified so its ISR can be updated. This allows the PIC to keep track of which interrupt levels are in the process of being serviced and their relative priorities. Three different End-Of-Interrupt (EOI) formats are available. They are: Non-Specific EOI Command, Specific EOI Command, and Automatic EOI Mode. Selection of which EOI to use is dependent upon the interrupt operations the user wishes to perform. If the 82380 is NOT programmed in the Automatic EOI Mode, an EOI command must be issued by the 80386 to the specific 82380 PIC Controller Bank. Also, if this controller bank is cascaded to another internal bank, an EOI command must also be sent to the bank to which this bank is cascaded. For example, if an interrupt request of Bank C in the 82380 PIC is serviced, an EOI should be written into Bank C, Bank B and Bank A. If the request comes from an external interrupt controller cascaded to Bank C. then an EOI should be written into the external controller as well. #### NON-SPECIFIC EOI COMMAND A Non-Specific EOI command sent from the 80386 lets the 82380 PIC bank know when a service routine has been completed, without specification of its exact interrupt level. The respective interrupt bank automatically determines the interrupt level and resets the correct bit in the ISR. To take advantage of the Non-Specific EOI, the interrupt bank must be in a mode of operation in which it can predetermine its in-service routine levels. For this reason, the Non-Specific EO! command should only be used when the most recent level acknowledged and serviced is always the highest priority level (i.e., in the Fully Nested Mode structure to be described below). When the interrupt bank receives a Non-Specific EOI command, it simply resets the highest priority ISR bit to indicate that the highest priority routine in service is finished. Special consideration should be taken when deciding to use the Non-Specific EOI command. Here are two operating conditions in which it is best NOT int<sub>el</sub>. used since the Fully Nested Mode structure will be destroyed: - Using the Set Priority command within an interrupt service routine. - Using a Special Mask Mode. These conditions are covered in more detail in their own sections, but are listed here for reference. #### SPECIFIC EOI COMMAND Unlike a Non-Specific EOI command which automatically resets the highest priority ISR bit, a Specific EOI command specifies an exact ISR bit to be reset. Any one of the IRQ levels of an interrupt bank can be specified in the command. The Specific EOI command is needed to reset the ISR bit of a completed service routine whenever the interrupt bank is not able to automatically determine it. The Specific EOI command can be used in all conditions of operation, including those that prohibit Non-Specific EOI command usage mentioned above. #### **AUTOMATIC EOI MODE** When programmed in the Automatic EOI Mode, the 80386 no longer needs to issue a command to notify the interrupt bank it has completed an interrupt routine. The interrupt bank accomplishes this by performing a Non-Specific EOI automatically at the end of the second INTA cycle. Special consideration should be taken when deciding to use the Automatic EOI Mode because it may disturb the Fully Nested Mode structure. In the Automatic EOI Mode, the ISR bit of a routine in service is reset right after it is acknowledged, thus leaving no designation in the ISR that a service routine is being executed. If any interrupt request within the same bank occurs during this time and interrupts are enabled, it will get serviced regardless of its priority. Therefore, when using this mode, the 80386 should keep its interrupt request input disabled during execution of a service routine. By doing this, higher priority interrupt levels will be serviced only after the completion of a routine in service. This guideline restores the Fully Nested Mode structure. However, in this scheme, a routine in service cannot be interrupted since the host's interrupt request input is disabled. #### **4.4.2 INTERRUPT PRIORITIES** The 82380 PIC provides various methods for arranging the interrupt priorities of the interrupt request inputs to suit different applications. The following subsections explain these methods in detail. #### 4.4.2.1 Fully Nested Mode The Fully Nested Mode of operation is a general purpose priority mode. This mode supports a multi-level interrupt structure in which all of the Interrupt Request (IRQ) inputs within one bank are arranged from highest to lowest. Unless otherwise programmed, the Fully Nested Mode is entered by default upon initialization. At this time, IRQ0# is assigned the highest priority (priority = 0) and IRQ7# the lowest (priority = 7). This default priority can be changed, as will be explained later in the Rotating Priority Mode. When an interrupt is acknowledged, the highest priority request is determined from the Interrupt Request Register (IRR) and its vector is placed on the bus. In addition, the corresponding bit in the In-Service Register (ISR) is set to designate the routine in service. This ISR bit will remain set until the 80386 issues an End Of Interrupt (EOI) command immediately before returning from the service routine; or alternately, if the Automatic End Of Interrupt (AEOI) bit is set, the ISR bit will be reset at the end of the second INTA cycle. # intط، 82380 While the ISR bit is set, all further interrupts of the same or lower priority are inhibited. Higher level interrupts can still generate an interrupt, which will be acknowledged only if the 80386 internal interrupt enable flip-flop has been re-enabled (through software inside the current service routine). ### 4.4.2.2 Automatic Rotation—Equal Priority Devices Automatic rotation of priorities serves in applications where the interrupting devices are of equal priority within an interrupt bank. In this kind of environment, once a device is serviced, all other equal priority peripherals should be given a chance to be serviced before the original device is serviced again. This is accomplished by automatically assigning a device the lowest priority after being serviced. Thus, in the worst case, the device would have to wait until all other peripherals connected to the same bank are serviced before it is serviced again. There are two methods of accomplishing automatic rotation. One is used in conjunction with the Non-Specific EOI command and the other is used with the Automatic EOI mode. These two methods are discussed below. #### **ROTATE ON NON-SPECIFIC EOI COMMAND** When the Rotate On Non-Specific EOI command is issued, the highest ISR bit is reset as in a normal Non-Specific EOI command. However, after it is reset, the corresponding Interrupt Request (IRQ) level is assigned the lowest priority. Other IRQ priorities rotate to conform to the Fully Nested Mode based on the newly assigned low priority. Figure 4-4 shows how the Rotate On Non-Specific EOI command affects the interrupt priorities. Assume the IRQ priorities were assigned with IRQ0 the highest and IRQ7 the lowest. IRQ6 and IRQ4 are already in service but neither is completed. Being the higher priority routine, IRQ4 is necessarily the routine being executed. During the IRQ4 routine, a rotate on Non-Specific EOI command is executed. When this happens, Bit 4 in the ISR is reset. IRQ4 then becomes the lowest priority and IRQ5 becomes the highest. Figure 4-4. Rotate On Non-Specific EOI Command ### intel. #### **ROTATE ON AUTOMATIC EQI MODE** The Rotate On Automatic EOI Mode works much like the Rotate On Non-Specific EOI Command. The main difference is that priority rotation is done automatically after the second INTA cycle of an interrupt request. To enter or exit this mode, a Rotate-On-Automatic-EOI Set Command and Rotate-On-Automatic-EOI Clear Command is provided. After this mode is entered, no other commands are needed as in the normal Automatic EOI Mode. However, it must be noted again that when using any form of the Automatic EOI Mode, special consideration should be taken. The guideline presented in the Automatic EOI Mode also applies here. ### 4.4.2.3 Specific Rotation—Specific Priority Specific rotation gives the user versatile capabilities in interrupt controlled operations. It serves in those applications in which a specific device's interrupt priority must be altered. As opposed to Automatic Rotation which will automatically set priorities after each interrupt request is serviced, specific rotation is completely user controlled. That is, the user selects which interrupt level is to receive the lowest or the highest priority. This can be done during the main program or within interrupt routines. Two specific rotation commands are available to the user: Set Priority Command and Rotate On Specific EOI Command. #### SET PRIORITY COMMAND The Set Priority Command allows the programmer to assign an IRQ level the lowest priority. All other interrupt levels will conform to the Fully Nested Mode based on the newly assigned low priority. #### ROTATE ON SPECIFIC EOI COMMAND The Rotate On Specific EOI Command is literally a combination of the Set Priority Command and the Specific EOI Command. Like the Set Priority Command, a specified IRQ level is assigned lowest priority. Like the Specific EOI Command, a specified level will be reset in the ISR. Thus, this command accomplishes both tasks in one single command. #### 4.4.2.4 Interrupt Priority Mode Summary In order to simplify understanding the many modes of interrupt priority, Table 4-2 is provided to bring out their summary of operations. **Table 4-2. Interrupt Priority Mode Summary** | Interrupt | Operation | Effect On Priority After EOI | | | |-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------|--| | Priority Mode | Summary | Non-Specific/Automatic | Specific | | | Fully-Nested Mode | IRQ0#-Highest Priority<br>IRQ7#-Lowest Priority | No change in priority.<br>Highest ISR bit is reset. | Not Applicable. | | | Automatic Rotation<br>(Equal Priority Devices) | Interrupt level just serviced is the lowest priority. Other priorities rotate to conform to Fully-Nested Mode. | Highest ISR bit is reset and the corresponding level becomes the lowest priority. | Not Applicable. | | | Specific Rotation<br>(Specific Priority<br>Devices) | User specifies the lowest priority level. Other priorities rotate to conform to Fully-Nested Mode. | Not Applicable. | As described under<br>'Operation Summary' | | 82380 #### 4.4.3 INTERRUPT MASKING #### VIA INTERRUPT MASK REGISTER Each bank in the 82380 PIC has an Interrupt Mask Register (IMR) which enhances interrupt control capabilities. This IMR allows individual IRQ masking. When an IRQ is masked, its interrupt request is disabled until it is unmasked. Each bit in the 8-bit IMR disables one interrupt channel if it is set (HIGH). Bit 0 masks IRQ0, Bit 1 masks IRQ1 and so forth. Masking an IRQ channel will only disable the corresponding channel and does not affect the others operations. The IMR acts only on the output of the IRR. That is, if an interrupt occurs while its IMR bit is set, this request is not 'forgotten'. Even with an IRQ input masked, it is still possible to set the IRR. Therefore, when the IMR bit is reset, an interrupt request to the 80386 will then be generated, providing that the IRQ request remains active. If the IRQ request is removed before the IMR is reset, the Default Interrupt Vector (Bank A, level 7) will be generated during the interrupt acknowledge cycle. #### SPECIAL MASK MODE In the Fully Nested Mode, all IRQ levels of lower priority than the routine in service are inhibited. However, in some applications, it may be desirable to let a lower priority interrupt request to interrupt the routine in service. One method to achieve this is by using the Special Mask Mode. Working in conjunction with the IMR, the Special Mask Mode enables interrupts from all levels except the level in service. This is usually done inside an interrupt service routine by masking the level that is in service and then issuing the Special Mask Mode Command. Once the Special Mask Mode is enabled, it remains in effect until it is disabled. ### 4.4.4 EDGE OR LEVEL INTERRUPT TRIGGERING Each bank in the 82380 PIC can be programmed independently for either edge or level sensing for the interrupt request signals. Recall that all IRQ inputs are active LOW. Therefore, in the edge triggered mode, an active edge is defined as an input transition from an inactive (HIGH) to active (LOW) state. The interrupt input may remain active without generating another interrupt. During level triggered mode, an interrupt request will be recognized by an active (LOW) input, and there is no need for edge detection. However, the interrupt request must be removed before the EOI Command is issued, or the 80386 must be disabled to prevent a second false interrupt from occurring. In either modes, the interrupt request input must be active (LOW) during the first INTA cycle in order to be recognized. Otherwise, the Default Interrupt Vector will be generated at level 7 of Bank A. #### 4.4.5 INTERRUPT CASCADING As mentioned previously, the 82380 allows for external Slave interrupt controllers to be cascaded to any of its external interrupt request pins. The 82380 PIC indicates that a external Slave Controller is to be serviced by putting the contents of the Vector Register associated with the particular request on the 80386 Data Bus during the first INTA cycle (instead of 00H during a non-slave service). The external logic should latch the vector on the Data Bus using the INTA status signals and use it to select the external Slave Controller to be serviced (see Figure 4-5). The selected Slave will then respond to the second INTA cycle and place its vector on the Data Bus. This method requires that if external Slave Controllers Figure 4-5. Slave Cascade Address Capturing int<sub>el</sub>. are used in the system, no vector should be programmed to 00H. Since the external Slave Cascade Address is provided on the Data Bus during INTA cycle 1, an external latch is required to capture this address for the Slave Controller. A simple scheme is depicted in Figure 4-5. #### 4.4.5.1 Special Fully Nested Mode This mode will be used where cascading is employed and the priority is to be conserved within each Slave Controller. The Special Fully Nested Mode is similar to the 'regular' Fully Nested Mode with the following exceptions: - When an interrupt request from a Slave Controller is in service, this Slave Controller is not locked out from the Master's priority logic. Further interrupt requests from the higher priority logic within the Slave Controller will be recognized by the 82380 PIC and will initiate interrupts to the 80386. In comparing to the 'regular' Fully Nested Mode, the Slave Controller is masked out when its request is in service and no higher requests from the same Slave Controller can be serviced. - Before exiting the interrupt service routine, the software has to check whether the interrupt serviced was the only request from the Slave Controller. This is done by sending a Non-Specific EOI Command to the Slave Controller and then reading its In Service Register. If there are no requests in the Slave Controller, a Non-Specific EOI can be sent to the corresponding 82380 PIC bank also. Otherwise, no EOI should be sent. #### 4.4.6 READING INTERRUPT STATUS The 82380 PIC provides several ways to read different status of each interrupt bank for more flexible interrupt control operations. These include polling the highest priority pending interrupt request and reading the contents of different interrupt status registers. #### 4.4.6.1 Poll Command The 82380 PIC supports status polling operations with the Poll Command. In a Poll Command, the pending interrupt request with the highest priority can be determined. To use this command, the INT output is not used, or the 80386 interrupt is disabled. Service to devices is achieved by software using the Poll Command. This mode is useful if there is a routine command common to several levels so that the INTA sequence is not needed. Another application is to use the Poll Command to expand the number of priority levels Notice that the ICW2 mechanism is not supported for the Poll Command. However, if the Poll Command is used, the programmable Vector Registers are of no concern since no INTA cycle will be generated. #### 4.4.6.2 Reading Interrupt Registers The contents of each interrupt register (IRR, ISR, and IMR) can be read to update the user's program on the present status of the 82380 PIC. This can be a versatile tool in the decision making process of a service routine, giving the user more control over interrupt operations. The reading of the IRR and ISR contents can be performed via the Operation Control Word 3 by using a Read Status Register Command and the content of IMR can be read via a simple read operation of the register itself. #### 4.5 Register Set Overview Each bank of the 82380 PIC consists of a set of 8-bit registers to control its operations. The address map of all the registers is shown in Table 4-3. Since all three register sets are identical in functions, only one set will be described. Functionally, each register set can be divided into five groups. They are: the four Initialization Command Words (ICW's), the three Operation Control Words (OCW's), the Poll/Interrupt Request/In-Service Register, the Interrupt Mask Register, and the Vector Registers. A description of each group follows. Table 4-3. Interrupt Controller Register Address Map | Port<br>Address | Access | Register Description | | |-----------------|------------|------------------------------------|--| | 20H | Write | Bank B ICW1, OCW2, or OCW3 | | | | Read | Bank B Poll, Request or In-Service | | | | | Status Register | | | 21H | Write | Bank B ICW2, ICW3, ICW4, OCW1 | | | | Read | Bank B Mask Register | | | 22H | Read | Bank B ICW2 | | | 28H | Read/Write | IRQ8 Vector Register | | | 29H | Read/Write | IRQ9 Vector Register | | | 2AH | Read/Write | Reserved | | | 2BH | Read/Write | IRQ11 Vector Register | | | 2CH | Read/Write | IRQ12 Vector Register | | | 2DH | Read/Write | IRQ13 Vector Register | | | 2EH | Read/Write | IRQ14 Vector Register | | | 2FH | Read/Write | IRQ15 Vector Register | | | A0H | Write | Bank C ICW1, OCW2, or OCW3 | | | İ | Read | Bank C Poll, Request or In-Service | | | | | Status Register | | | A1H | Write | Bank C ICW2, ICW3, ICW4, OCW1 | | | | Read | Bank C Mask Register | | | A2H | Read | Bank C ICW2 | | | A8H | Read/Write | IRQ16 Vector Register | | | A9H | Read/Write | IRQ17 Vector Register | | | AAH | Read/Write | IRQ18 Vector Register | | | ABH | Read/Write | IRQ19 Vector Register | | | ACH | Read/Write | IRQ20 Vector Register | | | ADH | Read/Write | IRQ21 Vector Register | | | AEH | Read/Write | IRQ22 Vector Register | | | AFH | Read/Write | IRQ23 Vector Register | | | 30H | Write | Bank A ICW1, OCW2, or OCW3 | | | | Read | Bank A Poll, Request or In-Service | | | 0411 | 144-24- | Status Register | | | 31H | Write | Bank A ICW2, ICW3, ICW4, OCW1 | | | 0011 | Read | Bank A Mask Register | | | 32H | Read | Bank ICW2 | | | 38H | Read/Write | IRQ0 Vector Register | | | 39H | Read/Write | IRQ1 Vector Register | | | 3AH | Read/Write | IRQ1.5 Vector Register | | | 3BH | Read/Write | IRQ3 Vector Register | | | 3CH | Read/Write | IRQ4 Vector Register | | | 3DH | Read/Write | Reserved | | | 3EH | Read/Write | Reserved | | | 3FH | Read/Write | IRQ7 Vector Register | | #### 4.5.1 INITIALIZATION COMMAND WORDS (ICW) Before normal operation can begin, the 82380 PIC must be brought to a known state. There are four 8-bit Initialization Command Words in each interrupt bank to setup the necessary conditions and modes for proper operation. Except for the second common word (ICW2) which is a read/write register, the other three are write-only registers. Without going into detail of the bit definitions of the command words, the following subsections give a brief description of what functions each command word controls. #### ICW<sub>1</sub> The ICW1 has three major functions. They are: - To select between the two IRQ input triggering modes (edge-or level-triggered); - To designate whether or not the interrupt bank is to be used alone or in the cascade mode. If the cascade mode is desired, the interrupt bank will accept ICW3 for further cascade mode programming. Otherwise, no ICW3 will be accepted; - To determine whether or not ICW4 will be issued; that is, if any of the ICW4 operations are to be used. #### ICW2 ICW2 is provided for compatibility with the 82C59A only. Its contents do not affect the operation of the interrupt bank in any way. Whenever the ICW2 of any of the three banks is written into, an interrupt is generated from Bank A at level 1.5. The interrupt request will be cleared after the ICW2 register has been read by the 80386. The user is expected to program the corresponding vector register or to use it as an indicator that an attempt was made to alter the contents. Note that each ICW2 register has different addresses for read and write operations. #### ICW3 The interrupt bank will only accept an ICW3 if programmed in the external cascade mode (as indicated in ICW1). ICW3 is used for specific programming within the cascade mode. The bits in ICW3 indicate which interrupt request inputs have a Slave cascaded to them. This will subsequently affect the interrupt vector generation during the interrupt acknowledge cycles as described previously. #### ICW4 The ICW4 is accepted only if it was selected in ICW1. This command word register serves two functions: - To select either the Automatic EOI mode or software EOI mode; - To select if the Special Nested mode is to be used in conjunction with the cascade mode. #### 4.5.2 OPERATION CONTROL WORDS (OCW) Once initialized by the ICW's, the interrupt banks will be operating in the Fully Nested Mode by default and they are ready to accept interrupt requests. However, the operations of each interrupt bank can be further controlled or modified by the use of OCW's. Three OCW's are available for programming various modes and commands. Note that all OCW's are 8-bit write-only registers. The modes and operations controlled by the OCW's are: - Fully Nested Mode; - Rotating Priority Mode; - Special Mask Mode; - Poil Mode; - EOI Commands; - Read Status Commands. #### OCW1 OCW1 is used solely for masking operations. It provides a direct link to the Interrupt Mask Register (IMR). The 80386 can write to this OCW register to enable or disable the interrupt inputs. Reading the pre-programmed mask can be done via the Interrupt Mask Register which will be discussed shortly. #### OCW2 OCW2 is used to select End-Of-Interrupt, Automatic Priority Rotation, and Specific Priority Rotation operations. Associated commands and modes of these operations are selected using the different combinations of bits in OCW2. Specifically, the OCW2 is used to: - Designate an interrupt level (0-7) to be used to reset a specific ISR bit or to set a specific priority. This function can be enabled or disabled; - Select which software EOI command (if any) is to be executed (i.e., Non-Specific or Specific EOI); - Enable one of the priority rotation operations (i.e., Rotate On Non-Specific EOI, Rotate On Automatic EOI, or Rotate on Specific EOI). #### OCW3 There are three main categories of operation that OCW3 controls. That are summarized as follows: ### intطِ - To select and execute the Read Status Register Commands, either reading the Interrupt Request Register (IRR) or the In-Service Register (ISR); - To issue the Poll Command. The Poll Command will override a Read Register Command if both functions are enabled simultaneously; - To set or reset the Special Mask Mode. ### 4.5.3 POLL/INTERRUPT REQUEST/IN-SERVICE STATUS REGISTER As the name implies, this 8-bit read-only register has multiple functions. Depending on the command issued in the OCW3, the content of this register reflects the result of the command executed. For a Poll Command, the register read contains the binary code of the highest priority level requesting service (if any). For a Read IRR Command, the register content will show the current pending interrupt request(s). Finally, for a Read ISR Command, this register will specify all interrupt levels which are being serviced. #### 4.5.4 INTERRUPT MASK REGISTER (IMR) This is a read-only 8-bit register which, when read, will specify all interrupt levels within the same bank that are masked. #### 4.5.5 VECTOR REGISTER (VR) Each interrupt request input has an 8-bit read/write programmable vector register associated with it. The registers should be programmed to contain the interrupt vector for the corresponding request. The contents of the Vector Register will be placed on the Data Bus during the INTA cycles as described previously. #### 4.6 Programming Programming the 82380 PIC is accomplished by using two types of command words: ICW's and OCW's. All modes and commands explained in the previous sections are programmable using the ICW's and OCW's. The ICW's are issued from the 80386 in a sequential format and are used to setup the banks in the 82380 PIC in an initial state of operation. The OCW's are issued as needed to vary and control the 82380 PIC's operations. Both ICW's and OCW's are sent by the 80386 to the interrupt banks via the Data Bus. Each bank distinguishes between the different ICW's and OCW's by the I/O address map, the sequence they are issued (ICW's only), and by some dedicated bits among the ICW's and OCW's. #### 82380 All three interrupt banks are programmed in a similar way. Therefore, only a single bank will be described. #### 4.6.1 INITIALIZATION (ICW) Before normal operation can begin, each bank must be initialized by programming a sequence of two to four bytes written into the ICW's. Figure 4-6 shows the initialization flow for an interrupt bank. Both ICW1 and ICW2 must be issued for any form of operation. However, ICW3 and ICW4 are used only if designated in ICW1. Once initialized, if any programming changes within the ICW's are to be made, the entire ICW sequence must be reprogrammed, not just an individual ICW. Note that although the ICW2's in the 82380 PIC do not affect the Bank's operation, they still must be programmed in order to preserve the compatibility with the 82C59A. The contents programmed are not relevant to the overall operations of the interrupt banks. Also, whenever one of the three ICW2's is programmed, an interrupt level 1.5 in Bank A will be generated. This interrupt request will be cleared upon reading of the ICW2 registers. Since the three ICW2's share the same interrupt level and the system may not know the origin of the interrupt, all three ICW2's must be read. However, it is not necessary to provide an interrupt service routine for the ICW2 interrupt. One way to avoid this is as follows. At the beginning of the initialization of the interrupt banks, the 80386 interrupt should be disabled. After each ICW2 register write operation is performed during the initialization, the corresponding ICW2 register is read. This read operation will clear the interrupt request of the 82380. At the end of the initialization, the 80386 interrupt is renabled. With this method, the 80386 will not detect the ICW2 interrupt request, thus eliminating the need of an interrupt service routine. Certain internal setup conditions occur automatically within the interrupt bank after the first ICW (ICW1) has been issued. They are: - The edge sensitive circuit is reset, which means that following initialization, an interrupt request input must make a HIGH-to-LOW transition to generate an interrupt; - The Interrupt Mask Register (IMR) is cleared; that is, all interrupt inputs are enabled; - IRQ7 input of each bank is assigned priority 7 (lowest); - Special Mask Mode is cleared and Status Read is set to IRR; - If no ICW4 is needed, then no Automatic-EOI is selected. Figure 4-6. Initialization Sequence #### 4.6.2 VECTOR REGISTERS (VR) Each interrupt request input has a separate Vector Register. These Vector Registers are used to store the pre-programmed vector number corresponding to their interrupt sources. In order to guarantee proper interrupt handling, all Vector Registers must be programmed with the predefined vector numbers. Since an interrupt request will be generated whenever an ICW2 is written during the initialization sequence, it is important that the Vector Register of IRQ1.5 in Bank A should be initialized and the interrupt service routine of this vector is set up before the ICW's are written. #### 4.6.3 OPERATION CONTROL WORDS (OCW) After the ICW's are programmed, the operations of each interrupt controller bank can be changed by writing into the OCW's as explained before. There is no special programming sequence required for the OCW's. Any OCW may be written at any time in order to change the mode of or to perform certain operations on the interrupt banks. #### 4.6.3.1 Read Status and Poll Commands (OCW3) Since the reading of IRR and ISR status as well as the result of a Poll Command are available on the 82380 same read-only Status Register, a special Read Status/Poll Command must be issued before the Poll/Interrupt Request/In-Service Status Register is read. This command can be specified by writing the required control word into OCW3. As mentioned earlier, if both the Poll Command and the Status Read Command are enabled simultaneously, the Poll Command will override the Status Read. That is, after the command execution, the Status Register will contain the result of the Poll Command. Note that for reading IRR and ISR, there is no need to issue a Read Status Command to the OCW3 every time the IRR or ISR is to be read. Once a Read Status Command is received by the interrupt bank, it 'remembers' which register is selected. However, this is not true when the Poll Command is used. In the Poll Command, after the OCW3 is written, the 82380 PIC treats the next read to the Status Register as an interrupt acknowledge. This will set the appropriate IS bit if there is a request and read the priority level. Interrupt Request input status remains unchanged from the Poll Command to the Status Read. In addition to the above read commands, the Interrupt Mask Register (IMR) can also be read. When read, this register reflects the contents of the preprogrammed OCW1 which contains information on which interrupt request(s) is(are) currently disabled. #### 4.7 Register Bit Definition #### **INITIALIZATION COMMAND WORD 1 (ICW1)** # | D7 | D6 | D5 | D4 | D3 | D2 | D1 | CONTENT IS NOT RELEVANT TO THE ACTUAL OPERATION OF THE BANK BUT CAN BE READ BY THE INTERRUPT SERVICE ROUTINE TO DETERMINE WHERE THE INTERRUPT VECTORS OF EACH BANK START. 290128-57 # INITIALIZATION COMMAND WORD 3 (ICW3) ICW3 for Bank A: #### ICW3 for Bank B: #### ICW3 for Bank C: ### **INITIALIZATION COMMAND WORD 4 (ICW4)** #### **OPERATION CONTROL WORD 1 (OCW1)** 82380 #### **OPERATION CONTROL WORD 2 (OCW2)** #### **OPERATION CONTROL WORD 3 (OCW3)** ESMM—Enable Special Mask Mode. When this bit is set to 1, it enables the SMM bit to set or reset the Special Mask Mode. When this bit is set to 0, SMM bit becomes don't care. SMM—Special Mask Mode. If ESMM = 1 and SMM = 1, the interrupt controller bank will enter Special Mask Mode. If ESMM = 1 and SMM = 0, the bank will revert to normal mask mode. When ESMM = 0, SMM has no effect. ### Poll/Interrupt Request/In-Service Status Register #### **POLL COMMAND STATUS** #### INTERRUPT REQUEST STATUS Although all Interrupt Request inputs are active LOW, the internal logical will invert the state of the pins so that when there is a pending interrupt request at the input, the corresponding IRQ bit will be set to HIGH in the Interrupt Request #### **IN-SERVICE STATUS** ### 4.8 Register Operational Summary For ease of reference, Table 4-4 gives a summary of the different operating modes and commands with their corresponding registers. **Table 4-4 Register Operational Summary** | Operational<br>Description | Command<br>Words | Bits | |------------------------------|------------------|------------| | Fully Nested Mode | OCW-Default | | | Non-specific EOI Command | OCW2 | EOI | | Specific EOI Command | OCW2 | SL, EOI, | | | | LO-L2 | | Automatic EOI Mode | ICW1, ICW4 | IC4, AEOI | | Rotate On Non-Specific | OCW2 | EOI | | EOI Command | İ | | | Rotate On Automatic EOI Mode | OCW2 | R, SL, EOI | | Set Priority Command | OCW2 | L0-L2 | | Rotate On Specific | ocw2 | R, SL, EOI | | EOI Command | | | | Interrupt Mask Register | OCW1 | M0-M7 | | Special Mask Mode | OCW3 | ESMM, SMM | | Level Triggered Mode | ICW1 | LTIM | | Edge Triggered Mode | ICW1 | LTIM | | Read Register Command, IRR | OCM3 | RR, RIS | | Read Register Command, ISR | ОСМЗ | RR, RIS - | | Red IMR | IMR | M0-M7 | | Poll Command | OCW3 | P | | Special Fully Nested Mode | ICW2, ICW4 | IC4, SFNM | ### 5.0 PROGRAMMABLE INTERVAL TIMER #### 5.1 Functional Description The 82380 contains four independently Programmable Interval Timers: Timer 0-3. All four timers are functionally compatible to the Intel 82C54. The first three timers (Timer 0-2) have specific functions. The fourth timer, Timer 3, is a general purpose timer. Table 5-1 depicts the functions of each timer. A brief description of each timer's function follows. Table 5-1. Programmable Interval Timer Functions | Timer | Output | Function | |-------|-----------------|--------------------------------| | 0 | IRQ8 | Event Based<br>IRQ8 Generator | | 1 | TOUT1/REF# | Gen. Purpose/DRAM | | | TOUTO # (IDOO # | Refresh Req. | | 2 | TOUT2#/IRQ3# | Gen. Purpose/Speaker Out/IRQ3# | | 3 | TOUT3# | Gen. Purpose/IRQ0 | | | | Generator | 82380 #### TIMER 0- Event Based IRQ8 Generator Timer 0 is intended to be used as an Event Counter. The output of this timer will generate an Interrupt Request 8 (IRQ8) upon a rising edge of the timer output (TOUT0). Typically, this timer is used to implement a time-of-day clock or system tick. The Timer 0 output is not available as an external signal. TIMER 1— General Purpose/DRAM Refresh Request The output of Timer 1, TOUT1, can be used as a general purpose timer or as a DRAM Refresh Request signal. The rising edge of this output creates a DRAM refresh request to the 82380 DRAM Refresh Controller. Upon reset, the Refresh Request function is disabled, and the output pin is the Timer 1 output. #### TIMER 2-General Purpose/Speaker Out/IRQ3# The Timer 2 output, TOUT2#, could be used to support tone generation to an external speaker. This pin is a bidirectional signal. When used as an input, a logic LOW asserted at this pin will generate an Interrupt Register 3 (IRQ3#) (see Programmable Interrupt Controller). Figure 5-1. Block Diagram of Programmable Interval Timer TIMER 3—General Purpose/Interrupt Request 0 Generator The output of Timer 3 is fed to an edge detector and generates an Interrupt Request 0 (IRQ0) in the 82380. The inverted output of this timer (TOUT3\*) is also available as an external signal for general purpose use. #### **5.1.1 INTERNAL ARCHITECTURE** The functional block diagram of the Programmable Interval Timer section is shown in Figure 5-1. Following is a description of each block. ### DATA BUFFER & READ/WRITE LOGIC This part of the Programmable Interval Timer is used to interface the four timers to the 82380 internal bus. The Data Buffer is for transferring commands and data between the 8-bit internal bus and the timers. The Read/Write Logic accepts inputs from the internal bus and generates signals to control other functional blocks within the timer section. #### CONTROL WORD REGISTERS I & II The Control Word Registers are write-only registers. They are used to control the operating modes of the timers. Control Word Register I controls Timers 0, 1 and 2, and Control Word Register II controls Timer 3. Detailed description of the Control Word Registers will be included in the Register Set Overview section. ### COUNTER 0, COUNTER 1, COUNTER 2, COUNTER 3 Counters 0, 1, 2, and 3 are the major parts of Timers 0, 1, 2, and 3, respectively. These four functional blocks are identical in operation, so only a single counter will be described. The internal block diagram of one counter is shown in Figure 5-2. Figure 5-2. Internal Block Diagram of A Counter ### int<sub>e</sub>l، 82380 The four counters share a common clock input (CLKIN), but otherwise are fully independent. Each counter is programmable to operate in a different Mode. Although the Control Word Register is shown in the Figure 5-2, it is not part of the counter itself. Its programmed contents are used to control the operations of the counters. The Status Register, when latched, contains the current contents of the Control Word Register and status of the output and Null Count Flag (see Read Back Command). The Counting Element (CE) is the actual counter. It is a 16-bit presettable synchronous down counter. The Output Latches (OL) contain two 8-bit latches (OLM and OLL). Normally, these latches 'follow' the content of the CE. OLM contains the most significant byte of the counter and OLL contains the least significant byte. If the Counter Latch Command is sent to the counter, OL will latch the present count until read by the 80386 and then return to follow the CE. One latch at a time is enabled by the timer's Control Logic to drive the internal bus. This is how the 16-bit Counter communicates over the 8-bit internal bus. Note that CE cannot be read. Whenever the count is read, it is one of the OL's that is being read. When a new count is written into the counter, the value will be stored in the Count Registers (CR), and transferred to CE. The transferring of the contents from CR's to CE is defined as 'loading' of the counter. The Count Register contains two 8-bit registers: CRM (which contains the most significant byte) and CRL (which contains the least significant byte). Similar to the OL's, the Control Logic allows one register at a time to be loaded from the 8-bit internal bus. However, both bytes are transferred from the CR's to the CE simultaneously. Both CR's are cleared when the Counter is programmed. This way, if the Counter has been programmed for one byte count (either the most significant or the least significant byte only), the other byte will be zero. Note that CE cannot be written into directly. Whenever a count is written, it is the CR that is being written. As shown in the diagram, the Control Logic consists of three signals: CLKIN, GATE, and OUT. CLKIN and GATE will be discussed in detail in the section that follows. OUT is the internal output of the counter. The external outputs of some timers (TOUT) are the inverted version of OUT (see TOUT1, TOUT2#, TOUT3#). The state of OUT depends on the mode of operation of the timer. ### 5.2 Interface Signals #### 5.2.1 CLKIN CLKIN is an input signal used by all four timers for internal timing reference. This signal can be independent of the 82380 system clock, CLK2. In the following discussion, each 'CLK Pulse' is defined as the time period between a rising edge and a falling edge, in that order, of CLKIN. During the rising edge of CLKIN, the state of GATE is sampled. All new counts are loaded and counters are decremented on the falling edge of CLKIN. Please note that there are restrictions on the CLKIN signal during WRITE cycles to the 82380 timer unit. Refer to the appendix of this data manual for details on this issue. ### 5.2.2 TOUT1, TOUT2#, TOUT3# TOUT1, TOUT2# and TOUT3# are the external output signals of Timer 1, Timer 2 and Timer 3, respectively. TOUT2# and TOUT3# are the inverted signals of their respective counter outputs, OUT. There is no external output for Timer 0. If Timer 2 is to be used as a tone generator of a speaker, external buffering must be used to provide sufficient drive capability. The Outputs of Timer 2 and 3 are dual function pins. The output pin of Timer 2 (TOUT2#/IRQ3#), which is a bidirectional open-collector signal, can also be used as interrupt request input. When the interrupt function is enabled (through the Programmable Interrupt Controller), a LOW on this input will generate an Interrupt Request 3# to the 82380 Programmable Interrupt Controller. This pin has a weak internal pull-up resistor. To use the IRQ3# function, Timer 2 should be programmed so that OUT2 is LOW. Additionally, OUT3 of Timer 3 is connected to an edge detector which will generate an Interrupt Request 0 (IRQ0) to the 82380 after the rising edge of OUT3 (see Figure 5-1). ### 5.2.3 GATE GATE is not an externally controllable signal. Rather, it can be software controlled with the Internal Control Port. The state of GATE is always sampled on the rising edge of CLKIN. Depending on the mode of operation, GATE is used to enable/disable counting or trigger the start of an operation. For Timer 0 and 1, GATE is always enabled (HIGH). For Timer 2 and 3, GATE is connected to Bit 0 and 6, respectively, of an Internal Control Port (at address 61H) of the 82380. After a hardware reset, the state of GATE of Timer 2 and 3 is disabled (LOW). ### 5.3 Modes of Operation Each timer can be independently programmed to operate in one of six different modes. Timers are programmed by writing a Control Word into the control Word Register followed by an Initial Count (see Programming). The following are defined for use in describing the different modes of operation. CLK Pulse—A rising edge, then a falling edge, in that order of CLKIN. Trigger—A rising edge of a timer's GATE input. Timer/Counter Loading-The transfer of a count from Count Register (CR) to Count Element (CE). Note that figures 5-3 through 5-8 show the logical outputs of the timer units, OUTx. This signal polarity does not reflect that of the TOUT<sub>x</sub> signals. See the first paragraph of Section 5.2.2. ### 5.3.1 MODE 0-INTERRUPT ON TERMINAL COUNT Mode 0 is typically used for event counting. After the Control Word is written, OUT is initially LOW, and will remain LOW until the counter reaches zero. OUT then goes HIGH and remains HIGH until a new count or a new Mode 0 Control Word is written into the counter. In this mode, GATE = HIGH enables counting; GATE = LOW disables counting. However, GATE has no effect on OUT. After the Control Word and initial count are written to a timer, the initial count will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not go HIGH until N + 1 CLK pulses after the initial count is written. If a new count is written to the timer, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens: - 1. Writing the first byte disables counting, OUT is set LOW immediately (i.e., no CLK pulse required). - 2. Writing the second byte allows the new count to be loaded on the next CLK pulse. This allows the counting sequence to be synchronized by software. Again, OUT does not go HIGH until N + 1 CLK pulses after the new count of N is writ- If an initial count is written while GATE is LOW, the counter will be loaded on the next CLK pulse. When GATE goes HIGH, OUT will go HIGH N CLK pulses later; no CLK pulse is needed to load the counter as this has already been done. ### 5.3.2 MODE 1-GATE RETRIGGERABLE **ONE-SHOT** In this mode, OUT will be initially HIGH. OUT will go LOW on the CLK pulse following a trigger to start the one-shot operation. The OUT signal will then remain LOW until the timer reaches zero. At this point, OUT will stay HIGH until the next trigger comes in. Since the state of GATE signals of Timer 0 and 1 are internally set to HIGH. After writing the Control Word and initial count, the timer is considered 'armed'. A trigger results in loading the timer and setting OUT LOW on the next CLK pulse. Therefore, an initial count of N will result in a one-shot pulse width of N CLK cycles. Note that this one-shot operation is retriggerable; i.e., OUT will remain LOW for N CLK pulses after every trigger. The one-shot operation can be repeated without rewriting the same count into the timer. If a new count is written to the timer during a oneshot operation, the current one-shot pulse width will not be affected until the timer is retriggered. This is because loading of the new count to CE will occur only when the one-shot is triggered. 82380 Figure 5-3. Mode 0 N stands for an undefined count. Vertical lines show transitions between count values. intel. Figure 5-4. Mode 1 #### 5.3.3 MODE 2-RATE GENERATOR This mode is a divide-by-N counter. It is typically used to generate a Real Time Clock interrupt. OUT will initially be HIGH. When the initial count has decremented to 1, OUT goes LOW for one CLK pulse, then OUT goes HIGH again. Then the timer reloads the initial count and the process is repeated. In other words, this mode is periodic since the same sequence is repeated itself indefinitely. For an initial count of N, the sequence repeats every N CLK cycles. Similar to Mode 0, GATE = HIGH enables counting, where GATE = LOW disables counting. If GATE goes LOW during an output pulse (LOW), OUT is set HIGH immediately. A trigger (rising edge on GATE) will reload the timer with the initial count on the next CLK pulse. Then, OUT will go LOW (for one CLK pulse) N CLK pulses after the new trigger. Thus, GATE can be used to synchronize the timer. 82380 Figure 5-5. Mode 2 After writing a Control Word and initial count, the timer will be loaded on the next CLK pulse. OUT goes LOW (for the CLK pulse) N CLK pulses after the initial count is written. This is another way the timer may be synchronized by software. Writing a new count while counting does not affect the current counting sequence because the new count will not be loaded until the end of the current counting cycle. If a trigger is received after writing a new count but before the end of the current period, the timer will be loaded with the new count on the next CLK pulse after the trigger, and counting will continue with the new count. ### 5.3.4 MODE 3-SQUARE WAVE GENERATOR Mode 3 is typically used for Baud Rate generation. Functionally, this mode is similar to Mode 2 except for the duty cycle of OUT. In this mode, OUT will be initially HIGH. When half of the initial count has expired, OUT goes low for the remainder of the count. intel. The counting sequence will be repeated, thus this mode is also periodic. Note that an initial count of N results in a square wave with a period of N CLK pulses. The GATE input can be used to synchronize the timer. GATE = HIGH enables counting; GATE = LOW disables counting. If GATE goes LOW while OUT is LOW, OUT is set HIGH immediately (i.e., no CLK pulse is required). A trigger reloads the timer with the initial count on the next CLK pulse. After writing a Control Word and initial count, the timer will be loaded on the next CLK pulse. This allows the timer to be synchronized by software. Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current half-cycle of the square wave, the timer will be loaded with the new count on the next CLK pulse and counting will continue from the new count. Otherwise, the new count will be loaded at the end of the current half-cycle. There is a slight difference in operation depending on whether the initial count is EVEN or ODD. The following description is to show exactly how this mode is implemented. ### **EVEN COUNTS:** OUT is initially HIGH. The initial count is loaded on one CLK pulse and is decremented by two on succeeding CLK pulses. When the count expires (decremented to 2), OUT changes to LOW and the timer is reloaded with the initial count. The above process is repeated indefinitely. #### ODD COUNTS: OUT is initially HIGH. The initial count minus one (which is an even number) is loaded on one CLK Figure 5-6. Mode 3 pulse and is decremented by two on succeeding CLK pulses. One CLK pulse after the count expires (decremented to 2), OUT goes LOW and the timer is loaded with the initial count minus one again. Succeeding CLK pulses decrement the count by two. When the count expires, OUT goes HIGH immediately and the timer is reloaded with the initial count minus one. The above process is repeated indefinitely. So for ODD counts, OUT will be HIGH for (N + 1)/2 counts and LOW for (N - 1)/2 counts. ### 5.3.5 MODE 4—INITIAL COUNT TRIGGERED STROBE This mode allows a strobe pulse to be generated by writing an initial count to the timer. Initially, OUT will be HIGH. When a new initial count is written into the timer, the counting sequence will begin. When the initial count expires (decremented to 1), OUT will go LOW for one CLK pulse and then go HIGH again. Again, GATE = HIGH enables counting while GATE = LOW disables counting. GATE has no effect on OUT. After writing the Control Word and initial count, the timer will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not strobe LOW until N $\pm$ 1 CLK pulses after initial count is written. If a new count is written during counting, it will be loaded in the next CLK pulse and counting will continue from the new count. Figure 5-7. Mode 4 intel. If a two-byte count is written, the following will occur: - 1. Writing the first byte has no effect on counting. - 2. Writing the second byte allows the new count to be loaded on the next CLK pulse. OUT will strobe LOW N $\,+\,$ 1 CLK pulses after the new count of N is written. Therefore, when the strobe pulse will occur after a trigger depends on the value of the initial count loaded. ### 5.3.6 MODE 5—GATE RETRIGGERABLE STROBE Mode 5 is very similar to Mode 4 except the count sequence is triggered by the GATE signal instead of by writing an initial count. Initially, OUT will be HIGH. Counting is triggered by a rising edge of GATE. When the initial count has expired (decremented to 1), OUT will go LOW for one CLK pulse and then go HIGH again. After loading the Control Word and initial count, the Count Element will not be loaded until the CLK pulse after a trigger. This CLK pulse does not decrement the count. Therefore, for an initial count of N, OUT does not strobe LOW until N + 1 CLK pulses after a trigger. Figure 5-8. Mode 5 ### SUMMARY OF GATE OPERATIONS | Mode | GATE LOW or<br>Going LOW | GATE Rising | GATE<br>HIGH | | |------|----------------------------------|-------------------|--------------|--| | 0 | Disable Count | No Effect | Enable Count | | | 1 | No Effect | 1. Initiate Count | No Effect | | | | | 2. Reset Output | | | | | | After Next Clock | | | | 2 | 1. Disable Count | Initiate Count | Enable Count | | | | Sets Output HIGH Immediately | ` | | | | 3 | 1. Disable Count | Initiate Count | Enable Count | | | | Sets Output HIGH Immediately | | | | | 4 | Disable Count | No Effect | Enable Count | | | 5 | No Effect | Initiate Count | No Effect | | The counting sequence is retriggerable. Every trigger will result in the timer being loaded with the initial count on the next CLK pulse. If the new count is written during counting, the current counting sequence will not be affected. If a trigger occurs after the new count is written but before the current count expires, the timer will be loaded with the new count on the next CLK pulse and a new count sequence will start from there. ### 5.3.7 OPERATION COMMON TO ALL MODES ### 5.3.7.1 GATE The GATE input is always sampled on the rising edge of CLKIN. In Modes 0, 2, 3 and 4, the GATE input is level sensitive. The logic level is sampled on the rising edge of CLKIN. In Modes 1, 2, 3 and 5, the GATE input is rising edge sensitive. In these modes, a rising edge of GATE (trigger) sets an edge sensitive flip-flop in the timer. The flip-flop is reset immediately after it is sampled. This way, a trigger will be detected no matter when it occurs; i.e., a HIGH logic level does not have to be maintained until the next rising edge of CLKIN. Note that in Modes 2 and 3. the GATE input is both edge and level sensitive. ### 5.3.7.2 Counter New counts are loaded and counters are decremented on the falling edge of CLKIN. The largest possible initial count is 0. This is equivalent to 2\*\*16 for binary counting and 10\*\*4 for BCD counting. Note that the counter does not stop when it reaches zero. In Modes 0, 1, 4, and 5, the counter 'wraps around' to the highest count: either FFFF Hex for binary counting or 9999 for BCD counting, and continues counting. Modes 2 and 3 are periodic. The counter reloads itself with the initial count and continues counting from there. The minimum and maximum initial count in each counter depends on the mode of operation. They are summarized below. | Mode | Min | Max | |------|-----|-----| | 0 | 1 | 0 | | 1 | 1 | 0 | | 2 | 2 | 0 | | 3 | 2 | 0 | | 4 | 1 | 0 | | 5 | 1 | 0 | ### 5.4 Register Set Overview The Programmable Interval Timer module of the 82380 contains a set of six registers. The port address map of these registers is shown in Table 5-2. Table 5-2. Timer Register Port Address Map | Port Address | Description | | | |--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 40H<br>41H<br>42H<br>43H | Counter 0 Register (read/write<br>Counter 1 Register (read/write<br>Counter 2 Register (read/write<br>Control Word Register I<br>(Counter 0, 1 & 2) (write-only) | | | | 44H<br>45H<br>46H<br>47H | Counter 3 Register (read/write) Reserved Reserved Control Word Register II (Counter 3) (write-only) | | | ### **5.4.1 COUNTER 0, 1, 2, 3 REGISTERS** These four 8-bit registers are functionally identical. They are used to write the initial count value into the respective timer. Also, they can be used to read the latched count value of a timer. Since they are 8-bit registers, reading and writing of the 16-bit initial count must follow the count format specified in the Control Word Registers; i.e., least significant byte only, most significant byte only, or least significant byte then most significant byte (see Programming). ### 5.4.2 CONTROL WORD REGISTER I & II There are two Control Word Registers associated with the Timer section. One of the two registers (Control Word Register I) is used to control the operations of Counters 0, 1, and 2 and the other (Control Word Register II) is for Counter 3. The major functions of both Control Word Registers are listed below: - Select the timer to be programmed. - Define which mode the selected timer is to operate in. - Define the count sequence; i.e., if the selected timer is to count as a Binary Counter or a Binary Coded Decimal (BCD) Counter. - Select the byte access sequence during timer read/write operations; i.e., least significant byte only, most significant byte only, or least significant byte first, then most significant byte. Also, the Control Word Registers can be programmed to perform a Counter Latch Command or a Read Back Command which will be described later. ### 5.5 Programming ### 5.5.1 INITIALIZATION Upon power-up or reset, the state of all timers is undefined. The mode, count value, and output of all timers are random. From this point on, how each timer operates is determined solely by how it is programmed. Each timer must be programmed before it can be used. Since the outputs of some timers can generate interrupt signals to the 82380, all timers should be initialized to a known state. Timers are programmed by writing a Control Word into their respective Control Word Registers. Then, an Initial Count can be written into the correspond- ing Count Register. In general, the programming procedure is very flexible. Only two conventions need to be remembered: - For each timer, the Control Word must be written before the initial count is written. - The 16-bit initial count must follow the count format specified in the Control Word (least significant byte only, most significant byte only, or least significant byte first, followed by most significant byte). Since the two Control Word Registers and the four Counter Registers have separate addresses, and each timer can be individually selected by the appropriate Control Word Register, no special instruction sequence is required. Any programming sequence that follows the conventions above is acceptable. A new initial count may be written to a timer at any time without affecting the timer's programmed mode in any way. Count sequence will be affected as described in the Modes of Operation section. Note that the new count must follow the programmed count format. If a timer is previously programmed to read/write two-byte counts, the following precaution applies. A program must not transfer control between writing the first and second byte to another routine which also writes into the same timer. Otherwise, the read/write will result in incorrect count. Whenever a Control Word is written to a timer, all control logic for that timer(s) is immediately reset (i.e., no CLK pulse is required). Also, the corresponding output pin, TOUT(\*), goes to a known initial state. ### 5.5.2 READ OPERATION Three methods are available to read the current count as well as the status of each timer. They are: Read Counter Registers, Counter Latch Command and Read Back Command. Following is a description of these methods. ### **READ COUNTER REGISTERS** The current count of a timer can be read by performing a read operation on the corresponding Counter Register. The only restriction of this read operation is that the CLKIN of the timers must be inhibited by ### intطِ using external logic. Otherwise, the count may be in the process of changing when it is read, giving an undefined result. Note that since all four timers are sharing the same CLKIN signal, inhibiting CLKIN to read a timer will unavoidably disable the other timers also. This may prove to be impractical. Therefore, it is suggested that either the Counter Latch Command or the Read Back Command be used to read the current count of a timer. Another alternative is to temporarily disable a timer before reading its Counter Register by using the GATE input. Depending on the mode of operation, GATE = LOW will disable the counting operation. However, this option is available on Timer 2 and 3 only, since the GATE signals of the other two timers are internally enabled all the time. #### COUNTER LATCH COMMAND A Counter Latch Command will be executed whenever a special Control Word is written into a Control Word Register. Two bits written into the Control Word Register distinguish this command from a 'regular' Control Word (see Register Bit Definition). Also, two other bits in the Control Word will select which counter is to be latched. Upon execution of this command, the selected counter's Output Latch (OL) latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the 80386, or until the timer is reprogrammed. The count is then unlatched automatically and the OL returns to 'following' the Counting Element (CE). This allows reading the contents of the counters on the fly' without affecting counting in progress. Multiple Counter Latch Commands may be used to latch more than one counter. Each latched count is held until it is read. Counter Latch Commands do not affect the programmed mode of the timer in any way. If a counter is latched, and at some time later, it is latched again before the prior latched count is read, the second Counter Latch Command is ignored. The count read will then be the count at the time the first command was issued. In any event, the latched count must be read according to the programmed format. Specifically, if the timer is programmed for two-byte counts, two bytes must be read. However, the two bytes do not have to be read right after the other. Read/write or programming operations of other timers may be performed between them. #### 82380 Another feature of this Counter Latch Command is that read and write operations of the same timer may be interleaved. For example, if the timer is programmed for two-byte counts, the following sequence is valid. - 1. Read least significant byte. - 2. Write new least significant byte. - 3. Read most significant byte. - 4. Write new most significant byte. If a timer is programmed to read/write two-byte counts, the following precaution applies. A program must not transfer control between reading the first and second byte to another routine which also reads from that same timer. Otherwise, an incorrect count will be read. ### **READ BACK COMMAND** The Read Back Command is another special Command Word operation which allows the user to read the current count value and/or the status of the selected timer(s). Like the Counter Latch Command, two bits in the Command Word identify this as a Read Back Command (see Register Bit Definition). The Read Back Command may be used to latch multiple counter Output Latches (OL's) by selecting more than one timer within a Command Word. This single command is functionally equivalent to several Counter Latch Commands, one for each counter to be latched. Each counter's latched count will be held until it is read by the 80386 or until the timer is reprogrammed. The counter is automatically unlatched when read, but other counters remain latched until they are read. If multiple Read Back commands are issued to the same timer without reading the count, all but the first are ignored; i.e., the count read will correspond to the very first Read Back Command issued. As mentioned previously, the Read Back Command may also be used to latch status information of the selected timer(s). When this function is enabled, the status of a timer can be read from the Counter Register after the Read Back Command is issued. The status information of a timer includes the following: - 1. Mode of timer: - This allows the user to check the mode of operation of the timer last programmed. - 2. State of TOUT pin of the timer: This allows the user to monitor the counter's output pin via software, possibly eliminating some hardware from a system. ### 3. Null Count/Count available: The Null Count Bit in the status byte indicates if the last count written to the Count Register (CR) has been loaded into the Counting Element (CE). The exact time this happens depends on the mode of the timer and is described in the Programming section. Until the count is loaded into the Counting Element (CE), it cannot be read from the timer. If the count is latched or read before this occurs, the count value will not reflect the new count just written. If multiple status latch operations of the timer(s) are performed without reading the status, all but the first command are ignored; i.e., the status read in will correspond to the first Read Back Command issued. Both the current count and status of the selected timer(s) may be latched simultaneously by enabling both functions in a single Read Back Command. This is functionally the same as issuing two separate Read Back Commands at once. Once again, if multiple read commands are issued to latch both the count and status of a timer, all but the first command will be ignored. If both count and status of a timer are latched, the first read operation of that timer will return the latched status, regardless of which was latched first. The next one or two (if two count bytes are to be read) read operations return the latched count. Note that subsequent read operations on the Counter Register will return the unlatched count (like the first read method discussed). ### 5.6 Register Bit Definitions COUNTER 0, 1, 2, 3 REGISTER (READ/WRITE) | Port Address | Description | | | |--------------|---------------------------------|--|--| | 40H | Counter 0 Register (read/write) | | | | 41H | Counter 1 Register (read/write) | | | | 42H | Counter 2 Register (read/write) | | | | 44H | Counter 3 Register (read/write) | | | | 45H | Reserved | | | | 46H | Reserved | | | Note that these 8-bit registers are for writing and reading of one byte of the 16-bit count value, either the most significant or the least significant byte. ### CONTROL WORD REGISTER I & II (WRITE-ONLY) | Port Address | Description | |--------------|-----------------------------------------------------------| | 43H | Control Word Register I<br>(Counter 0, 1, 2) (write-only) | | 47H | Control Word Register II<br>(Counter 3) (write-only) | ### **CONTROL WORD REGISTER I** ### 82380 ### CONTROL WORD REGISTER II ### COUNTER LATCH COMMAND FORMAT (Write to Control Word Register) | Timer | | | Gate<br>Trigger | | | |---------|----|--------------|------------------|----------------------|-------------| | 0 1 2 3 | | | | Edge | Level | | | | | | | Х | | NA | NA | Θ | 0 | Х | | | | | | | х | X | | | | | | Х | X | | | | | | | X | | NA | NA | 0 | 0 | X | | | | NA | 0 1<br>NA NA | 0 1 2<br>NA NA 0 | 0 1 2 3<br>NA NA 0 0 | Trig Trig | Interrupt on Terminal Count Gate Retriggerable One Shot Rate Generator Square Wave Generator Initial Count Triggered Strobe Gate Retriggerable Strobe NA = Not Applicable READ BACK COMMAND FORMAT (Write to Control Word Register) ### STATUS FORMAT (Returned from Read Back Command) ### 6.0 WAIT STATE GENERATOR ### 6.1 Functional Description The 82380 contains a programmable Wait State Generator which can generate a pre-programmed number of wait states during both CPU and DMA initiated bus cycles. This Wait State Generator is capable of generating 1 to 16 wait states in non-pipe- lined mode, and 0 to 15 wait states in pipelined mode. Depending on the bus cycle type and the two Wait State Control inputs (WSC 0-1), a pre-programmed number of wait states in the selected Wait State Register will be generated. The Wait State Generator can also be disabled to allow the use of devices capable of generating their own READY# signals. Figure 6-1 is a block diagram of the Wait State Generator. ### 6.2 Interface Signals The following describes the interface signals which affect the operation of the Wait State Generator. The READY#, WSC0 and WSC1 signals are inputs. READYO# is the ready output signal to the host processor. ### 6.2.1 READY# READY# is an active LOW input signal which indicates to the 82380 the completion of a bus cycle. In the Master mode (e.g., 82380 initiated DMA transfer), this signal is monitored to determine whether a peripheral or memory needs wait states inserted in the current bus cycle. In the Slave mode, it is used (together with the ADS# signal) to trace CPU bus cycles to determine if the current cycle is pipelined. ### 6.2.2 READYO# READYO# (Ready Out#) is an active LOW output signal and is the output of the Wait State Generator. The number of wait states generated depends on the WSC(0-1) inputs. Note that special cases are 82380 handled for access to the 82380 internal registers and for the Refresh cycles. For 82380 internal register access, READYO# will be delayed to take into account the command recovery time of the register. One or more wait states will be generated in a pipelined cycle. During refresh, the number of wait states will be determined by the preprogrammed value in the Refresh Wait State Register. In the simplest configuration, READYO# can be connected to the READY# input of the 82380 and the 80386 CPU. This is, however, not always the case. If external circuitry is to control the READY# inputs as well, additional logic will be required (see Application Issues). ### 6.2.3 WSC(0-1) These two Wait State Control inputs select one of the three pre-programmed 8-bit Wait State Registers which determines the number of wait states to be generated. The most significant half of the three Wait State Registers corresponds to memory accesses, the least significant half to I/O accesses. The combination WSC(0-1) = 11 disables the Wait State Generator. Figure 6-1. Wait State Generator Block Diagram Figure 6-2. Wait States in Non-Pipelined Cycles ### 6.3 Bus Function ### 6.3.1 WAIT STATES IN NON-PIPELINED CYCLE The timing diagram of two typical non-pipelined cycles with 82380 generated wait states is shown in Figure 6-2. In this diagram, it is assumed that the internal registers of the 82380 are not addressed. During the first T2 state of each bus cycle, the Wait State Control and the M/IO# inputs are sampled to determine which Wait State Register (if any) is selected. If the WSC inputs are active (i.e., not both are driven HIGH), the pre-programmed number of wait states corresponding to the selected Wait State Register will be requested. This is done by driving the READYO# output HIGH during the end of each T2 state. The WSC(0-1) inputs need only be valid during the very first T2 state of each non-pipelined cycle. As a general rule, the WSC inputs are sampled on the rising edge of the next clock (82384 CLK) after the last state when ADS# (Address Status) is asserted. The number of wait states generated depends on the type of bus cycle, and the number of wait states requested. The various combinations are discussed below. - Access the 82380 internal registers: 2 to 5 wait states, depending upon the specific register addressed. Some back-to-back sequences to the Interrupt Controller will require 7 wait states. - 2. Interrupt Acknowledge to the 82380: 5 wait - Refresh: As programmed in the Refresh Wait State Register (see Register Set Overview). Note that if WSC(0-1) = 11, READYO # will stay inactive. - 4. Other bus cycles: Depending on WSC(0-1) and M/IO# inputs, these inputs select a Wait State Register in which the number of wait states will be equal to the pre-programmed wait state count in the register plus 1. The Wait State Register selection is defined as follows (Table 6-1). # intط. Table 6-1. Wait State Register Selection | M/10# | WSC(1-0) | Register Selected | |-------|----------|--------------------------| | 0 | 00 | WAIT REG 0 (I/O half) | | 0 | 01 | WAIT REG 1 (I/O half) | | 0 | 10 | WAIT REG 2 (I/O half) | | 1 | 00 | WAIT REG 0 (MEM half) | | 1 | 01 | WAIT REG 1 (MEM half) | | 1 | 10 | WAIT REG 2 (MEM half) | | X | 11 | Wait State Gen. Disabled | The Wait State Control signals, WSC(0-1), can be generated with the address decode and the Read/ Write control signals as shown in Figure 6-3. Figure 6-3. WSC(0-1) Generation ### 82380 Note that during HALT and SHUTDOWN, the number of wait states will depend on the WSC(0-1) inputs, which will select the memory half of one of the Wait State Registers (see CPU Reset and Shutdown Detect). ### 6.3.2 WAIT STATES IN PIPELINED CYCLE The timing diagram of two typical pipelined cycles with 82380 generated wait states is shown in Figure 6-4. Again, in this diagram, it is assumed that the 82380 internal registers are not addressed. As defined in the timing of the 80386 processor, the Address (A 2-31), Byte Enable (BE 0-3), and other control signals (M/IO#, ADS#) are asserted one T state earlier than in a non-pipelined cycle; i.e., they are asserted at T2P. Similar to the non-pipelined case, the Wait State Control (WSC) inputs are sampled in the middle of the state after the last state when the ADS# signal is asserted. Therefore, the WSC inputs should be asserted during the T1P state of each pipelined cycle (which is one T state earlier than in the non-pipelined cycle). Figure 6-4. Wait State in Pipelined Cycles intel. The number of wait states generated in a pipelined cycle is selected in a similar manner as in the non-pipelined case discussed in the previous section. The only difference here is that the actual number of wait states generated will be one less than that of the non-pipelined cycle. This is done automatically by the Wait State Generator. ### 6.3.3 EXTENDING AND EARLY TERMINATING BUS CYCLE The 82380 allows external logic to either add wait states or cause early termination of a bus cycle by controlling the READY# input to the 82380 and the host processor. A possible configuration is shown in Figure 6-5. The EXT. RDY# (External Ready) signal of Figure 6-5 allows external devices to cause early termination of a bus cycle. When this signal is asserted LOW, the output of the circuit will also go LOW (even though the READYO# of the 82380 may still be HIGH). This output is fed to the READY# input of the 80386 and the 82380 to indicate the completion of the current bus cycle. Similarly, the EXT. NOT READY (External Not Ready) signal is used to delay the READY# input of the processor and the 82380. As long as this signal is driven HIGH, the output of the circuit will drive the READY# input HIGH. This will effectively extend the duration of a bus cycle. However, it is important to note that if the two-level logic is not fast enough to satisfy the READY# setup time, the OR gate should be eliminated. Instead, the 82380 Wait State Generator can be disabled by driving both WSC(0-1) HIGH. In this case, the addressed memory or I/O device should activate the external READY# input whenever it is ready to terminate the current bus cycle. Figure 6-6 and 6-7 show the timing relationships of the ready signals for the early termination and extension of the bus cycles. Section 6.7, Application Issues, contains a detailed timing analysis of the external circuit. Figure 6-5. External 'READY' Control Logic Figure 6-6. Early Termination of Bus Cycle By 'READY#' 82380 Figure 6-7. Extending Bus Cycle by 'READY#' Due to the following implications, it should be noted that early termination of bus cycles in which 82380 internal registers are accessed is not recommended. - Erroneous data may be read from or written into the addressed register. - The 82380 must be allowed to recover either before HLDA (Hold Acknowledge) is asserted or before another bus cycle into an 82380 internal register is initiated. The recovery time, in bus periods, equals the remaining wait states that were avoided plus 4. ### 6.4 Register Set Overview Altogether, there are four 8-bit internal registers associated with the Wait State Generator. The port address map of these registers is shown below in Table 6-2. A detailed description of each follows. Table 6-2. Register Address Map | Port Address | Description | | | |--------------|----------------------------------|--|--| | 72H | Wait State Reg 0 (read/write) | | | | 73H | Wait State Reg 1 (read/write) | | | | 74H | Wait State Reg 2 (read/write) | | | | 75H | Ref. Wait State Reg (read/write) | | | ### WAIT STATE REGISTER 0, 1, 2 These three 8-bit read/write registers are functionally identical. They are used to store the pre-programmed wait state count. One half of each register contains the wait state count for I/O accesses while the other half contains the count for memory accesses. The total number of wait states generated will depend on the type of bus cycle. For a non-pipelined cycle, the actual number of wait states requested is equal to the wait state count plus 1. For a pipelined cycle, the number of wait states will be equal to the wait state count in the selected register. Therefore, the Wait State Generator is capable of generating 1 to 16 wait states in non-pipelined mode, and 0 to 15 wait states in pipelined mode. Note that the minimum wait state count in each register is 0. This is equivalent to 0 wait states for a pipelined cycle and 1 wait state for a non-pipelined cycle. ### REFRESH WAIT STATE REGISTER Similar to the Wait State Registers discussed above, this 4-bit register is used to store the number of wait states to be generated during the DRAM refresh cycle. Note that the Refresh Wait State Register is not selected by the WSC inputs. It will automatically be chosen whenever a DRAM refresh cycle occurs. If the Wait State Generator is disabled during the refresh cycle (WSC(0-1) = 11), READYO# will stay inactive and the Refresh Wait State Register is ignored. ### 6.5 Programming Using the Wait State Generator is relatively straightforward. No special programming sequence is required. In order to ensure the expected number of wait states will be generated when a register is selected, the registers to be used must be programmed after power-up by writing the appropriate wait state count into each register. Note that upon hardware reset, all Wait State Registers are initialized with the value FFH, giving the maximum number of wait states possible. Also, each register can be read to check the wait state count previously stored in the register. ### 6.6 Register Bit Definition WAIT STATE REGISTER 0, 1, 2 | Port Address | Description | | | |--------------|------------------------------------|--|--| | 72H | Wait State Register 0 (read/write) | | | | 73H | Wait State Register 1 (read/write) | | | | 74H | Wait State Register 2 (read/write) | | | # intel. ### REFRESH WAIT STATE REGISTER Port Address: 75H (Read/Write) ### 6.7 Application Issues ### 6.7.1 EXTERNAL 'READY' CONTROL LOGIC As mentioned in section 6.3.3, wait state cycles generated by the 82380 can be terminated early or extended longer by means of additional external logic (see Figure 6-5). In order to ensure that the READY # input timing requirement of the 80386 and the 82380 is satisfied, special care must be taken when designing this external control logic. This section addresses the design requirements. 82380 A simplified block diagram of the external logic along with the READY # tilming diagram is shown in Figure 6-8. The purpose is to determine the maximum delay time allowed in the external control logic in order to satisfy the READY # setup time. First, it will be assumed that the 80386 is running at 16 MHz (i.e., CLK2 and 32 MHz). Therefore, one bus state (two CLK2 periods) will be equivalent to 62.5 nsec. According to the AC specifications of the 82380, the maximum delay time for valid READYO# signal is 31 ns after the rising edge of CLK2 in the beginning of T2 (for non-pipelined cycle) or T2P (for pipelined cycle). Also, the minimum READY# setup time of the 80386 and the 82380 should be 20 ns before the rising edge of CLK2 at the beginning of the next bus state. This limits the total delay time for the external READY# control logic to be 11 ns (62.5-31-21) in order to meet the READY# setup timing requirement. ## intel. ### 7.0 DRAM REFRESH CONTROLLER ### 7.1 Functional Description The 82380 DRAM Refresh Controller consists of a 24-bit Refresh Address Counter and Refresh Request logic for DRAM refresh operations (see Figure 7-1). TIMER 1 can be used as a trigger signal to the DRAM Refresh Request logic. The Refresh Bus Size can be programmed to be 8-, 16-, or 32-bit wide. Depending on the Refresh Bus Size, the Refresh Address Counter will be incremented with the appropriate value after every refresh cycle. The internal logic of the 82380 will give the Refresh operation the highest priority in the bus control arbitration process. Bus control is not released and re-requested if the 82380 is already a bus master. ### 7.2 Interface Signals ### 7.2.1 TOUT1/REF# The dual function output pin of TIMER 1 (TOUT1/REF#) can be programmed to generate DRAM Refresh signal. If this feature is enabled, the rising edge of TIMER 1 output (TOUT1) will trigger the DRAM Refresh Request logic. After some delay for gaining access of the bus, the 82380 DRAM Controller will generate a DRAM Refresh signal by driving REF# output LOW. This signal is cleared after the refresh cycle has taken place, or by a hardware reset. If the DRAM Refresh feature is disabled, the TOUT1/REF # output pin is simply the TIMER 1 output. Detailed information of how TIMER 1 operates is discussed in section 6—Programmable Interval Timer, and will not be repeated here. Figure 7-1. DRAM Refresh Controller # intها. ### 7.3 Bus Function ### 7.3.1 ARBITRATION In order to ensure data integrity of the DRAMs, the 82380 gives the DRAM Refresh signal the highest priority in the arbitration logic. It allows DRAM Refresh to interrupt a DMA in progress in order to perform the DRAM Refresh cycle. The DMA service will be resumed after the refresh is done. In case of a DRAM Refresh during a DMA process, the cascaded device will be requested to get off the bus. This is done by deasserting the EDACK signal. Once DREQn goes inactive, the 82380 will perform the refresh operation. Note that the DMA controller does not completely relinquish the system bus during refresh. The Refresh Generator simply 'steals' a bus cycle between DMA accesses. Figure 7-2 shows the timing diagram of a Refresh Cycle. Upon expiration of TIMER 1, the 82380 will try to take control of the system bus by asserting HOLD. As soon as the 82380 see HLDA go active, the DRAM Refresh Cycle will be carried out by activating the REF# signal as well as the refresh address and control signals on the system bus (Note 82380 that REF# will not be active until two CLK periods after HLDA is asserted). The address bus will contain the 24-bit address currently in the Refresh Address Counter. The control signals are driven the same way as in a Memory Read cycle. This 'read' operation is complete when the READY# signal is driven LOW. Then, the 82380 will relinquish the bus by de-asserting HOLD. Typically, a Refresh Cycle without wait states will take five bus states to execute. If 'n' wait states are added, the Refresh Cycle will last for five plus 'n' bus states. How often the Refresh Generation will initiate a refresh cycle depends on the frequency of CLKIN as well as TIMER1's programmed mode of operation. For this specific application, TIMER1 should be programmed to operate in Mode 2 or 3 to generate a constant clock rate. See section 6-Programmable Interval Timer for more information on programming the timer. One DRAM Refresh Cycle will be generated each time TIMER 1 expires (when TOUT1 changes to LOW to HiGH). The Wait State Generator can be used to insert wait states during a refresh cycle. The 82380 will automatically insert the desired number of wait states as programmed in the Refresh Wait State Register (see Wait State Generator). Figure 7-2. 82380 Refresh Cycle ### 7.4 Modes of Operation ### 7.4.1 WORD SIZE AND REFRESH ADDRESS COUNTER The 82380 supports 8-, 16- and 32-bit refresh cycle. The bus width during a refresh cycle is programmable (see Programming). The bus size can be programmed via the Refresh Control Register (see Register Overview). If the DRAM bus size is 8-, 16-, or 32-bits, the Refresh Address Counter will be incremented by 1, 2, or 4, respectively. The Refresh Address Counter is cleared by a hardware reset. ### 7.5 Register Set Overview The Refresh Generator has two internal registers to control its operation. They are the Refresh Control Register and the Refresh Wait State Register. Their port address map is shown in Table 7-1 below. | Port Address | Description | | | |--------------|-----------------------------------|--|--| | 1CH | Refresh Control Reg. (read/write) | | | | 75H | Ref. Wait State Reg. (read/write) | | | Table 7-1. Register Address Map The Refresh Wait State Register is not part of the Refresh Generator. It is only used to program the number of wait states to be inserted during a refresh cycle. This register is discussed in detail in section 7 (Wait State Generator) and will not be repeated ### REFRESH CONTROL REGISTER This 2-bit register serves two functions. First, it is used to enable/disable the DRAM Refresh function output. If disabled, the output of TIMER 1 is simply used as a general purpose timer. The second function of this register is to program the DRAM bus size for the refresh operation. The programmed bus size also determines how the Refresh Address Counter will be incremented after each refresh operation. ### 7.6 Programming Upon hardware reset, the DRAM Refresh function is disabled (the Refresh Control Register is cleared). The following programming steps are needed before the Refresh Generator can be used. Since the rate of refresh cycles depends on how TIMER 1 is programmed, this timer must be initialized with the desired mode of operation as well as the correct refresh interval (see Programming Interval Timer). Whether or not wait states are to be generated during a refresh cycle, the Refresh Wait State Register must also be programmed with the appropriate value. Then, the DRAM Refresh feature must be enabled and the DRAM bus width should be defined. These can be done in one step by writing the appropriate control word into the Refresh Control Register (see Register Bit Definition). After these steps are done, the refresh operation will automatically be invoked by the Refresh Generator upon expiration of Timer 1. In addition to the above programming steps, it should be noted that after reset, although the TOUT1/REF# becomes the Timer 1 output, the state of this pin is undefined. This is because the Timer module has not been initialized yet. Therefore, if this output is used as a DRAM Refresh signal, this pin should be disqualified by external logic until the Refresh function is enabled. One simple solution is to logically AND this output with HLDA, since HLDA should not be active after reset. ### 7.7 Register Bit Definition REFRESH CONTROL REGISTER Port Address: 1CH (Read/Write) ### **8.0 RELOCATION REGISTER AND ADDRESS DECODE** ### 8.1 Relocation Register All the integrated peripheral devices in the 82380 are controlled by a set of internal registers. These registers span a total of 256 consecutive address locations (although not all the 256 locations are used). The 82380 provides a Relocation Register which allows the user to map this set of internal registers into either the memory or I/O address space. The function of the Relocation Register is to define the base address of the internal register set of the 82380 as well as if the registers are to be memoryor I/O-mapped. The format of the Relocation Register is depicted in Figure 8-1. Figure 8-1. Relocation Register Note that the Relocation Register is part of the internal register set of the 82380. It has a port address of 7FH. Therefore, any time the content of the Relocation Register is changed, the physical location of this register will also be moved. Upon reset of the 82380, the content of the Relocation Register will be cleared. This implies that the 82380 will respond to its I/O addresses in the range of 0000H to 00FFH. #### 8.1.1 I/O-MAPPED 82380 As shown in the figure, Bit 0 of the Relocation Register determines whether the 82380 registers are to be memory-mapped or I/O-mapped. When Bit 0 is set to '0', the 82380 will respond to I/O Addresses. Address signals BE0#-BE3#, A2-A7 will be used to select one of the internal registers to be accessed. Bit 1 to Bit 7 of the Relocation Register will correspond to A9 to A15 of the Address bus, respectively. Together with A8 implied to be '0', A15 to A8 will be fully decoded by the 82380. The following shows how the 82380 is mapped into the I/O address space. ### Example Relocation Register = 11001110 (0CEH) 82380 will respond to I/O address range from 0CE00H to 0CEFFH. Therefore, this I/O mapping mechanism allows the 82380 internal registers to be located on any even, contiguous, 256 byte boundary of the system I/O space. Port Address: 7FH (Read/Write) ### 8.1.2 MEMORY-MAPPED 82380 When Bit 0 of the Relocation Register is set to '1', the 82380 will respond to memory addresses. Again, Address signals BE0#-BE3#, A2-A7 will be used to select one of the internal registers to be accessed. Bit 1 to Bit 7 of the Relocation Register will correspond to A25-A31, respectively. A24 is assumed to be '0', and A8-A23 are ignored. Consider the following example. 82380 ### Example Relocation Register = 10100111 (0A7H) The 82380 will respond to memory addresses in the range of 0A6XXXX00H to 0A6XXXXFFH (where 'X' is don't care). This scheme implies that the internal register can be located in any even, contiguous, 2\*\*24 byte page of the memory space. ### 8.2 Address Decoding As mentioned previously, the 82380 internal registers do not occupy the entire contiguous 256 address locations. Some of the locations are 'unoccupied'. The 82380 always decodes the lower 8 address bits (A0-A7) to determine if any one of its registers is being accessed. If the address does not correspond to any of its registers, the 82380 will not respond. This allows external devices to be located within the 'holes' in the 82380 address space. Note that there are several unused addresses reserved for future Intel peripheral devices. ### 9.0 CPU RESET AND SHUTDOWN DETECT The 82380 will activate the CPURST signal to reset the host processor when one of the following conditions occurs: - 82380 RESET is active; - 82380 detects a 80386 Shutdown cycle (this feature can be disabled); - CPURST software command is issued to 80386. Whenever the CPURST signal is activated, the 82380 will reset its own internal Slave-Bus state machine. ### 9.1 Hardware Reset Following a hardware reset, the 82380 will assert its CPURST output to reset the host processor. This output will stay active for as long as the RESET input is active. During a hardware reset, the 82380 internal registers will be initialized as defined in the corresponding functional descriptions. ### 9.2 Software Reset CPURST can be generated by writing the following bit pattern into 82380 register location 64H. | D7 | | | | | | | D0 | |--------|----------|---|---|---|---|---|----| | 1 | 1 | 1 | 1 | Х | Х | Х | 0 | | X = 00 | o't Care | | | | | | | The Write operation into this port is considered as an 82380 access and the internal Wait State Generator will automatically determine the required number of wait states. The CPURST will be active following the completion of the Write cycle to this port. This signal will last for 80 CLK2 periods. The 82380 should not be accessed until the CPURST is deactivated. This internal port is Write-Only and the 82380 will not respond to a Read operation to this location. Also, during a CPU software reset command, the 82380 will reset its Slave-Bus state machine. However, its internal registers remain unchanged. This allows the operating system to distinguish a 'warm' reset by reading any 82380 internal register previously programmed for a non-default value. The Diagnostic registers can be used or this purpose (see Internal Control and Diagnostic Ports). ### 9.3 Shutdown Detect The 82380 is constantly monitoring the Bus Cycle Definition signals (M/IO#, D/C#, R/W#) and is able to detect when the 80386 executes a Shutdown bus cycle. Upon detection of a processor shutdown, the 82380 will activate the CPURST output for 62 CLK2 periods to reset the host processor. This signal is generated after the Shutdown cycle is terminated by the READY # signal. Although the 82380 Wait State Generator will not automatically respond to a Shutdown (or Halt) cycle, the Wait State Control inputs (WSC0, WSC1) can be used to determine the number of wait states in the same manner as other non-82380 bus cycle. This Shutdown Detect feature can be enabled or disabled by writing a control bit in the Internal Control Port at address 61H (see Internal Control and Diag- nostic Ports). This feature is disabled upon a hardware reset of the 82380. As in the case of Software Reset, the 82380 will reset its Slave-Bus state machine but will not change any of its internal register contents. ### 10.0 INTERNAL CONTROL AND **DIAGNOSTIC PORTS** ### 10.1 Internal Control Port The format of the Internal Control Port of the 82380 is shown in Figure 10.1. This Control Port is used to enable/disable the Processor Shutdown Detect mechanism as well as controlling the Gate inputs of the Timer 2 and 3. Note that this is a Write-Only port. Therefore, the 82380 will not respond to a read operation to this port. Upon hardware reset, this port will be cleared; i.e., the Shutdown Detect feature and the Gate inputs of Timer 2 and 3 are disabled. ### 10.2 Diagnostic Ports Two 8-bit read/write Diagnostic Ports are provided in the 82380. These are two storage registers and have no effect on the operation of the 82380. They can be used to store checkpoint data or error codes in the power-on sequence and in the diagnostic service routines. As mentioned in CPU RESET AND SHUTDOWN DETECT section, these Diagnostic Ports can be used to distinguish between 'cold' and 'warm' reset. Upon hardware reset, both Diagnostic Ports are cleared. The address map of these Diagnostic Ports is shown in Figure 10-2. | Port | Address | |--------------------------------|---------| | Diagnostic Port 1 (Read/Write) | 80H | | Diagnostic Port 2 (Read/Write) | 88H | Figure 10-2. Address Map of Diagnostic Ports Port Address: 61H (Write Only) Figure 10-1. Internal Control Port 82380 ### 11.0 INTEL RESERVED I/O PORTS There are eleven I/O ports in the 82380 address space which are reserved for Intel future peripheral device use only. Their address locations are: 2AH, 3DH, 3EH, 45H, 46H, 76H, 77H, 7DH, 7EH, CCH and CDH. These addresses should not be used in the system since the 82380 may respond to read/write operations to these locations and bus conten- tion may occur if any peripheral is assigned to the same address location. ### 12.0 MECHANICAL DATA ### 12.1 Introduction In this section, the physical package and its connections are described in detail. Figure 12.1. 82380 PGA Pinout—View from TOP side ### intel. ### 12.2 Pin Assignment The 82380 pinout as viewed from the top side of the component is shown in Figure 12.1. Its pinout as viewed from the pin side of the component is shown in Figure 12.2. $V_{CC}$ and GND connections must be made to multiple $V_{CC}$ and $V_{SS}$ (GND) pins. Each $V_{CC}$ and $V_{SS}$ MUST be connected to the appropriate voltage level. The circuit board should include $V_{CC}$ and GND planes for power distribution and all $V_{CC}$ pins must be connected to the appropriate plane. Figure 12.2. 82380 PGA Pinout—View from PIN side 82380 Table 12-1. 82380 PGA Pinout—Functional Grouping | | Table 12-1. 02000 FGA Pillout—Punctional Grouping | | | | | | | | | | |-----|---------------------------------------------------|-----|------------|------|-----------------|------------|-----------------|--|--|--| | Pin | Pin/Signat | | Pin/Signal | | Pin/Signal | Pin/Signal | | | | | | A7 | A31 | A8 | D31 | P12 | V <sub>CC</sub> | L14 | V <sub>SS</sub> | | | | | C7 | A30 | B9 | D30 | M14 | Vcc · | A1 | VSS | | | | | B7 | A29 | A11 | D29 | P1 | V <sub>CC</sub> | P13 | V <sub>SS</sub> | | | | | A6 | A28 | C11 | D28 | P2 | V <sub>CC</sub> | N1 | V <sub>SS</sub> | | | | | B6 | A27 | D12 | D27 | P14 | Vcc | N2 | V <sub>SS</sub> | | | | | C6 | A26 | E13 | D26 | D1 | V <sub>CC</sub> | C1 | VSS | | | | | A5 | A25 | F14 | D25 | C14 | V <sub>CC</sub> | A3 | VSS | | | | | B5 | A24 | J13 | D24 | B1 | V <sub>CC</sub> | B14 | V <sub>SS</sub> | | | | | C5 | A23 | B8 | D23 | A2 - | Vcc | A13 | V <sub>SS</sub> | | | | | B4 | A22 | C9 | D22 | A4 | Vcc | N14 | VSS | | | | | B3 | A21 | B11 | D21 | A12 | V <sub>CC</sub> | 1. | | | | | | C4 | A20 | B13 | D20 | A14 | V <sub>CC</sub> | P6 | IRQ23# | | | | | B2 | A19 | D13 | D19 | | | N6 | IRQ22# | | | | | C3 | A18 | E14 | D18 | G14 | CLK2 | M7 | IRQ21# | | | | | C2 | A17 | G12 | D17 | L12 | D/C# | N7 | IRQ20# | | | | | D3 | A16 | H13 | D16 | K12 | W/R# | P7 | IRQ19# | | | | | D2 | A15 | C8 | D15 | L13 | M/IO# | P8 | IRQ18# | | | | | E3 | A14 | A10 | D14 | K2 | ADS# | M8 | IRQ17# | | | | | E2 | A13 | C10 | D13 | N4 | NA# | N8 - | IRQ16# | | | | | E1 | A12 | C12 | D12 | J12 | HOLD | P9 | IRQ15# | | | | | F3 | A11 | D14 | D11 | M3 | HLDA | N9 | IRQ14# | | | | | F2 | A10 | F12 | D10 | M6 | DREQ0 | M9 | IRQ13# | | | | | F1 | A9 | G13 | D9 | P5 | DREQ1 | N10 | IRQ12# | | | | | G1 | A8 | K14 | D8 | N5 | DREQ2 | P10 | IRQ11# | | | | | G2 | A7 | A9 | D7 | P4 | DREQ3 | M2 | INT | | | | | G3 | A6 | B10 | D6 | M5 | DREQ4/IRQ9# | } | | | | | | H1 | A5 | B12 | D5 | P3 | DREQ5 | N11 | CLKIN | | | | | H2 | A4 | C13 | D4 | M4 | DREQ6 | K13 | TOUT1/REF# | | | | | J1 | A3 | E12 | D3 | N3 | DREQ7 | N13 | TOUT2#/IRQ3# | | | | | НЗ | A2 | F13 | D2 | | | M13 | TOUT3# | | | | | J2 | BE3# | H14 | D1 | K3 | EOP# | M11 | READY# | | | | | J3 | BE2# | J14 | D0 | L3 | EDACK0 | H12 | READYO# | | | | | K1 | BE1# | | | M1 | EDACK1 | P11 | WSC0 | | | | | L1 | BE0# | N12 | RESET | L2 | EDACK2 | M10 | WSC1 | | | | | | | M12 | CPURST | | | | | | | | ## intel. ### 12.3 Package Dimensions and Mounting The 82380 package is a 132-pin ceramic Pin Grid Array (PGA). The pins are arranged 0.100 inch (2.54 mm) center-to-center, in a 14 x 14 matrix, three rows around. A wide variety of available sockets allow low insertion force or zero insertion force mountings, and a choice of terminals such as soldertail, surface mount, or wire wrap. Several applicable sockets are listed in Figure 12-4. Figure 12.3. 132-Pin Ceramic PGA Package Dimensions 82380 Figure 12-4. Several Socket Options for 132-pin PGA Figure 12-4. Several Socket Options for 132-pin PGA (Continued) ### 12.4 Package Thermal Specification The 82380 is specified for operation when case temperature is within the range of 0°C -85°C. The case temperature may be measured in any environment, to determine whether the 82380 is within the specified operating range. The PGA case temperature should be measured at the center of the top surface opposite the pins, as in Figure 12.5. Figure 12.5. Measuring 82380 PGA Case Temperature 82380 | Thermal Resistance—°C/Watt | | | | | | | | | |----------------------------------------------------------------------------|-------------------------|--------------|---------------|---------------|---------------|---------------|---------------|--| | | Airflow—f³/min (m³/sec) | | | | | | | | | Parameter | | 50<br>(0.25) | 100<br>(0.50) | 200<br>(1.01) | 400<br>(2.03) | 600<br>(3.04) | 800<br>(4.06) | | | θ Junction-to-Case (case measured as Fig. 6.4) | 2 | 2 | 2 | 2 | 2 | 2 | 2 | | | θ Case-to-Ambient (no heatsink) | 19 | 18 | 17 | 15 | 12 | 10 | 9 | | | $\theta$ Case-to-Ambient (with omnidirectional heatsink) | 16 | 15 | 14 | 12 | 9 | 7 | 6 | | | <ul><li>θ Case-to-Ambient<br/>(with unidirectional<br/>heatsink)</li></ul> | 15 | 14 | 13 | 11 | 8 | 6 | 5 | | ### NOTES: - 1. Table 12-6 applies to 82380 PGA plugged into socket or soldered directly into board. - 3. $\theta_{\text{J-PN}} = \theta_{\text{JC}} + \theta_{\text{CA}}$ . 9. $\theta_{\text{J-PN}} = 4^{\circ}\text{C/W}$ (approx.) (approx.) - $\theta_{\text{J-P!N}} = 8^{\circ}\text{C/W} \text{ (outer pins) (approx.)}$ Figure 12-6. 82380 PGA Package Typical Thermal Characteristics ### 13.0 ELECTRICAL DATA ### 13.1 Power and Grounding The large number of output buffers (address, data and control) can cause power surges as multiple output buffers drive new signal levels simultaneously. The 22 V<sub>CC</sub> and V<sub>SS</sub> pins of the 82380 each feed separate functional units to minimize switching induced noise effects. All V<sub>CC</sub> pins of the 82380 must be connected on the circuit board. ### 13.2 Power Decoupling Liberal decoupling capacitance should be placed close to the 82380. The 82380 driving its 32-bit parallel address and data buses at high frequencies can cause transient power surges when driving large capacitive loads. Low inductance capacitors and interconnects are recommended for the best reliability at high frequencies. Low inductance capacitors are available specifically for Pin Grid Array packages. ### 13.3 Unused Pin Recommendations For reliable operation, ALWAYS connect unused inputs to a valid logic level. As is the case with most other CMOS processes, a floating input will increase the current consumption of the component and give an indeterminate state to the component. ### 13.4 ICE-386 Support The 82380 specifications provide sufficient drive capability to support the ICE386. On the pins that are generally shared between the 80386 and the 82380, the additional loading represented by the ICE386 was allowed for in the design of the 82380. ### 13.5 Maximum Ratings ### NOTE: Stress above those listed above may cause permanent damage to the device. This is a stress rating only and functional operation at these or any other conditions above those listed in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Although the 82380 contains protective circuitry to reset damage from static electric discharges, always take precautions against high static voltages or electric fields. ### 13.6 D.C. Specifications $T_{CASE} = 0$ °C to 85°C; $V_{CC} = 5V \pm 5$ %; $V_{SS} = 0V$ . Table 13-1. | lable 13-1. | | | | | | | | |------------------|------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|------------|----------------------------------------------------|--|--| | Symbol | Parameter | Min | Max | Unit | Notes | | | | V <sub>IL</sub> | Input Low Voltage | -0.3 | 0.8 | V | (Note 1) | | | | V <sub>IH</sub> | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | | | | VILC | CLK2 Input Low Voltage | -0.3 | 0.8 | | (Note 1) | | | | V <sub>IHC</sub> | CLK2 Input High Voltage | V <sub>CC</sub> - 0.8 | V <sub>CC</sub> + 0.3 | V | | | | | V <sub>OL</sub> | Output Low Voltage<br>I <sub>OL</sub> = 4 mA: A2-A31,<br>D0-D31<br>I <sub>OL</sub> = 5 mA: All Others | | 0.45<br>0.45 | V | | | | | V <sub>OH</sub> | Output High Voltage<br>I <sub>OH</sub> = -1 mA: A2-A31,<br>D0-D31<br>I <sub>OH</sub> = -0.9 mA: All Others | 2.4<br>2.4 | | <b>V V</b> | | | | | lu | Input Leakage Current for<br>all ins except:<br>IRQ11#-IRQ23#,<br>TOUT2/IRQ3#, EOP#, DREQ4 | | ±15 | μΑ | 0V <v<sub>IN<v<sub>CC</v<sub></v<sub> | | | | l <sub>Li1</sub> | Input Leakage Current for pins: IRQ11#-IRQ23#, TOUT2#/IRQ3#, EOP#, DREQ4 | 10 | -300 | μΑ | 0V <v<sub>IN<v<sub>CC<br/>(Note 3)</v<sub></v<sub> | | | | lLO | Output Leakage Current | | ±15 | μΑ | 0.45 < V <sub>OUT</sub> < V <sub>CC</sub> | | | | lcc | Supply Current | | 300<br>325 | mA<br>mA | CLK2 = 32 MHz<br>= 40 MHz<br>(Note 4) | | | | (CAP) | Capacitance (Input/IO) | | 12 | ρF | f <sub>c</sub> = 1 MHz<br>(Note 2) | | | | CCLK | CLK2 Capacitance | | 20 | рF | f <sub>c</sub> = 1 MHz<br>(Note 2) | | | ### NOTES: - 1. Minimum value is not 100% tested. - 2. Sampled only. - 3. These pins have internal pullups on them. - 4. ICC is specified with inputs driven to CMOS levels. ICC may be higher if driven to TTL levels. ### 13.6 D.C. Specifications (Continued) $T_{CASE} = 0^{\circ}C \text{ to } 85^{\circ}C; V_{CC} = 5V \pm 5\%; V_{SS} = 0V.$ Table 13-2. 82380-25 D.C. Specifications | Symbol | Parameter | Min | Max | Unit | Notes | |------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|--------|---------------------------------------------------| | V <sub>IL</sub> | Input Low Voltage | -0.3 | 0.8 | ٧ | (Note 1) | | ViH | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | | VILC | CLK2 Input Low Voltage | -0.3 | 0.8 | ٧ | (Note 1) | | V <sub>IHC</sub> | CLK2 Input High Voltage | V <sub>CC</sub> - 0.8 | V <sub>CC</sub> + 0.3 | ٧ | | | V <sub>OL</sub> | Output Low Voltage<br>$I_{OL} = 4 \text{ mA}$ : $A_2$ - $A_{31}$ , $D_0$ - $D_{31}$<br>$I_{OL} = 5 \text{ mA}$ : All Others | | 0.45<br>0.45 | V<br>V | • | | V <sub>OH</sub> | Output High Voltage<br>$I_{OH} = -1 \text{ mA: } A_2-A_{31}, D_0-D_{31}$<br>$I_{OH} = -0.9 \text{ mA: All Others}$ | 2.4<br>2.4 | | V<br>V | | | Li | Input Leakage Current All Inputs except: IRQ11# - IRQ23#, EOP#, TOUT2/IRQ3#, DREQ4 | | ±15 | μА | | | ILI1 | Input Leakage Current Inputs: IRQ11#-IRQ23#, EOP#, TOUT2/IRQ3#, DREQ4 | 10 | -300 | μΑ | 0 < V <sub>IN</sub> < V <sub>CC</sub><br>(Note 3) | | lLO | Output Leakage Current | | ±15 | μΑ | 0 < V <sub>IN</sub> < V <sub>CC</sub> | | Icc | Supply Current (CLK2 = 50 MHz) | | 375 | mA | (Note 4) | | Cı | Input Capacitance | | 12 | pF | (Note 2) | | C <sub>CLK</sub> | CLK2 Input Capacitance | | 20 | pF | (Note 2) | ### NOTES: 1. Minimum value is not 100% tested. 2. f<sub>C</sub> = 1 MHz; Sampled only. 3. These pins have weak internal pullups. They should not be left floating. 4. l<sub>CC</sub> is specified with inputs driven to CMOS levels, and outputs driving CMOS loads. l<sub>CC</sub> may be higher if inputs are driven to TTL levels, or if outputs are driving TTL loads. ### 13.7 A.C. Specifications The A.C. specifications given in the following tables consist of output delays and input setup requirements. The A.C. diagram's purpose is to illustrate the clock edges from which the timing parameters are measured. The reader should not infer any other timing relationships from them. For specific information on timing relationships between signals, refer to the appropriate functional section. A.C. spec measurement is defined in Figure 13.1. Inputs must be driven to the levels shown when A.C. specifications are measured. 82380 output delays are specified with minimum and maximum limits, which are measured as shown. The minimum 82380 output delay times are hold times for external circuitry. 82380 input setup and hold times are specified as minimums and define the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct 82380 operation. Figure 13-1. Drive Levels and Measurement Points for A.C. Specification ### A.C. SPECIFICATION TABLES Functional Operating Range: $V_{CC} = 5V \pm 5\%$ ; $T_{CASE} = 0^{\circ}C$ to $+85^{\circ}C$ Table 13-3, 82380 A.C. Characteristics | Symbol | Parameter | 82380-16 | | 823 | 80-20 | Notes | |--------------------------|--------------------------------------------------------------------|-------------------|----------|-------------------|----------|---------------------------------| | Symbol | · wiwiiiotoi | Min | Max | Min | Max | HOLES | | | Operating Frequency | 4 MHz | 16 MHz | 4 MHz | 20 MHz | Half CLK2 Frequency | | t1 | CLK2 Period | 31 ns | 125 ns | 25 ns | 125 ns | | | t2a | CLK2 High Time | 9 | | 8 | - | at 2.0V | | t2b | CLK2 High Time | 5 | | 5 | | at (V <sub>CC</sub> -0.8)V | | t3a | CLK2 Low Time | 9 | | 8 | | at 2.0V | | t3b | CLK2 Low Time | 7 | | 6 | | at 0.8V | | t4 | CLK2 Fall Time | | 8 | | 8 | (V <sub>CC</sub> -0.8)V to 0.8V | | t5 | CLK2 Rise Time | | 8 | | 8 | 0.8V to (V <sub>CC</sub> -0.8)V | | t6<br>t7 | A (2-31), BE (0-3) #,<br>EDACK (0-2)<br>Valid Delay<br>Float Delay | 4<br>4 | 36<br>40 | 4 | 30<br>32 | CL = 120 pF<br>(Note 1) | | t8<br>t9 | A (2-31), BE (0-3) # Setup Time Hold Time | 6<br>4 | | 6 | | | | t10<br>t11<br>t12<br>t13 | W/R#, M/IO#, D/C#, Valid Delay Float Delay Setup Time Hold Time | 6<br>4<br>6<br>4 | 33<br>35 | 6<br>4<br>6<br>4 | 28<br>30 | CL = 75 pF<br>(Note 1) | | t14<br>t15<br>t16<br>t17 | ADS # Valid Delay<br>Float Delay<br>Setup Time<br>Hold Time | 6<br>4<br>21<br>4 | 33<br>35 | 6<br>4<br>15<br>4 | 28<br>30 | CL = 75 pF | | t18<br>t19 | Slave Mode—<br>D(0-31) Read<br>Valid Delay<br>Float Delay | 3<br>6 | 46<br>35 | 4<br>6 | 46<br>29 | CL = 120 pF<br>(Note 1) | | t20<br>t21 | Slave Mode—<br>D(0-31) Write<br>Setup Time<br>Hold Time | 31<br>26 | | 29<br>26 | | | ### A.C. SPECIFICATION TABLES (Continued) Functional Operating Range: $V_{CC} = 5V \pm 5\%$ ; $T_{CASE} = 0^{\circ}C$ to $+85^{\circ}C$ . Table 13-3. 82380 A.C. Characteristics (Continued) | Symbol | Parameter | 823 | 80-16 | 823 | 80-20 | Notes | |--------------|-------------------------------------------------------------|----------|----------|----------|----------|------------------------------| | - <b>,</b> | | Min | Max | Min | Max | Notes | | t22<br>t23 | Master Mode—<br>D(0-31) Write<br>Valid Delay<br>Float Delay | 4 4 | 48<br>35 | 4 | 38<br>27 | CL = 120 pF<br>(Note 1) | | t24<br>t25 | Master Mode— D(0-31) Read Setup Time Hold Time | 11<br>6 | | 11 6 | | (100) | | t26<br>t27 | READY # Setup Time<br>Hold Time | 21<br>4 | _ | 12<br>4 | | | | t28<br>t29 | WSC (0-1) Setup<br>Hold | 6<br>21 | | 6<br>21 | | | | t31<br>t30 | RESET Setup Time<br>Hold Time | 13<br>4 | | 12<br>4 | | · | | t32 | READYO# Valid Delay | 4 | 31 | 4 | 23 | CL = 25 pF | | t33 | CPU Reset From CLK2 | 2 | 18 | 2 | 16 | CL = 50 pF | | t34 | HOLD Valid Delay | 5 | 33 | 5 | 30 | CL = 100 pF | | t35<br>t36 | HLDA Setup Time<br>Hold Time | 21<br>6 | | 17<br>6 | | | | t37a | EOP# Setup Time | 21 | | 17 | | Synch, EOP | | t38a | EOP# Hold Time | 4 | | 4 | | | | t37b | EOP# Setup Time | 11 | | 11 | | Asynch. EOP | | t38b | EOP# Hold Time | 11 | | 11 | | | | t39 | EOP# Valid Delay | 5 | 38 | 5 | 30 | CL = 100 pF ('1'->'0') | | t40 | EOP# Float Delay | 5 | 40 | 5 | 32 | | | t41a<br>t42a | DREQ Setup Time<br>Hold Time | 21<br>4 | | 19<br>4 | | Synchronous DREQ | | t41b<br>t42b | DREQ Setup Time<br>Hold Time | 11<br>11 | | 11<br>11 | | Asynchronous DREQ | | t43 | INT Valid Delay | | 500 | | 500 | From IRQ Input<br>CL = 75 pF | | t44<br>t45 | NA # Setup Time<br>Hold Time | 11<br>15 | | 10<br>15 | | | #### A.C. SPECIFICATION TABLES (Continued) Functional Operating Range: $V_{CC} = 5V \pm 5\%$ ; $T_{CASE} = 0$ °C to +85°C. Table 13-3, 82380 A.C. Characteristics (Continued) | Symbol | Parameter | 82380-16 | | 82380-20 | | Notes | |--------|--------------------|----------|--------|----------|--------|------------------------------------------------| | | raiametei | Min | Max | Min | Max | 110.63 | | t46 | CLKIN Frequency | 0 MHz | 10 MHz | 0 MHz | 10 MHz | | | t47 | CLKIN High Time | 30 | | 30 | | At 1.5V | | t48 | CLKIN Low Time | 50 | | 50 | - | At 1.5V | | t49 | CLKIN Rise Time | | 10 | | 10 | 0.8V to 3.7V | | t50 | CLKIN Fall Time | | 10 | | 10 | 3.7V to 0.8V | | t51 | TOUT1/REF# Valid | 4 | 36 | 4 | 30 | From CLK2, CL = 25 pF | | t52 | TOUT1/REF # Valid | 3 | 93 | 3 | 93 | From CLKIN, CL = 120 pF | | t53 | TOUT2# Valid Delay | 3 | 93 | 3 | 93 | From CLKIN, CL = 120 pF<br>(Falling Edge Only) | | t54 | TOUT2# Float Delay | 3 | 40 | 3 | 40 | From CLKIN (Note 1) | | t55 | TOUT3# Valid Delay | 3 | 93 | 3 | 93 | From CLKIN, CL = 120 pF | 1. Float condition occurs when the maximum output current becomes less than ILO in magnitude. Float delay is not tested. For testing purposes, the float condition occurs when the dynamic output driven voltage changes with current loads. Functional Operating Range: $V_{CC} = 5V \pm 5\%$ ; $T_{CASE} = 0^{\circ}C$ to $+85^{\circ}C$ . A.C. timings are tested at 1.5V thresholds; except as noted. Table 13-4, 82380-25 A.C. Characteristics | Symbol | Parameter | 823 | 80-25 | Unit | Notes | |--------------------------------------|-------------------------------------------------------------------------------------------------------|------------------|----------|----------------------------|--------------------------------------------------------------------------| | Symbol | Farameter | Min | Max | | 110100 | | | Operating Frequency 1/(t1a × 2) | 4 | 25 | MHz | | | t1 | CLK2 Period | 20 | 125 | ns | | | t2a<br>t2b<br>t3a<br>t3b<br>t4<br>t5 | CLK2 High Time CLK2 High Time CLK2 Low Time CLK2 Low Time CLK2 Low Time CLK2 Fall Time CLK2 Rise Time | 7<br>4<br>7<br>4 | 7 7 | ns<br>ns<br>ns<br>ns<br>ns | at 2.0V<br>at 3.7V<br>at 2.0V<br>at 0.8V<br>3.7V to 0.8V<br>0.8V to 3.7V | | t6<br>t7 | A2-A31, BE0#-BE3# EDACK0-EDACK3 Valid Delay A2-A31, BE0#-BE3# EDACK0-EDACK3 Float Delay | 4 | 20<br>27 | ns<br>ns | 50 pF Load<br>50 pF Load | | t8<br>t9 | A2-A31, BE0#-BE3# Setup Time<br>A2-A31, BE0#-BE3# Hold Time | 6<br>4 | | · ns | | | t10<br>t11 | W/R#, M/IO#, D/C# Valid Delay<br>W/R#, M/IO#, D/C# Float Delay | 4 | 20<br>29 | ns<br>ns | 50 pF Load<br>50 pF Load | ### A.C. SPECIFICATION TABLES (Continued) Functional Operating Range: $V_{CC}=5V\pm5\%$ ; $T_{CASE}=0^{\circ}C$ to $+85^{\circ}C$ . A.C. timings are tested at 1.5V thresholds; except as noted. Table 13-4. 82380-25 A.C. Characteristics (Continued) | Symbol | Parameter | 823 | 80-25 | Unit | Notes | |--------------|------------------------------------------------------------------|----------------|----------|----------|--------------------------| | Oymbo. | raidiletei | Min | Max | Oint | | | t12<br>t13 | W/R#, M/IO#, D/C# Setup Time<br>W/R#, M/IO#, D/C# Hold Time | 6<br>4 | | ns<br>ns | | | t14<br>t15 | ADS # Valid Delay<br>ADS # Float Delay | 4 4 | 19<br>29 | ns<br>ns | 50 pF Load<br>50 pF Load | | t16<br>t17 | ADS# Setup Time<br>ADS# Hold Time | 12<br>4 | | ns<br>ns | | | t18<br>t19 | Slave Mode D0-D31 Read Valid<br>Slave Mode D0-D31 Read Float | 4<br>6 | 31<br>21 | ns<br>ns | 50 pF Load<br>50 pF Load | | t20<br>t21 | Slave Mode D0-D31 Write Setup<br>Slave Mode D0-D31 Write Hold | 20<br>20 | | ns<br>ns | | | t22<br>t23 | Master Mode D0-D31 Write Valid<br>Master Mode D0-D31 Write Float | 8<br>4 | 27<br>19 | ns<br>ns | 50 pF Load<br>50 pF Load | | t24<br>t25 | Master Mode D0-D31 Read Setup<br>Master Mode D0-D31 Read Hold | 7<br>4 | | ns<br>ns | | | t26<br>t27 | READY# Setup Time<br>READY# Hold Time | 9<br>4 | | ns<br>ns | | | t28<br>t29 | WSC0-WSC1 Setup Time<br>WSC0-WSC1 Hold Time | <b>6</b><br>15 | | ns<br>ns | | | t30<br>t31 | RESET Hold Time<br>RESET Setup Time | 4<br>9 | | ns<br>ns | | | t32 | READYO# Valid Delay | 3 | 21 | ns | 25 pF Load | | t33 | CPURST Valid Delay | 2 | 14 | ns | 50 pF Load | | t34 | HOLD Valid Delay | 4 | 22 | ns | 50 pF Load | | t35<br>t36 | HLDA Setup Time<br>HLDA Hold Time | 17<br>4 | | ns<br>ns | | | t37a<br>t38a | EOP# Setup (Synchronous)<br>EOP# Hold (Synchronous) | 13<br>4 | | ns<br>ns | | | t37b<br>t38b | EOP# Setup (Asynchronous)<br>EOP# Hold (Asynchronous) | 10<br>10 | | ns<br>ns | | | t39<br>t40 | EOP# Valid Delay<br>EOP# Float Delay | 4<br>4 | 21<br>21 | ns<br>ns | 50 pF Load<br>50 pF Load | | t41a<br>t42a | DREQ Setup (Synchronous)<br>DREQ Hold (Synchronous) | 17<br>4 | | ns<br>ns | | | t41b<br>t42b | DREQ Setup (Asynchronous)<br>DREQ Hold (Asynchronous) | 10<br>10 | | ns<br>ns | | | t43 | INT Valid Delay from IRQn | | 500 | ns | 50 pF Load | 82380 #### A.C. SPECIFICATION TABLES (Continued) Functional Operating Range: $V_{CC}=5V\pm5\%$ ; $T_{CASE}=0^{\circ}C$ to $\pm85^{\circ}C$ . A.C. timings are tested at 1.5V thresholds; except as noted. Table 13-4. 82380-25 A.C. Characteristics (Continued) | Symbol | Parameter | 82380-25 | | Unit | Notes | |---------------------------------|--------------------------------------------------------------------------------------------|---------------|----------------|-----------------------------|----------------------------------------------| | Cymbo. | | Min | Max | | 110163 | | t44<br>t45 | NA# Setup Time<br>NA# Hold Time | 7<br>8 | | ns<br>ns | | | t46<br>t47<br>t48<br>t49<br>t50 | CLKIN Frequency<br>CLKIN High Time<br>CLKIN Low Time<br>CLKIN Rise Time<br>CLKIN Fall Time | 0<br>30<br>50 | 10<br>10<br>10 | MHz<br>ns<br>ns<br>ns<br>ns | 2.0V<br>0.8V<br>0.8V to 3.7V<br>3.7V to 0.8V | | t51<br>t52 | TOUT1/REF # Valid Delay<br>from CLK2 (Refresh)<br>from CLKIN (Timer) | 4 3 | 20<br>90 | ns<br>ns | 50 pF Load<br>50 pF Load | | t53<br>t54 | TOUT2# Valid Delay<br>(Falling Edge Only)<br>TOUT2# Float Delay | 3<br>3 | 90<br>37 | ns<br>ns | 50 pF Load<br>50 pF Load | | t55 | TOUT3 # Valid Delay | 3 | 90 | ns | 50 pF Load | Figure 13-2. A.C. Test Load Figure 13-3. CLK2 Timing Figure 13-4. Input Setup and Hold Timing Figure 13-5. Reset Timing Figure 13-7. Data Bus Output Delays Figure 13-8. Control Output Delays Figure 13-9. Timer Output Delays ## APPENDIX A Ports Listed by Address | Port Address (HEX) | Description | |--------------------|----------------------------------------------------------------------| | 00 | Read/Write DMA Channel 0 Target Address, A0-A15 | | 01 | Read/Write DMA Channel 0 Byte Count, 80-B15 | | 02 | Read/Write DMA Channel 1 Target Address, A0-A15 | | 03 | Read/Write DMA Channel 1 Byte Count, B0-B15 | | 04 | Read/Write DMA Channel 2 Target Address, A0-A15 | | 05 | Read/Write DMA Channel 2 Byte Count, B0-B15 | | 06 | Read/Write DMA Channel 3 Target Address, A0-A15 | | 07 | Read/Write DMA Channel 3 Byte Count, B0-B15 | | 08 | Read/Write DMA Channel 0-3 Status/Command I Register | | 09 | Read/Write DMA Channel 0-3 Software Request Register | | 0 <b>A</b> | Write DMA Channel 0-3 Set-Reset Mask Register | | 0B | Write DMA Channel 0-3 Mode Register I | | 0C | Write Clear Byte-Pointer FF | | 0D | Write DMA Master-Clear | | 0E | Write DMA Channel 0-3 Clear Mask Register | | · OF | Read/Write DMA Channel 0-3 Mask Register | | 10 | Read/Write DMA Channel 0 Target Address, A24-A31 | | 11 | Read/Write DMA Channel 0 Byte Count, B16-B23 | | 12 | Read/Write DMA Channel 1 Target Address, A24-A31 | | 13 | Read/Write DMA Channel 1 Byte Count, B16-B23 | | 14 | Read/Write DMA Channel 2 Target Address, A24-A31 | | 15 | Read/Write DMA Channel 2 Byte Count, B16-B23 | | 16 | Read/Write DMA Channel 3 Target Address, A24-A31 | | 17 | Read/Write DMA Channel 3 Byte Count, B16-B23 | | 18 | Write DMA Channel 0-3 Bus Size Register | | 19 | Read/Write DMA Channel 0-3 Chaining Register | | 1A | Write DMA Channel 0-3 Command Register II | | 1B | Write DMA Channel 0-3 Mode Register II | | 1C | Read/Write Refresh Control Register | | 1E | Reset Software Request Interrupt | | 20 | Write Bank B ICW1, OCW2, or OCW3 | | | Read Bank B Poll, Interrupt Request or In-Service<br>Status Register | | 21 | Write Bank B ICW2, ICW3, ICW4 or OCW1 | | | Read Bank B Interrupt Mask Register | | 22 | Read Bank B ICW2 | | 28 | Read/Write IRQ8 Vector Register | | 29 | Read/Write IRQ9 Vector Register | | 2A | Reserved | | 2 <b>B</b> | Read/Write IRQ11 Vector Register | | 2C | Read/Write IRQ12 Vector Register | | 2D | Read/Write IRQ13 Vector Register | | 2E | Read/Write IRQ14 Vector Register | | | - 1041 0 15045 M | Read/Write IRQ15 Vector Register 2F ## intel. ### APPENDIX A-Ports Listed by Address (Continued) | Port Address (HEX) | Description | |--------------------|----------------------------------------------------------------------| | 30 | Write Bank A ICW1, OCW2 or OCW3 | | | Read Bank A Poll, Interrupt Request or In-Service<br>Status Register | | 31 | Write Bank A ICW2, ICW3, ICW4 or OCW1 | | | Read Bank A Interrupt Mask Register | | 32 | Read Bank A ICW2 | | 38 | Read/Write IRQ0 Vector Register | | 39 | Read/Write IRQ1 Vector Register | | 3A | Read/Write IRQ1.5 Vector Register | | 3B | Read/Write IRQ3 Vector Register | | 3C | Read/Write IRQ4 Vector Register | | 3D | Reserved | | 3E | Reserved | | 3F | Read/Write IRQ7 Vector Register | | 40 | Read/Write Counter 0 Register | | 41 | Read/Write Counter 1 Register | | 42 | Read/Write Counter 2 Register | | 43 | Write Control Word Register I—Counter 0, 1, 2 | | 44 | Read/Write Counter 3 Register | | 45 | Reserved | | 46 | Reserved | | 47 | Write Word Register II—Counter 3 | | 61 | Write Internal Control Port | | 64 | Write CPU Reset Register (Data-1111XXX0H) | | 72 | Read/Write Wait State Register 0 | | <b>73</b> | Read/Write Wait State Register 1 | | 74 | Read/Write Wait State Register 2 | | <b>75</b> | Read/Write Refresh Wait State Register | | 76 | Reserved | | 77 | Reserved | | 7D | Reserved | | 7E | Reserved | | 7F | Read/Write Relocation Register | | 80 | Read/Write Internal Diagnostic Port 0 | | 81 | Read/Write DMA Channel 2 Target Address, A16-A23 | | 82 | Read/Write DMA Channel 3 Target Address, A16-A23 | | 83 | Read/Write DMA Channel 1 Target Address, A16–A23 | | 87 | Read/Write DMA Channel 0 Target Address, A16–A23 | | 88 | Read/Write Internal Diagnostic Port 1 | | 89<br>8A | Read/Write DMA Channel 6 Target Address, A16–A23 | | 8B | Read/Write DMA Channel 7 Target Address, A16–A23 | | 8F | Read/Write DMA Channel 5 Target Address, A16-A23 | | ФГ | Read/Write DMA Channel 4 Target Address, A16-A23 | #### 82380 #### APPENDIX A-Ports Listed by Address (Continued) | Port Address (HEX) | Description | |--------------------|-------------------------------------------------------------------| | 90 | Read/Write DMA Channel 0 Requester Address, A0-A15 | | 91 | Read/Write DMA Channel 0 Requester Address, A16-A31 | | 92 | Read/Write DMA Channel 1 Requester Address, A0-A15 | | 93 | Read/Write DMA Channel 1 Requester Address, A16-A31 | | 94 | Read/Write DMA Channel 2 Requester Address, A0-A15 | | 95 | Read/Write DMA Channel 2 Requester Address, A16-A31 | | 96 | Read/Write DMA Channel 3 Requester Address, A0-A15 | | 97 | Read/Write DMA Channel 3 Requester Address, A16-A31 | | 98 | Read/Write DMA Channel 4 Requester Address, A0-A15 | | 99 | Read/Write DMA Channel 4 Requester Address, A16-A31 | | 9 <b>A</b> | Read/Write DMA Channel 5 Requester Address, A0-A15 | | 9B | Read/Write DMA Channel 5 Requester Address, A16-A31 | | 9C | Read/Write DMA Channel 6 Requester Address, A0-A15 | | 9D | Read/Write DMA Channel 6 Requester Address, A16-A31 | | 9E | Read/Write DMA Channel 7 Requester Address, A0-A15 | | 9 <b>F</b> | Read/Write DMA Channel 7 Requester Address, A16-A31 | | AO | Write Bank C ICW1, OCW2 or OCW3 | | | Read Bank C Poll, Interrupt Request or In-Service | | 4.4 | Status Register | | A1 | Write Bank C ICW2, ICW3, ICW4 or OCW1 | | 40 | Read Bank C Interrupt Mask Register | | A2 | Read Bank C ICW2 | | A8 | Read/Write IRQ16 Vector Register | | A9<br>AA | Read/Write IRQ17 Vector Register Read/Write IRQ18 Vector Register | | AB | Read/Write IRQ19 Vector Register | | AC | Read/Write IRQ20 Vector Register | | AD | Read/Write IRQ21 Vector Register | | AE | Read/Write IRQ22 Vector Register | | AF | Read/Write IRQ23 Vector Register | | Co | Read/Write DMA Channel 4 Target Address, A0-A15 | | C1 | Read/Write DMA Channel 4 Byte Count, B0-B15 | | C2 | Read/Write DMA Channel 5 Target Address, A0-A15 | | C3 | Read/Write DMA Channel 5 Byte Count, B0-B15 | | C4 | Read/Write DMA Channel 6 Target Address, A0-A15 | | C5 | Read/Write DMA Channel 6 Byte Count, B0-B15 | | C6 | Read/Write DMA Channel 7 Target Address, A0-A15 | | C7 | Read/Write DMA Channel 7 Byte Count, B0-B15 | | C8 | Read DMA Channel 4-7 Status/Command I Register | | C9 | Read/Write DMA Channel 4-7 Software Request Register | | CA | Write DMA Channel 4-7 Set-Reset Mask Register | | СВ | Write DMA Channel 4-7 Mode Register I | | CC | Reserved | | CD | Reserved | | CE | Write DMA Channel 4-7 Clear Mask Register | | CF · | Read/Write DMA Channel 4-7 Mask Register | ## intel. ### APPENDIX A-Ports Listed by Address (Continued) | Port Address (HEX) | Description | |--------------------|--------------------------------------------------| | D0 | Read/Write DMA Channel 4 Target Address, A24-A31 | | D1 | Read/Write DMA Channel 4 Byte Count, B16-B23 | | D2 | Read/Write DMA Channel 5 Target Address, A24-A31 | | D3 · | Read/Write DMA Channel 5 Byte Count, B16-B23 | | D4 | Read/Write DMA Channel 6 Target Address, A24-A31 | | D5 | Read/Write DMA Channel 6 Byte Count, B16-B23 | | D6 | Read/Write DMA Channel 7 Target Address, A24-A31 | | D7 | Read/Write DMA Channel 7 Byte Count, B16-B23 | | D8 | Write DMA Channel 4-7 Bus Size Register | | D9 | Read/Write DMA Channel 4-7 Chaining Register | | DA | Write DMA Channel 4-7 Command Register II | | DB | Write DMA Channel 4-7 Mode Register II | 82380 # APPENDIX B Ports Listed by Function | Port Address (HEX) | Description | |--------------------|------------------------------------------------------------------------------------------| | | DMA CONTROLLER | | 0D | Write DMA Master-Clear | | 0C | Write DMA Clear Byte-Pointer FF | | 08 | Read/Write DMA Channel 0-3 Status/Command I Register | | C8 | Read/Write DMA Channel 4-7 Status/Command I Register | | 1 <b>A</b> | Write DMA Channel 0-3 Command Register II | | DA | Write DMA Channel 4-7 Command Register II | | 0B | Write DMA Channel 0-3 Mode Register I | | СВ | Write DMA Channel 4-7 Mode Register! | | 18 | Write DMA Channel 0-3 Mode Register II | | DB | Write DMA Channel 4-7 Mode Register II | | 09 | Read/Write DMA Channel 0-3 Software Request Register | | C9 | Read/Write DMA Channel 4-7 Software Request Register | | 1E | Reset Software Request Interrupt | | 0E | Write DMA Channel 0-3 Clear Mask Register | | CE | Write DMA Channel 4-7 Clear Mask Register | | 0F | Read/Write DMA Channel 0-3 Mask Register | | CF | Read/Write DMA Channel 4-7 Mask Register | | 0A | Write DMA Channel 0-3 Set-Reset Mask Register | | CA | Write DMA Channel 4-7 Set-Reset Mask Register | | 18 | Write DMA Channel 0-3 Bus Size Register | | D8 | Write DMA Channel 4-7 Bus Size Register | | 19 | Read/Write DMA Channel 0-3 Chaining Register | | D9 | Read/Write DMA Channel 4-7 Chaining Register | | 00 | Read/Write DMA Channel 0 Target Address, A0-A15 | | 87 | Read/Write DMA Channel 0 Target Address, A16-A23 | | 10 | Read/Write DMA Channel 0 Target Address, A24-A31 | | 01 | Read/Write DMA Channel 0 Byte Count, B0-B15 | | 11 | Read/Write DMA Channel 0 Byte Count, B16-B23 | | 90<br>91 | Read/Write DMA Channel 0 Requester Address, A0-A15 | | | Read/Write DMA Channel 0 Requester Address, A16–A31 | | 02 | Read/Write DMA Channel 1 Target Address, A0-A15 | | 83 | Read/Write DMA Channel 1 Target Address, A16A23 | | 12<br>03 | Read/Write DMA Channel 1 Target Address, A24–A31 | | 13 | Read/Write DMA Channel 1 Byte Count, B0-B15 Read/Write DMA Channel 1 Byte Count, B16-B23 | | 92 | Read/Write DMA Channel 1 Requester Address, A0-A15 | | 93 | Read/Write DMA Channel 1 Requester Address, A0-A11 | | | Trouble Tring Shift Original Fridgeodick Addition, ATO-ADI | ### APPENDIX B-Ports Listed by Function (Continued) | Port Address (HEX) | Description | |--------------------|-----------------------------------------------------| | | DMA CONTROLLER | | 04 | Read/Write DMA Channel 2 Target Address, A0-A15 | | 81 | Read/Write DMA Channel 2 Target Address, A16-A23 | | 14 | Read/Write DMA Channel 2 Target Address, A24-A31 | | 05 | Read/Write DMA Channel 2 Byte Count, B0-B15 | | 15 | Read/Write DMA Channel 2 Byte Count, B16-B23 | | 94 | Read/Write DMA Channel 2 Requester Address, A0-A15 | | 95 | Read/Write DMA Channel 2 Requester Address, A16-A31 | | 06 | Read/Write DMA Channel 3 Target Address, A0-A15 | | 82 | Read/Write DMA Channel 3 Target Address, A16-A23 | | 16 | Read/Write DMA Channel 3 Target Address, A24-A31 | | 07 | Read/Write DMA Channel 3 Byte Count, 80-815 | | 17 | Read/Write DMA Channel 3 Byte Count, B16-B23 | | 96 | Read/Write DMA Channel 3 Requester Address, A0-A15 | | 97 | Read/Write DMA Channel 3 Requester Address, A16-A31 | | C0 | Read/Write DMA Channel 4 Target Address, A0-A15 | | 8F | Read/Write DMA Channel 4 Target Address, A16-A23 | | D0 | Read/Write DMA Channel 4 Target Address, A24-A31 | | C1 | Read/Write DMA Channel 4 Byte Count, B0-B15 | | D1 | Read/Write DMA Channel 4 Byte Count, B16-B23 | | 98 | Read/Write DMA Channel 4 Requester Address, A0-A15 | | 99 | Read/Write DMA Channel 4 Requester Address, A16-A31 | | C2 | Read/Write DMA Channel 5 Target Address, A0-A15 | | 8B | Read/Write DMA Channel 5 Target Address, A16-A23 | | D2 | Read/Write DMA Channel 5 Target Address, A24-A31 | | C3 | Read/Write DMA Channel 5 Byte Count, B0-B15 | | D3 | Read/Write DMA Channel 5 Byte Count, B16-B23 | | 9A | Read/Write DMA Channel 5 Requester Address, A0-A15 | | 98 | Read/Write DMA Channel 5 Requester Address, A16-A31 | | C4 | Read/Write DMA Channel 6 Target Address, A0-A15 | | 89 | Read/Write DMA Channel 6 Target Address, A16-A23 | | D4 | Read/Write DMA Channel 6 Target Address, A24-A31 | | C5 | Read/Write DMA Channel 6 Byte Count, 80-B15 | | D5 | Read/Write DMA Channel 6 Byte Count, B16-B23 | | 9C | Read/Write DMA Channel 6 Requester Address, A0-A15 | | 9D | Read/Write DMA Channel 6 Requester Address, A16-A31 | | C6 | Read/Write DMA Channel 7 Target Address, A0-A15 | | 8A | Read/Write DMA Channel 7 Target Address, A16-A23 | | D6 | Read/Write DMA Channel 7 Target Address, A24-A31 | | C7<br>D7 | Read/Write DMA Channel 7 Byte Count, 80-815 | | 9E | Read/Write DMA Channel 7 Byte Count, B16-B23 | | 9E<br>9F | Read/Write DMA Channel 7 Requester Address, A0-A15 | | <b>3</b> F | Read/Write DMA Channel 7 Requester Address, A16-A31 | 82380 ### APPENDIX B-Ports Listed by Function (Continued) Port Address (HEX) #### Description #### INTERRUPT CONTROLLER | | INTERRUPT CONTROLLER | |------------------|----------------------------------------------------| | 20 | Write Bank B ICW1, OCW2, or OCW3 | | | Read Bank B Poll, Interrupt Request or In-Service | | | Status Register | | 21 | Write Bank B ICW2, ICW3, ICW4 or OCW1 | | | Read Bank B Interrupt Mask Register | | 22 | Read Bank B ICW2 | | 28 | Read/Write IRQ8 Vector Register | | 29 | Read/Write IRQ9 Vector Register | | 2A | Reserved | | 2B | Read/Write IRQ11 Vector Register | | 2C | Read/Write IRQ12 Vector Register | | 2D | Read/Write IRQ13 Vector Register | | 2E | Read/Write IRQ14 Vector Register | | 2F | Read/Write IRQ15 Vector Register | | A0 | Write Bank C ICW1, OCW2 or OCW3 | | | Read Bank C Poll, Interrupt Request or In-Service | | | Status Register | | A1 | Write Bank C ICW2, ICW3, ICW4 or OCW1 | | | Read Bank C Interrupt Mask Register | | A2 | Read Bank C ICW2 | | A8 | Read/Write IRQ16 Vector Register | | A9 | Read/Write IRQ17 Vector Register | | AA | Read/Write IRQ18 Vector Register | | AB<br>AC | Read/Write IRQ19 Vector Register | | AD | Read/Write IRQ20 Vector Register | | AE | Read/Write IRQ21 Vector Register | | AF | Read/Write IRQ22 Vector Register | | | Read/Write IRQ23 Vector Register | | 30 | Write Bank A ICW1, OCW2 or OCW3 | | | Read Bank A Poll, Interrupt Request oor In-Service | | 04 | Status Register | | 31 | Write Bank A ICW2, ICW3, ICW4 or OCW1 | | 00 | Read Bank A Interrupt Mask Register | | 32<br>38 | Read Bank A ICW2 Read/Write IRQ0 Vector Register | | 39 | Read/Write IRQ1 Vector Register | | 3 <b>9</b><br>3A | Read/Write IRQ1.5 Vector Register | | 3B | Read/Write IRQ3 Vector Register | | 3C | Read/Write IRQ4 Vector Register | | 3D | Reserved | | 3E | Reserved | | 3F | Read/Write IRQ7 Vector Register | | J. | Fredor Hille II fer Approximation | ## intel. ### APPENDIX B-Ports Listed by Function (Continued) | Port Address (HEX | () Description | |----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | • | PROGRAMMABLE INTERVAL TIMER | | 40<br>41<br>42<br>43<br>44 | Read/Write Counter 0 Register Read/Write Counter 1 Register Read/Write Counter 2 Register Write Control Word Register I—Counter 0, 1, 2 Read/Write Counter 3 Register | | . 41 | Write Word Register II—Counter 3 CPU RESET | | 64 | Write CPU Reset Register (Data-1111XXX0H) | | | WAIT STATE GENERATOR | | 72<br>73<br>74<br>75 | Read/Write Wait State Register 0 Read/Write Wait State Register 1 Read/Write Wait State Register 2 Read/Write Refresh Wait State Register | | | DRAM REFRESH CONTROLLER | | 1C | Read/Write Refresh Control Register | | II | NTERNAL CONTROL AND DIAGNOSTIC PORTS | | 61<br>80<br>88 | Write Internal Control Port Read/Write Internal Diagnostic Port 0 Read/Write Internal Diagnostic Port 1 | | | RELOCATION REGISTER | | 7 <b>F</b> | Read/Write Relocation Register | | | INTEL RESERVED PORTS | | 2A<br>3D<br>3E<br>45<br>46<br>76<br>77<br>7D<br>7E<br>CC | Reserved | | 90 | 110301400 | 82380 ### APPENDIX C Pin Descriptions The 82380 provides all of the signals necessary to interface it to an 80386 processor. It has separate 32-bit address and data buses. It also has a set of control signals to support operation as a bus master or a bus slave. Several special function signals exist on the 82380 for interfacing the system support peripherals to their respective system counterparts. Following are the definitions of the individual pins of the 82380. These brief descriptions are provided as a reference. Each signal is further defined within the sections which describe the associated 82380 function. A2-A31 I/O ADDRESS BUS This is the 32-bit address bus. The addresses are doubleword memory and I/O addresses. These are three-state signals which are active only during Master mode. The address lines should be connected directly to the 80386's local bus. BEO# I/O BYTE-ENABLE 0 BE0# active indicates that data bits D0-D7 are being accessed or are valid. It is connected directly to the 80386's BE0#. The byte enable signals are active outputs when the 82380 is in the Master mode. BE1# I/O BYTE-ENABLE 1 BE1# active indicates that data bits D8-D15 are being accessed or are valid. It is connected directly to the 80386's BE1#. The byte enable signals are active only when the 82380 is in the Master mode. BE2# I/O BYTE-ENABLE 2 BE2# active indicates that data bits D15-D23 are being accessed or are valid. It is connected directly to the 80386's BE2#. The byte enable signals are active only when the 82380 is in the Master mode. BE3# I/O BYTE-ENABLE 3 BE3# active indicates that data bits D24-D31 are being accessed or are valid. The byte enable signals are active only when the 82380 is in the Master mode. This pin should be connected directly to the 80386's BE3#. This pin is used for factory testing and must be low during reset. The 80386 drives BE3# low during reset. D0-D31 I/O DATA BUS This is the 32-bit data bus. These pins are active outputs during interrupt acknowledges, during Slave accesses, and when the 82380 is in the Master mode. CLK2 I PROCESSOR CLOCK This pin must be connected to CLK2. The 82380 monitors the phase of this clock in order to remain synchronized with the 80386. This clock drives all of the internal synchronous circuitry. D/C# I/O DATA/CONTROL D/C# is used to distinguish between 80386 control cycles and DMA or 80386 data access cycles. It is active as an output only in the Master mode. W/R# I/O WRITE/READ W/R# is used to distinguish between write and read cycles. It is active as an output only in the Master mode. M/IO# I/O MEMORY/IO M/IO# is used to distinguish between memory and IO accesses. It is active as an output only in the Master mode. ADS# I/O ADDRESS STATUS This signal indicates presence of a valid address on the address bus. It is active as output only in the Master mode. ADS# is active during the first T-state where addresses and control signals are valid. NA# I NEXT ADDRESS Asserted by a peripheral or memory to begin a pipelined address cycle. This pin is monitored only while the 82380 is in the Master mode. In the Slave mode, pipelining is determined by the current and past status of the ADS# and READY# signals. intel. HOLD O HOLD REQUEST This is an active-high signal to the 80386 to request control of the system bus. When control is granted, the 80386 activates the hold acknowledge signal (HLDA). HLDA I HOLD ACKNOWLEDGE This input signal tells the DMA controller that the 80386 has relinquished control of the system bus to the DMA controller. DREQ (0-3, 5-7) I DMA REQUEST The DMA Request inputs monitor requests from peripherals requiring DMA service. Each of the eight DMA channels has one DREQ input. These active-high inputs are internally synchronized and prioritized. Upon reset, channel 0 has the highest priority and channel 7 the lowest. DREQ4/IRQ9# I DMA/INTERRUPT RE-QUEST This is the DMA request input for channel 4. It is also connected to the interrupt controller via interrupt request 9. This internal connection is available for DMA channel 4 only. The interrupt input is active low and can be programmed as either edge of level triggered. Either function can be masked by the appropriate mask register. Priorities of the DMA channel and the interrupt request are not related but follow the rules of the individual controllers. Note that this pin has a weak internal pull-up. This causes the interrupt request to be inactive, but the DMA request will be active if there is no external connection made. Most applications will require that either one or the other of these functions be used, but not both. For this reason, it is advised that DMA channel 4 be used for transfers where a software request is more appropriate (such as memory-tomemory transfers). In such an application, DREQ4 can be masked by software, freeing IRQ9# for other purposes. EOP# I/O END OF PROCESS As an output, this signal indicates that the current Requester access is the last access of the currently operating DMA channel. It is activated when Terminal Count is reached. As an input, it signals the DMA channel to terminate the current buffer and proceed to the next buffer, if one is available. This signal may be programmed as an asynchronous or synchronous input. EOP# must be connected to a pull-up resistor. This will prevent erroneous external requests for termination of a DMA process. EDACK (0-2) O ENCODED DMA ACKNOWL-EDGE These signals contain the encoded acknowledgement of a request for DMA service by a peripheral. The binary code formed by the three signals indicates which channel is active. Channel 4 does not have a DMA acknowledge. The inactive state is indicated by the code 100. During a Requester access, EDACK presents the code for the active DMA channel. During a Target access, EDACK presents the inactive code 100. IRQ (11-23)# I INTERRUPT REQUEST These are active low interrupt request inputs. The inputs can be programmed to be edge or level sensitive. Interrupt priorities are programmable as either fixed or rotating. These inputs have weak internal pull-up resistors. Unused interrupt request inputs should be tied inactive externally. INT O INTERRUPT OUT INT signals the 80386 that an interrupt request is pending. CLKIN 1 TIMER CLOCK INPUT This is the clock input signal to all of the 82380's programmable timers. It is independent of the system clock input (CLK2). TOUT1/REF# O TIMER 1 OUTPUT/REFRESH This pin is software programmable as either the direct output of Timer 1, or as the indicator of a refresh cycle in progress. As REF#, this signal is active during the memory read cycle which occurs during refresh. TOUT2#/IRQ3# I/O TIMER 2 OUTPUT/IN-TERRUPT REQUEST3 This is the inverted output of Timer 2. It is also connected directly to interrupt request 3. External hardware can use IRQ3# if Timer 2 is programmed as OUT = 0 (TOUT2# = 1) TOUT3# O TIMER 3 OUTPUT This is the inverted output of Timer 3. 82380 READY# **READY INPUT** This active-low input indicates to the 82380 that the current bus cycle is complete. READY is sampled by the 82380 both while it is in the Master mode, and while it is in the Slave mode. WSC (0-1) WAIT STATE CONTROL WSC0 AND WSC1 are inputs used by the Wait-State Generator to determine the number of wait states required by the currently accessed memory or I/O. The binary code on these ins, combined with the M/IO# signal, selects an internal register in which a wait-state count is stored. The combination WSC = 11 disables the wait-state generator. READYO# 0 **READY OUTPUT** This is the synchronized output of the wait-state generator. It is also valid during 80386 accesses to the 82380 in the Slave Mode when the 82380 requires wait states. READYO# should feed directly the 80386's READY# input. RESET I RESET This synchronous input serves to initialize the state of the 82380 and provides basis for the CPURST output. RESET must be held active for at least 15 CLK2 cycles in order to guarantee the state of the 82380. After Reset, the 82380 is in the Slave mode with all outputs except timers and interrupts in their inactive states. The state of the timers and interrupt controller must be initialized through software. This input must be active for the entire time required by the 80386 to guarantee proper reset. **CPURST** CPU RESET CPURST provides a synchronized reset signal for the CPU. It is activated in the event of a software reset command, an 80386 shut-down detect, or a hardware reset via the RESET pin. The 82380 holds CPURST active for 62 clocks in response to either a software reset command or a shut-down detection. Otherwise CPURST reflects the RESET input. $V_{CC}$ +5V input power Vss Ground Table C-1. Wait-State Select Inputs | Port | Wait-State Registers | | | | Select Inputs | | |---------|----------------------|-------|------|----|---------------|------| | Address | D7 | D4 | D3 | D0 | WSC1 | wsco | | 72H | Memory 0 | | 1/00 | | 0 | 0 | | 73H | Memory 1 | | 1/01 | | 0 | 1 | | 74H | Mem | ory 2 | 1/02 | | 1 | 1 | | | DISABLED | | | | 1 | 1 | | M/IO# | | 1 | 0 | | | | ### APPENDIX D 82380 System Notes #### 82380 TIMER UNIT SYSTEM NOTES The 82380 DMA controller with Integrated System Peripherals is functionally inconsistent with the data sheet. This document explains the behavior of the 82380 Timer Unit and outlines subsequent limitations of the timer unit. This document also provides recommended workarounds. ### 1.0 WRITE CYCLES TO THE 82380 TIMER UNIT This errata applies only to SLAVE WRITE cycles to the 82380 timer unit. During these cycles, the data being written into the 82380 timer unit may be corrupted if CLKIN is not inhibited during a certain "window" of the write cycle. #### 1.1 Description Please refer to Figure 1. During write cycles to the 82380 timer unit, the 82380 translates the 386DX interface signals such as ADS#, W/R#, M/IO#, and D/C# into several internal signals that control the operation of the internal sub-blocks (e.g., Timer Unit). The 82380 timer unit is controlled by such internal signals. These internal signals are generated and sampled with respect to two separate clock signals: CLK2 (the system clock) and CLKIN (the 82380 timer unit clock). Since the CLKIN and CLK2 clock signals are used internally to generate control signals for the interface to the timer unit, some timing parameters must be met in order for the interface logic to function properly. Those timing parameters are met by inhibiting the CLKIN signal for a specific window during Write Cycles to the 82380 Timer Unit. The CLKIN signal must be inhibited using external logic, as the GATE function of the 82380 timer unit is not guaranteed to totally inhibit CLKIN. #### 1.2 Consequences This CLKIN inhibit circuitry guarantees proper write cycles to the 82380 timer unit. Without this solution, write cycles to the 82380 timer unit could place corrupted data into the timer unit registers. This, in turn, could yield inaccurate results and improper timer operation. The proposed solution would involve a hardware modification for existing systems. #### 1.3 Solution A timing waveform (Figure 2) shows the specific window during which CLKIN must be inhibited. Please note that CLKIN must only be inhibited during the window shown in Figure 2. This window is defined by two AC timing parameters: ta = 9 ns t<sub>b</sub> = 28 ns The proposed solution provides a certain amount of system "guardband" to make sure that this window is avoided. PAL equations for a suggested workaround are also included. Please refer to the comments in the PAL codes for stated assumptions of this particular workaround. A state diagram (Figure 3) is provided to help clarify how this PAL is designed. Figure 4 shows how this PAL would fit into a system workaround. In order to show the effect of this workaround on the CLKIN signal, Figure 5 shows how CLKIN is inhibited. Note that you must still meet the CLKIN AC timing parameters (e.g., t<sub>47</sub> (min), t<sub>48</sub> (min)) in order for the timer unit to function properly. Please note that this workaround has not been tested. It is provided as a suggested solution. Actual solutions will vary from system to system. #### 1.4 Long Term Plans Intel has no plans to fix this behavior in the 82380 timer unit. module Timer\_82380\_Fix 82380 flag '-r2','-q2','-fl', '-t4', '-w1,3,6,5,4,16,7,12,17,18,15,14' title '82380 Timer Unit CLKIN INHIBIT signal PAL Solution ' Timer\_Unit\_Fix device 'P16R6'; \*This PAL inhibits the CLKIN signal (that comes from an oscillator) during Slave Writes to the 82380 Timer unit. "ASSUMPTION: This PAL assumes that an external system address decoder provides a signal to indicate that an 82380 Timer Unit access is taking place. This input signal is called TMR in this PAL. This PAL also assumes that this TMR signal occurs during a specific T-State. Please see Figure 3 of this document to see when this signal is expected to be active by this PAL. "NOTE: This PAL does not support pipelined 82380 SLAVE cycles. "(c) Intel Corporation 1989. This PAL is provided as a proposed "method of solving a certain 82380 Timer Unit problem. This PAL "has not been tested or validated. Please validate this solution "for your system and application. ``` "Input Pins" CLK2. pin 1; *System Clock RESET pin 2; "Microprocessor RESET signal TMR 3; "Input from Address Decoder, indicating pin *an access to the timer unit of the *82380. !RDY pin 4; "End of Cycle indicator pin 5; "Address and control strobe !ADS 6; *PHI2 clock CLK pin W_R 7; "Write/Read Signal" pin pin 8; "No Connect O" ncl nc3 pin 9; "No Connect 1" pin GNDa 10; "Tied to ground, documentation only GNDb pin 11; "Output enable, documentation only CLKIN_IN pin 12; *Input-CLKIN directly from oscillator "Output Pins" 18; "Internal signal only, fed back to Q_0 pin "PAL logic" pin 17; *CLKIN signal fed to 82380 Timer Unit CLKIN_OUT 16; *CLKIN Inhibit signal INHIBIT pin pin 15; *Unused State Indicator Pin 14; *Unused State Indicator Pin Sl pin "Declarations" Valid_ADS = ADS & CLK ; "ADS# sampled in PHIL of 386DX T-State Valid_RDY = RDY & CLK ; *RDY# sampled in PHI1 of 386DX T-State Timer_Acc = TMR & CLK ; "Timer Unit Access, as provided by *external Address Decoder * State_Diagram [INHIBIT, S1, S0] state 000: if RESET then 000 else if Valid_ADS & W_R then 001 else 000; if RESET then 000 state 001: else if Timer_Acc then 010 else if !Timer_Acc then 000 else 001; state 010: if RESET then 000 else if CLK then 110 else 010; state 110: if RESET then 000 else if CLK then 111 else 110; ``` 82380 ``` state 111: if RESET then 000 else if CLK then Oll else 111; state Oll: if RESET then 000 else if Valid_RDY then 000 else Oll; state 100: if RESET then 000 else 000; if RESET then 000 state 101: else 000; EQUATIONS Q_O := CLKIN_IN ; "Latched incoming clock. This signal is used "internally to feed into the MUX-ing logic" CLKIN_OUT := (INHIBIT & CLKIN_OUT & !RESET) +(!INHIBIT & Q_O & !RESET); *Equation for CLKIN_OUT. This "feeds directly to the 82380 Timer Unit." END Page 1 ABEL(tm) 3.10 - Document Generator 30-June 89 03:17 82380 Timer Unit CLKIN INHIBIT signal PAL Solution Equations for Module Timer_82380_Fix Device Timer_Unit_Fix - Reduced Equations: !INHIBIT := (!CLK & !INHIBIT # CLK & SO # RESET # !S1); !S1 := (RESET # INHIBIT & !S1 # CLK & !INHIBIT & !~ RDY & SO & S1 # !CLK & !Sl # !S1 & !TMR # !SO & !S1); !SO := (RESET # INHIBIT & !S1 # CLK & !INHIBIT & !~ RDY & S1 # !CLK & !SO # !INHIBIT & !SO & S1 # SO & !S1 # !S1 & !W_R # ~ ADS & !S1); ``` Figure 1. Translation of 386DX Signals to Internal 82380 Timer Unit Signals Figure 2. 82380 Timer Unit Write Cycle Figure 3. State Diagram for Inhibit Signal Figure 4. System with 82380 Timer Unit "Inhibit" Circuitry Figure 5(a). Inhibited CLKIN in an 82380 Timer Unit and CLKIN Minimum HIGH Time Figure 5(b). Inhibited CLKIN in an 82380 Timer Unit and CLKIN Minimum LOW Time 82380 #### 82380 DATA SHEET REVISION HISTORY Changes in this revision: Figure 4-1: Added details about IRQ3# and IRQ2#/IRQ1.5#. Section 5.2.1: Added note referring reader to Appendix D (System Notes). Table 13-2: Changed $V_{IHC}$ MIN to $V_{CC}$ - 0.8V. Figure 13-1: Changed signal names to reflect accurate drive levels and measurement points for those sig- nais. Appendix D: Added this appendix to explain the restrictions on the CLKIN signal of the 82380 Timer Unit.