

## **Chapter 6**

### **Flow Control in Assembly**

Zonghua Gu

Fall 2025

# Three Control Structures

---

## ▶ Sequence Structure

- ▶ Computer executes statements (instructions), one after another, in the order listed in the program



Sequence Structure

# Three Control Structures

- ▶ Selection Structure
  - ▶ If-then-else
- ▶ Loop Structure
  - ▶ while loop
  - ▶ for loop



Sequence Structure



Selection Structure



Loop Structure

# Review: Condition Flags



- ▶ **Negative** bit
  - ▶ N = 1 if most significant bit of result is 1
- ▶ **Zero** bit
  - ▶ Z = 1 if all bits of result are 0
- ▶ **Carry** bit
  - ▶ For unsigned addition, C = 1 if carry takes place
  - ▶ For unsigned subtraction, C = 0 (carry = not borrow) if borrow takes place
  - ▶ For shift/rotation, C = last bit shifted out
- ▶ **oVerflow** bit
  - ▶ V = 1 if adding 2 same-signed numbers produces a result with the opposite sign
    - ▶ Positive + Positive = Negative, or
    - ▶ Negative + negative = Positive
  - ▶ Non-arithmetic operations does not touch V bit, such as MOV, AND, LSL, MUL

# Updating Condition Flags

---

- ▶ Method 1: append with “**S**”
  - ▶ ADD r0,r1,r2 → ADDS r0,r1,r2
  - ▶ SUB r0,r1,r2 → SUBS r0,r1,r2
- ▶ Method 2: using compare instructions

| Instruction | Brief description | Flags   |
|-------------|-------------------|---------|
| <b>CMP</b>  | Compare           | N,Z,C,V |
| <b>CMN</b>  | Compare Negative  | N,Z,C,V |
| <b>TEQ</b>  | Test Equivalence  | N,Z,C   |
| <b>TST</b>  | Test              | N,Z,C   |

# Updating Condition Flags

| Instruction | Operands | Brief description | Flags   |
|-------------|----------|-------------------|---------|
| <b>CMP</b>  | Rn, Op2  | Compare           | N,Z,C,V |
| <b>CMN</b>  | Rn, Op2  | Compare Negative  | N,Z,C,V |
| <b>TEQ</b>  | Rn, Op2  | Test Equivalence  | N,Z,C   |
| <b>TST</b>  | Rn, Op2  | Test              | N,Z,C   |

## ➤ Update the status flags

- No need to add S bit.
- No need to specify destination register.

## ➤ Operations are:

- **CMP** operand1 - operand2, but result not written
- **CMN** operand1 + operand2, but result not written
- **TST** operand1 & operand2, but result not written
- **TEQ** operand1 ^ operand2, but result not written

## ➤ Examples:

- **CMP** r0, r1
- **TST** r2, #5

# Updating Condition Flags: CMP and CMN

---

**CMP Rn, Operand2**

**CMN Rn, Operand2**

- ▶ Update N, Z, C and V according to the result
- ▶ **CMP** **subtracts** Operand2 from Rn.
  - ▶ Same as SUBS, except result is discarded.
- ▶ **CMN** **adds** Operand2 to Rn.
  - ▶ Same as ADDS, except result is discarded.

# Example of CMP

$$f(x) = |x|$$

```
Area absolute, CODE, READONLY
EXPORT __main
ENTRY

__main PROC
    CMP    r1, #0
    RSBLT r0, r1, #0

    done    B done      ; deadloop

    ENDP
END
```

Assume register  
r1 holds x's value.

Note: RSB = Reverse Subtract

# Updating Condition Flags: TST and TEQ

---

**TST Rn, Operand2 ; Bitwise AND**

**TEQ Rn, Operand2 ; Bitwise Exclusive OR**

- ▶ Update N and Z according to the result
- ▶ Can update C during the calculation of Operand2
- ▶ Do not affect V
- ▶ TST performs **bitwise AND** on Rn and Operand2.
  - ▶ Same as ANDS, except result is discarded.
