ECE 471 Embedded Systems Lecture 9

Similar documents
ECE 471 Embedded Systems Lecture 7

ECE 471 Embedded Systems Lecture 5

ECE 571 Advanced Microprocessor-Based Design Lecture 3

ECE 471 Embedded Systems Lecture 6

ECE 498 Linux Assembly Language Lecture 5

ECE 471 Embedded Systems Lecture 10

ECE 471 Embedded Systems Lecture 9

ECE 471 Embedded Systems Lecture 7

ECE 471 Embedded Systems Lecture 6

ARM Instruction Set Architecture. Jin-Soo Kim Computer Systems Laboratory Sungkyunkwan University

ARM Cortex M3 Instruction Set Architecture. Gary J. Minden March 29, 2016

ARM Cortex-A9 ARM v7-a. A programmer s perspective Part 2

The ARM Instruction Set

ECE 471 Embedded Systems Lecture 6

MNEMONIC OPERATION ADDRESS / OPERAND MODES FLAGS SET WITH S suffix ADC

STEVEN R. BAGLEY ARM: PROCESSING DATA

Writing ARM Assembly. Steven R. Bagley

ARM Instruction Set. Computer Organization and Assembly Languages Yung-Yu Chuang. with slides by Peng-Sheng Chen

ARM Instruction Set. Introduction. Memory system. ARM programmer model. The ARM processor is easy to program at the

Cortex M3 Programming

ARM Assembly Programming

The ARM Cortex-M0 Processor Architecture Part-2

ARM Assembly Language

ARM Architecture and Instruction Set

Comparison InstruCtions

Chapter 3: ARM Instruction Set [Architecture Version: ARMv4T]

ARM-7 ADDRESSING MODES INSTRUCTION SET

Chapter 15. ARM Architecture, Programming and Development Tools

Processor Status Register(PSR)

CS 310 Embedded Computer Systems CPUS. Seungryoul Maeng

ARM Assembly Language. Programming

ECE 571 Advanced Microprocessor-Based Design Lecture 4

ENGN1640: Design of Computing Systems Topic 03: Instruction Set Architecture Design

ARM Shift Operations. Shift Type 00 - logical left 01 - logical right 10 - arithmetic right 11 - rotate right. Shift Amount 0-31 bits

Chapter 2 Instructions Sets. Hsung-Pin Chang Department of Computer Science National ChungHsing University

VE7104/INTRODUCTION TO EMBEDDED CONTROLLERS UNIT III ARM BASED MICROCONTROLLERS

ARM Instruction Set Dr. N. Mathivanan,

Chapter 15. ARM Architecture, Programming and Development Tools

18-349: Introduction to Embedded Real- Time Systems Lecture 3: ARM ASM

ARM Cortex-M4 Architecture and Instruction Set 2: General Data Processing Instructions

Lecture 4 (part 2): Data Transfer Instructions

The ARM instruction set

Branch Instructions. R type: Cond

CprE 288 Introduction to Embedded Systems Course Review for Exam 3. Instructors: Dr. Phillip Jones

ARM7TDMI Instruction Set Reference

Cortex-M3 Instruction Set

3 Assembly Programming (Part 2) Date: 07/09/2016 Name: ID:

Embedded Systems Ch 12B ARM Assembly Language

Cortex-M4F Instructions used in ARM Assembly for Embedded Applications (ISBN )

Basic ARM InstructionS

The PAW Architecture Reference Manual

Instruction Set. ARM810 Data Sheet. Open Access - Preliminary

Outline. ARM Introduction & Instruction Set Architecture. ARM History. ARM s visible registers

(2) Part a) Registers (e.g., R0, R1, themselves). other Registers do not exists at any address in the memory map

Introduction to the ARM Processor Using Intel FPGA Toolchain. 1 Introduction. For Quartus Prime 16.1

Control Flow Instructions

EE251: Tuesday September 5

Bitwise Instructions

EE319K Spring 2015 Exam 1 Page 1. Exam 1. Date: Feb 26, 2015

Introduction to the ARM Processor Using Altera Toolchain. 1 Introduction. For Quartus II 14.0

Instruction Set Architecture (ISA)

Exam 1. Date: Oct 4, 2018

Introduction to C. Write a main() function that swaps the contents of two integer variables x and y.

Hi Hsiao-Lung Chan, Ph.D. Dept Electrical Engineering Chang Gung University, Taiwan

Assembly Language. CS2253 Owen Kaser, UNBSJ

Lecture 15 ARM Processor A RISC Architecture

EEM870 Embedded System and Experiment Lecture 4: ARM Instruction Sets

