

## Module - 2

1. Explain in detail about data processing instruction in ARM.

Ans

→ Move instruction :-

\* Simplest ARM instruction

\* Copies N into a destination register Rd, where N is a register or ~~integer~~ immediate value

Syntax:-

$\{ \text{cond} \} \{ \text{sy} \} \text{ Rd}, \text{N}$

e.g:- PRE :-  $r5 = 5$

$r7 = 8$

MOV  $r7, r5$  with condition

POST  $r5 = 5$

$r7 = 5$

→ Arithmetic instruction :-  
\* implements addition Subtraction & 32-bit signed & unsigned value.

Syntax:-  $\langle \text{instruction} \rangle \{ \text{cond} \} \{ \text{sy} \} \text{ Rd}, \text{Rn}, \text{N}$

e.g:- PRE

$r0 = 0x0000 0000$

$r1 = 0x0000 0002$

$r2 = 0x0000 0001$

SUB  $r0, r1, r2$

POST  $r0 = 0x0000 0001$

→ Logical instruction  
\* Performs bitwise logical operations on the 2 source register.

Syntax:-  $\langle \text{instruction} \rangle \{ \langle \text{cond} \rangle \} \{ \text{S} \} \text{ Rd}, \text{Rn}, \text{N}$

eg:-  $r0 = 0x0000\ 0000$

$r1 = 0x02040608$

$r2 = 0x12308070$

$\text{ORR} r0, r1, r2$

POST  $r0 = 0x12345678$

→ Comparison Instruction  
\* Used to compare a register with a 32-bit value  
\* Update the CPSR flag bits acc. to the result  
\* Update the CPSR flag bits acc. to the result  
but do not affect other register.

Syntax:-  $\langle \text{instruction} \rangle \{ \langle \text{cond} \rangle \} \{ \text{S} \} \text{ Rd}, \text{N}$

eg:- PRE  $\text{CPSR} = \text{nZCPQFiT }$  USER

$r0 = 4$

$r9 = 4$

$\text{CMP } r0, r9$

POST

$\text{CPSR} = \text{nZCPQFiT }$  USER.

NEVER used - Z

NEVER used - C

→ Multiply instructions.

\* Multiply ~~subtraction~~ the contents of a pair of registers and depending upon the instruction, accumulate the register in with another register.

\* The final result is placed in destination register.

Syntax:-

MUL {<cond>} {S} Rd, Rm, Rs  $\Rightarrow$  Rd = Rm \* Rs

MLA {<cond>} {S} Rd, Rm, Rs, Rn  $\Rightarrow$  Rd = (Rm \* Rs) + Rn

Eg:- PRE  $r_0 = 0x0000\ 0000$

$r_1 = 0x0000\ 0002$

$r_2 = 0x0000\ 0009$

MUL  $r_0, r_1, r_2$

POST  $r_0 = 0x0000\ 0004$

$r_1 = 0x0000\ 0002$

$r_2 = 0x0000\ 0002$

Q7 List & Explain all logical & Arithmetic Shift & rotate instruction.

→ Logical shift Left (LSL) :- This operation shift the bits of register Rm to the left by a specified no. of bits indicated by <Shift>.

\* Zeros are shifted in from the right & bits shifted out from the left are discarded.

Syntax:- LSL Rd, Rm, #<Shift>

Eg:- Rm = 10101010  
#3

Rm = 01010000

→ Logical Shift Right (LSR) :- This operation shifts the bits of the register Rm to the right by a specified no. of bits indicated by <Shift>

\* zeros shifted in from left & bits shifted out from the right are discarded.

Syntax:- LSR Rd, Rm, #<Shift>

eg:- Rm = 00110011 #2 bits shift right  
Rd = ~~00001100~~ 00001100

→ Arithmetic Shift right (ASR) :- This operation Shifts the bits of Register Rm to the right by a Specified no. of bits indicated by <Shift>. while preserving the sign bit.

