# **CS61C - Machine Structures**

Lecture 10 - Floating Point, Part II and Miscellaneous

> September 29, 2000 David Patterson

http://www-inst.eecs.berkeley.edu/~cs61c/

### Review

<sup>°</sup>Floating Point numbers approximate values that we want to use.

- <sup>o</sup> IEEE 754 Floating Point Standard is most widely accepted attempt to standardize interpretation of such numbers (\$1T)
- °New MIPS registers(\$f0-\$f31), instruct.:
- Single Precision (32 bits, 2x10<sup>-38</sup>... 2x10<sup>38</sup>): add.s, sub.s, mul.s, div.s
- Double Precision (64 bits, 2x10<sup>-308</sup>...2x10<sup>308</sup>): add.d, sub.d, mul.d, div.d

<sup>°</sup>Type is not associated with data, bits have no meaning unless given in context

### **Overview**

- <sup>o</sup> Special Floating Point Numbers: NaN, Denorms
- ° IEEE Rounding modes
- <sup>o</sup> Floating Point fallacies, hacks
- ° Catchup topics:
  - · Representation of jump, jump and link
  - Reverse time travel:
  - MIPS machine language -> MIPS assembly language
  - -> C code
  - l spinel, shift instructions (time r
  - Logical, shift instructions (time permiting)

# MIPS Floating Point Architecture (1/2)

- ° 1990 Solution: Make a completely separate chip that handles only FP.
- <sup>o</sup>Coprocessor 1: FP chip
  - contains 32 32-bit registers: \$f0, \$f1, ...
    most registers specified in .s and .d
  - instruction refer to this set
  - separate load and store: lwc1 and swc1
    ("load word coprocessor 1", "store ...")
  - Double Precision: by convention, even/odd pair contain one DP FP number: \$f0/\$f1, \$f2/\$f3,..., \$f30/\$f31

S61C L10 Fl. Pt. © UC Regen



<sup>o</sup> Appendix pages A-70 to A-74 contain many, many more FP operations.



CS61C L10 Fl. Pt. © UC Reger



| Special Numl<br>° What have v<br>(Single Pred | bers (cont'd)<br>we defined so<br>cision)? | far?          | _ |
|-----------------------------------------------|--------------------------------------------|---------------|---|
| Exponent                                      | Significand                                | Object        |   |
| 0                                             | 0                                          | 0             |   |
| 0                                             | <u>nonzero</u>                             | <u>???</u>    |   |
| 1-254                                         | anything                                   | +/- fl. pt. # |   |
| 255                                           | 0                                          | +/- infinity  |   |
| 255                                           | nonzero                                    | NaN           |   |
|                                               |                                            |               |   |
| CS61C L10 Fl. Pt. © UC Regents                |                                            |               | 8 |









## Round to Even

<sup>o</sup> Round like you learned in grade school

<sup>°</sup> Except if the value is right on the borderline, in which case we round to the nearest EVEN number

•2.5 -> 2

•3.5 -> 4

° Insures fairness on calculation

• This way, half the time we round up on tie, the other half time we round down

Ask statistics majors

° Default C rounding mode; only Java mode























| Decoding Example (4/6)                                                                                                                                                         |                                      |                                                                                  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------|--|--|
| ° MIPS Assembly (Part 1):                                                                                                                                                      |                                      |                                                                                  |  |  |
| $\begin{array}{c} 0 \times 004 \ 00000 \\ 0 \times 004 \ 00004 \\ 0 \times 004 \ 00008 \\ 0 \times 004 \ 0000 \ 0 \\ 0 \times 004 \ 00010 \\ 0 \times 004 \ 00014 \end{array}$ | or<br>slt<br>beq<br>add<br>addi<br>j | \$2,\$0,\$0<br>\$8,\$0,\$5<br>\$8,\$0,3<br>\$2,\$2,\$4<br>\$5,\$5,-1<br>0x100001 |  |  |
| <ul> <li>Next step: translate to more meaningful instructions (fix the branch/jump and add labels)</li> <li>Remember: jump address add 00 to end</li> </ul>                    |                                      |                                                                                  |  |  |

| Decoding Example (5/6)                                     |                         |                                                                                 |    |  |
|------------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------|----|--|
| ° MIPS Assembly (Part 2):                                  |                         |                                                                                 |    |  |
| Loop :                                                     | or<br>slt<br>beq<br>add | \$v0,\$0,\$0<br>\$t0,\$0,\$a1<br>\$t0,\$0,Fin<br>\$v0,\$v0,\$a0<br>\$a1 \$a1 =1 |    |  |
| Fin:                                                       | j                       | Loop                                                                            |    |  |
| <sup>o</sup> Next step: translate to C code (be creative!) |                         |                                                                                 |    |  |
| CS61C L10 Fl. Pt. © UC Regents                             |                         |                                                                                 | 29 |  |







# <section-header><section-header><list-item><list-item><list-item><list-item><list-item></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row></table-row>

| Logical Operators (2/4)<br>° Truth Table: standard table listing all<br>possible combinations of inputs and<br>resultant output for each |                |         |         |          |    |
|------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|---------|----------|----|
| °T                                                                                                                                       | ruth 1         | Table   | for ANI | ) and OR |    |
|                                                                                                                                          | A              | В       | AND     | OR       |    |
|                                                                                                                                          | 0              | 0       | 0       | 0        |    |
|                                                                                                                                          | 0              | 1       | 0       | 1        |    |
|                                                                                                                                          | 1              | 0       | 0       | 1        |    |
|                                                                                                                                          | 1              | 1       | 1       | 1        |    |
|                                                                                                                                          |                |         |         |          |    |
| CS61C L1                                                                                                                                 | 0 Fl. Pt. © UC | Regents |         |          | 34 |

| Logical Operators (3/4)                                           |
|-------------------------------------------------------------------|
| °Logical Instruction Syntax:                                      |
| 1 2,3,4                                                           |
| • where                                                           |
| 1) operation name                                                 |
| 2) register that will receive value                               |
| 3) first operand (register)                                       |
| 4) second operand (register) or<br>immediate (numerical constant) |
|                                                                   |
|                                                                   |
|                                                                   |















CS61C L10 Fl. Pt. © UC Regent

41













| Things to Remember (3/3)         |  |  |  |
|----------------------------------|--|--|--|
| ° New Instructions:              |  |  |  |
| and, andi, or, ori               |  |  |  |
| sll, srl, sra                    |  |  |  |
|                                  |  |  |  |
|                                  |  |  |  |
|                                  |  |  |  |
|                                  |  |  |  |
|                                  |  |  |  |
| S61C L10 Fi. Pt. © UC Regents 51 |  |  |  |