- ▶ TEQ performs **bitwise Exclusive OR** on Rn and Operand2.
  - ▶ Same as EORS, except result is discarded.

# Unconditional Branch Instructions

---

| Instruction | Operands | Brief description         |
|-------------|----------|---------------------------|
| <b>B</b>    | label    | Branch                    |
| <b>BL</b>   | label    | Branch with Link          |
| <b>BLX</b>  | Rm       | Branch indirect with Link |
| <b>BX</b>   | Rm       | Branch indirect           |

- ▶ *B label*
  - ▶ cause a branch to label.
- ▶ *BL label*
  - ▶ copy the address of the next instruction into r14 (lr, the link register), and
  - ▶ cause a branch to label.
- ▶ *BX Rm*
  - ▶ branch to the address held in Rm
- ▶ *BLX Rm:*
  - ▶ copy the address of the next instruction into r14 (lr, the link register) and
  - ▶ branch to the address held in Rm

# Unconditional Branch Instructions: A Simple Example

---

```
MOVS r1, #1
B    target ; Branch to target
MOVS r2, #2 ; Not executed
MOVS r3, #3 ; Not executed
MOVS r4, #4 ; Not executed
target MOVS r5, #5
```

- ▶ A **label** marks the location of an instruction
- ▶ Labels helps human to read the code
- ▶ In machine program, labels are converted to numeric offsets by assembler

# Condition Codes

---

| Suffix | Description               |
|--------|---------------------------|
| EQ     | EQual                     |
| NE     | Not EQual                 |
| CS/HS  | Unsigned HIGher or SAmee  |
| CC/LO  | Unsigned LOwer            |
| MI     | MInus (Negative)          |
| PL     | PLus (Positive or Zero)   |
| VS     | oVerflow Set              |
| VC     | oVerflow Clear            |
| HI     | Unsigned HIGher           |
| LS     | Unsigned LOwer or SAmee   |
| GE     | Signed GReater or EQual   |
| LT     | Signed LEss Than          |
| GT     | Signed GReater Than       |
| LE     | Signed LEss than or EQual |
| AL     | ALways                    |

*Note AL is the default and does not need to be specified*

# Signed vs. Unsigned Comparison

Conditional codes applied to  
branch instructions

| Compare | Signed | Unsigned |
|---------|--------|----------|
| >       | GT     | HI       |
| ≥       | GE     | HS       |
| <       | LT     | LO       |
| ≤       | LE     | LS       |
| ==      | EQ     |          |
| ≠       | NE     |          |



| Compare | Signed | Unsigned |
|---------|--------|----------|
| >       | BGT    | BHI      |
| ≥       | BGE    | BHS      |
| <       | BLT    | BLO      |
| ≤       | BLE    | BLS      |
| ==      | BEQ    |          |
| ≠       | BNE    |          |

# Branch Instructions

