Overview of Assembly Language - PowerPoint PPT Presentation

About This Presentation
Title:

Overview of Assembly Language

Description:

Title: Interrupts & Input/output Author: S. Dandamudi Last modified by: Sivarama Dandamudi Created Date: 11/24/1998 12:49:00 AM Document presentation format – PowerPoint PPT presentation

Number of Views:48
Avg rating:3.0/5.0
Slides: 80
Provided by: S316
Category:

less

Transcript and Presenter's Notes

Title: Overview of Assembly Language


1
Overview of Assembly Language
  • Chapter 9
  • S. Dandamudi

2
Outline
  • Assembly language statements
  • Data allocation
  • Where are the operands?
  • Addressing modes
  • Register
  • Immediate
  • Direct
  • Indirect
  • Data transfer instructions
  • mov, xchg, and xlat
  • PTR directive
  • Overview of assembly language instructions
  • Arithmetic
  • Conditional
  • Logical
  • Shift
  • Rotate
  • Defining constants
  • EQU and directives
  • Macros
  • Illustrative examples

3
Assembly Language Statements
  • Three different classes
  • Instructions
  • Tell CPU what to do
  • Executable instructions with an op-code
  • Directives (or pseudo-ops)
  • Provide information to assembler on various
    aspects of the assembly process
  • Non-executable
  • Do not generate machine language instructions
  • Macros
  • A shorthand notation for a group of statements
  • A sophisticated text substitution mechanism with
    parameters

4
Assembly Language Statements (contd)
  • Assembly language statement format
  • label mnemonic operands comment
  • Typically one statement per line
  • Fields in are optional
  • label serves two distinct purposes
  • To label an instruction
  • Can transfer program execution to the labeled
    instruction
  • To label an identifier or constant
  • mnemonic identifies the operation (e.g., add, or)
  • operands specify the data required by the
    operation
  • Executable instructions can have zero to three
    operands

5
Assembly Language Statements (contd)
  • comments
  • Begin with a semicolon () and extend to the end
    of the line
  • Examples
  • repeat inc result increment result
  • CR EQU 0DH carriage return character
  • White space can be used to improve readability
  • repeat
  • inc result

6
Data Allocation
  • Variable declaration in a high-level language
    such as C
  • char response
  • int value
  • float total
  • double average_value
  • specifies
  • Amount storage required (1 byte, 2 bytes, )
  • Label to identify the storage allocated
    (response, value, )
  • Interpretation of the bits stored (signed,
    floating point, )
  • Bit pattern 1000 1101 1011 1001 is interpreted as
  • -29,255 as a signed number
  • 36,281 as an unsigned number

7
Data Allocation (contd)
  • In assembly language, we use the define directive
  • Define directive can be used
  • To reserve storage space
  • To label the storage space
  • To initialize
  • But no interpretation is attached to the bits
    stored
  • Interpretation is up to the program code
  • Define directive goes into the .DATA part of the
    assembly language program
  • Define directive format
  • var-name D? init-value ,init-value,...

8
Data Allocation (contd)
  • Five define directives
  • DB Define Byte allocates 1 byte
  • DW Define Word allocates 2 bytes
  • DD Define Doubleword allocates 4 bytes
  • DQ Define Quadword allocates 8 bytes
  • DT Define Ten bytes allocates 10 bytes
  • Examples
  • sorted DB y
  • response DB ? no initialization
  • value DW 25159
  • float1 DD 1.234
  • float2 DQ 123.456

9
Data Allocation (contd)
  • Multiple definitions can be abbreviated
  • Example
  • message DB B
  • DB y
  • DB e
  • DB 0DH
  • DB 0AH
  • can be written as
  • message DB B,y,e,0DH,0AH
  • More compactly as
  • message DB Bye,0DH,0AH

10
Data Allocation (contd)
  • Multiple definitions can be cumbersome to
    initialize data structures such as arrays
  • Example
  • To declare and initialize an integer array of 8
    elements
  • marks DW 0,0,0,0,0,0,0,0
  • What if we want to declare and initialize to zero
    an array of 200 elements?
  • There is a better way of doing this than
    repeating zero 200 times in the above statement
  • Assembler provides a directive to do this (DUP
    directive)

