

## 08A ARM Machine Code: Data Processing Instructions

**CPE 221** 

The University of Alabama in Huntsville

Rahul Bhadani March 19, 2025

#### Table of Content

Encoding Immediates in ARM Assembly

**Encoding Shift Instructions** 

Multiply Instructions



## **Data Processing Instructions**

| 31:28  | 27:26  | 25:20  | 19:16  | 15:12  | 11:0    |
|--------|--------|--------|--------|--------|---------|
| cond   | ор     | funct  | Rn     | Rd     | Src2    |
| 4 bits | 2 bits | 6 bits | 4 bits | 4 bits | 12 bits |

| Bit 25                    | Bits 24:21               | Bit 20                      |
|---------------------------|--------------------------|-----------------------------|
| I                         | cmd                      | S                           |
| I=1 when $Src2$ is an im- | Specific data-processing | $S{=1}$ when an instruction |
| mediate                   | instruction              | sets the condition flags    |



## **Encoding Immediates in ARM Assembly**



## **Encoding Immediates for Data Processing Instructions**

| 31:28 | 27:26 | 25:20 | 19:16 | 15:12 | 11:0 |
|-------|-------|-------|-------|-------|------|
| cond  | ор    | funct | Rn    | Rd    | Src2 |

| Bit 11:8 | Bits 7:0 |
|----------|----------|
| rot      | imm8     |

imm8 = 8-bit immediate

rot = 4-bit rotation

imm8 is rotated right by 2  $\times$  rot to create a 32-bit constant.



#### 4-bit Rotation, 8-bit Immediate

ARM doesn't use the 12-bit immediate value as a 12-bit number. Instead, it's an 8-bit number with a 4-bit rotation, like this:

| Bit 11:8 | Bits 7:0 |
|----------|----------|
| rot      | imm8     |

The 4-bit rotation value has 16 possible settings (i.e. 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30), so it's not possible to rotate the 8-bit value to any position in the 32-bit word. The most useful way to use this rotation value is to multiply it by two. It can then represent all even numbers from zero to 30.



#### 4-bit Rotation, 8-bit Immediate

To form the constant for the data processing instruction, the 8-bit immediate value is extended with zeroes to 32 bits, then rotated the specified number of places to the right. For some values of rotation, this can allow splitting the 8-bit value between bytes. See the table in the next slide for all possible rotations.



| Rotation | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0x1      | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | 7 | 6 | 5 | 4 | 3 | 2 |
| 0x2      | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 7 | 6 | 5 | 4 |
| 0x3      | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 7 | 6 |
| 0×4      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0x5      |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0×6      |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0×7      |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0×8      |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0x9      |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0xA      |    |    |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |    |    |   |   |   |   |   |   |   |   |   |   |
| 0xB      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |   |   |   |   |   |   |   |   |   |
| 0xC      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |   |   |   |   |   |   |   |   |
| 0xD      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5  | 4  | 3 | 2 | 1 | 0 |   |   |   |   |   |   |
| 0xE      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7  | 6  | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |
| 0xF      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |

#### Encode SUB R2, R3, 0xFF0

- $\triangleright$  0xFF0 = 1111 1111 0000
- ▶ It is 12 bits but need to find a way to represent using 8 bits.
- ► Given, 0XFF0, we first write it as 32-bit: 0x00000FF0 which is 0000 0000 0000 0000 0000 1111 1111 0000
- ▶ Since the above number cannot be accommodated in 8 bits (minimum need is 12 bits), we need to rotate it.
- By looking at the table in the previous slide, we see that 0000 0000 0000 0000 0000 1111 1111 0000 is corresponding to 0xE which means we need  $14 \times 2 = 28$  rotation.



Hence rot = 1110, imm8 =  $1111 \ 1111$ 

#### Note

Not all 32 bits can be represented by the above logic, so not all immediates greater than 8 bits are valid immediates.



## **Encoding Shift Instructions**



## **Encoding Shift Instructions**

| 31:28  | 27:26  | 25:20  | 19:16  | 15:12  | 11:0    |
|--------|--------|--------|--------|--------|---------|
| cond   | ор     | funct  | Rn     | Rd     | Src2    |
| 4 bits | 2 bits | 6 bits | 4 bits | 4 bits | 12 bits |

| Bit 25                       | Bits 24:21 | Bit 20                      |
|------------------------------|------------|-----------------------------|
| 1                            | cmd        | S                           |
| I = 0 for LSL, LSR, ROR, ASR | 1101       | $S{=1}$ when an instruction |
| I=1 for $MOV$                |            | sets the condition flags    |



## Encoding Shift Instructions: Register Value Shift by Constant

## Register Value Shift by Constant or Immediate (Shift Amount)

| 31:28  | 27:26  | 25:20  | 19:16  | 15:12  | 11:0    |
|--------|--------|--------|--------|--------|---------|
| cond   | ор     | funct  | Rn     | Rd     | Src2    |
| 4 bits | 2 bits | 6 bits | 4 bits | 4 bits | 12 bits |

## LSL/LSR/ASR/ROR Rd, Rm, shamt5

| Bits 11:7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|----------|-------|----------|
| shamt5    | sh       | 0     | Rm       |

shamt5 = a constant by which the register Rm is shifted

| sh | Instructions |
|----|--------------|
| 00 | LSL          |
| 01 | LSR          |
| 10 | ASR          |
| 11 | ROR          |
|    |              |



Encode LSL R3, R2, #23