|                             | Instruction          | Description                                         | Flags tested             |
|-----------------------------|----------------------|-----------------------------------------------------|--------------------------|
| <b>Unconditional Branch</b> | <b>B Label</b>       | Branch to label                                     |                          |
| <b>Conditional Branch</b>   | <b>BEQ Label</b>     | Branch if <b>E</b> Qual                             | <b>Z = 1</b>             |
|                             | <b>BNE Label</b>     | Branch if <b>N</b> ot <b>E</b> qual                 | <b>Z = 0</b>             |
|                             | <b>BCS/BHS Label</b> | Branch if unsigned <b>H</b> igher or <b>S</b> ame   | <b>C = 1</b>             |
|                             | <b>BCC/BLO Label</b> | Branch if unsigned <b>L</b> ower                    | <b>C = 0</b>             |
|                             | <b>BMI Label</b>     | Branch if <b>M</b> inus (Negative)                  | <b>N = 1</b>             |
|                             | <b>BPL Label</b>     | Branch if <b>P</b> lus (Positive or Zero)           | <b>N = 0</b>             |
|                             | <b>BVS Label</b>     | Branch if o <b>V</b> erflow <b>S</b> et             | <b>V = 1</b>             |
|                             | <b>BVC Label</b>     | Branch if o <b>V</b> erflow <b>C</b> lear           | <b>V = 0</b>             |
|                             | <b>BHI Label</b>     | Branch if unsigned <b>H</b> igher                   | <b>C = 1 &amp; Z = 0</b> |
|                             | <b>BLS Label</b>     | Branch if unsigned <b>L</b> ower or <b>S</b> ame    | <b>C = 0 or Z = 1</b>    |
|                             | <b>BGE Label</b>     | Branch if signed <b>G</b> reater or <b>E</b> qual   | <b>N = V</b>             |
|                             | <b>BLT Label</b>     | Branch if signed <b>L</b> ess <b>T</b> han          | <b>N != V</b>            |
|                             | <b>BGT Label</b>     | Branch if signed <b>G</b> reater <b>T</b> han       | <b>Z = 0 &amp; N = V</b> |
|                             | <b>BLE Label</b>     | Branch if signed <b>L</b> ess than or <b>E</b> qual | <b>Z = 1 or N = !V</b>   |

# Condition Codes

---

| Suffix | Description               | Flags tested |
|--------|---------------------------|--------------|
| EQ     | EQual                     |              |
| NE     | Not EQual                 |              |
| CS/HS  | Unsigned HIGher or SAmee  |              |
| CC/LO  | Unsigned LOwer            |              |
| MI     | MInus (Negative)          |              |
| PL     | PLus (Positive or Zero)   |              |
| VS     | oVerflow Set              |              |
| VC     | oVerflow Clear            |              |
| HI     | Unsigned HIGher           |              |
| LS     | Unsigned LOwer or SAmee   |              |
| GE     | Signed GReater or EQual   |              |
| LT     | Signed LEss Than          |              |
| GT     | Signed GReater Than       |              |
| LE     | Signed LEss than or EQual |              |
| AL     | ALways                    |              |

Note AL is the default and does not need to be specified

# Condition Codes

- ▶ The possible condition codes are listed below:

| Suffix | Description               | Flags tested  |
|--------|---------------------------|---------------|
| EQ     | EQual                     | Z==1          |
| NE     | Not EQual                 | Z==0          |
| CS/HS  | Unsigned HIGher or Same   | C==1          |
| CC/LO  | Unsigned LOwer            | C==0          |
| MI     | MInus (Negative)          | N==1          |
| PL     | PLus (Positive or Zero)   | N==0          |
| VS     | oVerflow Set              | V==1          |
| VC     | oVerflow Clear            | V==0          |
| HI     | Unsigned HIgher           | C==1 and Z==0 |
| LS     | Unsigned Lower or Same    | C==0 or Z==1  |
| GE     | Signed GReater or Equal   | N==V          |
| LT     | Signed Less Than          | N!=V          |
| GT     | Signed Greater Than       | Z==0 and N==V |
| LE     | Signed Less than or Equal | Z==1 or N!=V  |
| AL     | ALways                    |               |

Note AL is the default and does not need to be specified

# Signed Greater or Equal ( $N == V$ )

**CMP r<sub>0</sub>, r<sub>1</sub>**

perform subtraction  $r_0 - r_1$ , without saving the result

