## 12. Soubor instrukcí FPU.

### Instrukční soubor FPU procesorů Pentium:

- přenosové instrukce
- aritmetické instrukce
- porovnávací instrukce
- transcendentní instrukce
- řídící instrukce

### Přenosové instrukce

- FLD
- FILD
- FBLD
- FST
- FIST
- FSTP
- FISTP
- FBSTP
- FXCH
- FCMOVcc

- **FLD1**
- FLDL2T
- FLDL2E
- FLDPI
- FLDLG2
- FLDLN2
- FLDZ

## FLD, FILD, FBLD

```
(Load Real)
```

```
FLD m32real
D9 / 0
DD/0
                FLD m64real
                FLD m80real
DB/5
D9 C0+i
                FLD ST(i)
if src is ST(i) then ST(i) \rightarrow temp
top - 1 \rightarrow top {if old top is 0 then new top will be 7}
if src is ST(i)
then temp \rightarrow ST(0)
    else ExtendedReal(src) \rightarrow ST(0)
if stack overflow occurred then 1 \rightarrow C1 else 0 \rightarrow C1
C3, C2, C0 are not defined
```

FILD src

(Load Integer)

```
DF /0 FILD m16int
DB /0 FILD m32int
DF /5 FILD m64int
```

```
top - 1 \rightarrow top {if old top is 0 then new top will be 7}
ExtendedReal(src) \rightarrow ST(0)
```

if stack overflow occurred then  $1 \rightarrow C1$  else  $0 \rightarrow C1$  C3, C2, C0 are not defined

FBLD src

(Load BCD)

**DF** /4

FBLD m80bcd

$$top - 1 \rightarrow top$$
 {if old top is 0 then new top will be 7}   
ExtendedReal(src)  $\rightarrow$  ST(0)

if stack overflow occurred then  $1 \rightarrow C1$  else  $0 \rightarrow C1$  C3, C2, C0 are not defined

## FST, FIST, FSTP, FISTP, FBSTP

FST dest

(Store Real)

D9 /2 FST m32real

DD /2 FST m64real

DD D0+i FST ST(i)

 $ST(0) \rightarrow dest$ 

Při ukládání do paměti je hodnota konvertována na Single Real, resp. Double Real formát.

if stack underflow occurred then  $0 \rightarrow C1$ else C1 indicates rounding direction

C3, C2, C0 are not defined

FIST dest

(Store Integer)

DF /2 FIST m16int DB /2 FIST m32int

 $ST(0) \rightarrow dest$ 

Hodnota je konvertována na Word Integer, resp. Short Integer.

if stack underflow occurred then 0 → C1 else C1 indicates rounding direction C3, C2, C0 are not defined

### FSTP dest

### (Store Real and Pop)

D9 /3 FSTP m32real

DD /3 FSTP m64real

DB /7 FSTP m80real

DD D8+i FSTP ST(i)

 $ST(0) \rightarrow dest$ 

PopRegisterStack

{if old top is 7 then new top will be 0}

Při ukládání do paměti je hodnota konvertována na Single Real, resp. Double Real formát.

if stack underflow occurred then  $0 \rightarrow C1$ , else C1 indicates rounding direction

C3, C2, C0 are not defined

| F  | $\Gamma$ 21 | ΓР | des | t |
|----|-------------|----|-----|---|
| 1. |             |    | ucs | ι |

(Store Integer and Pop)

| DF /3 | FISTP m16int |
|-------|--------------|
| DB /3 | FISTP m32int |
| DF /7 | FISTP m64int |

```
ST(0) \rightarrow dest
PopRegisterStack
```

{if old top is 7 then new top will be 0}

Hodnota je konvertována na Word Integer, Short Integer, resp. Long Integer formát.

if stack underflow occurred then  $0 \rightarrow C1$ else C1 indicates rounding direction

C3, C2, C0 are not defined

FBSTP dest

(Store BCD and Pop)

DF /6 FBSTP m80bcd

 $ST(0) \rightarrow dest$ PopRegisterStack

{if old top is 7 then new top will be 0}

Hodnota je konvertována na Packed BCD formát.

if stack underflow occurred then  $0 \rightarrow C1$  else C1 indicates rounding direction C3, C2, C0 are not defined

## **FXCH**

FXCH [dest]

(Exchange Register Contents)

D9 C8+i FXCH ST(i)

D9 C9 FXCH

implicitním operandem je ST(1)

 $ST(0) \rightarrow temp$ 

 $ST(i) \rightarrow ST(0)$ 

 $temp \rightarrow ST(i)$ 

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$  C3, C2, C0 are not defined

## **FCMOVcc**

# FCMOVcc ST(0),ST(i) (Float Point Conditional Move Pentium® Pro)

```
DA C0+i FCMOVB ST(0),ST(i) Move if below (CF=1)
```

