CE302 Outline Multiplication Division Program Segment Prefix Command Line Parameters.

Slides:



Advertisements
Similar presentations
Registers of the 8086/ /2002 JNM.
Advertisements

There are two types of addressing schemes:
Introduction to Computer Engineering by Richard E. Haskell Multiplication and Division Instructions Module M16.4 Section 10.4.
Computer Architecture and Operating Systems CS 3230 :Assembly Section Lecture 2 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
Department of Computer Science and Software Engineering
Assembly Language Lecture 9
1 Multiplication, Division, and Numerical Conversions Chapter 6.
Web siteWeb site ExamplesExamples Irvine, Kip R. Assembly Language for Intel-Based Computers, MUL Instruction The MUL (unsigned multiply) instruction.
Assembly 02. Outline mov Command Registers Memory EFLAGS Arithmetic 1.
Gursharan Singh Tatla 21-Nov-20101www.eazynotes.com.
Shift and Rotate Instructions
Chapter 4 Basic Instructions. 4.1 Copying Data mov Instructions mov (“move”) instructions are really copy instructions, like simple assignment statements.
MUL Instruction (Unsigned Multiply) Multiplies an 8-, 16-, or 32-bit operand by either AL, AX or EAX. MUL r/m8 MUL r/m16 MUL r/m32.
ECE291 Lecture 4 Jumping in head first. ECE 291 Lecture 4Page 2 of 42 Lecture outline Multiplication and Division Program control instructions Unconditional.
Assembly Language – Lab 5
1/2002JNM1 Positional Notation (Hex Digits). 1/2002JNM2 Problem The 8086 has a 20-bit address bus. Therefore, it can access 1,048,576 bytes of memory.
INSTRUCTION SET AND ASSEMBLY LANGUAGE PROGRAMMING
ECE291 Computer Engineering II Lecture 6 & Lecture 7 Dr. Zbigniew Kalbarczyk University of Illinois at Urbana- Champaign.
Lecture 5 Multiplication, Division and Branches Dr. Dimitrios S. Nikolopoulos CSL/UIUC.
Multiplication and Division Instructions & the 0Ah function.
Microprocessors Monday, Apr. 13 Dr. Asmaa Farouk Faculty of Engineering, Electrical Department, Assiut University.
ECE291 Computer Engineering II Lecture 3 Josh Potts University of Illinois at Urbana- Champaign.
Arithmetic Flags and Instructions
Computer Architecture and Operating Systems CS 3230 :Assembly Section Lecture 4 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
Offset Length Description 0 2 An INT 20h instruction is stored here 2 2 Program ending address 4 1 Unused, reserved by DOS 5 5 Call to DOS function.
UHD:CS2401: A. Berrached1 The Intel x86 Hardware Organization.
ECE291 Computer Engineering II Lecture 3 Josh Potts University of Illinois at Urbana- Champaign.
Arithmetic and Logic Instructions
ECE291 Computer Engineering II Lecture 3 Dr. Zbigniew Kalbarczyk University of Illinois at Urbana- Champaign.
October 1, 2003Serguei A. Mokhov, 1 SOEN228, Winter 2003 Revision 1.2 Date: October 25, 2003.
ICS 312 SET 10 Multiplication & Division & input using function 0Ah.
The Assemble, Unassemble commands of the debugger: U Command for converting machine code language source Equivalent machine code instructions Equivalent.
Introduction Arithmetic instructions are used to perform arithmetic operation such as Addition Subtraction Multiplication Division These operations can.
Chapter 7 Bit Manipulation. 7.1 Logical Operations.
Microprocessor & Assembly Language Arithmetic and logical Instructions.
Calling Procedures C calling conventions. Outline Procedures Procedure call mechanism Passing parameters Local variable storage C-Style procedures Recursion.
Internal Programming Architecture or Model
Preliminary to Assembly Language Programming CE 140 A1/A2 28 June 2003.
Multiplication and Division instructions Dr.Hadi AL Saadi.
I NTEL 8086 M icroprocessor بسم الله الرحمن الرحيم 1.
Instruction set Architecture
Format of Assembly language
Data Transfers, Addressing, and Arithmetic
8086 Microprocessor.
ADDRESSING MODES.
Basic Assembly Language
Multiplication and Division Instructions
Assembly Language Programming Part 2
ADDRESSING MODES.
CS-401 Computer Architecture & Assembly Language Programming
INSTRUCTION SET OF 8086 PAWAN KUMAR SINGH.
X86’s instruction sets.
Chapter 4: Instructions
Morgan Kaufmann Publishers Computer Organization and Assembly Language
Microprocessor and Assembly Language
8086 Registers Module M14.2 Sections 9.2, 10.1.
Morgan Kaufmann Publishers Computer Organization and Assembly Language
Symbolic Instruction and Addressing
Multiplication and Division Instructions
CNET 315 Microprocessor & Assembly Language
Assembly Language for Intel-Based Computers, 4th Edition
Assembly Language for Intel-Based Computers, 5th Edition
Chapter 5 Arithmetic and Logic Instructions
Chapter 6 –Symbolic Instruction and Addressing
Multiplication and Division Instructions
Multiplication and Division Instructions
Division instruction.
Computer Architecture and System Programming Laboratory
Part I Data Representation and 8086 Microprocessors
Presentation transcript:

CE302 Outline Multiplication Division Program Segment Prefix Command Line Parameters

CE302 Multiplication The product after a multiplication is always a double-width product, e.g, –if we multiply two 16-bit numbers, they generate a 32-bit product –unsigned: ( ) * ( ) = ( * < ( ) –signed: (-2 15 ) * (-2 15 ) = 2 30 < ( ) –overflow cannot occur Modification of Flags –Most flags are undefined after multiplication –O and C flags clear to 0 if the result fit into half-size register –e.g., if the most significant 16 bits of the product are 0, both flags C and O clear to 0

CE302 Multiplication (cont.) Two different instructions for multiplication –MULMultiply unsigned –IMULInteger Multiply (2’s complement) Multiplication is performed on bytes, words, or double words Which operation to perform depends on the size of the multiplier The multiplier can be any register or any memory location MUL CX; AX * CX (unsigned result in DX--AX); IMUL WORD PTR [SI] ; AX * [word contents of memory location ; addressed by SI] (signed product in DX--AX)

CE302 Multiplication (16 bit) The use of the AX (and DX) registers is implied!!!!! Multiplicand AX Multiplier (16-bit register, 16-bit memory variable) DX, AX = PRODUCT (High word in DX : Low word in AX)

CE302 Multiplication 8-bit multiplication Multiplicand AL Multiplier (8-bit register, 8-bit memory variable) AX PRODUCT 32-bit multiplication Multiplicand EAX Multiplier (32-bit register, 32-bit memory variable) EDX, EAX PRODUCT (High word in EDX : Low word in EAX) –32-bit multiplication is available only on and above

CE302 Binary Multiplication Long Multiplication is done through shifts and additions This works if both numbers are positive To multiply a negative numbers, the CPU will store the sign bits of the numbers, make both numbers positive, compute the result, then negate the result if necessary (98) x (37) (3626)

CE302 Division X / Y = Q; R X Dividend YDivisor QQuotient RRemainder Note: Remainder has the same sign as X (Dividend) Examples (Signed Integers) X / YQR 9 / / / /

CE302 Division (cont.) Two different instructions for division –DIVDivision unsigned –IDIVInteger Division (2’s complement) Division is performed on bytes, words, or double words Which operation to perform depends on the size of the divisor The dividend is always a double-width dividend that is divided by the operand (divisor) The divisor can be any register or any memory location

CE302 Division (32-bit/16-bit) The use of the AX (and DX) registers is implied!!!!! Dividend DX, AX (high word in DX, low word in AX) Divisor(16-bit register, 16-bit memory variable) QuotientAX RemainderDX

CE302 Division (cont.) 16-bit/8-bit Dividend AX Divisor(8-bit register, 8-bit memory variable) QuotientAL RemainderAH 64-bit/32-bit Dividend EDX, EAX (high double word in EDX, low double word in EAX) Divisor(32-bit register, 32-bit memory variable) QuotientEAX RemainderEDX Available on and above

CE302 Division (cont.) Division of two equally sized words Prepare the dividend –Unsigned numbers: move zero into high order-word –Signed numbers: use signed extension ( implicitly uses AL, AX, DX registers ) to fill high-word with ones or zeros –CBW (convert byte to word) AX = xxxx xxxx snnn nnnn (before) AX = ssss ssss snnn nnnn (after) –CWD (convert word to double) DX:AX = xxxx xxxx xxxx xxxx snnn nnnn nnnn nnnn (before) DX:AX = ssss ssss ssss ssss snnn nnnn nnnn nnnn (after) –CWDE (convert double to double-word extended) and above

CE302 Division (cont.) Flag settings –none of the flag bits change predictably for a division A division can result in two types of errors –divide by zero –divide overflow (a small number divides into a large number), e.g., 3000 / 2 AX = 3000; Devisor is 2 => 8 bit division is performed Quotient will be written to AL => but 1500 does not fit into AL consequently we have divide overflow in both cases microprocessor generates interrupt (interrupts are covered later in this course)

CE302 Division (Example) Division of the byte contents of memory NUMB by the contents of NUMB1 Unsigned MOVAL, NUMB ;get NUMB MOVAH, 0 ;zero extend DIVNUMB1 MOVANSQ, AL ;save quotient MOVANSR, AH ;save remainder Signed MOVAL, NUMB ;get NUMB CBW ;signed-extend IDIVNUMB1 MOVANSQ, AL ;save quotient MOVANSR, AH ;save remainder

CE302 Division (cont.) What do we do with remainder after division? –use the remainder to round the result –drop the remainder to truncate the result –if the division is unsigned, rounding requires that remainder is compared with half the divisor to decide whether to round up the quotient –e.g., sequence of instructions that divide AX by BL and round the result DIVBL ADDAH, AH;double remainder CMPAH, BL;test for rounding JBNEXT INCAL NEXT:

CE302 Program Segment Prefix (PSP) When a program is loaded into memory for execution, DOS first builds up a program segment prefix immediately before the program is loaded into memory. This PSP contains lots of information, some of it useful, most of it obsolete. Understanding the layout of the PSP is essential for programmers designing assembly language programs. The PSP is 256 bytes long

CE302 Program Segment Prefix (PSP) Offset Ah 0Eh 12h 16h 2Ch 2Eh 50h 53h 5Ch 6Ch 80h 81h Length Description An INT 20h instruction is stored here Program ending address Unused, reserved by DOS Call to DOS function dispatcher Address of program termination code Address of break handler routine Address of critical error handler routine Reserved for use by DOS Segment address of environment area Reserved by DOS INT 21h, RETF instructions Reserved by DOS Default FCB #1 Default FCB #2 Length of command line string Command line string

CE302 PSP – Program Ending Address Field number two contains a value which points to the last memory address allocated to your program. By subtracting the address of the PSP from this value, you can determine the amount of memory allocated to your program

CE302 PSP – Environment Area Address This field contains the segment address of the environment storage area The environment strings always begin from an offset of zero from the above segment address This area of memory consists of a sequence of zero- terminated strings using the format: string1 0 string2 0 string3 0 0 Strings are usually placed in the environment area using DOS commands like PATH or SET Generally an environment string takes the form name = parameters

CE302 PSP – Environment Area Address For example the statement set ipath=c:\assembly\include copies the string “ipath=c:\assembly\include” into the environment string storage area. Many programs scan the env storage area for paths and other information. Your programs can take advantage of this too.

CE302 PSP – Command Line String Many programs allow you to append parameters after the executable name: e.g. Notepad mydoc.txt This command line string is stored in the PSP Location 80h of the PSP stores the length of the CLS Locations 81h through FFh contain the string itself You can use CLS in your ASM programs just like you would use argc, argv to access command line parameters in C/C++

CE302 PSP – Command Line String For example, consider MYPGM parameter1, parameter2 The CLS for this will be 23, “ parameter1, parameter2”, 0Dh Notice that the carriage return character is not figured into the length Please read Section of the online text for an in depth discussion of this topic with parsing examples

CE302 Accessing the PSP Although the PSP is loaded into memory immediately before your program, that doesn’t necessarily mean that it appears 100h bytes before your code Your data segments may have been loaded into memory before your code segments, thereby invalidating this method of locating the PSP The segment address of the PSP is passed to your program in the DS register Use the following code to extract the PSP segment address

CE302 Accessing the PSP Push ds;Save PSP value in the stack Mov ax, seg DSEG;Point DS and ES to our data segment Mov ds, ax Mov es, ax Pop PSP;Store PSP segment address into “PSP variable

CE302 Accessing the PSP In DOS 5.0 and later, you can make a DOS call to obtain the PSP address Load AH with 51h and execute an int 21h instruction DOS will return the segment address of the current PSP in the bx register