|         | $N = 0$                                                                                                                                                                                                                                                                                      | $N = 1$                                                                                                                                                                                                                                                                                      |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $V = 0$ | <ul style="list-style-type: none"><li>• No overflow, implying the result is correct.</li><li>• The result is non-negative,</li><li>• Thus <math>r_0 - r_1 \geq 0</math>, i.e., <math>r_0 \geq r_1</math></li></ul>                                                                           | <ul style="list-style-type: none"><li>• No overflow, implying the result is correct.</li><li>• The result is negative.</li><li>• Thus <math>r_0 - r_1 &lt; 0</math>, i.e., <math>r_0 &lt; r_1</math></li></ul>                                                                               |
| $V = 1$ | <ul style="list-style-type: none"><li>• Overflow occurs, implying the result is incorrect.</li><li>• The result is mistakenly reported as non-negative and in fact it should be negative.</li><li>• Thus <math>r_0 - r_1 &lt; 0</math> in reality, i.e., <math>r_0 &lt; r_1</math></li></ul> | <ul style="list-style-type: none"><li>• Overflow occurs, implying the result is incorrect.</li><li>• The result is mistakenly reported as negative and in fact it should be non-negative.</li><li>• Thus <math>r_0 - r_1 \geq 0</math> in reality, i.e., <math>r_0 \geq r_1</math></li></ul> |

Conclusions:

- If  $N == V$ , then it is signed greater or equal (GE).
- Otherwise, it is signed less than (LT)

# Signed Greater or Equal ( $N == V$ )

**CMP r0, r1**

perform subtraction  $r0 - r1$ , without saving the result

|         | $N = 0$      | $N = 1$      |
|---------|--------------|--------------|
| $V = 0$ | $r0 \geq r1$ | $r0 < r1$    |
| $V = 1$ | $r0 < r1$    | $r0 \geq r1$ |

Conclusions:

- If  $N == V$ , then it is signed greater or equal (GE).
- Otherwise, it is signed less than (LT)

# Signed Greater or Equal ( $N == V$ )

**CMP r0, r1**

perform subtraction  $r0 - r1$ , without saving the result

|         | $N = 0$ | $N = 1$ |
|---------|---------|---------|
| $V = 0$ | 1       | 0       |
| $V = 1$ | 0       | 1       |

Conclusions:

- If  $N == V$ , then it is signed greater or equal (GE).
- Otherwise, it is signed less than (LT)

# Number Interpretation

---

Which is greater?

**0xFFFFFFFF or 0x00000001**

- ▶ If they represent signed numbers, the latter is greater.  
**(1 > -1).**
  
- ▶ If they represent unsigned numbers, the former is greater.  
**(4294967295 > 1).**

# Which is Greater: 0xFFFFFFFF or 0x00000001?

It's **software's responsibility** to tell computer how to interpret data:

- If written in C, declare the signed vs unsigned variable
- If written in Assembly, use signed vs unsigned branch instructions

```
signed int x, y ;  
x = -1;  
y = 1;  
if (x > y)  
    ...
```

```
MOVS r5, #0xFFFFFFFF  
MOVS r6, #0x00000001  
CMP r5, r6  
BLE Then_Clause  
...
```

**BLE**: Branch if less than or equal, signed ≤

```
unsigned int x, y ;  
x = 4294967295;  
y = 1;  
if (x > y)  
    ...
```

```
MOVS r5, #0xFFFFFFFF  
MOVS r6, #0x00000001  
CMP r5, r6  
BLS Then_Clause  
...
```

**BLS**: Branch if lower or same, unsigned ≤

# If-then Statement

```
C Program
// a is signed integer
if (a < 0 ) {
    a = 0 - a;
}
x = x + 1;
```



Implementation 1:

```
; r1 = a (signed integer), r2 = x
CMP r1, #0           ; Compare a with 0
BGE endif            ; Go to endif if a ≥ 0
then    RSB r1, r1, #0 ; a = - a
endif    ADD r2, r2, #1 ; x = x + 1
```

# If-then Statement

```
C Program
// a is signed integer
if (a < 0 ) {
    a = 0 - a;
}
x = x + 1;
```



Implementation 2:

```
; r1 = a, r2 = x
CMP r1, #0           ; Compare a with 0
RSBLT r1, r1, #0   ; a = 0 - a if a < 0
ADD r2, r2, #1       ; x = x + 1
```

