6-21
CHIP-SELECT UNIT
Example 6-1. Initializing the Chip-Select Unit (Continued)
DRAM_BASE
EQU
256
;window start address in Kbytes
DRAM_SIZE
EQU
256
;window size in Kbytes
DRAM_WAIT
EQU
0
;wait states
DRAM_RDY
EQU
INTRDY
;ignore bus ready
;The MPCS register is used to program both the MCS and PCS chip-selects.
;Below are the equates for the I/O peripherals (also used to program the PACS
;register.
IO_WAIT
EQU
4
;IO wait states
IO_RDY
EQU
INTRDY
;ignore bus ready
PCS_SPACE
EQU
IO
;put PCS# chip-selects in I/O space
PCS_FUNC
EQU
ALLPCS
;generate PCS5# and PCS6#
;The MMCS and MPCS register values are calculated using the above system
;constraints and the equations below:
MMCS_VAL
EQU
(DRAM_BASE SHL 6) OR (001F8H) OR (DRAM_RDY) OR (DRAM_WAIT)
MPCS_VAL
EQU
(DRAM_SIZE SHL 5) OR (08038H) OR (PCS_SPACE) OR (PCS_FUNC) OR
&
(IO_RDY) OR (IO_WAIT)
;I/O is selected using the PCS0# chip-select. Wait states assume operation at
;16 MHz. For this example, the Floppy Disk Controller is connected to PCS2# and
;PCS1# provides the DACK signal.
IO_BASE
EQU
1
;I/O start address in Kbytes
;The PACS register value is calculated using the above system constraints and
;the equation below.
PACS_VAL
EQU
(IO_BASE SHL 6) OR (0038H) OR (IO_RDY) OR (IO_WAIT)
;The following statements define the default assumptions for segment locations.
ASSUME
CS:CODE
ASSUME
DS:DATA
ASSUME
SS:DATA
ASSUME
ES:DATA
CODE
SEGMENT PUBLIC 'CODE'
;
;Entry point on power-up
;
FW_START
LABEL
FAR
;forces far jump
CLI
;disable interrupts
;Place register initialization code here
;
;Set up chip-selects.
;UCS - EPROM Select
(initialized during POWER_ON code)
;LCS - SRAM Select
(set to SRAM size)
;PCS - I/O Select
(PCS1:0 to support floppy)
;MCS - DRAM Select
(set to DRAM size)
mov
dx, LMCS_REG
;set up LMCS register
mov
ax, LMCS_VAL
out
dx, al
;remember that byte writes are OK
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: ......