**ZF=0**)

if cc then  $ST(i) \rightarrow ST(0)$ 

if stack underflow occurred then  $0 \rightarrow C1$ , C3, C2, C0 are not defined

# FLD1, FLDL2T, FLDL2E, FLDPI, FLDLG2, FLDLN2, FLDZ

## FLD1/FLDL2T/FLDL2E/FLDPI/FLDLG2/FLDLN2/FLDZ (Load Constant)

```
D9 E8
             FLD1
                              Constant = 1.0
D9 E9
             FLDL2T
                              Constant = \log_2 10
D9 EA
             FLDL2E
                              Constant = log_2e
D9 EB
             FLDPI
                              Constant = \pi
D9 EC
             FLDLG2
                              Constant = \log_{10} 2
D9 ED
             FLDLN2
                              Constant = \log_{e} 2
D9 EE
             FLDZ
                              Constant = 0.0
```

 $top - 1 \rightarrow top$  {if old top is 0 then new top will be 7} Constant  $\rightarrow$  ST(0)

if stack overflow occurred then  $1 \rightarrow C1$  else  $0 \rightarrow C1$ , C3, C2, C0 are not defined

### Aritmetické instrukce

- FADD
- FADDP
- FIADD
- FSUB
- FSUBP
- FISUB
- FSUBR
- FSUBRP
- FISUBR
- FMUL
- FMULP
- FIMUL
- FDIV
- FDIVP
- FIDIV
- FDIVR
- FDIVRP
- FIDIVR

- FPREM
- FPREM1
- FABS
- FCHS
- FSQRT
- FRNDINT
- FSCALE
- FXTRACT

FADD, FADDP, FIADD, FSUB, FSUBP, FISUB, FSUBR, FSUBRP, FISUBR, FMUL, FMULP, FIMUL, FDIV, FDIVP, FIDIV, FDIVR, FDIVRP, FIDIVR

FADD/FADDP/FIADD [[dest,]src]

(Add)

| D8 /0   | FADD m32real      | dest = ST(0)              |
|---------|-------------------|---------------------------|
| DC /0   | FADD m64real      | dest = ST(0)              |
| D8 C0+i | FADD ST(0),ST(i)  |                           |
| DC C0+i | FADD ST(i),ST(0)  |                           |
| DE C0+i | FADDP ST(i),ST(0) |                           |
| DE C1   | FADDP             | dest = ST(1), src = ST(0) |
| DA/0    | FIADD m32int      | dest = ST(0)              |
| DE /0   | FIADD m16int      | dest = ST(0)              |

dest + ExtendedReal(src) → dest if FADDP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$ ,

else C1 indicates rounding direction

C3, C2, C0 are not defined

FSUB/FSUBP/FISUB [[dest,]src]

(Subtract)

| D8 /4   | FSUB m32real      | dest = ST(0)              |
|---------|-------------------|---------------------------|
| DC /4   | FSUB m64real      | dest = ST(0)              |
| D8 E0+i | FSUB ST(0),ST(i)  |                           |
| DC E8+i | FSUB ST(i),ST(0)  |                           |
| DE E8+i | FSUBP ST(i),ST(0) |                           |
| DE E9   | FSUBP             | dest = ST(1), src = ST(0) |
| DA /4   | FISUB m32int      | dest = ST(0)              |
| DE /4   | FISUB m16int      | dest = ST(0)              |

 $dest - ExtendedReal(src) \rightarrow dest$ if FSUBP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$ 

else C1 indicates rounding direction

C3, C2, C0 are not defined

### FSUBR/FSUBRP/FISUBR [[dest,]src] (Reverse Subtract)

| D8/5    | FSUBR m32real      | dest = ST(0)              |
|---------|--------------------|---------------------------|
| DC /5   | FSUBR m64real      | dest = ST(0)              |
| D8 E8+i | FSUBR ST(0),ST(i)  |                           |
| DC E0+i | FSUBR ST(i),ST(0)  |                           |
| DE E0+i | FSUBRP ST(i),ST(0) |                           |
| DE E1   | FSUBRP             | dest = ST(1), src = ST(0) |
| DA /5   | FISUBR m32int      | dest = ST(0)              |
| DE /5   | FISUBR m16int      | dest = ST(0)              |

ExtendedReal(src) – dest → dest if FSUBRP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$ ,

else C1 indicates rounding direction

C3, C2, C0 are not defined

FMUL/FMULP/FIMUL [[dest,]src]

(Multiply)

D8/1FMUL m32real dest = ST(0)dest = ST(0)DC/1FMUL m64real D8 C8+i FMUL ST(0),ST(i) FMUL ST(i),ST(0) DC C8+i FMULP ST(i),ST(0) DE C8+i DE C9 dest = ST(1), src = ST(0)**FMULP** DA/1FIMUL m32int dest = ST(0)