# Compound Boolean Expression

```
x > 20 && x < 25  
x == 20 || x == 25  
!(x == 20 || x == 25)
```

| C Program                                                         | Assembly Program                                                                                                                                                                                       |
|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // x is a signed integer<br>if(x <= 20    x >= 25){<br>a = 1<br>} | ; r0 = x<br>CMP r0, #20 ; compare x and 20<br><b>BLE then</b> ; go to then if x ≤ 20<br>CMP r0, #25 ; compare x and 25<br><b>BLT endif</b> ; go to endif if x < 25<br>then MOV r1, #1 ; a = 1<br>endif |

# If-then-else

```
C Program  
if (a == 1)  
    b = 3;  
else  
    b = 4;
```



```
; r1 = a, r2 = b  
CMP r1, #1      ; compare a and 1  
BNE else        ; go to else if a ≠ 1  
then  MOV r2, #3  ; b = 3  
      B endif     ; go to endif  
else  MOV r2, #4  ; b = 4  
endif
```

# For Loop

## C Program

```
int i;
int sum = 0;
for(i = 0; i < 10; i++){
    sum += i;
}
```



Implementation I:

```
MOV r0, #0 ; i
MOV r1, #0 ; sum

B check
loop ADD r1, r1, r0 ; sum += i
        ADD r0, r0, #1 ; i++
check CMP r0, #10 ; check whether i < 10
        BLT loop ; loop if signed less than
endloop
```

# For Loop

## C Program

```
int i;
int sum = 0;
for(i = 0; i < 10; i++){
    sum += i;
}
```



## Implementation 2:

```
MOV r0, #0 ; i
MOV r1, #0 ; sum

loop   CMP r0, #10 ; check whether i < 10
       BGE endloop ; skip if ≥
       ADD r1, r1, r0 ; sum += i
       ADD r0, r0, #1 ; i++
       B loop

endloop
```

# Combined Program Status Registers (xPSR)



# Condition Codes

- ▶ The possible condition codes are listed below:

| Suffix | Description               | Flags tested |
|--------|---------------------------|--------------|
| EQ     | Equal                     | Z=1          |
| NE     | Not equal                 | Z=0          |
| CS/HS  | Unsigned higher or same   | C=1          |
| CC/LO  | Unsigned lower            | C=0          |
| MI     | Negative                  | N=1          |
| PL     | Positive or Zero          | N=0          |
| VS     | Overflow                  | V=1          |
| VC     | No overflow               | V=0          |
| HI     | Unsigned higher           | C=1 & Z=0    |
| LS     | Unsigned lower or same    | C=0 or Z=1   |
| GE     | Signed Greater or equal   | N=V          |
| LT     | Signed Less than          | N!=V         |
| GT     | Signed Greater than       | Z=0 & N=V    |
| LE     | Signed Less than or equal | Z=1 or N!=V  |
| AL     | Always                    |              |

Note AL is the default and does not need to be specified

# Conditional Execution

---

| Add instruction         | Condition                        | Flag tested            |
|-------------------------|----------------------------------|------------------------|
| <b>ADDEQ</b> r3, r2, r1 | Add if EQual                     | Add if Z = 1           |
| <b>ADDNE</b> r3, r2, r1 | Add if Not Equal                 | Add if Z = 0           |
| <b>ADDHS</b> r3, r2, r1 | Add if Unsigned Higher or Same   | Add if C = 1           |
| <b>ADDLO</b> r3, r2, r1 | Add if Unsigned LOwer            | Add if C = 0           |
| <b>ADDMI</b> r3, r2, r1 | Add if Minus (Negative)          | Add if N = 1           |
| <b>ADDPL</b> r3, r2, r1 | Add if PLus (Positive or Zero)   | Add if N = 0           |
| <b>ADDVS</b> r3, r2, r1 | Add if oVerflow Set              | Add if V = 1           |
| <b>ADDVC</b> r3, r2, r1 | Add if oVerflow Clear            | Add if V = 0           |
| <b>ADDHI</b> r3, r2, r1 | Add if Unsigned HIgher           | Add if C = 1 & Z = 0   |
| <b>ADDLS</b> r3, r2, r1 | Add if Unsigned Lower or Same    | Add if C = 0 or Z = 1  |
| <b>ADDGE</b> r3, r2, r1 | Add if Signed Greater or Equal   | Add if N = V           |
| <b>ADDLT</b> r3, r2, r1 | Add if Signed Less Than          | Add if N != V          |
| <b>ADDGT</b> r3, r2, r1 | Add if Signed Greater Than       | Add if Z = 0 & N = V   |
| <b>ADDLE</b> r3, r2, r1 | Add if Signed Less than or Equal | Add if Z = 1 or N = !V |