Exam 1 Fun Times. EE319K Fall 2012 Exam 1A Modified Page 1. Date: October 5, Printed Name:

Introduction to Embedded Systems EE319K (Gerstlauer), Spring 2013

EE319K Exam 1 Summer 2014 Page 1. Exam 1. Date: July 9, Printed Name:

The ARM processor. Morgan Kaufman ed Overheads for Computers as Components

AND SOLUTION FIRST INTERNAL TEST

ARM Cortex-M4 Programming Model Arithmetic Instructions. References: Textbook Chapter 4, Chapter ARM Cortex-M Users Manual, Chapter 3

3. The Instruction Set

EE319K Fall 2013 Exam 1B Modified Page 1. Exam 1. Date: October 3, 2013

Architecture. Digital Computer Design

ARM Cortex-M4 Programming Model Logical and Shift Instructions

Raspberry Pi / ARM Assembly. OrgArch / Fall 2018

Topic 10: Instruction Representation

EE319K Spring 2016 Exam 1 Solution Page 1. Exam 1. Date: Feb 25, UT EID: Solution Professor (circle): Janapa Reddi, Tiwari, Valvano, Yerraballi

Embedded assembly is more useful. Embedded assembly places an assembly function inside a C program and can be used with the ARM Cortex M0 processor.

ARM Cortex-M4 Programming Model Memory Addressing Instructions

Chapters 3. ARM Assembly. Embedded Systems with ARM Cortext-M. Updated: Wednesday, February 7, 2018

F28HS2 Hardware-Software Interfaces. Lecture 6: ARM Assembly Language 1

ARM Instruction Set 1

ECE 471 Embedded Systems Lecture 12

Unsigned and signed integer numbers

The ARM Architecture T H E A R C H I T E C T U R E F O R TM T H E D I G I T A L W O R L D

ARM Processors ARM ISA. ARM 1 in 1985 By 2001, more than 1 billion ARM processors shipped Widely used in many successful 32-bit embedded systems

University of California, San Diego CSE 30 Computer Organization and Systems Programming Winter 2014 Midterm Dr. Diba Mirza

Chapters 5. Load & Store. Embedded Systems with ARM Cortex-M. Updated: Thursday, March 1, 2018

Control Flow. September 2, Indiana University. Geoffrey Brown, Bryce Himebaugh 2015 September 2, / 21

Overview COMP Microprocessors and Embedded Systems. Lectures 14: Making Decisions in C/Assembly Language II

Developing StrongARM/Linux shellcode

Assembler: Basics. Alberto Bosio October 20, Univeristé de Montpellier

The Original Instruction Pipeline

ARM Cortex-M4 Architecture and Instruction Set 3: Branching; Data definition and memory access instructions

Chapter 2. Instructions: Language of the Computer

ECE 471 Embedded Systems Lecture 8

CprE 488 Embedded Systems Design. Lecture 3 Processors and Memory

Transcription:

ECE 471 Embedded Systems Lecture 9 Vince Weaver http://web.eece.maine.edu/~vweaver vincent.weaver@maine.edu 18 September 2017

How is HW#3 going? Announcements 1

HW3 Notes Writing int to string conversion is a complex test. Good reverse engineering experience. Block of code from one of my older projects when I wasn t quite as good at ARM assembly. What does.lcomm do? Reserves region in the BSS..lcomm buffer,20 is similar to C char buffer[20] Went over algorithm. Need to divide by 10, put remainder into array backwards, then keep dividing the quotient. Also need to convert to ASCII. 2

ARM32 Assembly Review 3

Arithmetic Instructions Operate on 32-bit integers. Most of these take optional s to set status flag adc v1 add with carry add v1 add rsb v1 reverse subtract (immediate - rx) rsc v1 reverse subtract with carry sbc v1 subtract with carry sub v1 subtract 4

Logic Instructions and v1 bitwise and bfc?? bitfield clear, clear bits in reg bfi?? bitfield insert bic v1 bitfield clear: and with negated value clz v7 count leading zeros eor v1 exclusive or (name shows 6502 heritage) orn v6 or not orr v1 bitwise or 5

Register Manipulation mov, movs v1 move register mvn, mvns v1 move inverted 6

Loading Constants In general you can get a 12-bit immediate which is 8 bits of unsigned and 4-bits of even rotate (rotate by 2*value). 0 7 6 5 4 3 2 1 0 1 1 0 7 6 5 4 3 2 2 3 2 1 0 7 6 5 4... 15 7 6 5 4 3 2 1 0 This allows any single bit mask, and also allows masking of any four sub-bytes. You can specify you want the assembler to try to make 7

