11-15
MATH COPROCESSING
Example 11-1. Initialization Sequence for 80C187 Math Coprocessor
$mod186
name
example_80C187_init
;
;FUNCTION:
This function initializes the 80C187 numerics coprocessor.
;
;SYNTAX:
extern unsigned char far 187_init(void);
;
;INPUTS:
None
;
;OUTPUTS:
unsigned char - 0000h -> False -> coprocessor not initialized
;
ffffh -> True -> coprocessor initialized
;
;NOTE:
Parameters are passed on the stack as required by
;
high-level languages.
;
lib_80186
segment public ’code’
assume cs:lib_80186
public _187_init
_187_initproc far
push
bp
;save caller’s bp
mov
bp, sp
;get current top of stack
cli
;disable maskable interrupts
fninit
;init 80C187 processor
fnstcw [bp-2]
;get current control word
sti
;enable interrupts
mov
ax, [bp-2]
and
ax, 0300h
;mask off unwanted control bits
cmp
ax, 0300h
;PC bits = 11
je
Ok
;yes: processor ok
xor
ax, ax
;return false (80C187 not ok)
pop
bp
;restore caller’s bp
ret
Ok:
and
[bp-2], 0fffeh
;unmask possible exceptions
fldcw
[bp-2]
mov
ax,0ffffh
;return true (80C187 ok)
pop
bp
;restore caller’s bp
ret
_187_initendp
lib_80186ends
end
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: ......