# Conditional Execution Examples

| C Program                                                                               | Assembly Program                                                                                                                                                     |
|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // x, y are signed integers<br>int32_t a, y<br>if (a <= 0)<br>y = -1;<br>else<br>y = 1; | ; r0 = a, r1 = y<br>CMP r0, #0<br>MOV <b>LE</b> r1, #-1 ; executed if LE<br>MOV <b>GT</b> r1, #1 ; executed if GT                                                    |
| if(a <= 20    a >= 25){<br>y = 1;<br>}                                                  | CMP r0, #20 ; compare a and 20<br>MOV <b>LE</b> r1, #1 ; y=1 if less or equal<br>CMP r0, #25 ; CMP if greater than<br>MOV <b>GE</b> r1, #1 ; y=1 if greater or equal |
| if (a==1    a==7    a==11)<br>y = 1;<br>else<br>y = -1;                                 | CMP r0, #1<br>CMP <b>NE</b> r0, #7 ; executed if r0 != 1<br>CMP <b>NE</b> r0, #11 ; executed if r0 != 7<br>MOV <b>EQ</b> r1, #1<br>MOV <b>NE</b> r1, #-1             |

**LE**: Signed Less than or Equal  
**GT**: Signed Greater Than  
**NE**: Not Equal  
**EQ**: Equal

# Conditional Execution Examples Con't

| C Program                                                                                                     | Assembly Program w/ Branching                                                                                                                                                               | Assembly Program w/ Conditional Execution                                                  |
|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| <pre>int32_t x, y; if (x + y &lt; 0)     x = 0; else     x = 1;</pre>                                         | <pre>% r0 = x, r1 = y         ADDS r0, r0, r1         BPL PosOrZ         MOV r0, #0         B done PosOrZ MOV r0, #1 done</pre>                                                             | <pre>ADDS r0, r0, r1 MOVMI r0, #0 ;return 0 if N = 1 MOVPL r0, #1 ;return 1 if N = 0</pre> |
| <pre>uint32_t x, y; while (x != y) {     if (x &gt; y)         x = x - y;     else         y = y - x; }</pre> | <pre>gcd   CMP r0, r1       BEQ end      ; if a = b, done       BLO less     ; a &lt; b       SUB r0, r0, r1 ; a = a - b       B gcd less  SUB r1, r1, r0 ; b = b - a       B gcd end</pre> | <pre>gcd   CMP r0, r1       SUBHI r0, r0, r1       SUBLO r1, r1, r0       BNE gcd</pre>    |

# Combination

---

| Instruction | Operands  | Brief description              |
|-------------|-----------|--------------------------------|
| <b>CBZ</b>  | Rn, label | Compare and Branch if Zero     |
| <b>CBNZ</b> | Rn, label | Compare and Branch if Non Zero |

- ▶ Except that it does not change the status flags, **CBZ Rn, label** is equivalent to:  
**CMP Rn, #0**  
**BEQ label**
- ▶ Except that it does not change the status flags, **CBNZ Rn, label** is equivalent to:  
**CMP Rn, #0**  
**BNE label**

