10-7
DIRECT MEMORY ACCESS UNIT
10.1.6 DMA Transfer Counts
Each DMA Unit maintains a programmable 16-bit transfer count value that controls the total
number of transfers the channel runs. The transfer count is decremented by one after each transfer
(regardless of data size). The DMA channel can be programmed to terminate transfers when the
transfer count reaches zero (also referred to as terminal count).
10.1.7 Termination and Suspension of DMA Transfers
When DMA transfers for a channel are terminated, no further DMA requests for that channel will
be granted until the channel is re-started by direct programming. A suspended DMA transfer tem-
porarily disables transfers in order to perform a specific task. A suspended DMA channel does
not need to be re-started by direct programming.
10.1.7.1 Termination at Terminal Count
When programmed to terminate on terminal count, the DMA channel disarms itself when the
transfer count value reaches zero. No further DMA transfers take place on the channel until it is
re-armed by direct programming. Unsynchronized transfers always terminate when the transfer
count reaches zero, regardless of programming.
10.1.7.2 Software Termination
A DMA channel can be disarmed by direct programming. Any DMA transfer that is in progress
will complete, but no further transfers are run until the channel is re-armed.
10.1.7.3 Suspension of DMA During NMI
DMA transfers are inhibited during the service of Non-Maskable Interrupts (NMI). DMA activity
is halted in order to give the CPU full command of the system bus during the NMI service. Exit
from the NMI via an IRET instruction re-enables the DMA Unit. DMA transfers can be enabled
during an NMI service routine by the system software.
10.1.7.4 Software Suspension
DMA transfers can be temporarily suspended by direct programming. In time-critical sections of
code, such as interrupt handlers, it may be necessary to shut off DMA activity temporarily in or-
der to give the CPU total control of the bus.
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: ......