October 12, 1997

## Compare and Test

- test and compare <u>synthetic</u> instructions set condition codes
- to test a single value

orcc reg, %g0, %g0

compare two values

cmp

cmp src, value subcc src, value, %g0 subcc ,%g0

using %g0 as a destination discards the result

Copyright @1995 D. Hanson, K. Li & J.P. Singh

Computer Science 217: Compare and Test

Page 155

### Condition Codes

processor state register (psr)

| +   | 5 | 6  | 7 | 11 | 12 | 13 | 19 | 23  | 27  | 31   |
|-----|---|----|---|----|----|----|----|-----|-----|------|
| CWP | E | SP | S |    | F  | EC |    | icc | ver | impl |
|     |   |    |   |    |    |    |    |     |     |      |

integer condition codes — the icc field — holds 4 bits



- set if the last ALU result was <u>negative</u> set if the last ALU result was <u>zero</u>
- 0 < N > set if the last ALU result overflowed
- set if the last ALU instruction that modified *icc* caused a *c*arry out of, or a borrow into, bit 31
- cc versions of the integer arithmetic instructions set all the codes
- cc versions of the logical instructions set only N and Z
- tests on the condition codes implement conditionals and loops
- carry and overflow are used to implement multiple-precision arithmetic
- see page 28 in the SPARC Architecture Manual, §4.8 in Paul

Copyright ©1995 D. Hanson, K. Li & J.P. Singh Computer Science 217: Condition Codes

**Branches** 

October 12, 1997

branch instructions transfer control based on icc

branches are format 2 instructions

| 31 | 00     |  |
|----|--------|--|
| 29 | а      |  |
| 28 | cond   |  |
| 24 | 010    |  |
| 21 | disp22 |  |

- target is a <u>PC-relative</u> address and is address of the branch instruction
  - , where is the

unconditional branches

branch condition branch always branch never synthetic synonym dou duic

Copyright ©1995 D. Hanson, K. Li & J.P. Singh

Computer Science 217: Branches

Page 157

October 12, 1997

# Carry and Overflow

if the carry bit (c) is set

the last addition resulted in a carry

or the last subtraction resulted in a borrow

carry is needed to implement arithmetic using numbers represented in several words, e.g. multiple-precision addition

addxcc %g2,%g4,%g6 addcc %g3,%g5,%g7

(%g6, %g7) = (%g2, %g3) + (%g4, %g5)

the *most-significant word* is in the *even* register; the *least-significant word* is in the *odd* register

 $\bullet$  overflow (v) indicates that the result of signed addition or subtraction doesn't fit

Page 154 Copyright ©1995 D. Hanson, K. Li & J.P. Singh Computer Science 217: Carry and Overflow Page 156

### **Control Transfer**

- normally, instructions are fetched and executed from sequential memory locations
- program counter, *PC*, is address of the current instruction, and the program counter, *nPC*, is address of the next instruction:
- branches, control-transfer instructions change nPC to something else
- control-transfer instructions

| instruction                                    | type                                            | addressing mode                                |
|------------------------------------------------|-------------------------------------------------|------------------------------------------------|
| b <i>icc</i><br>fb <i>fcc</i><br>cb <i>ccc</i> | conditional branches floating point coprocessor | PC-relative<br>PC-relative<br>PC-relative      |
| jmpl<br>rett                                   | jump and link<br>return from trap               | register indirect register indirect            |
| call<br>t <i>icc</i>                           | procedure call traps                            | <b>PC</b> -relative register-indirect vectored |
|                                                |                                                 |                                                |

 PC-relative addressing is like register displacement addressing that uses PC as the base register

Copyright © 1995 D. Hanson, K. Li. & J.P. Singh Computer Science 2.17; Control Transfer

October 12, 1997

Page 159

## Branches, cont'd

raw condition-code branches

| bvs | bvc | bcs | ხсс  | bneg | sodq | дz | bnz | branch    |           |
|-----|-----|-----|------|------|------|----|-----|-----------|-----------|
| <   | ï   | C   | i.   | >    | Ž    | Z  | i Z | condition |           |
|     |     | blu | bgeu |      |      |    |     | synonym   | synthetic |

comparisons

| bl blu | ble bleu                                | be<br>bne | branches             |
|--------|-----------------------------------------|-----------|----------------------|
| × × ×  | Z   (N^V)                               | Z Z Z     | signed               |
| o i    | 2 C C C C C C C C C C C C C C C C C C C | -         | unsigned             |
|        |                                         | bz        | synthetic<br>synonym |

Copyright ©1995 D. Hanson, K. Li & J.P. Singh

Computer Science 217: Branches, cont'd

Page 158

# **Branching Examples**

### if-then-else

if (a > b) c = a; else c = b;

#### becomes

#define a %10 #define b %11 #define c %13

cmp a,b
ble Il; nop
mov a,c
ba Il; nop
Ll: mov b,c
Ll: mov b,c

Copyright ©1995 D. Hanson, K. Li & J.P. Singh

Computer Science 217: Branching Examples

examples

Page 161

# Control Transfer, cont'd

### branches

 00
 | a |
 cond
 |
 010
 |
 disp22

 1
 29
 28
 24
 21

jumping to an arbitrary location may require two branches, but branches are used to build conditionals and loops in "small" code blocks

#### calls

is multiplied by 4 because all instructions are word aligned

 position-independent code is code whose correct execution does not depend on where it is loaded, i.e., all instructions use PC-relative addressing

Copyright © 1995 D. Hanson, K. Li & J.P. Singh Computer Science 217: Control Transfer cont'd Page 160