~erdo.dev


ARM Architecture Instruction Set

2019-07-06

In this article, finally, we will start to take a glance at ARM’s arithmetical, logical, data transfer, and branching instructions. But before that, you should check your microprocessor’s model and serial number. Instructions might differ according to these two numbers. The reason for this is that ARM has updated its designs due to technological developments.

Instruction Set

The arm instructions process data in the register. Therefore, the data must be transferred to the registers before arithmetic, logic, or other types of processing. This information is very important to us. The way to do this is to load data into registers by using load/store instructions. ARM instructions generally take three or two operands. To explain this with an example let’s check the syntax of Instructions:

INS Operan1, Operand2, Operand3

where: * INS: Name of the instruction * Operand1: Destination register (Operand getting result) * Operand2: First register for operation (Operand getting 1st source) * Operand3: Second register for operation (Operand getting 2nd source)

Quick example;

ADD(INS) r0(Operand1), r1(Operand2), r2(Operand3)  
// This_ instructions _set is basically adds r1 and r2 registers and writes the results into the r0 register.  
// ! r0 = r1+r2;  (in C)

Some ARM instructions may also take some prefixes and suffixes.

Types of Instructions

ARM (Advanced RISC Machine) instructions can be broadly categorized into two primary types: Data Transfer and Process, Arithmetic and Logical Computation, and Barrel Control operations. These categories encompass the fundamental operations that ARM processors perform to manipulate data and control the flow of information within a system.

Data Transfer and Process Instructions

These instructions are almost available in every microprocessor as well as in ARM microprocessors. These are very simple to use. Basically, provide to load or store the desired initial values to the register before processing. The instruction duty and usage structure are as follows.

MOV: The MOV instruction copies the value of Operand2 into Rd.

MVN: The MVN instruction takes the value of Operand2, performs a bitwise logical NOT operation on the value and places the result into Rd.

Syntax:

MOV{S}{cond} Rd, Operand2
MOV{cond} Rd, #imm16
MVN{S}{cond} Rd, Operand2

Example: We can assign a register value as well as we can assign a constant number.

MOV r0, r1    
MOV r0, 5  
MVN r0, r1  // r0 = NOT(r1)

where:

Arithmetic and Logical Computation Instructions

Arithmetic Computation Instructions

These instructions are fundamental arithmetic operations for all kinds of processors. They compute the sum (or difference), multiplication (or division)of two registers, and store the result in a register. Multiplication and division operations can also be performed via barrel shift.

ADD: The ADD instruction adds the value of Register1 toRegister2.

SUB: The SUB instruction subtracts the value of Register2 from Register1.

MUL: The MUL instruction multiplies the value of Register1 byRegister2.

SDIV: The SDIV instruction divides the value of Register1 byRegister2.

Note: Division with a constant number might not be supported by all ARM processors.

Syntax:

ADD{S}{cond} Register0, Register1, Register2
ADD Register1, #imm16  // 5
SUB{S}{cond} Register3, Register4, Register5
MUL Register0, Register1, Register2
SDIV Register3, Register4, Register5

Example:

Given the following operations in the pseudocode:

result = (a + b) - (c + d);
a = b \* b;
c = d / e;

We can do the same operations with ARM instructions as follows:

// result = (a + b) - (c + d);
ADD   r0, r2, r3  // result = a + b;  (in C)
ADD   r1, r4, r5  // temp= c + d;  (in C)
SUB   r0, r0, r1  // result = result - temp;  (in C)
MUL r0, r2, r3    // a = b * c; (only 32 bits stored)  (in C)
SDIV  r0, r2, r4  // c = d / e; (signed divide)  (in C)

Logic Computation Instructions

The ARM instruction set provides instructions such as AND, OR, XOR, and BIC, which sets, and clears the bits according to the need of the program. Usually, you find these as part of if-else, while statements in high-level languages.

AND: The AND instruction adds the value of Register1 to Register2.

OR: The OR instruction subtracts the value of Register2 from Register1.

XOR: The XOR instruction multiplies the value of Register1 by Register2.

BIC: The BIC instruction divides the value of Register1 by Register2.

Syntax:

AND Register0, Register1, Register2  // r0 = r1 & r2;  (in C)   
ORR Register3, Register4, Register5  // r3 = r4 | r5;  (in C)   
EOR Register0, Register1, Register2  // r0 = r1 ^ r2;  (in C)  
BIC Register3, Register4, Register5  // r3 = r4 & (!r5);  (in C)

Example:

//  r0 = 01101001    
//  r1 = 11000111  
AND r3, r0, r1; r3  // 01000001  
ORR r3, r0, r1; r3  // 11101111   
EOR r3, r0, r1; r3  // 10101110   
BIC r3, r0, r1; r3  // 00101000

Branch Control Instructions

These instructions change the flow of execution via jumping to another instruction or subroutine such as conditional jump e.g., branch if register == 0.

Barrel Shifter: As we mentioned in our first articles, the ARM’s arithmetic logic unit has a 32-bit barrel shifter that is capable of shifting and rotating operations. To be able to do this, the value must be in the register Rm. Briefly, the results are pre-processed by the barrel shifter before being processed in ALU.

MOV r0, r0, LSL #1  // Multiply r0 by two  
MOV r1, r1, LSR #2  // Divide r1 by four  
MOV r2, r2, ASR #2  // Divide r2 by four(signed).

If you remember from digital electronic circuits, shifting a number 1 step left is equal to multiplying the number by 2. Shifting the number to 2 steps right means dividing the number by 4.

The last column specifies how many cycle times each command takes. Although the basic logic of all barrel shifter instructions is the same, the only direction of shifting may vary. There are two types of usage of barrel shifters. These uses may be shifting by the value of any register or shifting by a specified fixed number.

In the next article, I am planning to focus on the registers, CPU, and memory structure. Until then, I wish you no blue screen of death.

Continue reading this series of articles:

References