dest \* ExtendedReal(src) → dest if FMULP then PopRegisterStack

{if old top is 7 then new top will be 0}

dest = ST(0)

if stack underflow occurred then  $0 \rightarrow C1$ ,

FIMUL m16int

else C1 indicates rounding direction

C3, C2, C0 are not defined

DE/1

FDIV/FDIVP/FIDIV [[dest,]src]

(Divide)

| D8 /6   | FDIV m32real      | dest = ST(0)              |
|---------|-------------------|---------------------------|
| DC /6   | FDIV m64real      | dest = ST(0)              |
| D8 F0+i | FDIV ST(0),ST(i)  |                           |
| DC F8+i | FDIV ST(i),ST(0)  |                           |
| DE F8+i | FDIVP ST(i),ST(0) |                           |
| DE F9   | FDIVP             | dest = ST(1), src = ST(0) |
| DA /6   | FIDIV m32int      | dest = ST(0)              |
| DE /6   | FIDIV m16int      | dest = ST(0)              |

dest / ExtendedReal(src) → dest if FDIVP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$ ,

else C1 indicates rounding direction

C3, C2, C0 are not defined

FDIVR/FDIVRP/FIDIVR [[dest,]src]

(Reverse Divide)

D8 /7 FDIVR m32real dest = ST(0)

DC /7 FDIVR m64real dest = ST(0)

D8 F8+i FDIVR ST(0),ST(i)

DC F0+i FDIVR ST(i),ST(0)

DE F0+i FDIVRP ST(i),ST(0)

DE F1 FDIVRP dest = ST(1), src = ST(0)

DA /7 FIDIVR m32int dest = ST(0)

DE /7 FIDIVR m16int dest = ST(0)

ExtendedReal(src) / dest  $\rightarrow$  dest

if FDIVRP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$ ,

else C1 indicates rounding direction

C3, C2, C0 are not defined

## FPREM, FPREM1

### D9 F8 FPREM

```
exponent(ST(0)) - exponent(ST(1)) \rightarrow D
if D < 64 then begin
  Integer(TruncateTowardZero(ST(0) / ST(1))) \rightarrow Q
  ST(0) - (ST(1) * Q) \rightarrow ST(0)
  0 \rightarrow C2
  LeastSignificantBits(Q): Q2, Q1, Q0 \rightarrow C0, C3, C1
end
else begin
  1 \rightarrow C2
  an implementation-dependent number between 32 and 63 \rightarrow N
  Integer(TruncateTowardZero((ST(0) / ST(1)) / 2^{(D-N)})) \rightarrow QQ
  ST(0) - (ST(1) * QQ * 2^{(D-N)}) \rightarrow ST(0)
end;
if stack underflow occurred then 0 \rightarrow C1
```

#### D9 F5 FPREM1

```
exponent(ST(0)) - exponent(ST(1)) \rightarrow D
if D < 64 then begin
  Integer(RoundTowardNearestInteger(ST(0) / ST(1))) \rightarrow Q
  ST(0) - (ST(1) * Q) \rightarrow ST(0)
  0 \rightarrow C2
  LeastSignificantBits(Q): Q2, Q1, Q0 \rightarrow C0, C3, C1
end
else begin
  1 \rightarrow C2
  an implementation-dependent number between 32 and 63 \rightarrow N
  Integer(TruncateTowardZero((ST(0) / ST(1)) / 2^{(D-N)})) \rightarrow QQ
  ST(0) - (ST(1) * QQ * 2^{(D-N)}) \rightarrow ST(0)
end;
if stack underflow occurred then 0 \rightarrow C1
```

## FABS, FCHS, FSQRT

**FABS** 

(Absolute Value)

D9 E1

**FABS** 

$$|ST(0)| \rightarrow ST(0)$$

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$  C3, C2, C0 are not defined

**FCHS** 

(Change Sign)

D9 E0

**FCHS** 

$$-ST(0) \to ST(0)$$

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$  C3, C2, C0 are not defined

**FSQRT** 

(Square Root)

D9 FA

**FSQRT** 

$$\sqrt{ST(0)} \rightarrow ST(0)$$

if stack underflow occurred then  $0 \rightarrow C1$ else C1 indicates rounding direction

C3, C2, C0 are not defined

## FRNDINT, FSCALE, FXTRACT

**FRNDINT** 

(Round to Integer)

D9 FC FRNDINT

Integer(RoundTowardNearestInteger(ST(0)))  $\rightarrow$  ST(0)

if stack underflow occurred then  $0 \rightarrow C1$  else C1 indicates rounding direction

C3, C2, C0 are not defined

FSCALE

D9 FD FSCALE

$$ST(0) * 2^{ST(1)} \rightarrow ST(0)$$