11
Data Allocation (contd)
  • Multiple initializations
  • The DUP assembler directive allows multiple
    initializations to the same value
  • Previous marks array can be compactly declared as
  • marks DW 8 DUP (0)
  • Examples
  • table1 DW 10 DUP (?) 10 words,
    uninitialized
  • message DB 3 DUP (Bye!) 12 bytes,
    initialized
  • as
    Bye!Bye!Bye!
  • Name1 DB 30 DUP (?) 30 bytes, each
  • initialized
    to ?

12
Data Allocation (contd)
  • The DUP directive may also be nested
  • Example
  • stars DB 4 DUP(3 DUP (),2 DUP (?),5 DUP
    (!))
  • Reserves 40-bytes space and initializes it as
  • ??!!!!!??!!!!!??!!!!!??!!!!!
  • Example
  • matrix DW 10 DUP (5 DUP (0))
  • defines a 10X5 matrix and initializes its
    elements to 0
  • This declaration can also be done by
  • matrix DW 50 DUP (0)

13
Data Allocation (contd)
  • Symbol Table
  • Assembler builds a symbol table so we can refer
    to the allocated storage space by the associated
    label
  • Example
  • .DATA name offset
  • value DW 0 value 0
  • sum DD 0 sum 2
  • marks DW 10 DUP (?) marks 6
  • message DB The grade is,0 message 26
  • char1 DB ? char1 40

14
Data Allocation (contd)
  • Correspondence to C Data Types
  • Directive C data type
  • DB char
  • DW int, unsigned
  • DD float, long
  • DQ double
  • DT internal intermediate
  • float value

15
Data Allocation (contd)
  • LABEL Directive
  • LABEL directive provides another way to name a
    memory location
  • Format
  • name LABEL type
  • type can be
  • BYTE 1 byte
  • WORD 2 bytes
  • DWORD 4 bytes
  • QWORD 8 bytes
  • TWORD 10 bytes

16
Data Allocation (contd)
  • LABEL Directive
  • Example
  • .DATA
  • count LABEL WORD
  • Lo-count DB 0
  • Hi_count DB 0
  • .CODE...
  • mov Lo_count,AL
  • mov Hi_count,CL
  • count refers to the 16-bit value
  • Lo_count refers to the low byte
  • Hi_count refers to the high byte

17
Where Are the Operands?
  • Operands required by an operation can be
    specified in a variety of ways
  • A few basic ways are
  • operand in a register
  • register addressing mode
  • operand in the instruction itself
  • immediate addressing mode
  • operand in memory
  • variety of addressing modes
  • direct and indirect addressing modes
  • operand at an I/O port
  • discussed in Chapter 19

18
Where Are the Operands? (contd)
  • Register addressing mode
  • Operand is in an internal register
  • Examples
  • mov EAX,EBX 32-bit copy
  • mov BX,CX 16-bit copy
  • mov AL,CL 8-bit copy
  • The mov instruction
  • mov destination,source
  • copies data from source to destination

19
Where Are the Operands? (contd)
  • Register addressing mode (contd)
  • Most efficient way of specifying an operand
  • No memory access is required
  • Instructions using this mode tend to be shorter
  • Fewer bits are needed to specify the register
  • Compilers use this mode to optimize code
  • total 0
  • for (i 1 to 400)
  • total total marksi
  • end for
  • Mapping total and i to registers during the for
    loop optimizes the code

20
Where Are the Operands? (contd)
  • Immediate addressing mode
  • Data is part of the instruction
  • Ooperand is located in the code segment along
    with the instruction
  • Efficient as no separate operand fetch is needed
  • Typically used to specify a constant
  • Example
  • mov AL,75
  • This instruction uses register addressing mode
    for destination and immediate addressing mode for
    the source

21
Where Are the Operands? (contd)
  • Direct addressing mode
  • Data is in the data segment
  • Need a logical address to access data
  • Two components segmentoffset
  • Various addressing modes to specify the offset
    component
  • offset part is called effective address
  • The offset is specified directly as part of
    instruction
  • We write assembly language programs using memory
    labels (e.g., declared using DB, DW, LABEL,...)
  • Assembler computes the offset value for the label
  • Uses symbol table to compute the offset of a label