# Break and Continue

---

| Example code for break                                                                                      | Example code for continue                                                                                      |
|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| <pre>for(int i = 0; i &lt; 5; i++){<br/>    if (i == 2) <b>break</b>;<br/>    printf("%d, ", i)<br/>}</pre> | <pre>for(int i = 0; i &lt; 5; i++){<br/>    if (i == 2) <b>continue</b>;<br/>    printf("%d, ", i)<br/>}</pre> |
| Output: 0, 1                                                                                                | Output: 0, 1, 3, 4                                                                                             |

# Break and Continue

| C Program                                                                                                                                  | Assembly Program                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // Find string length<br>char str[] = "hello";<br>int len = 0;<br><br>for( ; ; ) {<br>if (*str == '\0')<br>break;<br>str++;<br>len++;<br>} | ; r0 = string memory address<br>; r1 = string length<br>MOV r1, #0 ; len = 0<br><br>loop LDRB r2, [r1]<br>CBNZ r2, notZero<br>B endloop<br><br>notZero ADD r0, r0, #1 ; str++<br>ADD r1, r1, #1 ; len++<br>B loop<br><br>endloop |

# IT (If-Then) instruction

**IT{x{y{z}}}** {cond}

- where the x, y, and z specify the existence of the optional second, third, and fourth conditional instruction respectively.
- x, y, and z are either **T** (Then) or **E** (Else)

Examples:

```
ITTE NE      ; IT can be omitted  
ANDNE r0,r0,r1 ; 16-bit AND, not ANDS  
ADDNE r2,r2,#1 ; 32-bit ADDS  
MOVEQ r2,r3    ; 16-bit MOV
```

```
ITT EQ  
MOVEQ r0,r1  
BEQ dloop    ; branch at end of IT block is permitted
```

```
ITT EQ  
MOVEQ r0,r1  
ADDEQ r0,r0,#1
```

```
ITT AL      ; emit 2 non-flag setting 16-bit instructions  
ADDAL r0,r0,r1 ; 16-bit ADD, not ADDS  
SUBAL r2,r2,#1 ; 16-bit SUB, not SUB  
ADD   r0,r0,r1 ; expands into 32-bit ADD, and is not in IT block
```

# IT (If-Then) instruction

---

**IT{x{y{z}}}} {cond}**

- ▶ where the x, y, and z specify the existence of the optional second, third, and fourth conditional instruction respectively.
- ▶ x, y, and z are either **T** (Then) or **E** (Else)
  
- ▶ You do not need to write IT instructions in your code.
  
- ▶ The assembler generates them for you automatically according to the conditions specified.

# Summary: Condition Codes

| Suffix | Description               | Flags tested |
|--------|---------------------------|--------------|
| EQ     | EQual                     | Z=1          |
| NE     | Not EQual                 | Z=0          |
| CS/HS  | Unsigned HIGher or SAmes  | C=1          |
| CC/LO  | Unsigned LOwer            | C=0          |
| MI     | MINus (Negative)          | N=1          |
| PL     | PLus (Positive or Zero)   | N=0          |
| VS     | oVerflow Set              | V=1          |
| VC     | oVerflow Cleared          | V=0          |
| HI     | Unsigned HIgher           | C=1 & Z=0    |
| LS     | Unsigned Lower or SAmes   | C=0 or Z=1   |
| GE     | Signed GREATER or EQUAL   | N=V          |
| LT     | Signed LESS Than          | N!=V         |
| GT     | Signed GREATER Than       | Z=0 & N=V    |
| LE     | Signed LESS than or EQUAL | Z=1 or N!=V  |
| AL     | ALways                    |              |

Note AL is the default and does not need to be specified

# Summary: Branch Instructions