if stack underflow occurred then  $0 \rightarrow C1$  else C1 indicates rounding direction C3, C2, C0 are not defined

(Scale)

#### **FXTRACT**

## (Extract Exponent and Significant)

D9 F4 FXTRACT

Significand(ST(0)) 
$$\rightarrow$$
 temp  
Exponent(ST(0))  $\rightarrow$  ST(0)  
top - 1  $\rightarrow$  top  
temp  $\rightarrow$  ST(0)

if stack underflow occurred then  $0 \rightarrow C1$  if stack overflow occurred then  $1 \rightarrow C1$  C3, C2, C0 are not defined

## Porovnávací instrukce

- FCOM
- FCOMP
- FCOMPP
- FICOM
- FICOMP
- FUCOM
- FUCOMP
- FUCOMPP
- FCOMI
- FCOMIP
- FUCOMI
- FUCOMIP
- FTST
- FXAM

# FCOM, FCOMP, FCOMPP

## FCOM/FCOMP/FCOMPP [src]

## (Compare Real)

| D8/2    | FCOM m32real  |              |
|---------|---------------|--------------|
| DC/2    | FCOM m64real  |              |
| D8 D0+i | FCOM ST(i)    |              |
| D8 D1   | FCOM          | src = ST(1)  |
| D8 /3   | FCOMP m32real |              |
| DC /3   | FCOMP m64real |              |
| D8 D8+i | FCOMP ST(i)   |              |
| D8 D9   | FCOMP         | src = ST(1)  |
| DE D9   | FCOMPP        | src = ST(1). |

### FCOM/FCOMP/FCOMPP [src]

#### Continuation

```
case (relation of operands) of
 ST(0) > src : 000 \rightarrow C3, C2, C0
 ST(0) < src : 001 \rightarrow C3, C2, C0
 ST(0) = scr : 100 \rightarrow C3, C2, C0
end
if (any operand is NaN or unsupported format) and (IM=1)
then 111 \rightarrow C3, C2, C0
                                         {IM ... viz řídící registr FPU}
if FCOMP or FCOMPP
                                  {if old top is 7 then new top will be 0}
then PopRegisterStack
if FCOMPP
                                  {if old top is 7 then new top will be 0}
then PopRegisterStack
```

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$ 

SW:

| 15 | 14         | 13 | 12  | 11 | - | 10 | 9  | 8  |
|----|------------|----|-----|----|---|----|----|----|
| В  | <b>C</b> 3 |    | TOI | )  |   | C2 | C1 | C0 |

FLAGS:

| 7  | 6  | 5 | 4  | 3 | 2  | 1 | 0  |
|----|----|---|----|---|----|---|----|
| SF | ZF | 0 | AF | 0 | PF | 1 | CF |

 $ST(0) > src : 000 \rightarrow C3, C2, C0$ 

 $ST(0) < src : 001 \rightarrow C3, C2, C0$  (CF)

 $ST(0) = scr : 100 \to C3, C2, C0$  (**ZF**)

unordered  $111 \rightarrow C3, C2, C0$  (ZF, **PF**, CF)

Skoky: JA, JB, JE a jejich negace a kombinace (přestože se v FPU porovnávají čísla se znaménky) !!!!

# FICOM, FICOMP

## FICOM/FICOMP [src]

(Compare Integer)

| DE /2 | FICOM m16int  |
|-------|---------------|
| DA /2 | FICOM m32int  |
| DE /3 | FICOMP m16int |
| DA /3 | FICOMP m32int |

#### FICOM/FICOMP [src]

#### Continuation

```
case (relation of operands) of ST(0) > src : 000 \rightarrow C3, C2, C0 ST(0) < src : 001 \rightarrow C3, C2, C0 ST(0) = scr : 100 \rightarrow C3, C2, C0 end if (any operand is NaN or unsupported format) and (IM=1) then 111 \rightarrow C3, C2, C0 {IM ... viz řídící registr FPU} if FICOMP then PopRegisterStack {if old top is 7 then new top will be 0}
```

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$ 

# FUCOM, FUCOMP, FUCOMPP

## FUCOM/FUCOMP/FUCOMPP [src]

(Unordered Compare Real)

DD E0+i FUCOM ST(i)

DD E1 FUCOM src = ST(1)

DD E8+i FUCOMP ST(i)

DD E9 FUCOMP src = ST(1)

DA E9 FUCOMPP src = ST(1)

Instrukce FUCOM/FUCOMP/FUCOMPP pracují stejně jako instrukce FCOM/FCOMP/FCOMPP; jediným rozdílem je, že je-li libovolným operandem tzv. Q-NaN (výklad přesahuje rámec předmětu) negenerují výjimku IE (neplatná operace, viz stavový registr FPU).

#### FUCOM/FUCOMP/FUCOMPP [src] Continuation

