10-3
DIRECT MEMORY ACCESS UNIT
10.1.1.1
DMA Transfer Directions
The source and destination addresses for a DMA transfer are programmable and can be in either
memory or I/O space. DMA transfers can be programmed for any of the following four direc-
tions:
•
from memory space to I/O space
•
from I/O space to memory space
•
from memory space to memory space
•
from I/O space to I/O space
DMA transfers can access the Peripheral Control Block.
10.1.1.2
Byte and Word Transfers
DMA transfers can be programmed to handle either byte or word transfers. The handling of byte
and word data is the same as that for normal bus cycles and is dependent upon the processor bus
width. For example, odd-aligned word DMA transfers on a processor with a 16-bit bus requires
two fetches and two deposits (all back-to-back). BIU bus cycles are covered in Chapter 3, “Bus
Interface Unit.” Word transfers are illegal on the 8-bit bus device.
10.1.2 Source and Destination Pointers
Each DMA channel maintains a twenty-bit pointer for the source of data and a twenty-bit pointer
for the destination of data. The twenty-bit pointers allow access to the full 1 Mbyte of memory
space. The DMA Unit views memory as a linear (unsegmented) array.
With a twenty-bit pointer, it is possible to create an I/O address that is above the CPU limit of 64
Kbytes. The DMA Unit will run I/O DMA cycles above 64K, even though these addresses are
not accessible through CPU instructions (e.g., IN and OUT). Some applications may wish to
make use of this by swapping pages of data from I/O space above 64K to standard CPU memory.
The source and destination pointers can be individually programmed to increment, decrement or
remain constant after each transfer. The programmed data width (byte or word) determines the
amount that a pointer is incremented or decremented. Word transfers change the pointer by two;
byte transfers change the pointer by one.
10.1.3 DMA Requests
There are three distinct sources of DMA requests: the external DRQ pin, the internal DMA re-
quest line and the system software. In all three cases, the system software must arm a DMA chan-
nel before it recognizes DMA requests. (See “Arming the DMA Channel” on page 10-18.)
Summary of Contents for 80C186XL
Page 1: ...80C186XL 80C188XL Microprocessor User s Manual...
Page 2: ...80C186XL 80C188XL Microprocessor User s Manual 1995...
Page 18: ...1 Introduction...
Page 19: ......
Page 27: ......
Page 28: ...2 Overview of the 80C186 Family Architecture...
Page 29: ......
Page 79: ......
Page 80: ...3 Bus Interface Unit...
Page 81: ......
Page 127: ......
Page 128: ...4 Peripheral Control Block...
Page 129: ......
Page 137: ......
Page 138: ...5 ClockGenerationand Power Management...
Page 139: ......
Page 154: ...6 Chip Select Unit...
Page 155: ......
Page 178: ...7 Refresh Control Unit...
Page 179: ......
Page 193: ......
Page 194: ...8 Interrupt Control Unit...
Page 195: ......
Page 227: ......
Page 228: ...9 Timer Counter Unit...
Page 229: ......
Page 253: ......
Page 254: ...10 Direct Memory Access Unit...
Page 255: ......
Page 283: ......
Page 284: ...11 Math Coprocessing...
Page 285: ......
Page 302: ...12 ONCE Mode...
Page 303: ......
Page 306: ...A 80C186 Instruction Set Additions and Extensions...
Page 307: ......
Page 318: ...B Input Synchronization...
Page 319: ......
Page 322: ...C Instruction Set Descriptions...
Page 323: ......
Page 371: ......
Page 372: ...D Instruction Set Opcodes and Clock Cycles...
Page 373: ......
Page 396: ...Index...
Page 397: ......