| 31:28  | 27:26  | 25:20    | 19:16  | 15:12  | 11:0    |
|--------|--------|----------|--------|--------|---------|
| 1110   | 00     | 0 1101 0 | 0000   | 0011   | Src2    |
| 4 bits | 2 bits | 6 bits   | 4 bits | 4 bits | 12 bits |

#### Src2:

| Bits 11:7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|----------|-------|----------|
| 10111     | 00       | 0     | 0010     |



#### Encode MOV R3, R2

| 31:28  | 27:26  | 25:20    | 19:16  | 15:12  | 11:0    |
|--------|--------|----------|--------|--------|---------|
| 1110   | 00     | 1 1101 0 | 0000   | 0011   | Src2    |
| 4 bits | 2 bits | 6 bits   | 4 bits | 4 bits | 12 bits |

#### Src2:

| Bits 11:7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|----------|-------|----------|
| 00000     | 00       | 0     | 0010     |



1110 0011 1010 0000 0011 0000 0000 0010 0x E 3 A 0 3 0 0 2



| 31:28  | 27:26  | 25:20    | 19:16  | 15:12  | 11:0    |
|--------|--------|----------|--------|--------|---------|
| 1110   | 00     | 1 1101 0 | 0000   | 0011   | Src2    |
| 4 bits | 2 bits | 6 bits   | 4 bits | 4 bits | 12 bits |

**Src2:** follows the same convention as in Example 1.

1110 0011 1010 0000 0011 1110 1111 1111 0x E 3 A 0 3 E F F



## Encoding Shift Instructions: Register Value Shift by Register Value

### Register Value Shift by Constant or Immediate (Shift Amount)

| 31:28  | 27:26  | 25:20  | 19:16  | 15:12  | 11:0    |
|--------|--------|--------|--------|--------|---------|
| cond   | ор     | funct  | Rn     | Rd     | Src2    |
| 4 bits | 2 bits | 6 bits | 4 bits | 4 bits | 12 bits |

## LSL/LSR/ASR/ROR Rd, Rm, Rs

| Bits 11:8 | Bit 7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|-------|----------|-------|----------|
| Rs        | 0     | sh       | 1     | Rm       |

| sh | Instructions |
|----|--------------|
| 00 | LSL          |
| 01 | LSR          |
| 10 | ASR          |
| 11 | ROR          |



Encode ASR R3, R5, R7

| 31:28  | 27:26  | 25:20    | 19:16  | 15:12  | 11:0    |
|--------|--------|----------|--------|--------|---------|
| 1110   | 00     | 0 1101 0 | 0000   | 0011   | Src2    |
| 4 bits | 2 bits | 6 bits   | 4 bits | 4 bits | 12 bits |

#### Src2:

| Bits 11:8 | Bit 7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|-------|----------|-------|----------|
| 0111      | 0     | 10       | 1     | 0101     |





$$Rn = R2$$
,  $Rd = R7$ ,  $Rm = R3$ 

| 31:28  | 27:26  | 25:20    | 19:16  | 15:12  | 11:0    |
|--------|--------|----------|--------|--------|---------|
| 1110   | 00     | 0 0100 0 | 0010   | 0111   | Src2    |
| 4 bits | 2 bits | 6 bits   | 4 bits | 4 bits | 12 bits |

#### Src2:

| Bits 11:7 | Bits 6:5 | Bit 4 | Bits 3:0 |
|-----------|----------|-------|----------|
| 00010     | 00       | 0     | 0011     |



1110 0000 1000 0010 0111 0001 0000 0011 0x E 0 8 2 7 1 0 3

## **Multiply Instructions**



### **Multiply Instructions**

Multiply instructions use the encoding in below. The 3-bit *cmd* field specifies the type of multiply, as given in the Table.

## Multiply

| 31:28  |          |        |     |        |        |        |        |        |    |
|--------|----------|--------|-----|--------|--------|--------|--------|--------|----|
| cond   | op<br>00 | 00     | cmd | S      | Rd     | Ra     | Rm     | 1001   | Rn |
| 4 bits | 2 bits   | 6 bits |     | 4 bits |    |

Multiply instruction encoding



## Types of Multiply Instructions

| cmd | Name                 | Description            | Operation                                                 |
|-----|----------------------|------------------------|-----------------------------------------------------------|
| 000 | MUL Rd, Rn, Rm       | Multiply               | $Rd \leftarrow Rn \times Rm \; (low \; 32 \; bits)$       |
| 001 | MLA Rd, Rn, Rm, Ra   | Multiply<br>Accumulate | $Rd \leftarrow (Rn \times Rm) + Ra \text{ (low 32 bits)}$ |
| 100 | UMULL Rd, Rn, Rm, Ra | Unsigned Multiply      | $\{Rd,Ra\}\leftarrowRn	imesRm$                            |
|     |                      | Long                   | (all 64 bits, Rm/Rn unsigned)                             |
| 101 | UMLAL Rd, Rn, Rm, Ra | Unsigned Multiply      | $\{Rd, Ra\} \leftarrow (Rn \times Rm) + \{Rd, Ra\}$       |
|     |                      | Accumulate Long        | (all 64 bits, Rm/Rn unsigned)                             |
| 110 | SMULL Rd, Rn, Rm, Ra | Signed Multiply        | $\{Rd, Ra\} \leftarrow Rn \times Rm$                      |
|     |                      | Long                   | (all 64 bits, Rm/Rn signed)                               |
| 111 | SMLAL Rd, Rn, Rm, Ra | Signed Multiply        | $\{Rd, Ra\} \leftarrow (Rn \times Rm) + \{Rd, Ra\}$       |
|     |                      | Accumulate Long        | (all 64 bits, Rm/Rn signed)                               |



# The End