10-23
DIRECT MEMORY ACCESS UNIT
Example 10-1. Initializing the DMA Unit
$MOD186
name
DMA_EXAMPLE_1
; This example shows code necessary to set up two DMA channels.
; One channel performs an unsynchronized transfer from memory to memory.
; The second channel is used by a hard disk controller located in
; I/O space.
; It is assumed that the constants for PCB register addresses are
; defined elsewhere with EQUates.
CODE_SEG
SEGMENT
ASSUME CS:CODE_SEG
START:
MOV
AX, DATA_SEG
; DATA SEGMENT POINTER
MOV
DS, AX
ASSUME DS:DATA_SEG
; First we must initialize DMA channel 0. DMA0 will perform an
; unsynchronized transfer from SOURCE_DATA_1 to DEST_DATA_1.
; The first step is to calculate the proper values for the
; source and destination pointers.
MOV
AX, SEG SOURCE_DATA_1
ROL
AX, 4
; GET HIGH 4 BITS
MOV
BX, AX
; SAVE ROTATED VALUE
AND
AX, 0FFF0H
; GET SHIFTED LOW 4 NIBBLES
ADD
AX, OFFSET SOURCE_DATA_1
; NOW LOW BYTES OF POINTER ARE IN AX
ADC
BX, 0
; ADD IN THE CARRY
; TO THE HIGH NIBBLE
AND
BX, 000FH
; GET JUST THE HIGH NIBBLE
MOV
DX, D0SRCL
OUT
DX, AL
; AX=LOW 4 BYTES
MOV
DX, D0SRCH
MOV
AX, BX
; GET HIGH NIBBLE
OUT
DX, AX
; SOURCE POINTER DONE. REPEAT FOR DESTINATION.
MOV
AX, SEG DEST_DATA_1
ROL
AX, 4
; GET HIGH 4 BITS
MOV
BX, AX
; SAVE ROTATED VALUE
AND
AX, 0FFF0H
; GET SHIFTED LOW 4 NIBBLES
ADD
AX, OFFSET DEST_DATA_1
; NOW LOW BYTES OF POINTER ARE IN AX
ADC
BX, 0
; ADD IN THE CARRY
; TO THE HIGH NIBBLE
AND
BX, 000FH
; GET JUST THE HIGH NIBBLE
MOV
DX, D0DSTL
OUT
DX, AX
; AX=LOW 4 BYTES
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: ......