```
case (relation of operands) of
 ST(0) > src : 000 \rightarrow C3, C2, C0
 ST(0) < src : 001 \rightarrow C3, C2, C0
 ST(0) = scr : 100 \rightarrow C3, C2, C0
end
if (any operand is Q-NaN) or
((any operand is NaN or unsupported format) and (IM=1))
                                           {IM ... viz řídící registr FPU}
then 111 \rightarrow C3, C2, C0
if FUCOMP or FUCOMPP
then PopRegisterStack
                                {if old top is 7 then new top will be 0}
if FUCOMPP
then PopRegisterStack
                                {if old top is 7 then new top will be 0}
```

if stack underflow occurred then  $0 \rightarrow C1$ 

# FCOMI, FCOMIP, FUCOMI, FUCOMI

#### FCOMI/FCOMIP/FUCOMI/FUCOMIP ST(i)

(Compare Real and Set EFLAGS, Pentium® Pro)

DB F0+i FCOMI ST(i)

DF F0+i FCOMIP ST(i)

DB E8+i FUCOMI ST(i)

DF E8+i FUCOMIP ST(i)

Instrukce FCOMI/FCOMIP, resp. FUCOMI/FUCOMIP pracují stejně jako instrukce FCOM/FCOMP, resp. FUCOM/FUCOMP, místo podmínkového kódu ve stavovém registru FPU však nastavují přímo příznaky ZF, PF a CF v registru (E)FLAGS.

#### FCOMI/FCOMIP/FUCOMI/FUCOMIP ST(i)

(Continuation)

```
case (relation of operands) of
```

```
ST(0) > ST(i) : 000 \rightarrow ZF, PF, CF
```

$$ST(0) < ST(i) : 001 \rightarrow ZF, PF, CF$$

$$ST(0) = ST(i): 100 \rightarrow ZF, PF, CF$$

unordered :  $111 \rightarrow ZF$ , PF, CF

#### end

if FCOMIP or FUCOMIP then PopRegisterStack

{if old top is 7 then new top will be 0}

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$ 

# FTST

FTST (Test)

D9 E4 FTST

case (relation of operands) of

 $ST(0) > 0.0: 000 \rightarrow C3, C2, C0$ 

 $ST(0) < 0.0: 001 \rightarrow C3, C2, C0$ 

 $ST(0) = 0.0: 100 \rightarrow C3, C2, C0$ 

unordered :  $111 \rightarrow C3, C2, C0$ 

end

if stack underflow occurred then  $0 \rightarrow C1$  else  $0 \rightarrow C1$ 

# **FXAM**

FXAM (Examine)

D9 E5 FXAM

Sign bit of  $ST(0) \rightarrow C1$ 

case (class of value or number in ST(0)) of

Unsupported:  $000 \rightarrow C3$ , C2, C0

NaN:  $001 \rightarrow C3, C2, C0$ 

Normal:  $010 \rightarrow C3$ , C2, C0

Infinity:  $011 \rightarrow C3, C2, C0$ 

Zero:  $100 \rightarrow C3, C2, C0$ 

Empty:  $101 \rightarrow C3, C2, C0$ 

Denormal:  $110 \rightarrow C3, C2, C0$ 

end

#### Real Number and NaN Encodings

| Class    |                                               | Sign | Biased Exponent                          | Significand          |                   |  |  |  |
|----------|-----------------------------------------------|------|------------------------------------------|----------------------|-------------------|--|--|--|
|          |                                               |      |                                          | Integer <sup>1</sup> | Fraction          |  |  |  |
| Positive | +00                                           | 0    | 1111                                     | 1                    | 0000              |  |  |  |
|          | +Normals                                      | 0    | 1110                                     | 1                    | 1111              |  |  |  |
|          |                                               |      |                                          |                      | -                 |  |  |  |
|          |                                               | Ó    | 0001                                     | i                    | 0000              |  |  |  |
|          | +Denormals                                    | 0    | 0000                                     | 0                    | 11.11             |  |  |  |
|          |                                               |      |                                          |                      |                   |  |  |  |
|          |                                               | Ô    | 0000                                     | 0                    | 0001              |  |  |  |
|          | +Zero                                         | 0    | 0000                                     | 0                    | 0000              |  |  |  |
| Negative | -Zero                                         | 1    | 0000                                     | 0                    | 0000              |  |  |  |
|          | -Denormals                                    | 1    | 0000                                     | 0                    | 0001              |  |  |  |
|          |                                               |      |                                          |                      |                   |  |  |  |
|          |                                               | 1    | 0000                                     | 0                    | 1111              |  |  |  |
|          | -Normals                                      | 1    | 0001                                     | 1                    | 0000              |  |  |  |
|          |                                               |      |                                          |                      |                   |  |  |  |
|          |                                               | 1    | 1110                                     | 1                    | 1111              |  |  |  |
|          | -00                                           | 1    | 1111                                     | 1                    | 0000              |  |  |  |
| NaNs     | SNaN                                          | Х    | 1111                                     | 1                    | 0XXX <sup>2</sup> |  |  |  |
|          | QNaN                                          | Х    | 1111                                     | 1                    | 1XXX              |  |  |  |
|          | Real Indefinite<br>(QNaN)                     | 1    | 1111                                     | 1                    | 1000              |  |  |  |
|          | Single-Real:<br>Double-Real:<br>Extended-Real |      | ← 8 Bits →<br>← 11 Bits →<br>← 15 Bits → |                      |                   |  |  |  |