\* Sign bit is replicated to maintain the sign of the no.

Syntax:- ASR Rd, Rm, #<Shift>

eg:- Rm = 11100100

Rd = 11110011

→ Rotate Right (ROR) :- This operation rotates the bits of the register Rm to the right by a specified no. of bits indicated by <Shift>

\* The bits that are shifted out from the right are rotated back to the left & inserted into the leftmost positions.

Syntax :- ROR Rd, Rm, #<Shift>

$$Rm = 10101100$$

#2

$$Rd = 00101011$$

→ Rotate Right with Extend (RRX)

\* This operation rotates the bits of the register Rm to the right by one bit position. The carry flag (C) is extended into the vacated most significant bit (MSB) position.

Syntax :- RRX Rd, Rm

eg:- Rm = 10011011

Carry flag = 1

11001101



- Contents of Bit 0 are shifted to Bit 1
- Bit 0 is cleared.
- The C flag is updated with least significant bit of the register.
- 14) Define Barrel shifter? Which are diff. barrel shifter operations.

5) Describe various logical instruction?

→ Logical AND Operation.

\* Syntax:- AND {S} {cond} Rd, Rn, Operand2

eg:- AND R1, R2, #0xFF

\* R1 is destination register, R2 is first operand  
\* 0xFF is immediate value.

\* Say R<sub>2</sub> contains 11001100

\* Result is 11001100 AND 11111111 = 11001100

→ Logical ORR operation

\* Syntax :- ORR & S<sub>Y</sub> { cond } Rd, Rn, Operand2

Eg:- ORR R<sub>3</sub>, R<sub>1</sub>, #0x00FF

\* R<sub>3</sub> is destination register, R<sub>1</sub> is first operand  
#0x00FF is immediate value representing 255 in  
Hexadecimal.

\* It performs bitwise OR operation b/w the value  
in register R<sub>1</sub> & immediate value #0x00FF and store  
result in R<sub>3</sub>.

Eg:- Let value of R<sub>1</sub> is #0XAAAA (10101010101010)  
after executing this instruction R<sub>3</sub> would contain  
0XAAFF i.e. (1010101111111)

→ Logical EOR instruction.

\* Syntax :- EOR & S<sub>Y</sub> { cond } Rd, Rn, Operand2

Eg:- EOR R<sub>3</sub>, R<sub>1</sub>, R<sub>2</sub>

\* It performs a bitwise operation Exclusive OR operation  
b/w R<sub>1</sub> & R<sub>2</sub> & stores in R<sub>3</sub>.

\* Exclusive OR operation compares each pair of corresponding  
bits in the operand. \* If bits are diff. result is 1 or 0

egr R1 = 01010101  
 R2 = 11001100

01010101  
 EOR  
 11001100  
1001001

→ BIC [Bit clear] logical operation instruction  
 \* It performs a bitwise logical AND operation  
 blur the contents of 2 registers & then clears the  
 corresponding bit in destination register.  
 Syntax :- BIC {cond} Rd, Rn, Operand2

eg:- BIC R3, R1, R2

R1 = 11001100  
 R2 = 10101010  
 R3 = 10001000

8) Explain four Branch instructions

- ~~B~~ {< cond>} label
- BL {< cond>} label
- BX {< cond>} Rm
- BLX {< cond>} label | Rm

$\rightarrow B = \text{Branch}$       pc = label

BL = Branch with link      pc = label

lr = add. of next instruction after BL

Bx = Branch exchange      pc = Rm & 0xffffffe, T = Rm & 1

BX = Branch exchange  
with link

pc = Label, T = 1

pc = Rm & 0xffffffe, T = Rm & 1

lr = add. of next instruction after BX

The BX instruction uses an absolute address stored in Register Rm

↳ Primarily used to branch to C from Thumb code.

↳ T bit of CPSR is updated by least significant bit of the branch register.

The BLX instruction updates the T bits by least significant bit and additionally sets the Link register with return address.

