Download presentation
Presentation is loading. Please wait.
Published byKathleen Eaton Modified over 6 years ago
1
Assembly Language Programming IV: shift, struct, recursion
2
Homework Reading PAL, pp
3
Using C Structs in Assembly Code
How do we access a C structure such as: #define NAMELEN 20 struct teststruct { int x, int y; char name[NAMELEN]; }t; t.x = 2; t.y = 5; strncpy(t.name, “wilson”, NAMELEN); trystruct(&t); /* pass to asm via pointer*/
4
Using C Structs in Assembly Code
Assembly code would look like: Movl 4(%esp),%edx # ptr to t: edx=0x0200e0 Movl (%edx),%eax # x itself: eax = 2 Movl 4(%edx),%ebx # y itself: ebx = 5 Movb 8(%edx),%cl # 1st string char: cl = ‘w’ struct teststruct t.x t.y ‘w’ ‘i’ ‘l’ ‘s’ ‘o’ ‘n’ ‘\0’ %esp Stack 0x0200e0 0x0200e4 0x0200e . . . Return %eip 0x0200e0 0xfffff4 0xfffff8 0xfffffc
5
Using C Structs in Assembly Code
However, we would normally have a pointer to string: #define NAMELEN 20 char array [NAMELEN]; struct teststruct { int x, int y; char *name; }t; t.x = 2; t.y = 5; t.name = array; strncpy(array, “wilson”, NAMELEN); trystruct(&t); /* pass to asm via pointer*/
6
Using C Structs in Assembly Code
Assembly code would look like: movl 4(%esp),%edx # ptr to t: edx = 0x0200e0 movl (%edx),%eax # x itself: eax = 2 movl 4(%edx),%ebx # y itself: ebx = 5 movl 8(%edx),%edx # ptr to string: edx = 0x20158 movb (%edx),%cl # first string char: cl = ‘w’ struct teststruct t.x t.y t.name %esp Stack 0x0200e0 0x0200e4 0x0200e . . . &t Return %eip ‘w’ ‘i’ ‘l’ ‘s’ ‘o’ ‘n’ ‘\0’ 0xfffff4 0xfffff8 0xfffffc 0x
7
Introduction to Shift Instructions
We can shift the bits in a byte, word, or long word by a variable number of positions These are the machine level instructions used to implement the C language operators << and >> SAL / SHL are the left shift instructions for signed or unsigned data. SAL and SHL performs the same operations SAR is the right shift instruction for signed data (arithmetic right shift) SHR is the right shift instruction for unsigned data (logical right shift)
8
Introduction to Shift Instructions
The SAL / SHL Instruction (Signed / Unsigned) The SAR Instruction (Signed or Arithmetic shift) The SHR Instruction (Unsigned or logical shift) CF CF CF
9
Introduction to Shift Instructions
The target of the shifting can be a register or memory location (byte, word, or long word) The count for the number of bits to shift can be specified with immediate data (constant) or the %cl register (variable) Examples: sall $4, %eax # logical left shift of %eax by 4 bits sarb %cl, label # arithmetic right shift of memory byte # by a variable value stored in the %cl
10
Introduction to Shift Instructions
Multiplication by 2N can be done via left shift sall $4, %eax # %eax times 24 Can combine left shifts and addition Division by 2N can be done via right shift sarb %cl, label # memory byte / 2%cl Can combine right shifts and subtraction
11
Introduction to Multiply and Divide
Unsigned Multiply and Divide mul div Signed Multiply and Divide imul idiv We won’t do much with these because of the complexity involved - especially for divide
12
Introduction to Multiply and Divide
Multiply always operates with %al, %ax, or %eax Result needs more bits than either operand Syntax: mulb %bl %ax %al * %bl mulw %bx %dx, %ax %ax * %bx mull %ebx %edx, %eax %eax * %ebx
13
Introduction to Multiply and Divide
Register Pictures (Byte) (Word) %bl * %ax %bx * %dx, %ax
14
Example – For/While Loop and mul
C code for n = 5! (done as a for loop) unsigned int i, n; n = 1; for (i = 1; i <= 5; i++) n *= i; C code for n = 5! (done as a while loop) n = i = 1; while (i <= 5) n *= i++;
15
Example – For/While Loop and mul
Assembly code for n = 5! (byte * byte = word) movb $1, %bl # i = 1 movb %bl, %al # n = i = 1 loop: cmpb $5, %bl # while (%bl <= 5) ja exit # %bl > 5 now mulb %bl # %ax = %al * %bl incb %bl # incr %bl jmp loop # and loop exit: # 5! in %ax Note: No difference between for and while in assy
16
Example – For/While Loop and mul
Assembly code for n = 5! (word * word = long) movw $1, %bx # i = 1 movw %bx, %ax # n = i = 1 loop: cmpw $5, %bx # while (%bx <= 5) ja exit # %bx > 5 now mulw %bx # %ax = %ax * %bx # %dx = 0 now incw %bx # incr %bx jmp loop # and loop exit: # 5! in %eax
17
Recursive Factorial Main program to call recursive factorial subr
.text pushl $5 call factorial addl $4, %esp ret
18
Recursive Factorial factorial: # works up to 16 bit results
movl 4(%esp), %eax cmpl $1, %eax jna return decl %eax pushl %eax call factorial addl $4, %esp movw 4(%esp), %bx mulw %bx # 16 lsbs go to %ax return: # ignore msbs in %dx ret .end
19
Recursive Factorial Stack Operations (while calling)
Stack Operations (while returning) %esp at main Decr & 5th Call Decr & 4th Call Decr & 3rd Call Decr & 2nd Call 1st Call %eip (fact) value 1 %eip (fact) value 2 %eip (fact) value 3 %eip (fact) value 4 %eip (main) value 5 arg ==1 so 1st Return Multiply & 2nd Return Multiply & 3rd Return Multiply & 4th Return Multiply & 5th Return %eax = 1 %eax = 2 %eax = 6 %eax = 24 %eax = 120
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.