the immediate for you: ldr r0,=0xff ldr r0,=label If it can t make the immediate value, it will store in nearby in a literal pool and do a memory read. 8

Barrel Shift in ALU instructions If second source is a register, can optionally shift: LSL Logical shift left LSR Logical shift right ASR Arithmetic shift right ROR Rotate Right RRX Rotate Right with Extend bit zero into C, C into bit 31 (33-bit rotate) Why no ASL? Adding s lsls, lsrs puts shifted out bit into C. 9

shift pseudo instructions lsr r0, #3 is same as mov r0,r0 LSR #3 For example: add r1, r2, r3, lsr #4 r1 = r2 + (r3>>4) Another example (what does this do): add r1, r2, r2, lsl #2 10

Fast multipliers are optional For 64-bit results, Multiply Instructions mla v2 multiply two registers, add in a third (4 arguments) mul v2 multiply two registers, only least sig 32bit saved smlal v3m 32x32+64 = 64-bit (result and add source, reg pair rdhi,rdlo) smull v3m 32x32 = 64-bit umlal v3m unsigned 32x32+64 = 64-bit umull v3m unsigned 32x32=64-bit 11

Divide Instructions On some machines it s just not there. Original Pi. Why? What do you do if you want to divide? Shift and subtract (long division) Multiply by reciprocal. 12

Prefixed instructions Most instructions can be prefixed with condition codes: EQ, NE (equal) Z==1/Z==0 MI, PL (minus/plus) N==1/N==0 HI, LS (unsigned higher/lower) C==1&Z==0/C==0 Z==1 GE, LT (greaterequal/lessthan) N==V/N!=V GT, LE (greaterthan, lessthan) N==V&Z==0/N!=V Z==1 CS,HS, CC,LO (carry set,higher or same/clear) C==1,C==0 VS, VC (overflow set / clear) V==1,V==0 AL (always) (this is the default) 13

Setting Flags add r1,r2,r3 adds r1,r2,r3 set condition flag addeqs r1,r2,r3 set condition flag and prefix compiler and disassembler like addseq, GNU as doesn t? 14

if (x == 1 ) a+=2; else b-=2; cmp r1, #5 addeq r2,r2,#2 subne r3,r3,#2 Conditional Execution 15

Load/Store Instructions ldr v1 load register ldrb v1 load register byte ldrd v5 load double, into consecutive registers (Rd even) ldrh v1 load register halfword, zero extends ldrsb v1 load register signed byte, sign-extends ldrsh v1 load register halfword, sign-extends str v1 store register strb v1 store byte strd v5 store double strh v1 store halfword 16