- 1. Integer bit is implied and not stored for single-real and double-real formats.
- 2. The fraction for SNaN encodings must be non-zero.

## Unsupported formats:

| Class          |                  | Sign   | Biased Exponent | Significand |             |
|----------------|------------------|--------|-----------------|-------------|-------------|
|                |                  |        |                 | Integer     | Fraction    |
| Positive       | Outet            | 0      | 1111            | 0           | 1111        |
| Pseudo-NaNs    | Quiet            | ò      | 1111            |             | 1000        |
|                | Oili             | 0      | 1111            | 0           | 0111        |
|                | Signaling        | ò      | 1111            |             | 0001        |
| Positive Reals | Pseudo-infinity  | 0      | 1111            | 0           | 0000        |
|                | l lan annuala    | 0      | 1110            | 0           | 1111        |
|                | Unnormals        | ò      | 0001            |             | 0000        |
|                | Pseudo-denormals | 0      | 0000            | 1           | 1111        |
|                |                  | ò      | 0000            |             | 0000        |
| Negative Reals | Pseudo-denormals | 1      | 0000            | 1           | 1111        |
|                |                  | i      | 0000            |             | 0000        |
|                | Unnormals        | 1      | 1110            | 0           | 1101        |
|                |                  | i      | 0001            |             | 0000        |
|                | Pseudo-infinity  | 1      | 1111            | 0           | 0000        |
| Negative       | Signaling        | 1      | 1111            | 0           | 0111        |
| Pseudo-NaNs    |                  | i      | 1111            |             | 0001        |
|                |                  | 1      | 1111            | 0           | 1111        |
|                | Quiet            | i<br>1 | 1111            |             | 1000        |
|                |                  |        | ← 15 bits →     |             | ← 63 bits → |

## Transcendentní instrukce

- FSIN
- FCOS
- FSINCOS
- FPTAN
- FPATAN
- F2XM1
- FYL2X
- FYL2XP1

# FSIN, FCOS, FSICOS, FPTAN, FPATAN

FSIN (Sine)

D9 FE FSIN

```
if |ST(0)| < 2^{63} then begin

0 \to C2

\sin(ST(0)) \to ST(0)

end

else 1 \to C2 {source operand is out of range}
```

if stack underflow occurred then 0 → C1 else C1 indicates rounding direction C3, C0 are not defined FCOS (Cosine)

D9 FF

**FCOS** 

```
if |ST(0)| < 2^{63} then begin

0 \to C2

\cos(ST(0)) \to ST(0)

end

else 1 \to C2 {source operand is out of range}
```

if stack underflow occurred then 0 → C1 else C1 indicates rounding direction C3, C0 are not defined

```
FSINCOS
```

(Sine and Cosine)

D9 FB

**FSINCOS** 

```
if |ST(0)| < 2^{63} then begin
 0 \rightarrow C2
  \cos(ST(0)) \rightarrow temp
  \sin(ST(0)) \rightarrow ST(0)
  top - 1 \rightarrow top
  temp \rightarrow ST(0)
end
else 1 \rightarrow C2
                          {source operand is out of range}
if stack underflow occurred then 0 \rightarrow C1
if stack overflow occurred then 1 \rightarrow C1
if stack is OK then C1 indicates rounding direction
C3, C0 are not defined
```

```
FPTAN
```

(Partial Tangent)

D9 F2

**FPTAN** 

```
if |ST(0)| < 2^{63} then begin

0 \to C2

\tan(ST(0)) \to ST(0)

top - 1 \to top

1.0 \to ST(0)

end

else 1 \to C2 {source operand is out of range}
```

if stack underflow occurred then  $0 \rightarrow C1$ if stack overflow occurred then  $1 \rightarrow C1$ if stack is OK then C1 indicates rounding direction C3, C0 are not defined

#### **FPATAN**

(Partial Arctangent)

D9 F3

**FPATAN** 

 $arctan(ST(1) / ST(0)) \rightarrow ST(1)$ PopRegisterStack

if stack underflow occurred then 0 → C1 else C1 indicates rounding direction C3, C0 are not defined