22
Where Are the Operands? (contd)
  • Direct addressing mode (contd)
  • Examples
  • mov AL,response
  • Assembler replaces response by its effective
    address (i.e., its offset value from the symbol
    table)
  • mov table1,56
  • table1 is declared as
  • table1 DW 20 DUP (0)
  • Since the assembler replaces table1 by its
    effective address, this instruction refers to the
    first element of table1
  • In C, it is equivalent to
  • table10 56

23
Where Are the Operands? (contd)
  • Direct addressing mode (contd)
  • Problem with direct addressing
  • Useful only to specify simple variables
  • Causes serious problems in addressing data types
    such as arrays
  • As an example, consider adding elements of an
    array
  • Direct addressing does not facilitate using a
    loop structure to iterate through the array
  • We have to write an instruction to add each
    element of the array
  • Indirect addressing mode remedies this problem

24
Where Are the Operands? (contd)
  • Indirect addressing mode
  • The offset is specified indirectly via a register
  • Sometimes called register indirect addressing
    mode
  • For 16-bit addressing, the offset value can be in
    one of the three registers BX, SI, or DI
  • For 32-bit addressing, all 32-bit registers can
    be used
  • Example
  • mov AX,BX
  • Square brackets are used to indicate that BX
    is holding an offset value
  • BX contains a pointer to the operand, not the
    operand itself

25
Where Are the Operands? (contd)
  • Using indirect addressing mode, we can process
    arrays using loops
  • Example Summing array elements
  • Load the starting address (i.e., offset) of the
    array into BX
  • Loop for each element in the array
  • Get the value using the offset in BX
  • Use indirect addressing
  • Add the value to the running total
  • Update the offset in BX to point to the next
    element of the array

26
Where Are the Operands? (contd)
  • Loading offset value into a register
  • Suppose we want to load BX with the offset value
    of table1
  • We cannot write
  • mov BX,table1
  • Two ways of loading offset value
  • Using OFFSET assembler directive
  • Executed only at the assembly time
  • Using lea instruction
  • This is a processor instruction
  • Executed at run time

27
Where Are the Operands? (contd)
  • Loading offset value into a register (contd)
  • Using OFFSET assembler directive
  • The previous example can be written as
  • mov BX,OFFSET table1
  • Using lea (load effective address) instruction
  • The format of lea instruction is
  • lea register,source
  • The previous example can be written as
  • lea BX,table1

28
Where Are the Operands? (contd)
  • Loading offset value into a register (contd)
  • Which one to use -- OFFSET or lea?
  • Use OFFSET if possible
  • OFFSET incurs only one-time overhead (at assembly
    time)
  • lea incurs run time overhead (every time you run
    the program)
  • May have to use lea in some instances
  • When the needed data is available at run time
    only
  • An index passed as a parameter to a procedure
  • We can write
  • lea BX,table1SI
  • to load BX with the address of an element of
    table1 whose index is in SI register
  • We cannot use the OFFSET directive in this case

29
Default Segments
  • In register indirect addressing mode
  • 16-bit addresses
  • Effective addresses in BX, SI, or DI is taken as
    the offset into the data segment (relative to DS)
  • For BP and SP registers, the offset is taken to
    refer to the stack segment (relative to SS)
  • 32-bit addresses
  • Effective address in EAX, EBX, ECX, EDX, ESI, and
    EDI is relative to DS
  • Effective address in EBP and ESP is relative to
    SS
  • push and pop are always relative to SS

30
Default Segments (contd)
  • Default segment override
  • Possible to override the defaults by using
    override prefixes
  • CS, DS, SS, ES, FS, GS
  • Example 1
  • We can use
  • add AX,SSBX
  • to refer to a data item on the stack
  • Example 2
  • We can use
  • add AX,DSBP
  • to refer to a data item in the data segment

31
Data Transfer Instructions
  • We will look at three instructions
  • mov (move)
  • Actually copy
  • xchg (exchange)
  • Exchanges two operands
  • xlat (translate)
  • Translates byte values using a translation table
  • Other data transfer instructions such as
  • movsx (move sign extended)
  • movzx (move zero extended)
  • are discussed in Chapter 12

32
Data Transfer Instructions (contd)
  • The mov instruction
  • The format is
  • mov destination,source
  • Copies the value from source to destination
  • source is not altered as a result of copying
  • Both operands should be of same size
  • source and destination cannot both be in memory
  • Most Pentium instructions do not allow both
    operands to be located in memory
  • Pentium provides special instructions to
    facilitate memory-to-memory block copying of data

