Presentation is loading. Please wait.

Presentation is loading. Please wait.

© 2000 Morgan Kaufman Overheads for Computers as Components ARM instruction set zARM versions. zARM assembly language. zARM programming model. zARM memory.

Similar presentations


Presentation on theme: "© 2000 Morgan Kaufman Overheads for Computers as Components ARM instruction set zARM versions. zARM assembly language. zARM programming model. zARM memory."— Presentation transcript:

1

2 © 2000 Morgan Kaufman Overheads for Computers as Components ARM instruction set zARM versions. zARM assembly language. zARM programming model. zARM memory organization. zARM data operations. zARM flow of control.

3 © 2000 Morgan Kaufman Overheads for Computers as Components ARM versions zARM architecture has been extended over several versions. zWe will concentrate on ARM7.

4 © 2000 Morgan Kaufman Overheads for Computers as Components ARM assembly language zFairly standard assembly language: LDR r0,[r8] ; a comment labelADD r4,r0,r1

5 © 2000 Morgan Kaufman Overheads for Computers as Components ARM programming model r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12 r13 r14 r15 (PC) CPSR 31 0 N Z C V

6 © 2000 Morgan Kaufman Overheads for Computers as Components Endianness zRelationship between bit and byte/word ordering defines endianness: byte 3byte 2byte 1byte 0 byte 1byte 2byte 3 bit 31 bit 0 bit 31 little-endianbig-endian

7 © 2000 Morgan Kaufman Overheads for Computers as Components ARM data types zWord is 32 bits long. zWord can be divided into four 8-bit bytes. zARM addresses cam be 32 bits long. zAddress refers to byte. yAddress 4 starts at byte 4. zCan be configured at power-up as either little- or bit-endian mode.

8 © 2000 Morgan Kaufman Overheads for Computers as Components ARM status bits zEvery arithmetic, logical, or shifting operation sets CPSR bits: yN (negative), Z (zero), C (carry), V (overflow). zExamples: y-1 + 1 = 0: NZCV = 0110. y2 31 -1+1 = -2 31 : NZCV = 0101.

9 © 2000 Morgan Kaufman Overheads for Computers as Components ARM data instructions zBasic format: ADD r0,r1,r2 yComputes r1+r2, stores in r0. zImmediate operand: ADD r0,r1,#2 yComputes r1+2, stores in r0.

10 © 2000 Morgan Kaufman Overheads for Computers as Components ARM data instructions zADD, ADC : add (w. carry) zSUB, SBC : subtract (w. carry) zRSB, RSC : reverse subtract (w. carry) zMUL, MLA : multiply (and accumulate) z AND, ORR, EOR z BIC : bit clear z LSL, LSR : logical shift left/right z ASL, ASR : arithmetic shift left/right z ROR : rotate right z RRX : rotate right extended with C

11 © 2000 Morgan Kaufman Overheads for Computers as Components Data operation varieties zLogical shift: yfills with zeroes. zArithmetic shift: yfills with ones. zRRX performs 33-bit rotate, including C bit from CPSR above sign bit.

12 © 2000 Morgan Kaufman Overheads for Computers as Components ARM comparison instructions zCMP : compare zCMN : negated compare zTST : bit-wise test zTEQ : bit-wise negated test zThese instructions set only the NZCV bits of CPSR.

13 © 2000 Morgan Kaufman Overheads for Computers as Components ARM move instructions zMOV, MVN : move (negated) MOV r0, r1 ; sets r0 to r1

