### intel

### 8237A HIGH PERFORMANCE PROGRAMMABLE DMA CONTROLLER (8237A-5)

- Y Enable/Disable Control of Individual DMA Requests
- Y Four Independent DMA Channels
- Independent Autoinitialization of All Channels
- Y Memory-to-Memory Transfers
- Y Memory Block Initialization
- Y Address Increment or Decrement
- Y High Performance: Transfers up to 1.6M Bytes/Second with 5 MHz 8237A-5
- Y Directly Expandable to Any Number of Channels
- Y End of Process Input for Terminating Transfers
- Y Software DMA Requests
- Y Independent Polarity Control for DREQ and DACK Signals
- Available in EXPRESS
- Standard Temperature Range
- Y Available in 40-Lead Cerdip and Plastic Packages
  - (See Packaging Spec, Order ?231369)

The 8237A Multimode Direct Memory Access (DMA) Controller is a peripheral interface circuit for microprocessor systems. It is designed to improve system performance by allowing external devices to directly transfer information from the system memory. Memory-to-memory transfer capability is also provided. The 8237A offers a wide variety of programmable control features to enhance data throughput and system optimization and to allow dynamic reconfiguration under program control.

The 8237A is designed to be used in conjunction with an external 8-bit address latch. It contains four independent channels and may be expanded to any number of channels by cascading additional controller chips. The three basic transfer modes allow programmalbility of the types of DMA service by the user. Each <u>channel</u> can be individually programmed to Autoinitialize to its original condition following an End of Process (EOP). Each channel has a full 64K address and word count capability.



Figure 1. Block Diagram

September 1993

Order Number: 231466-005

#### 8237A

# intel

| Symbol          | Туре  | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|-----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| V <sub>CC</sub> |       | POWER: a5/ supply.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| V <sub>SS</sub> |       | GROUND: Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| CLK             |       | CLOCK INPUT: Clock Input controls the internal operations of the 8237A and its rate of data transfers. The input may be driven at u to 5 MHz for the 8237A-5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| CS              | I     | CHIP SELECT: Chip Select is an active low input used to select<br>the 8237A as an I/O device during the Idle cycle. This allows CPU<br>communication on the data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| RESET           |       | RESET: Reset is an active high input which clears the Command,<br>Status, Request and Temporary registers. It also clears the first/<br>last flip/flop and sets the Mask register. Following a Reset the<br>device is in the Idle cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| READY           | I     | READY: Ready is an input used to extend the memory read and<br>write pulses from the 8237A to accommodate slow memories or<br>I/O peripheral devices. Ready must not make transitions during its<br>specified setup/hold time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| HLDA            |       | HOLD ACKNOWLEDGE: The active high Hold Acknowledge from<br>the CPU indicates that it has relinquished control of the system<br>busses.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| DREQ0-DREQ3     |       | DMA REQUEST: The DMA Request lines are individual<br>asynchronous channel request inputs used by peripheral circuits to<br>obtain DMA service. In fixed Priority, DREQ0 has the highest<br>priority and DREQ3 has the lowest priority. A request is generate<br>by activating the DREQ line of a channel. DACK will acknowledge<br>the recognition of DREQ signal. Polarity of DREQ is<br>programmable. Reset initializes these lines to active high. DREQ<br>must be maintained until the corresponding DACK goes active.                                                                                                                                                                                                                                                              |  |  |
| DB0-DB7         | I/O   | DATA BUS: The Data Bus lines are bidirectional three-state<br>signals connected to the system data bus. The outputs are<br>enabled in the Program condition during the I/O Read to output<br>the contents of an Address register, a Status register, the<br>Temporary register or a Word Count register to the CPU. The<br>outputs are disabled and the inputs are read during an I/O Write<br>cycle when the CPU is programming the 8237A control registers.<br>During DMA cycles the most significant 8 bits of the address are<br>output onto the data bus to be strobed into an external latch by<br>ADSTB. In memory-to-memory operations, data from the memory<br>comes into the 8237A on the data bus during the read-from-<br>memory transfer. In the write-to-memory location. |  |  |
| ĪOR             | . I/O | I/O READ: I/O Read is a bidirectional active low three-state line.<br>In the Idle cycle, it is an input control signal used by the CPU to<br>read the control registers. In the Active cycle, it is an output control<br>signal used by the 8237A to access data from a peripheral during a<br>DMA Write transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| ĪOW             | I/O   | I/O WRITE: I/O Write is a bidirectional active low three-state line.<br>In the Idle cycle, it is an input control signal used by the CPU to<br>load information into the 8237A. In the Active cycle, it is an output<br>control signal used by the 8237A to load data to the peripheral<br>during a DMA Read transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