Pozn.: Hodnoty operandů pro dřívější koprocesory (do 80287) byly omezeny podmínkou

$$0 \le |ST(1)| < |ST(0)| < +\infty$$

# F2XM1, FYL2X, FYL2XP1

F2XM1

(Compute  $2^x - 1$ )

D9 F0

F2XM1

{musí být splněna výchozí podmínka:  $-1 \le ST(0) \le 1$ }

$$(2^{ST(0)} - 1) \rightarrow ST(0)$$

if stack underflow occurred then 0 → C1 else C1 indicates rounding direction C3, C0 are not defined FYL2X

(Compute  $y * log_2 x$ )

D9 F0

FYL2X

{musí být splněna výchozí podmínka: ST(0) > 0}

 $ST(1) * log_2ST(0) \rightarrow ST(1)$ PopRegisterStack

if stack underflow occurred then  $0 \rightarrow C1$  else C1 indicates rounding direction C3, C0 are not defined

FYL2XP1

(Compute  $y * log_2(x+1)$ )

D9 F9

FYL2XP1

{musí být splněna výchozí podmínka: 
$$-\left(1-\frac{\sqrt{2}}{2}\right) \le ST(0) \le \left(1-\frac{\sqrt{2}}{2}\right)$$
}

 $ST(1) * log_2(ST(0) + 1) \rightarrow ST(1)$ PopRegisterStack

if stack underflow occurred then  $0 \rightarrow C1$  else C1 indicates rounding direction C3, C0 are not defined

# <u>**Řídící instrukce**</u>

- FINIT/FNINIT
- FCLEX/FNCLEX
- FSTCW/FNSTCW
- FLDCW
- FSTSW/FNSTSW
- FSTENV/FNSTENV
- FLDENV
- FSAVE/FNSAVE
- FRSTOR
- FINCSTP
- FDECSTP
- FFREE
- FWAIT/WAIT
- FNOP

# FINIT, FNINIT

#### FINIT/FNINIT

(Initialize FPU)

9B DB E3 FINIT

DB E3 FNINIT

 $037FH \rightarrow FPU ControlWord$ 

 $0 \longrightarrow FPU StatusWord$ 

 $FFFFH \rightarrow FPU TagWord$ 

- $0 \rightarrow FPU DataPointer$
- $0 \rightarrow FPU$  InstructionPointer
- $0 \rightarrow FPU LastInstructionOpcode$
- $0 \rightarrow C3, C2, C1, C0$

Instrukce FINIT čeká na zpracování všech čekajících FPU výjimek.

037FH → FPU ControlWord

| 15 | 1 4 | 13 | 1 2 | 11               | 10 | 9 | 8 | 7 | 6 | 5   | 4   | 3   | 2   | 1   | 0  |
|----|-----|----|-----|------------------|----|---|---|---|---|-----|-----|-----|-----|-----|----|
|    |     |    | IC  | R                | С  | P | C |   |   | P M | U M | O M | Z M | D M | IM |
| 0  | 0   | 0  | 0   | $\overline{  0}$ | 0  | 1 | 1 | 0 | 1 | 1   | 1   | 1   | 1   | 1   | 1  |

RC = 0 zaokrouhlování k nejbližšímu číslu

PC = 3 64 bitová přesnost mantisy

# FCLEX, FNCLEX

#### FCLEX/FNCLEX

(Clear Exceptions)

9B DB E2 FCLEX

DB E2 FNCLEX

 $0 \rightarrow \text{FPUStatusWord}[7..0]$ 

 $0 \rightarrow \text{FPUS} \text{tatusWord}[15]$ 

C3, C2, C1, C0 are not defined

Instrukce FCLEX čeká na zpracování všech čekajících FPU výjimek.

# FSTCW, FNSTCW

#### FSTCW/FNSTCW dest

(Store Control Word)

9B D9 /7

FSTCW m16

D9 /7

FNSTCW m16

 $FPUControlWord \rightarrow dest$ 

C3, C2, C1, C0 are not defined

Instrukce FSTCW čeká na zpracování všech čekajících FPU výjimek.

## **FLDCW**

FLDCW src

(Load Control Word)

D9 /5

FLDCW m16

 $src \rightarrow FPUControlWord$ 

C3, C2, C1, C0 are not defined

# FSTSW, FNSTSW

FSTSW/FNSTSW dest

(Store Status Word)

9B DD /7 FSTSW m16

9B DF E0 FSTSW AX

DD /7 FNSTSW m16

DF E0 FNSTSW AX

 $FPUStatusWord \rightarrow dest$ 

C3, C2, C1, C0 are not defined

Instrukce FSTSW čeká na zpracování všech čekajících FPU výjimek.

# FSTENV, FNSTENV