33
Data Transfer Instructions (contd)
  • The mov instruction
  • Five types of operand combinations are allowed
  • Instruction type Example
  • mov register,register mov DX,CX
  • mov register,immediate mov BL,100
  • mov register,memory mov BX,count
  • mov memory,register mov count,SI
  • mov memory,immediate mov count,23
  • The operand combinations are valid for all
    instructions that require two operands

34
Data Transfer Instructions (contd)
  • Ambiguous moves PTR directive
  • For the following data definitions
  • .DATA
  • table1 DW 20 DUP (0)
  • status DB 7 DUP (1)
  • the last two mov instructions are ambiguous
  • mov BX,OFFSET table1
  • mov SI,OFFSET status
  • mov BX,100
  • mov SI,100
  • Not clear whether the assembler should use byte
    or word equivalent of 100

35
Data Transfer Instructions (contd)
  • Ambiguous moves PTR directive
  • The PTR assembler directive can be used to
    clarify
  • The last two mov instructions can be written as
  • mov WORD PTR BX,100
  • mov BYTE PTR SI,100
  • WORD and BYTE are called type specifiers
  • We can also use the following type specifiers
  • DWORD for doubleword values
  • QWORD for quadword values
  • TWORD for ten byte values

36
Data Transfer Instructions (contd)
  • The xchg instruction
  • The syntax is
  • xchg operand1,operand2
  • Exchanges the values of operand1 and operand2
  • Examples
  • xchg EAX,EDX
  • xchg response,CL
  • xchg total,DX
  • Without the xchg instruction, we need a temporary
    register to exchange values using only the mov
    instruction

37
Data Transfer Instructions (contd)
  • The xchg instruction
  • The xchg instruction is useful for conversion of
    16-bit data between little endian and big endian
    forms
  • Example
  • mov AL,AH
  • converts the data in AX into the other endian
    form
  • Pentium provides bswap instruction to do similar
    conversion on 32-bit data
  • bswap 32-bit register
  • bswap works only on data located in a 32-bit
    register

38
Data Transfer Instructions (contd)
  • The xlat instruction
  • The xlat instruction translates bytes
  • The format is
  • xlatb
  • To use xlat instruction
  • BX should be loaded with the starting address of
    the translation table
  • AL must contain an index in to the table
  • Index value starts at zero
  • The instruction reads the byte at this index in
    the translation table and stores this value in AL
  • The index value in AL is lost
  • Translation table can have at most 256 entries
    (due to AL)

39
Data Transfer Instructions (contd)
  • The xlat instruction
  • Example Encrypting digits
  • Input digits 0 1 2 3 4 5 6 7 8 9
  • Encrypted digits 4 6 9 5 0 3 1 8 7 2
  • .DATA
  • xlat_table DB 4695031872
  • ...
  • .CODE
  • mov BX,OFFSET xlat_table
  • GetCh AL
  • sub AL,0 converts input character to index
  • xlatb AL encrypted digit character
  • PutCh AL
  • ...

40
Pentium Assembly Instructions
  • Pentium provides several types of instructions
  • Brief overview of some basic instructions
  • Arithmetic instructions
  • Jump instructions
  • Loop instruction
  • Logical instructions
  • Shift instructions
  • Rotate instructions
  • These instructions allow you to write reasonable
    assembly language programs

41
Arithmetic Instructions
  • INC and DEC instructions
  • Format
  • inc destination dec destination
  • Semantics
  • destination destination /- 1
  • destination can be 8-, 16-, or 32-bit operand, in
    memory or register
  • No immediate operand
  • Examples
  • inc BX
  • dec value

42
Arithmetic Instructions (contd)
  • Add instructions
  • Format
  • add destination,source
  • Semantics
  • destination destination source
  • Examples
  • add EBX,EAX
  • add value,35
  • inc EAX is better than add EAX,1
  • inc takes less space
  • Both execute at about the same speed

43
Arithmetic Instructions (contd)
  • Add instructions
  • Addition with carry
  • Format
  • adc destination,source
  • Semantics
  • destination destination source CF
  • Example 64-bit addition
  • add EAX,ECX add lower 32 bits
  • adc EBX,EDX add upper 32 bits with carry
  • 64-bit result in EBXEAX