## int<sub>el</sub>.

| Symbol      | Туре | Name and Function   END OF PROCESS: End of Process is an active low bidirectional signal. Information concerning the completion of DMA services is available at the bidirectional EOP pin. The 8237A allows an external signal to terminate an active DMA service. This is                            |  |
|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| EOP         | I/O  |                                                                                                                                                                                                                                                                                                       |  |
| A0-A3       | I/O  | ADDRESS: The four least significant address lines are<br>bidirectional three-state signals. In the Idle cycle they are inputs<br>and are used by the CPU to address the register to be loaded or<br>read. In the Active cycle they are outputs and provide the lower 4<br>bits of the output address. |  |
| A4–A7       | 0    | ADDRESS: The four most significant address lines are three-state<br>outputs and provide 4 bits of address. These lines are enabled<br>only during the DMA service.                                                                                                                                    |  |
| HRQ         | 0    | HOLD REQUEST: This is the Hold Request to the CPU and is<br>used to request control of the system bus. If the corresponding<br>mask bit is clear, the presence of any valid DREQ causes 8237A to<br>issue the HRQ.                                                                                    |  |
| DACK0-DACK3 | 0    | DMA ACKNOWLEDGE: DMA Acknowledge is used to notify the individual peripherals when one has been granted a DMA cycle. The sense of these lines is programmable. Reset initializes them to active low.                                                                                                  |  |
| AEN         | 0    | ADDRESS ENABLE: Address Enable enables the 8-bit latch<br>containing the upper 8 address bits onto the system address bus.<br>AEN can also be used to disable other system bus drivers during<br>DMA transfers. AEN is active HIGH.                                                                   |  |
| ADSTB       | 0    | ADDRESS STROBE: The active high, Address Strobe is used to<br>strobe the upper address byte into an external latch.                                                                                                                                                                                   |  |
| MEMR        | 0    | MEMORY READ: The Memory Read signal is an active low three-<br>state output used to access data from the selected memory<br>location during a DMA Read or a memory-to-memory transfer.                                                                                                                |  |
| MEMW        | 0    | MEMORY WRITE: The Memory Write is an active low three-state<br>output used to write data to the selected memory location during a<br>DMA Write or a memory-to-memory transfer.                                                                                                                        |  |
| PIN5        | I    | PIN5: This pin should always be at a logic HIGH level. An internal<br>pull-up resistor will establish a logic high when the pin is left<br>floating. It is recommended however, that PIN5 be connected to                                                                                             |  |

8237A

3

#### FUNCTIONAL DESCRIPTION

The 8237A block diagram includes the major logic blocks and all of the internal registers. The data interconnection paths are also shown. Not shown are the various control signals between the blocks. The 8237A contains 344 bits of internal memory in the form of registers. Figure 3 lists these registers by name and shows the size of each. A detailed description of the registers and their functions can be found under Register Description.

| Name                          | Size    | Number |  |
|-------------------------------|---------|--------|--|
| Base Address Registers        | 16 bits | 4      |  |
| Base Word Count Registers     | 16 bits | 4      |  |
| Current Address Registers     | 16 bits | 4      |  |
| Current Word Count Registers  | 16 bits | 4      |  |
| Temporary Address Register    | 16 bits | 1      |  |
| Temporary Word Count Register | 16 bits | 1      |  |
| Status Register               | 8 bits  | 1      |  |
| Command Register              | 8 bits  | 1      |  |
| Temporary Register            | 8 bits  | · 1    |  |
| Mode Registers                | 6 bits  | 4      |  |
| Mask Register                 | 4 bits  | 1      |  |
| Request Register              | 4 bits  | 1      |  |

#### Figure 3. 8237A Internal Registers

The 8237A contains three basic blocks of control logic. The Timing Control block generates internal timing and external control signals for the 8237A. The Program Command Control block decodes the various commands given to the 8237A by the micro-processor prior to servicing a DMA Request. It also decodes the Mode Control word used to select the type of DMA during the servicing. The Priority Encoder block resolves priority contention between DMA channels requesting service simultaneously.

The Timing Control block derives internal timing from the clock input. In 8237A systems, this input will usually be the  $_{\rm W}2$  TTL clock from an 8224 or CLK from an 8085AH or 8284A. 33% duty cycle clock generators, however, may not meet the clock

