10-1
CHAPTER 10
DIRECT MEMORY ACCESS UNIT
In many applications, large blocks of data must be transferred between memory and I/O space. A
disk drive, for example, usually reads and writes data in blocks that may be thousands of bytes
long. If the CPU were required to handle each byte of the transfer, the main tasks would suffer a
severe performance penalty. Even if the data transfers were interrupt driven, the overhead for
transferring control to the interrupt handler would still decrease system throughput.
Direct Memory Access, or DMA, allows data to be transferred between memory and peripherals
without the intervention of the CPU. Systems that use DMA have a special device, known as
the DMA controller, that takes control of the system bus and performs the transfer between mem-
ory and the peripheral device. When the DMA controller receives a request for a transfer from a
peripheral, it signals the CPU that it needs control of the system bus. The CPU then releases con-
trol of the bus and the DMA controller performs the transfer. In many cases, the CPU releases the
bus and continues to execute instructions from the prefetch queue. If the DMA transfers are rel-
atively infrequent, there is no degradation of software performance; the DMA transfer is trans-
parent to the CPU.
The DMA Unit has two channels. Each channel can accept DMA requests from one of three
sources: an external request pin, the Timer/Counter Unit or direct programming. Data can be
transferred between any combination of memory and I/O space. The DMA Unit can access the
entire memory and I/O space in either byte or word increments.
10.1 FUNCTIONAL OVERVIEW
The DMA Unit consists of two channels that are functionally identical. The following discussion
is hierarchical, beginning with an overview of a single channel and ending with a description of
the two-channel unit.
10.1.1 The DMA Transfer
A DMA transfer begins with a request. The requesting device may either have data to transmit (a
source request) or it may require data (a destination request). Alternatively, transfers may be ini-
tiated by the system software without an external request.
Summary of Contents for 80C186EA
Page 1: ...80C186EA 80C188EA Microprocessor User s Manual...
Page 2: ...80C186EA 80C188EA Microprocessor User s Manual 1995...
Page 19: ......
Page 20: ...1 Introduction...
Page 21: ......
Page 28: ...2 Overview of the 80C186 Family Architecture...
Page 29: ......
Page 79: ......
Page 80: ...3 Bus Interface Unit...
Page 81: ......
Page 129: ......
Page 130: ...4 Peripheral Control Block...
Page 131: ......
Page 139: ......
Page 140: ...5 ClockGenerationand Power Management...
Page 141: ......
Page 165: ......
Page 166: ...6 Chip Select Unit...
Page 167: ......
Page 190: ...7 Refresh Control Unit...
Page 191: ......
Page 205: ......
Page 206: ...8 Interrupt Control Unit...
Page 207: ......
Page 239: ...INTERRUPT CONTROL UNIT 8 32...
Page 240: ...9 Timer Counter Unit...
Page 241: ......
Page 265: ......
Page 266: ...10 Direct Memory Access Unit...
Page 267: ......
Page 295: ...DIRECT MEMORY ACCESS UNIT 10 28...
Page 296: ...11 Math Coprocessing...
Page 297: ......
Page 314: ...12 ONCE Mode...
Page 315: ......
Page 318: ...A 80C186 Instruction Set Additions and Extensions...
Page 319: ......
Page 330: ...B Input Synchronization...
Page 331: ......
Page 334: ...C Instruction Set Descriptions...
Page 335: ......
Page 383: ...INSTRUCTION SET DESCRIPTIONS C 48...
Page 384: ...D Instruction Set Opcodes and Clock Cycles...
Page 385: ......
Page 408: ...Index...
Page 409: ......