Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Coprocessor

Download as pptx, pdf, or txt
Download as pptx, pdf, or txt
You are on page 1of 23

8087 Coprocessor

Presented by,
C.Balasubramaniam,
Lect / CSE
ESEC
OBJECTIVE
• To learn about the 8087 coprocessor like,
 Pin Diagram
 Architecture
 Instruction set
Introduction
•The Intel 8087, announced in 1980.
•This was the first floating point
Coprocessor for the 8086 line of
Processors.
•It had 45,000 transistors and uses HMOS
Circuit.
•Why this Coprocesors was Developed?

Contd..
Bcoz, to Speed up
computations on demanding
applications involving floating
point arithmetic.

Contd..
Cont..

* The 8087 introduces 60 new instructions,


and their assembly mnemonics all begins with
“F” to differentiate them from the 8086
integer instructions.
* For Eg: ADD / MUL /CMP  8086
FADD / FMUL / FCOM  8087
Overview of 8087
• Each processor in the 80x86 family has a
corresponding coprocessor with which it is
compatible
• Math Coprocessor is known as NPX,NDP,FUP.
• Numeric processor extension (NPX),
• Numeric data processor (NDP),
• Floating point unit (FUP).
Compatible Processor and
Coprocessor
Processors Coprocessor
• 1. 8086 & 8088 8087
• 2. 80286 80287, 80287LX
• 3. 80386DX 80287 ,80387DX
• 4. 80386SX 80387SX
• 5. 80486DX Inbuilt
• 6. 80486SX 80487SX
Architecture of 8087
ARCHITECTURE OF 8087
• 8087 coprocessor is designed to operate with 8086
microprocessor.
• The microprocessor and coprocessor can execute
their respective instructions simultaneously.
• Microprocessor interprets and executes the normal
instruction set and the coprocessor interprets and
executes only the coprocessor instructions.
• All the coprocessor instructions are ESC instructions,
i.e. they start with “F”.
Architecture of 8087
• Control Unit

• Execution Unit
Control Unit
• Control unit: To synchronize the operation of
the coprocessor and the processor.
• This unit has a Control word and Status word
and Data Buffer
• If instruction is an ESCape (coprocessor)
instruction,the coprocessor executes it, if not
the microprocessor executes.
Status Register
B C S C C C E P U O Z D IE
3 T 2 1 0 S E E E E E
15 0

• C3-C0 Condition code bits


• TOP Top-of-stack (ST)
• ES Error summary
• PE Precision error
• UE Under flow error
• OE Overflow error
• ZE Zero error
• DE Denormalized error
• IE Invalid error
• B Busy bit
Status Register (cont..)
• Status register reflects the over all operation of the
coprocessor.
• B-Busy bit indicates that coprocessor is busy
executing a task. Busy can be tested by examining
the status or by using the FWAIT instruction. Newer
coprocessor automatically synchronize with the
microprocessor, so busy flag need not be tested
before performing additional coprocessor tasks.
• C3-C0 Condition code bits indicates conditions about
the coprocessor.
Status Register (cont..)
• TOP- Top of the stack (ST) bit indicates the current
register address as the top of the stack.
• ES-Error summary bit is set if any unmasked error bit
(PE,UE, OE, ZE, DE, or IE) is set. In the 8087 the error
summary is also caused a coprocessor interrupt.
• PE- Precision error indicates that the result or
operand executes selected precision.
• UE-Under flow error indicates the result is too large
to be represent with the current precision selected
by the control word.
Status Register (cont..)
• OE-Over flow error indicates a result that is too large
to be represented. If this error is masked, the
coprocessor generates infinity for an overflow error.

• ZE-A Zero error indicates the divisor was zero while


the dividend is a non-infinity or non-zero number.

• DE-Denormalized error indicates at least one of the


operand is denormalized.
• IE-Invalid error indicates a stack overflow or
underflow, indeterminate from (0/0,0,-0, etc)
or the use of a NAN as an operand. This flag
indicates error such as those produced by
taking the square root of a negative number.
Control Register
• Control register selects precision, rounding
control,infinity control.
• It also masks an unmasks the exception bits
that correspond to the rightmost Six bits of
status register.
• Instruction FLDCW is used to load the value
into the control register.
Control Register
IC RC PC P U O Z D I
M M M M M M
15 0

• IC Infinity control
• RC Rounding control
• PC Precision control
• PM Precision control
• UM Underflow mask
• OM Overflow mask
• ZM Division by zero mask
• DM Denormalized operand mask
• IM Invalid operand mask
Control Register
TAG REGISTER
• Tag Register is used to indicate the contents of
each register in the stack.
• There are total 8 tags (Tag 0 to Tag 7) in this
register and each tag uses 2 bits to represent a
value.
• Therefore, it is a 16-bit register
Tag Register
TAG7 TAG6 TAG5 TAG4 TAG3 TAG2 TAG1 TAG0
Numeric Execution Unit
• This performs all operations that access and
manipulate the numeric data in the
coprocessor’s registers.
• Numeric registers in NUE are 80 bits wide.
• NUE is able to perform arithmetic, logical and
transcendental operations as well as supply a
small number of mathematical constants from
its on-chip ROM.
• Numeric data is routed into two parts ways
a 64 bit mantissa bus and
a 16 bit sign/exponent bus.

You might also like