DIRECT MEMORY ACCESS UNIT
10-24
Example 10-1. Initializing the DMA Unit (Continued)
MOV
DX, D0DSTH
MOV
AX, BX
; GET HIGH NIBBLE
OUT
DX, AX
; THE POINTER ADDRESSES HAVE BEEN SET UP. NOW WE SET UP THE TRANSFER COUNT.
MOV
AX, 29
; THE MESSAGE IS 29 BYTES LONG.
MOV
DX, D0TC
; XFER COUNT REG
OUT
DX, AX
; NOW WE NEED TO SET THE PARAMETERS FOR THE CHANNEL AS FOLLOWS:
;
;
DESTINATION
SOURCE
;
-----------
------
;
MEMORY SPACE
MEMORY SPACE
;
INCREMENT PTR INCREMENT PTR
;
; TERMINATE ON TC, NO INTERRUPT, UNSYNCHRONIZED, LOW PRIORITY RELATIVE
; TO CHANNEL 1, BYTE XFERS. WE START THE CHANNEL.
MOV
AX, 1011011000000110B
MOV
DX, D0CON
OUT
DX, AX
; THE UNSYNCHRONIZED BURST IS NOW RUNNING ON THE BUS...
; NOW SET UP CHANNEL 1 TO SERVICE THE DISK CONTROLLER.
; FOR THIS EXAMPLE WE WILL ONLY BE READING FROM THE DISK.
; THE SOURCE IS THE I/O PORT FOR THE DISK CONTROLLER.
MOV
AX, DISK_IO_ADDR
MOV
DX, D1SRCL
OUT
DX, AX
; PROGRAM LOW ADDR
XOR
AX, AX
MOV
DX, D1SRCH
; HI ADDR FOR IO=0
OUT
DX, AX
; THE DESTINATION IS THE DISK BUFFER IN MEMORY
MOV
AX, SEG DISK_BUFF
ROL
AX, 4
; GET HIGH 4 BITS
MOV
BX, AX
; SAVE ROTATED VALUE
AND
AX, 0FFF0H
; GET SHIFTED LOW 4 NIBBLES
ADD
AX, OFFSET DISK_BUFF
; 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, D1DSTL
OUT
DX, AL
; AX=LOW 4 BYTES
MOV
DX, D1DSTH
MOV
AX, BX
; GET HIGH NIBBLE
OUT
DX, AX
; THE POINTER ADDRESSES HAVE BEEN SET UP. NOW WE SET UP THE TRANSFER COUNT.
Содержание 80C186XL
Страница 1: ...80C186XL 80C188XL Microprocessor User s Manual...
Страница 2: ...80C186XL 80C188XL Microprocessor User s Manual 1995...
Страница 18: ...1 Introduction...
Страница 19: ......
Страница 27: ......
Страница 28: ...2 Overview of the 80C186 Family Architecture...
Страница 29: ......
Страница 79: ......
Страница 80: ...3 Bus Interface Unit...
Страница 81: ......
Страница 127: ......
Страница 128: ...4 Peripheral Control Block...
Страница 129: ......
Страница 137: ......
Страница 138: ...5 ClockGenerationand Power Management...
Страница 139: ......
Страница 154: ...6 Chip Select Unit...
Страница 155: ......
Страница 178: ...7 Refresh Control Unit...
Страница 179: ......
Страница 193: ......
Страница 194: ...8 Interrupt Control Unit...
Страница 195: ......
Страница 227: ......
Страница 228: ...9 Timer Counter Unit...
Страница 229: ......
Страница 253: ......
Страница 254: ...10 Direct Memory Access Unit...
Страница 255: ......
Страница 283: ......
Страница 284: ...11 Math Coprocessing...
Страница 285: ......
Страница 302: ...12 ONCE Mode...
Страница 303: ......
Страница 306: ...A 80C186 Instruction Set Additions and Extensions...
Страница 307: ......
Страница 318: ...B Input Synchronization...
Страница 319: ......
Страница 322: ...C Instruction Set Descriptions...
Страница 323: ......
Страница 371: ......
Страница 372: ...D Instruction Set Opcodes and Clock Cycles...
Страница 373: ......
Страница 396: ...Index...
Страница 397: ......