44
Arithmetic Instructions (contd)
  • Subtract instructions
  • Format
  • sub destination,source
  • Semantics
  • destination destination - source
  • Examples
  • sub EBX,EAX
  • sub value,35
  • dec EAX is better than sub EAX,1
  • dec takes less space
  • Both execute at about the same speed

45
Arithmetic Instructions (contd)
  • Subtract instructions
  • Subtract with borrow
  • Format
  • sbb destination,source
  • Semantics
  • destination destination - source - CF
  • Like the adc, sbb is useful in dealing with more
    than 32-bit numbers
  • Negation
  • neg destination
  • Semantics
  • destination 0 - destination

46
Arithmetic Instructions (contd)
  • CMP instruction
  • Format
  • cmp destination,source
  • Semantics
  • destination - source
  • destination and source are not altered
  • Useful to test relationship (gt, ) between two
    operands
  • Used in conjunction with conditional jump
    instructions for decision making purposes
  • Examples
  • cmp EBX,EAX cmp count,100

47
Unconditional Jump
  • Format
  • jmp label
  • Semantics
  • Execution is transferred to the instruction
    identified by label
  • Target can be specified in one of two ways
  • Directly
  • In the instruction itself
  • Indirectly
  • Through a register or memory
  • Discussed in Chapter 12

48
Unconditional Jump (contd)
  • Example
  • Two jump instructions
  • Forward jump
  • jmp CX_init_done
  • Backward jump
  • jmp repeat1
  • Programmer specifies target by a label
  • Assembler computes the offset using the symbol
    table
  • . . .
  • mov CX,10
  • jmp CX_init_done
  • init_CX_20
  • mov CX,20
  • CX_init_done
  • mov AX,CX
  • repeat1
  • dec CX
  • . . .
  • jmp repeat1
  • . . .

49
Unconditional Jump (contd)
  • Address specified in the jump instruction is not
    the absolute address
  • Uses relative address
  • Specifies relative byte displacement between the
    target instruction and the instruction following
    the jump instruction
  • Displacement is w.r.t the instruction following
    jmp
  • Reason IP points to this instruction after
    reading jump
  • Execution of jmp involves adding the displacement
    value to current IP
  • Displacement is a signed 16-bit number
  • Negative value for backward jumps
  • Positive value for forward jumps

50
Target Location
  • Inter-segment jump
  • Target is in another segment
  • CS target-segment (2 bytes)
  • IP target-offset (2 bytes)
  • Called far jumps (needs five bytes to encode jmp)
  • Intra-segment jumps
  • Target is in the same segment
  • IP IP relative-displacement (1 or 2 bytes)
  • Uses 1-byte displacement if target is within -128
    to 127
  • Called short jumps (needs two bytes to encode
    jmp)
  • If target is outside this range, uses 2-byte
    displacement
  • Called near jumps (needs three bytes to encode
    jmp)

51
Target Location (contd)
  • In most cases, the assembler can figure out the
    type of jump
  • For backward jumps, assembler can decide whether
    to use the short jump form or not
  • For forward jumps, it needs a hint from the
    programmer
  • Use SHORT prefix to the target label
  • If such a hint is not given
  • Assembler reserves three bytes for jmp
    instruction
  • If short jump can be used, leaves one byte of nop
    (no operation)
  • See the next example for details

52
Example
  • . . .
  • 8 0005 EB 0C jmp SHORT CX_init_done
  • 0013 - 0007 0C
  • 9 0007 B9 000A mov CX,10
  • 10 000A EB 07 90 jmp CX_init_done
  • nop 0013 - 000D 07
  • 11 init_CX_20
  • 12 000D B9 0014 mov CX,20
  • 13 0010 E9 00D0 jmp near_jump
  • 00E3 - 0013 D0
  • 14 CX_init_done
  • 15 0013 8B C1 mov AX,CX

53
Example (contd)
  • 16 repeat1
  • 17 0015 49 dec CX
  • 18 0016 EB FD jmp repeat1
  • 0015 - 0018 -3 FDH
  • . . .
  • 84 00DB EB 03 jmp SHORT short_jump
  • 00E0 - 00DD 3
  • 85 00DD B9 FF00 mov CX, 0FF00H
  • 86 short_jump
  • 87 00E0 BA 0020 mov DX, 20H
  • 88 near_jump
  • 89 00E3 E9 FF27 jmp init_CX_20
  • 000D - 00E6 -217 FF27H