high time requirement of the 8237A of the same frequency. For example, 82C84A-5 CLK output violates the clock high time requirement of 8237A-5. In this case 82C84A CLK can simply be inverted to meet 8237A-5 clock high and low time requirements. For 8085AH-2 systems above 3.9 MHz, the 8085 CLK(OUT) does not satisfy 8237A-5 clock LOW and HIGH time requirements. In this case, an external clock should be used to drive the 8237A-5.

#### DMA OPERATION

The 8237A is designed to operate in two major cycles. These are called Idle and Active cycles. Each device cycle is made up of a number of states. The 8237A can assume seven separate states, each composed of one full clock period. State I (SI) is the inactive state. It is entered when the 8237A has no valid DMA requests pending. While in SI, the DMA controller is inactive but may be in the Program Condition, being programmed by the processor. State S0 (S0) is the first state of a DMA service. The 8237A has requested a hold but the processor has not yet returned an acknowledge. The 8237A may still be programmed until it receives HLDA from the CPU. An acknowledge from the CPU will signal that DMA transfers may begin. S1, S2, S3 and S4 are the working states of the DMA service. If more time is needed to complete a transfer than is available with normal timing, wait states (SW) can be inserted between S2 or S3 and S4 by the use of the Ready line on the 8237A. Note that the data is transferred directly from the I/O device to memory (or vice versa) with IOR and MEMW (or MEMR and IOW) being active at the same time. The data is not read into or driven out of the 8237A in I/O-to-memory or memory-to-I/O DMA transfers.

Memory-to-memory transfers require a read-from and a write-to-memory to complete each transfer. The states, which resemble the normal working states, use two digit numbers for identification. Eight states are required for a single transfer. The first four states (S11, S12, S13, S14) are used for the readfrom-memory half and the last four states (S21, S22, S23, S24) for the write-to-memory half of the transfer.

#### IDLE CYCLE

When no channel is requesting service, the 8237A will enter the Idle cycle and perform "SI" states. In this cycle the 8237A will sample the DREQ lines every clock cycle to determine if any channel is requesting a DMA service. The device will also sample CS, looking for an attempt by the microprocessor to write or read the internal registers of the 8237A. When CS is low and HLDA is low, the 8237A enters the Program Condition. The CPU can now establish, change or inspect the internal definition of the part by reading from or writing to the internal registers. Address lines A0 - A3 are inputs to the device and select which registers will be read or written. The IOR and IOW lines are used to select and time reads or writes Due to the number and size of the internal registers, an internal flip-flop is used to generate an additional bit of address. This bit is used to determine the upper or lower byte of the 16-bit Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. A separate software command can also reset this flip-flop.

Special software commands can be executed by the 8237A in the Program Condition. These commands are decoded as sets of addresses with the CS and IOW. The commands do not make use of the data bus. Instructions include Clear First/Last Flip-Flop and Master Clear.

### intel

#### ACTIVE CYCLE

When the 8237A is in the Idle cycle and a nonmasked channel requests a DMA service, the device will output an HRQ to the microprocessor and enter the Active cycle. It is in this cycle that the DMA service will take place, in one of four modes:

Single Transfer Mode?In Single Transfer mode the device is programmed to make one transfer only. The word count will be decremented and the ad- dress decremented or ncremented following each transfer. When the word count "rolls over" from zero to FFFFH, a Terminal Count (TC) will cause an Auto-initialize if the channel has been programmed to do so.

DREQ must be held active until DACK becomes active in order to be recognized. If DREQ is held active throughout the single transfer, HRQ will go inactive and release the bus to the system. It will again go active and, upon receipt of a new HLDA, another single transfer will be performed. In 8080A, 8085AH, 8088, or 8086 system, this will ensure one full machine cycle execution between DMA transfers. Details of timing between the 8237A and other bus control protocols will depend upon the characteristics of the microprocessor involved.

Block Transfer Mode?In Block Transfer mode the device is activated by DREQ to continue making transfers during the service until a TC, caused by word count going to FFFFH, or an external End of

Process ( $\overline{\text{EOP}}$ ) is encountered. DREQ need only be held active until DACK becomes active. Again, an Autoinitialization will occur at the end of the service if the channel has been programmed for it.