#### FSTENV/FNSTENV dest (Store FPU Environment)

9B D9 /6 FSTENV m14/28byte

D9 /6 FNSTENV m14/28byte

FPU\_Environment → dest

C3, C2, C1, C0 are not defined

Instrukce FSTENV čeká na zpracování všech čekajících FPU výjimek.

#### FPU environment:

| 31 16   |                   |     |                         | 0                     |         |         |
|---------|-------------------|-----|-------------------------|-----------------------|---------|---------|
| 0 0 0 0 | OPER. POINTER 31. | 16  | 0                       | 0 0 0 0 0 0 0 0 0 0 0 | +12 +13 | +24 +27 |
|         | RESERVED          | OP  | ER                      | AND POINTER 150       | +10 +11 | +20 +23 |
| 0 0 0 0 | INSTR. POINTER 31 | 16  | 0                       | OPCODE 100            | +8 +9   | +16 +19 |
|         | RESERVED          | INS | INSTRUCTION POINTER 150 |                       |         | +12 +15 |
|         | RESERVED          |     |                         | TAG WORD              | +4 +5   | +8 +11  |
|         |                   | S   | TATUS WORD              | +2 +3                 | +4 +7   |         |
|         | RESERVED          |     | C                       | ONTROL WORD           | 0 +1    | 0 +3    |
|         |                   |     |                         |                       |         |         |

### **FLDENV**

#### FLDENV src

### (Load FPU Environment)

D9 /4

#### FLDENV m14/28byte

#### $src \rightarrow FPU\_Environment$

| 31       |                         | 16 | 15 |         | 0                     |         |         |
|----------|-------------------------|----|----|---------|-----------------------|---------|---------|
| 0 0 0 0  | OPER. POINTER           | 31 | 16 | 0       | 0 0 0 0 0 0 0 0 0 0 0 | +12 +13 | +24 +27 |
|          | OPERAND POINTER 150     |    |    | +10 +11 | +20 +23               |         |         |
| 0 0 0 0  | INSTR. POINTER          | 31 | 16 | 0       | OPCODE 100            | +8 +9   | +16 +19 |
|          | INSTRUCTION POINTER 150 |    |    | +6 +7   | +12 +15               |         |         |
|          | TAG WORD                |    |    | +4 +5   | +8 +11                |         |         |
| RESERVED |                         |    |    | S       | TATUS WORD            | +2 +3   | +4 +7   |
| RESERVED |                         |    |    | C       | ONTROL WORD           | 0 +1    | 0 +3    |

# FSAVE, FNSAVE

#### FSAVE/FNSAVE dest

(Store FPU State)

9B DD /6 FSAVE m94/108byte

DD /6 FNSAVE m94/108byte

 $FPU\_State \rightarrow dest$ 

Initialize FPU { see FINIT }

Instrukce FSAVE čeká na zpracování všech čekajících FPU výjimek.

#### FPU State:

15 0

|             | _       |          |
|-------------|---------|----------|
| ST(7)       | +84 +93 | +98 +107 |
| ST(6)       | +74 +83 | +88 +97  |
| ST(5)       | +64 +73 | +78 +87  |
| ST(4)       | +54 +63 | +68 +77  |
| ST(3)       | +44 +53 | +58 +67  |
| ST(2)       | +34 +43 | +48 +57  |
| ST(1)       | +24 +33 | +38 +47  |
| ST(0)       | +14 +23 | +28 +37  |
| Environment | 0 +13   | 0 +27    |

### **FRSTOR**

FRSTOR src

(Restore FPU State)

DD/4

FRSTOR m94/108byte

 $src \rightarrow FPU\_State$ 

## FINCSTP, FDECSTP, FFREE

D9 F7

**FINCSTP** 

if top = 7 then  $0 \rightarrow top$  else  $top + 1 \rightarrow top$ 

 $0 \rightarrow C1$ ,

C3, C2, C0 are not defined

#### **FDECSTP**

### (Decrement Stack-Top Pointer)

D9 F6

**FDECSTP** 

if top = 0 then  $7 \rightarrow top$  else  $top - 1 \rightarrow top$ 

 $0 \rightarrow C1$ ,

C3, C2, C0 are not defined

#### **FFREE**

### (Free Floating Point Register)

DD CO +i

FFREE ST(i)

 $11 \rightarrow TAG(i)$ 

C3, C2, C1, C0 are not defined

### FWAIT/WAIT

FWAIT/WAIT

(Wait for FPU)

**B9** 

FWAIT/WAIT

C3, C2, C1, C0 are not defined

Slouží k synchronizaci práce procesoru a koprocesoru (FPU). Asembler ji vkládá automaticky na potřebná místa.

## **FNOP**

**FNOP** 

(No Operation)

D9 DO

**FNOP** 

C3, C2, C1, C0 are not defined