54
Conditional Jumps (contd)
  • Format
  • jltcondgt lab
  • Execution is transferred to the instruction
    identified by label only if ltcondgt is met
  • Example Testing for carriage return
  • read_char
  • . . .
  • cmp AL,0DH 0DH ASCII carriage return
  • je CR_received
  • inc CL
  • jmp read_char
  • . . .
  • CR_received

55
Conditional Jumps (contd)
  • Some conditional jump instructions
  • Treats operands of the CMP instruction as signed
    numbers
  • je jump if equal
  • jg jump if greater
  • jl jump if less
  • jge jump if greater or equal
  • jle jump if less or equal
  • jne jump if not equal

56
Conditional Jumps (contd)
  • Conditional jump instructions can also test
    values of the individual flags
  • jz jump if zero (i.e., if ZF 1)
  • jnz jump if not zero (i.e., if ZF 0)
  • jc jump if carry (i.e., if CF 1)
  • jnc jump if not carry (i.e., if CF 0)
  • jz is synonymous for je
  • jnz is synonymous for jne

57
A Note on Conditional Jumps
  • All conditional jumps are encoded using 2 bytes
  • Treated as short jumps
  • What if the target is outside this range?
  • Use this code to get around
  • target
  • . . .
  • cmp AX,BX
  • jne skip1
  • jmp target
  • skip1
  • mov CX,10
  • . . .
  • target
  • . . .
  • cmp AX,BX
  • je target
  • mov CX,10
  • . . .
  • traget is out of range for a short jump

58
Loop Instructions
  • Unconditional loop instruction
  • Format
  • loop target
  • Semantics
  • Decrements CX and jumps to target if CX ? 0
  • CX should be loaded with a loop count value
  • Example Executes loop body 50 times
  • mov CX,50
  • repeat
  • ltloop bodygt
  • loop repeat
  • ...

59
Loop Instructions (contd)
  • The previous example is equivalent to
  • mov CX,50
  • repeat
  • ltloop bodygt
  • dec CX
  • jnz repeat
  • ...
  • Surprisingly,
  • dec CX
  • jnz repeat
  • executes faster than
  • loop repeat

60
Loop Instructions (contd)
  • Conditional loop instructions
  • loope/loopz
  • Loop while equal/zero
  • CX CX 1
  • ff (CX 0 and ZF 1)
  • jump to target
  • loopne/loopnz
  • Loop while not equal/not zero
  • CX CX 1
  • ff (CX 0 and ZF 0)
  • jump to target

61
Logical Instructions
  • Format
  • and destination,source
  • or destination,source
  • xor destination,source
  • not destination
  • Semantics
  • Performs the standard bitwise logical operations
  • result goes to destination
  • test is a non-destructive and instruction
  • test destination,source
  • Performs logical AND but the result is not stored
    in destination (like the CMP instruction)

62
Logical Instructions (contd)
  • Example
  • . . .
  • and AL,01H test the least significant
    bit
  • jz bit_is_zero
  • ltbit 1 codegt
  • jmp skip1
  • bit_is_zero
  • ltbit 0 codegt
  • skip1
  • . . .
  • test instruction is better in place of and

63
Shift Instructions
  • Two types of shifts
  • Logical
  • Arithmetic
  • Logical shift instructions
  • Shift left
  • shl destination,count
  • shl destination,CL
  • Shift right
  • shr destination,count
  • shr destination,CL
  • Semantics
  • Performs left/right shift of destination by the
    value in count or CL register
  • CL register contents are not altered

64
Shift Instructions (contd)
  • Logical shift
  • Bit shifted out goes into the carry flag
  • Zero bit is shifted in at the other end

65
Shift Instructions (contd)
  • count is an immediate value
  • shl AX,5
  • Specification of count greater than 31 is not
    allowed
  • If a greater value is specified, only the least
    significant 5 bits are used
  • CL version is useful if shift count is known at
    run time
  • Ex when the shift count value is passed as a
    parameter in a procedure call
  • Only the CL register can be used
  • Shift count value should be loaded into CL
  • mov CL,5
  • shl AX,CL

66
Shift Instructions (contd)
  • Arithmetic shift
  • Two versions as in logical shift
  • sal/sar destination,count
  • sal/sar destination,CL