↗ Explain any 4 arithmetic instruction.

$\rightarrow \underline{\text{ADD}}$

\* Syntax:- ADD {destination}, {opd1}, {opd2}

e.g.: Add R1, R2, R3 ; Adds the contents of register R2 and R3 & stores the result in R1

- ADC [Add with Carry]
- \* Syntax:- ADC {S}, Rd, Rn, Opd2
  - \* Here {S} is an optional suffix to update conditional flags, Rd is destination register, Rn is first operand register & Opd2 can be either register or an value.

eg:- ADC R1, R2, R3

Here R2 = 10 (0x0A)

R3 = 15 (0x0F)

carry flag = 1

$$\text{Result} \rightarrow R1 = R1 + R2 + CF$$

$$= 10 + 15 + 1$$

$$= 26 (0x1A)$$

→ SUB: Used to subtract one operand from another.

→ SUB {S} {Rd}, {Rn}, Opd2

\* Syntax:- SUB {S} {Rd}, {Rn}, Opd2

\* SUB R1, R2, R3; Subtract the value in R3 from the value in R2 & store the result in R1.

This instruction subtracts the value in R3 from the value in R2 & stores the result in R1.

This instruction subtracts the value in R3 from the value in R2 & stores the result in R1.

This instruction subtracts the value in R3 from the value in R2 & stores the result in R1.

This instruction subtracts the value in R3 from the value in R2 & stores the result in R1.

→ SBC [Subtract with Carry]

\* Syntax :- SBC{S} Rd, Rn, opd2

\* SBCS R2, R3, R4; Subtract the value in R4 from R3 along with the carry flag and store the result in R2. Update condition flag.

\* The value of R4 is subtracted from the value in R3 including the carry flag & the result is stored in R2

e.g.: -  $R_0 = 10$

$R_1 = 5$

SUBS R2, R0, R1 [ $10 - 5 = 5$ , set flag]

i) Explain Load Store instruction

→ Transfer data b/w memory & processor registers.

→ There are three types of load-store instructions

\* Single register transfer.

\* Multiple register transfer.

\* Swap.

→ Single-Register Transfer

\* Used for moving a single data item in a set of registers  
\* The datatypes supported are signed & unsigned words,

halfwords & bytes

Syntax:-  $\langle LDR | STR \rangle \{ \langle cond \rangle \} \{ B \} \text{ Rd, addressing 1 }$   
 $\langle LDR \rangle \{ \langle cond \rangle \} \{ B \} \{ H \} \text{ SH Rd, addressing 2 }$   
 $\langle STR \rangle \{ \langle cond \rangle \} \{ H \} \text{ Rd, addressing 2 }$

- Multiple Register Transfer
- \* Transfer multiple register block memory of the processor in single instruction
  - \* The transfer occurs from a base address register Rn pointing into memory.
  - \* More efficient from single-register transfer for moving blocks of data around memory & saving by restoring context and stacks.

Syntax:-

$\langle \text{LDM/STM} \rangle \{ \langle \text{cond} \rangle \} \langle \text{addressing mode} \rangle Rn \{ ! \}, \langle \text{Registers} \rangle \{ ! \}$

Explain following Instruction:-

→ MLA:- This instruction that performs a multiplication of 2 operands, adds the result to a third operand & stores the final result in destination register

Syntax:-  $\text{MLA} \{ S \} \{ \text{cond} \} Rd, Rn, Rm, Ra$

- \* {S} is optional suffix specifying whether the instruction updates the conditional flags.
- \* {Cond} is an optional conditional code.
- \* Rd is destination register
- \* Rn & Rm are containing values to be multiplied
- \* Ra is register containing value to be added to Result of Rn & Rm

eg:- MLA R3, R1, R2, R4

Suppose R1=2 R2=2 R4=3

$$\begin{aligned}R3 &= \{2 * 2\} + 3 \\&= 4 + 3 = \underline{\underline{7}}\end{aligned}$$

