# ISA Overview (1A) 06/12/19 Young Won Lim 6/12/19 Copyright (c) 2014 - 2019 Young W. Lim. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled "GNU Free Documentation License". Please send corrections (or suggestions) to youngwlim@hotmail.com. This document was produced by using LibreOffice. 06/12/19 Young Won Lim 6/12/19 #### Based on ARM System-on-Chip Architecture, 2<sup>nd</sup> ed, Steve Furber ### Types of Instructions Data Processing Instructions Data Transfer Instructions Control Flow Instructions #### **Data Processing Instructions** Arithmetic Operations Bit-wise Logical Operations Register Movement Operations Comparison Operations #### **Arithmetic Operation** ``` ADD r0, r1, r2 ; r0 := r1 + r2 ADC r0, r1, r2 ; r0 := r1 + r2 + C SUB r0, r1, r2 ; r0 := r1 - r2 SBC r0, r1, r2 ; r0 := r1 - r2 + C - 1 RSB r0, r1, r2 ; r0 := r2 + r1 RSC r0, r1, r2 ; r0 := r2 + r1 + C - 1 ``` #### Bit-wise Logical Operations ``` AND r0, r1, r2 ; r0 := r1 + r2 ADC r0, r1, r2 ; r0 := r1 + r2 + C SUB r0, r1, r2 ; r0 := r1 - r2 SBC r0, r1, r2 ; r0 := r1 - r2 + C - 1 RSB r0, r1, r2 ; r0 := r2 + r1 RSC r0, r1, r2 ; r0 := r2 + r1 + C - 1 ``` #### Bit-wise Logical Operations ``` AND r0, r1, r2 ; r0 := r1 + r2 ADC r0, r1, r2 ; r0 := r1 + r2 + C SUB r0, r1, r2 ; r0 := r1 - r2 SBC r0, r1, r2 ; r0 := r1 - r2 + C - 1 RSB r0, r1, r2 ; r0 := r2 + r1 RSC r0, r1, r2 ; r0 := r2 + r1 + C - 1 ``` #### **Register Movement Operations** MOV r0, r2 ; r0 := r2 MVN r0, r2 ; r0 := not r2 Move Negated MOV r0 - r1 #### **Comparison Operations** ``` r1, r2 CMP ; set cc on r1 - r2 Compare r1, r2 CMN ; set cc on r1 + r2 Compare Negated TST r1, r2 ; set cc on r1 and r2 bit Test TEQ r1, r2 Test Equal ; set cc on r1 xor r2 ``` #### **Data Transfer Instrucitons** Single Register Load and Store Instructions Multiple Register Load and Store Instructions Single Register Swap Instructions #### Single Register Load and Store Instructions ``` LDR r0, [r1]; r0 := mem_{32}[r1] ; mem_{32}[r1] := r0 STR r0, [r1] r0, [r1, #4] ; r0 := mem_{32}[r1 + 4] LDR r0, [r1, #4] ; mem_{32}[r1 + 4] := r0 STR r0, [r1, #4]!; r0 := mem_{32}[r1 + 4]; r1 := r1 + 4 LDR r0, [r1, #4]!; mem_{32}[r1 + 4] := r0; r1 := r1 + 4 STR LDR r0, [r1], #4 ; r0 := mem_{32}[r1] ; r1 := r1 + 4 r0, [r1], #4; mem_{32}[r1] := r0; r1 := r1 + 4 STR ``` LDR $$r0 \leftarrow [r1...$$ STR $r0 \rightarrow [r1...$ ### Multiple Register Load and Store Instructions (1) ``` LDMIA r1, \{r0,r2,r5\} ; r0 := mem<sub>32</sub>[r1] ; r2 := mem_{32}[r1+4] ; r5 := mem_{32}[r1+8] ; r2 := mem_{32}[r0], r0 := r0+4 LDMIA r0!, {r2-r4} ; r3 := mem_{32}[r0], r0 := r0+4 ; r4 := mem_{32}[r0], r0 := r0+4 ; mem_{32}[r1] := r2 STMIA r1, {r2-r4} ; mem_{32}[r1+4] := r3 ; mem_{32}[r1+8] := r4 ``` LDM $$r0 \leftarrow \{r1...\}$$ STM $r0 \rightarrow \{r1...\}$ ### Multiple Register Load and Store Instructions (2) LDM $$r0 \leftarrow \{r1...\}$$ STM $r0 \rightarrow \{r1...\}$ ### Multiple Register Load and Store Instructions (3) STMFD r5! {r2-r3}; save regs onto stack LDMIA r0!, {r2-r3} STMIA r1, {r2-r3} LDMFD r5!, {r2-r3}; restore regs from stack **FD Stack** STORE PUSH Growing Downward Filled TOP LOAD POP Contracting Upward Filled TOP IA Block Copy STORE PUSH Growing Upward Empty TOP LOAD POP Contracting Downward Empty TOP ### Single Register Swap Instruction ADR r0, SEMAPHORE SWAP r1, r1, [r0] ; exchange byte #### **Control Flow Instructions** Branch Instruction Branch and Link Instruction Subroutine Return Instruction Supervisor Call Instruction #### **Branch Instructions** ``` B LABEL ... LABEL ... BL SUBR ; branch to SUBR ... ; return to here SUBR ... ; subroutine entry point MOV pc, r14 ; return ``` #### Branch and link Instruction ``` BL SUBR ; branch to SUBR ... ; return to here SUBR ... ; subroutine entry point MOV pc, r14 ; return BL SUB1 ... SUB1 STMFD r13!, {r0-r2, r14} BL SUB2 ... SUB2 ``` #### Subroutine return address ``` SUB2 ... MOV pc, r14 ; copy r14 into r15 to return SUB1 STMFD r13!, {r0-r2,r14}; save work regs and link BL SUB2 ... LDMFD r13!, {r0-r2,pc} ``` ### Supervisor calls SWI SWI\_WriteC ; output r0[7:0] SWI SWI\_Exit ; return to monitor ### Supervisor calls SWI SWI\_WriteC ; output r0[7:0] SWI SWI\_Exit ; return to monitor ## **Supervisor Branch conditions** | В | Unconditional | Always take this branch | |-----|------------------|---------------------------------------------------| | BAL | Always | Always take this branch | | BEQ | Equal | Comparison equal or zero result | | BNE | Not Equal | Comparison not equal or non-zero result | | BPL | Plus | Result positive or zero | | BMI | Minus | Result minus or negative | | BCC | Carry Clear | Arithmetic operation did not give carry-out | | BLO | Lower | Unsigned comparison gave lower | | BCS | Carry Set | Arithmetic operation gave carry-out | | BHS | Higher or Same | Unsigned comparison gave higher or same | | BVC | Overflow Clear | Signed integer operation; no overflow occurred | | BVS | Overflow Set | Signed integer comparison; overflow occurred | | BGT | Greater Than | Signed integer comparison gave greater than | | BGE | Greater or Equal | Signed integer comparison gave greater or equal | | BLT | Less Than | Signed integer comparison gave less than | | BLE | Less or Equal | Signed integer comparison gave less than or equal | | BHI | Higher | Unsigned comparison gave higher | | BLS | Lower or same | Unsigned comparison gave lower or same | | | | | #### References - [1] ftp://ftp.geoinfo.tuwien.ac.at/navratil/HaskellTutorial.pdf - [2] https://www.umiacs.umd.edu/~hal/docs/daume02yaht.pdf