67
Double Shift Instructions
  • Double shift instructions work on either 32- or
    64-bit operands
  • Format
  • Takes three operands
  • shld dest,src,count left shift
  • shrd dest,src,count right shift
  • dest can be in memory or register
  • src must be a register
  • count can be an immediate value or in CL as in
    other shift instructions

68
Double Shift Instructions (contd)
  • src is not modified by doubleshift instruction
  • Only dest is modified
  • Shifted out bit goes into the carry flag

69
Rotate Instructions
  • Two types of ROTATE instructions
  • Rotate without carry
  • rol (ROtate Left)
  • ror (ROtate Right)
  • Rotate with carry
  • rcl (Rotate through Carry Left)
  • rcr (Rotate through Carry Right)
  • Format of ROTATE instructions is similar to the
    SHIFT instructions
  • Supports two versions
  • Immediate count value
  • Count value in CL register

70
Rotate Instructions (contd)
  • Bit shifted out goes into the carry flag as in
    SHIFT instructions

71
Rotate Instructions (contd)
  • Bit shifted out goes into the carry flag as in
    SHIFT instructions

72
Rotate Instructions (contd)
  • Example Shifting 64-bit numbers
  • Multiplies a 64-bit value in EDXEAX by 16
  • Rotate version
  • mov CX,4
  • shift_left
  • shl EAX,1
  • rcl EDX,1
  • loop shift_left
  • Doubleshift version
  • shld EDX,EAX,4
  • shl EAX,4
  • Division can be done in a similar a way

73
Defining Constants
  • Assembler provides two directives
  • EQU directive
  • No reassignment
  • String constants can be defined
  • directive
  • Can be reassigned
  • No string constants
  • Defining constants has two advantages
  • Improves program readability
  • Helps in software maintenance
  • Multiple occurrences can be changed from a single
    place
  • Convention
  • We use all upper-case letters for names of
    constants

74
Defining Constants (contd)
  • The EQU directive
  • Syntax
  • name EQU expression
  • Assigns the result of expression to name
  • The expression is evaluated at assembly time
  • Similar to define in C
  • Examples
  • NUM_OF_ROWS EQU 50
  • NUM_OF_COLS EQU 10
  • ARRAY_SIZE EQU NUM_OF_ROWS NUM_OF_COLS
  • Can also be used to define string constants
  • JUMP EQU jmp

75
Defining Constants (contd)
  • The directive
  • Syntax
  • name expression
  • Similar to EQU directive
  • Two key differences
  • Redefinition is allowed
  • count 0
  • . . .
  • count 99
  • is valid
  • Cannot be used to define string constants or to
    redefine keywords or instruction mnemonics
  • Example JUMP jmp is not allowed

76
Macros
  • Macros can be defined with MACRO and ENDM
  • Format
  • macro_name MACROparameter1, parameter2,...
  • macro body
  • ENDM
  • A macro can be invoked using
  • macro_name argument1, argument2,
  • Example Definition
    Invocation
  • multAX_by_16 MACRO ...
  • sal AX,4 mov AX,27
  • ENDM multAX_by_16
  • ...

77
Macros (contd)
  • Macros can be defined with parameters
  • More flexible
  • More useful
  • Example
  • mult_by_16 MACRO operand
  • sal operand,4
  • ENDM
  • To multiply a byte in DL register
  • mult_by_16 DL
  • To multiply a memory variable count
  • mult_by_16 count

78
Macros (contd)
  • Example To exchange two memory words
  • Memory-to-memory transfer
  • Wmxchg MACRO operand1, operand2
  • xchg AX,operand1
  • xchg AX,operand2
  • xchg AX,operand1
  • ENDM

79
Illustrative Examples
  • Five examples in this chapter
  • Conversion of ASCII to binary representation
    (BINCHAR.ASM)
  • Conversion of ASCII to hexadecimal by character
    manipulation (HEX1CHAR.ASM)
  • Conversion of ASCII to hexadecimal using the XLAT
    instruction (HEX2CHAR.ASM)
  • Conversion of lowercase letters to uppercase by
    character manipulation (TOUPPER.ASM)
  • Sum of individual digits of a number
    (ADDIGITS.ASM)

Last slide
Write a Comment
User Comments (0)
About PowerShow.com