14 © 2000 Morgan Kaufman Overheads for Computers as Components ARM load/store instructions zLDR, LDRH, LDRB : load (half-word, byte) zSTR, STRH, STRB : store (half-word, byte) zAddressing modes:  register indirect : LDR r0,[r1]  with second register : LDR r0,[r1,-r2]  with constant : LDR r0,[r1,#4]

15 © 2000 Morgan Kaufman Overheads for Computers as Components ARM ADR pseudo-op zCannot refer to an address directly in an instruction. zGenerate value by performing arithmetic on PC. zADR pseudo-op generates instruction required to calculate address: ADR r1,FOO

16 © 2000 Morgan Kaufman Overheads for Computers as Components Example: C assignments zC: x = (a + b) - c; zAssembler: ADR r4,a; get address for a LDR r0,[r4]; get value of a ADR r4,b; get address for b, reusing r4 LDR r1,[r4]; get value of b ADD r3,r0,r1; compute a+b ADR r4,c; get address for c LDR r2[r4]; get value of c

17 © 2000 Morgan Kaufman Overheads for Computers as Components C assignment, cont’d. SUB r3,r3,r2; complete computation of x ADR r4,x; get address for x STR r3[r4]; store value of x

18 © 2000 Morgan Kaufman Overheads for Computers as Components Example: C assignment zC: y = a*(b+c); zAssembler: ADR r4,b ; get address for b LDR r0,[r4] ; get value of b ADR r4,c ; get address for c LDR r1,[r4] ; get value of c ADD r2,r0,r1 ; compute partial result ADR r4,a ; get address for a LDR r0,[r4] ; get value of a

19 © 2000 Morgan Kaufman Overheads for Computers as Components C assignment, cont’d. MUL r2,r2,r0 ; compute final value for y ADR r4,y ; get address for y STR r2,[r4] ; store y

20 © 2000 Morgan Kaufman Overheads for Computers as Components Example: C assignment zC: z = (a << 2) | (b & 15); zAssembler: ADR r4,a ; get address for a LDR r0,[r4] ; get value of a MOV r0,r0,LSL 2 ; perform shift ADR r4,b ; get address for b LDR r1,[r4] ; get value of b AND r1,r1,#15 ; perform AND ORR r1,r0,r1 ; perform OR

21 © 2000 Morgan Kaufman Overheads for Computers as Components C assignment, cont’d. ADR r4,z ; get address for z STR r1,[r4] ; store value for z

22 © 2000 Morgan Kaufman Overheads for Computers as Components Additional addressing modes zBase-plus-offset addressing: LDR r0,[r1,#16] yLoads from location r1+16 zAuto-indexing increments base register: LDR r0,[r1,#16]! zPost-indexing fetches, then does offset: LDR r0,[r1],#16 yLoads r0 from r1, then adds 16 to r1.

23 © 2000 Morgan Kaufman Overheads for Computers as Components ARM flow of control zAll operations can be performed conditionally, testing CPSR: yEQ, NE, CS, CC, MI, PL, VS, VC, HI, LS, GE, LT, GT, LE zBranch operation: B #100 yCan be performed conditionally.

24 © 2000 Morgan Kaufman Overheads for Computers as Components Example: if statement zC: if (a > b) { x = 5; y = c + d; } else x = c - d; zAssembler: ; compute and test condition ADR r4,a ; get address for a LDR r0,[r4] ; get value of a ADR r4,b ; get address for b LDR r1,[r4] ; get value for b CMP r0,r1 ; compare a < b BGE fblock ; if a >= b, branch to false block

25 © 2000 Morgan Kaufman Overheads for Computers as Components If statement, cont’d. ; true block MOV r0,#5 ; generate value for x ADR r4,x ; get address for x STR r0,[r4] ; store x ADR r4,c ; get address for c LDR r0,[r4] ; get value of c ADR r4,d ; get address for d LDR r1,[r4] ; get value of d ADD r0,r0,r1 ; compute y ADR r4,y ; get address for y STR r0,[r4] ; store y B after ; branch around false block

26 © 2000 Morgan Kaufman Overheads for Computers as Components If statement, cont’d. ; false block fblock ADR r4,c ; get address for c LDR r0,[r4] ; get value of c ADR r4,d ; get address for d LDR r1,[r4] ; get value for d SUB r0,r0,r1 ; compute a-b ADR r4,x ; get address for x STR r0,[r4] ; store value of x after...

27 © 2000 Morgan Kaufman Overheads for Computers as Components Example: Conditional instruction implementation ; true block MOVLT r0,#5 ; generate value for x ADRLT r4,x ; get address for x STRLT r0,[r4] ; store x ADRLT r4,c ; get address for c LDRLT r0,[r4] ; get value of c ADRLT r4,d ; get address for d LDRLT r1,[r4] ; get value of d ADDLT r0,r0,r1 ; compute y ADRLT r4,y ; get address for y STRLT r0,[r4] ; store y

28 © 2000 Morgan Kaufman Overheads for Computers as Components Conditional instruction implementation, cont’d. ; false block ADRGE r4,c ; get address for c LDRGE r0,[r4] ; get value of c ADRGE r4,d ; get address for d LDRGE r1,[r4] ; get value for d SUBGE r0,r0,r1 ; compute a-b ADRGE r4,x ; get address for x STRGE r0,[r4] ; store value of x

29 © 2000 Morgan Kaufman Overheads for Computers as Components Example: switch statement zC: switch (test) { case 0: … break; case 1: … } zAssembler: ADR r2,test ; get address for test LDR r0,[r2] ; load value for test ADR r1,switchtab ; load address for switch table LDR r1,[r1,r0,LSL #2] ; index switch table switchtab DCD case0 DCD case1...

30 © 2000 Morgan Kaufman Overheads for Computers as Components Example: FIR filter zC: for (i=0, f=0; i<N; i++) f = f + c[i]*x[i]; zAssembler ; loop initiation code MOV r0,#0 ; use r0 for I MOV r8,#0 ; use separate index for arrays ADR r2,N ; get address for N LDR r1,[r2] ; get value of N MOV r2,#0 ; use r2 for f

31 © 2000 Morgan Kaufman Overheads for Computers as Components FIR filter, cont’.d ADR r3,c ; load r3 with base of c ADR r5,x ; load r5 with base of x ; loop body loop LDR r4,[r3,r8] ; get c[i] LDR r6,[r5,r8] ; get x[i] MUL r4,r4,r6 ; compute c[i]*x[i] ADD r2,r2,r4 ; add into running sum ADD r8,r8,#4 ; add one word offset to array index ADD r0,r0,#1 ; add 1 to i CMP r0,r1 ; exit? BLT loop ; if i < N, continue

32 © 2000 Morgan Kaufman Overheads for Computers as Components ARM subroutine linkage zBranch and link instruction: BL foo yCopies current PC to r14. zTo return from subroutine: MOV r15,r14

33 © 2000 Morgan Kaufman Overheads for Computers as Components Nested subroutine calls zNesting/recursion requires coding convention: f1LDR r0,[r13] ; load arg into r0 from stack ; call f2() STR r13!,[r14] ; store f1’s return adrs STR r13!,[r0] ; store arg to f2 on stack BL f2 ; branch and link to f2 ; return from f1() SUB r13,#4 ; pop f2’s arg off stack LDR r13!,r15 ; restore register and return

34 © 2000 Morgan Kaufman Overheads for Computers as Components Summary zLoad/store architecture zMost instructions are RISCy, operate in single cycle. ySome multi-register operations take longer. zAll instructions can be executed conditionally.


Download ppt "© 2000 Morgan Kaufman Overheads for Computers as Components ARM instruction set zARM versions. zARM assembly language. zARM programming model. zARM memory."

Similar presentations


Ads by Google