Addressing Modes Regular ldrb r1, [r2] @ register ldrb r1, [r2,#20] @ register/offset ldrb r1, [r2,+r3] @ register + register ldrb r1, [r2,-r3] @ register - register ldrb r1, [r2,r3, LSL #2] @ register +/- register, shift Pre-index. Calculate address, load, then store back ldrb r1, [r2, #20]! @ pre-index. Load from 17

r2+20 then write back into r2 ldrb r1, [r2, r3]! @ pre-index. register ldrb r1, [r2, r3, LSL #4]! @ pre-index. shift Post-index: load from base, then add in and write new value to base ldrb r1, [r2],#+1 @ post-index. load, then add value to r2 ldrb r1, [r2],r3 @ post-index register ldrb r1, [r2],r3, LSL #4 @ post-index shift 18

Why some of these? ldrb r1, [r2,#20] @ register/offset Useful for structs in C (i.e. something.else=4;) ldrb r1, [r2,r3, LSL #2] @ register +/- register, shift Useful for indexing arrays of integers (a[5]=4;) 19

Comparison Instructions Updates status flag, no need for s cmp v1 compare (subtract but discard result) cmn v1 compare negative (add) teq v1 tests if two values equal (xor) (preserves carry) tst v1 test (and) 20

Control-Flow Instructions Can use all of the condition code prefixes. Branch to a label, which is +/- 32MB from PC b v1 branch bl v1 branch and link (return value stored in lr ) bx v4t branch to offset or reg, possible THUMB switch blx v5 branch and link to register, with possible THUMB switch mov pc,lr v1 return from a link 21

Load/Store multiple (stack?) In general, no interrupt during instruction so long instruction can be bad in embedded Some of these have been deprecated on newer processors ldm load multiple memory locations into consecutive registers stm store multiple, can be used like a PUSH instruction push and pop are thumb equivalent 22

Can have address mode and! (update source): IA increment after ( start at Rn) IB increment before ( start at Rn+4) DA decrement after DB decrement before Can have empty/full. Full means SP points to a used location, Empty means it is empty: FA Full ascending 23

FD Full descending EA Empty ascending ED Empty descending Recent machines use the ARM-Thumb Proc Call Standard which says a stack is Full/Descending, so use LDMFD/STMFD. What does stm SP!, {r0,lr} then ldm SP!, {r0,pc,pc} do? 24

System Instructions svc, swi software interrupt takes immediate, but ignored. mrs, msr copy to/from status register. use to clear interrupts? Can only set flags from userspace cdp perform coprocessor operation mrc, mcr move data to/from coprocessor ldc, stc load/store to coprocessor from memory 25

Co-processor 15 is the system control coprocessor and is used to configure the processor. Co-processor 14 is the debugger 11 is double-precision floating point 10 is singleprecision fp as well as VFP/SIMD control 0-7 vendor specific 26

Other Instructions swp atomic swap value between register and memory (deprecated armv7) ldrex/strex atomic load/store (armv6) wfe/sev armv7 low-power spinlocks pli/pld preload instructions/data dmb/dsb memory barriers 27

Pseudo-Instructions adr nop add immediate to PC, store address in reg no-operation 28

Fancy ARMv6 mla multiply/accumulate (armv6) mls multiply and subtract pkh pack halfword (armv6) qadd, qsub, etc. saturating add/sub (armv6) rbit reverse bit order (armv6) rbyte reverse byte order (armv6) rev16, revsh reverse halfwords (armv6) sadd16 do two 16-bit signed adds (armv6) sadd8 do 4 8-bit signed adds (armv6) 29

sasx (armv6) sbfx signed bit field extract (armv6) sdiv signed divide (only armv7-r) udiv unsigned divide (armv7-r only) sel select bytes based on flag (armv6) sm* signed multiply/accumulate setend set endianess (armv6) sxtb sign extend byte (armv6) tbb table branch byte, jump table (armv6) teq test equivalence (armv6) u* unsigned partial word instructions 30

Floating Point ARM floating point varies and is often optional. various versions of vector floating point unit vfp3 has 16 or 32 64-bit registers Advanced SIMD reuses vfp registers Can see as 16 128-bit regs q0-q15 or 32 64-bit d0-d31 and 32 32-bit s0-s31 SIMD supports integer, also 16-bit? Polynomial? FPSCR register (flags) 31

Setting Flags add r1,r2,r3 adds r1,r2,r3 set condition flag addeqs r1,r2,r3 set condition flag and prefix compiler and disassembler like addseq, GNU as doesn t? 32

i f ( x == 5 ) a+=2; e l s e b =2; e l s e : Conditional Execution cmp r1, #5 bne e l s e add r2, r2,#2 b done sub r3, r3,#2 33

done : cmp r1, #5 addeq r2,r2,#2 subne r3,r3,#2 34

ARM Instruction Set Encodings ARM 32 bit encoding THUMB 16 bit encoding THUMB-2 THUMB extended with 32-bit instructions STM32L only has THUMB2 Original Raspberry Pis do not have THUMB2 Raspberry Pi 2/3 does have THUMB2 THUMB-EE extensions for running in JIT runtime AARCH64 64 bit. Relatively new. Completely different from ARM32 35

Recall the ARM32 encoding ADD{S}<c> <Rd>,<Rn>,<Rm>{,<shift>} Data Immediate Processing ADD opcode 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 cond 0 0 0 0 1 0 0 Opcode S Rn 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Rd Shift imm5 Shift typ Sh Reg Rm Immediate value (if immediate) 36

THUMB Most instructions length 16-bit (a few 32-bit) Only r0-r7 accessible normally add, cmp, mov can access high regs Some operands (sp, lr, pc) implicit Can t always update sp or pc anymore. No prefix/conditional execution Only two arguments to opcodes (some exceptions for small constants: add r0,r1,#1) 8-bit constants rather than 12-bit 37

Limited addressing modes: [rn,rm], [rn,#imm], [pc sp,#imm] No shift parameter ALU instructions Makes assumptions about S setting flags (gas doesn t let you superfluously set it, causing problems if you naively move code to THUMB-2) new push/pop instructions (subset of ldm/stm), neg (to negate), asr,lsl,lsr,ror, bic (logic bit clear) 38

THUMB/ARM interworking See print string armthumb.s BX/BLX instruction to switch mode. If target is a label, always switchmode If target is a register, low bit of 1 means THUMB, 0 means ARM Can also switch modes with ldrm, ldm, or pop with PC as a destination (on armv7 can enter with ALU op with PC destination) Can use.thumb directive,.arm for 32-bit. 39