|                             | Instruction          | Description                                         | Flags tested             |
|-----------------------------|----------------------|-----------------------------------------------------|--------------------------|
| <b>Unconditional Branch</b> | <b>B Label</b>       | Branch to label                                     |                          |
| <b>Conditional Branch</b>   | <b>BEQ Label</b>     | Branch if <b>E</b> Qual                             | <b>Z = 1</b>             |
|                             | <b>BNE Label</b>     | Branch if <b>N</b> ot <b>E</b> qual                 | <b>Z = 0</b>             |
|                             | <b>BCS/BHS Label</b> | Branch if unsigned <b>H</b> igher or <b>S</b> ame   | <b>C = 1</b>             |
|                             | <b>BCC/BLO Label</b> | Branch if unsigned <b>L</b> ower                    | <b>C = 0</b>             |
|                             | <b>BMI Label</b>     | Branch if <b>M</b> inus (Negative)                  | <b>N = 1</b>             |
|                             | <b>BPL Label</b>     | Branch if <b>P</b> lus (Positive or Zero)           | <b>N = 0</b>             |
|                             | <b>BVS Label</b>     | Branch if o <b>V</b> erflow <b>S</b> et             | <b>V = 1</b>             |
|                             | <b>BVC Label</b>     | Branch if o <b>V</b> erflow <b>C</b> lear           | <b>V = 0</b>             |
|                             | <b>BHI Label</b>     | Branch if unsigned <b>H</b> igher                   | <b>C = 1 &amp; Z = 0</b> |
|                             | <b>BLS Label</b>     | Branch if unsigned <b>L</b> ower or <b>S</b> ame    | <b>C = 0 or Z = 1</b>    |
|                             | <b>BGE Label</b>     | Branch if signed <b>G</b> reater or <b>E</b> qual   | <b>N = V</b>             |
|                             | <b>BLT Label</b>     | Branch if signed <b>L</b> ess <b>T</b> han          | <b>N != V</b>            |
|                             | <b>BGT Label</b>     | Branch if signed <b>G</b> reater <b>T</b> han       | <b>Z = 0 &amp; N = V</b> |
|                             | <b>BLE Label</b>     | Branch if signed <b>L</b> ess than or <b>E</b> qual | <b>Z = 1 or N = !V</b>   |

# Summary: Conditionally Executed

---

| Add instruction         | Condition                        | Flag tested            |
|-------------------------|----------------------------------|------------------------|
| <b>ADDEQ</b> r3, r2, r1 | Add if EQual                     | Add if Z = 1           |
| <b>ADDNE</b> r3, r2, r1 | Add if Not Equal                 | Add if Z = 0           |
| <b>ADDHS</b> r3, r2, r1 | Add if Unsigned Higher or Same   | Add if C = 1           |
| <b>ADDLO</b> r3, r2, r1 | Add if Unsigned LOwer            | Add if C = 0           |
| <b>ADDMI</b> r3, r2, r1 | Add if Minus (Negative)          | Add if N = 1           |
| <b>ADDPL</b> r3, r2, r1 | Add if PLus (Positive or Zero)   | Add if N = 0           |
| <b>ADDVS</b> r3, r2, r1 | Add if oVerflow Set              | Add if V = 1           |
| <b>ADDVC</b> r3, r2, r1 | Add if oVerflow Clear            | Add if V = 0           |
| <b>ADDHI</b> r3, r2, r1 | Add if Unsigned HIgher           | Add if C = 1 & Z = 0   |
| <b>ADDLS</b> r3, r2, r1 | Add if Unsigned Lower or Same    | Add if C = 0 or Z = 1  |
| <b>ADDGE</b> r3, r2, r1 | Add if Signed Greater or Equal   | Add if N = V           |
| <b>ADDLT</b> r3, r2, r1 | Add if Signed Less Than          | Add if N != V          |
| <b>ADDGT</b> r3, r2, r1 | Add if Signed Greater Than       | Add if Z = 0 & N = V   |
| <b>ADDLE</b> r3, r2, r1 | Add if Signed Less than or Equal | Add if Z = 1 or N = !V |