→ MUL :- MUL instruction is used to perform unsigned integer multiplication

\* It multiplies 2 registers operands together & store the result in another register.

Syntax :- MUL {S} {Cond} Rd, Rn, Rm

\* Rd = destination register.

\* Rn & Rm = Registers that contain values.

Example for

if MLA

ENTRY

START

MOV R0, #6

MOV R1, #5

MOV R2, #1

MLA R3, R0, R1, R2

~~BACK~~ B BACK

END

- Multiple Register Transfer
- \* Transfer multiple register block memory in single instruction
  - \* The transfer occurs from a base address register Rn pointing into memory.
  - \* More efficient from single-register transfer for moving blocks of data around memory by saving restoring context and stacks.

Syntax:-

$\langle \text{LDM} | \text{STM} \rangle \{ \langle \text{cond} \rangle \} \langle \text{addressing mode} \rangle Rn \{ ? \}, \{ \langle \text{Registers} \rangle \}$

Explain following Instruction:-

→ MLA:- This instruction that performs a multiplication of 2 operands, adds the result to a third operand & stores the final result in destination register

Syntax:-  $\text{MLA} \{ s \} \{ \text{cond} \} Rd, Rn, Rm, Ra$

- \* {s} is optional suffix specifying whether the instruction updates the conditional flags.
- \* {Cond} is an optional conditional code.
- \* Rd is destination register
- \* Rn & Rm are containing values to be multiplied
- \* Ra is register containing value to be added to Result of Rn & Rm

e.g.: MLA R3, R1, R2, R4

Suppose R1 = 2 R2 = 2 R4 = 3

$$\begin{aligned}R3 &= \{2 * 2\} + 3 \\&= 4 + 3 \underline{\underline{=}} 7\end{aligned}$$

→ MUL :- MUL instruction is used to perform unsigned integer multiplication

\* It multiplies 2 registers operands together & store the result in another register.

Syntax :- MUL {S} {Cond} Rd, Rn, Rm

\* Rd = destination register.

\* Rn & Rm = Registers that contain values.

Example for

i) MLA

ENTRY

START      MOV R0, #6

              MOV R1, #5

              MOV R2, #1

MLA R3, R0, R1, R2

~~B~~ BACK B BACK

END

ii) MUL

ENTRY

START

MOV R0, #5

MOV R1, #2

MUL R2, R0, R1

BACK B BACK

END

→ TEQ [Test Equivalence]

\* It performs a bitwise Exclusive OR (XOR) operation between a register value & an operand & updates the conditional flag based on result.

\* Syntax :- TEQ {cond} Rn, Operand 2

e.g:- TEQ R1, #10

\* R1 is the register to be tested.

\* #10 is an immediate value to be xorred with value

in R1

### iii) UMLAL [Unsigned Multiply Accumulate Long]

- \* It is used to multiply 2 unsigned 32-bit integers & store the 64-bit result in 2 32-bit registers, but it also adds 64-bit result to the value in destination register. Before storing it in RdLo & RdHi

RdHi

\* Syntax :- UMLAL {RdLo, RdHi}, Rn, Rm

\* RdLo holds lower 32 bits

RdHi " Upper "

Rn specifies first operand

2nd "

Rm "

eg:- ENTRY

START

LDR R0, #0x5

LDR R1, 0x5

LDR R2, =0x2

LDR R3, =0x4

UMLAL R3, R2, R0, R1

BACK B BACK

END

Factorial Code

ENTRY      MOV R0, #3  
 MOV R1, R0  
 FACT      SUBS R1, R1, #1  
 CMP R1, #1  
 BE EQUAL  
 MUL R3, R0, R1  
 MOV R0, R3  
 BNE FACT

EQUAL      STOP  
 END

SUM Code

ENTRY      MOV R1, #10  
 MOV R2, #0  
 LOOP      ADD R2, R2, R1  
 SUBS R1, #0x01  
 BNE LOOP  
 BACK  
 END