Demand Transfer Mode?In Demand Transfer mode the device is programmed to continue making transfers until a TC or external EOP is encountered or until DREQ goes inactive. Thus transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has had a chance to catch up, the DMA service is re-established by means of a DREQ. During the time between services when the microprocessor is allowed to operate, the intermediate values of address and word count are stored in the 8237A Current Address and Current Word Count registers. Only an EOP can cause an Autoinitialize at the end of the service. EOP is generated either by TC or by an external signal. DREQ has

Cascade Mode?This mode is used to cascade more than one 8237A together for simple system expansion. The HRQ and HLDA signals from the additional 8237A are connected to the DREQ and DACK signals of a channel of the initial 8237A. This allows the DMA requests of the additional device to propagate through the priority network circuitry of the preceding device. The priority chain is preserved and the new device must wait for its turn to acknowl- edge requests. Snce the cascade channel of the initial 8237A is used only for prioritizing the addition- al device, it does not output any address or control



Figure 4. Cascaded 8237As

5

#### 8237A

signals of its own. These could conflict with the outputs of the active channel in the added device. The 8237A will respond to DREQ and DACK but all other outputs except HRQ will be disabled. The ready input is ignored.

Figure 4 shows two additional devices cascaded into an initial device using two of the previous channels. This forms a two level DMA system. More 8237As could be added at the second level by using the remaining channels of the first level. Additional devices can also be added by cascading into the channels of the second level device, forming a third level.

#### TRANSFER TYPES

Each of the three active transfer modes can perform three different types of transfers. These are Read, Write and Verify. Write transfers move data from an <u>I/O</u> device to the memory by activating MEMW and IOR. Read transfers move data from memory to an I/O device by activating MEMR and IOW. Verify transfers are pseudo transfers. The 8237A operates as in Read or Write transfers generating addresses, and responding to EOP, etc. However, the memory and I/O control lines all remain inactive. The ready input is ignored in verify mode.

Memory-to-Memory?To perform block moves of data from one memory address space to another with a minimum of program effort and time, the 8237A includes a memory-to-memory transfer fea- ture. Programming a bit in the Command register selects channels 0 and 1 to operate as memory-to- memory transfer channels. The transfer is initiated by setting the software DREQ for channel 0. The 8237A requests a DMA service in the normal man-ner. After HLDA is true, the device, using four state transfers in Block Transfer mode, reads data from the memory. The channel 0 Current Address register is the source for the address used and is decrement- ed or incremented in the normal manner. The data byte read from the memory is stored in the 8237A internal Temporary register. Channel 1 then per- forms a four-state transfer of the data from the Tem- porary register to memory using the address in its Current Address register and norementing or decre- menting it in the normal manner. The channel 1 cur- rent Word Count is decremented. When the word count of channel 1 goes to FFFFH, a TC is generat- ed causing an EOP output terminating the service.

Channel 0 may be programmed to retain the same address for all transfers. This allows a single word to be written to a block of memory.

## intel

The 8237A will respond to external EOP signals during memory-to-memory transfers. Data comparators in block search schemes may use this input to terminate the service when a match is found. The timing of memory-to-memory transfers is found in Figure 12. Memory-to-memory operations can be detected as an active AEN with no DACK outputs.

Autoinitialize?By programming a bit in the Mode register, a channel may be set up as an Autoinitialize channel. During Autoinitialize initialization, the original values of the Current Address and Current Word Count registers are automatically restored from the Base Address and Base Word count registers of that channel following EOP. The base registers are loaded simultaneously with the current registers by the microprocessor and remain unchanged throughout the DMA service. The mask bit is not altered when the channel is in Autoinitialize. Following Autoinitialize the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected. In order to Autoinitialize both channels in a memory-to-memory transfer, both word counts should be programmed identically. If interrupted externally, EOP pulses should be applied in both bus cvcles.

Priority?The 8237A has two types of priority encoding available as software selectable options. The first is Fixed Priority which fixes the channels in priority order based upon the descending value of their number. The channel with the lowest priority is 3 followed by 2, 1 and the highest priority channel, 0. After the recognition of any one channel for service, the other channels are prevented from interfering with that service until it is completed.

After completion of a service, HRQ will go inactive and the 8237A will wait for HLDA to go low before activating HRQ to service another channel.

The second scheme is Rotating Priority. The last channel to get service becomes the lowest priority channel with the others rotating accordingly.



以上内容仅为本文档的试下载部分,为可阅读页数的一半内容。如 要下载或阅读全文,请访问: <u>https://d.book118.com/44802601307</u> <u>4006024</u>