Multiplication and Division Instructions

Slides:



Advertisements
Similar presentations
1 x86’s instruction sets. 2 Instruction Set Classification  Transfer Move  Arithmetic Add / Subtract Mul / Div, etc.  Control Jump Call / Return, etc.
Advertisements

Assembly Language for x86 Processors 6th Edition
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.
1 Lecture 7 Integer Arithmetic Assembly Language for Intel-Based Computers, 4th edition Kip R. Irvine.
Assembly 02. Outline mov Command Registers Memory EFLAGS Arithmetic 1.
Assembly Language for Intel-Based Computers
Assembly Language for Intel-Based Computers, 5 th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may.
Assembly Language for Intel-Based Computers, 5 th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may.
Shift and Rotate Instructions
Assembly Language for Intel-Based Computers, 4 th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may modify.
Chapter 4 Basic Instructions. 4.1 Copying Data mov Instructions mov (“move”) instructions are really copy instructions, like simple assignment statements.
Assembly Language for Intel-Based Computers, 4 th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may modify.
Assembly Language for Intel-Based Computers
Integer Arithmetic Computer Organization & Assembly Language Programming Dr Adnan Gutub aagutub ‘at’ uqu.edu.sa [Adapted from slides of Dr. Kip Irvine:
Integer Arithmetic COE 205 Computer Organization and Assembly Language
CE302 Outline Multiplication Division Program Segment Prefix Command Line Parameters.
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.
Assembly Language – Lab 5
Khaled A. Al-Utaibi  Introduction  Arithmetic Instructions  Basic Logical Instructions  Shift Instructions  Rotate Instructions.
ASCII and BCD Arithmetic Chapter 11 S. Dandamudi.
Multiplication and Division Instructions & the 0Ah function.
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.
1 IKI10230 Pengantar Organisasi Komputer Kuliah no. 05.b: Arithmetic Operations Sumber: 1. Paul Carter, PC Assembly Language 2. Hamacher. Computer Organization,
Integer Arithmetic Computer Organization and Assembly Languages Yung-Yu Chuang 2007/12/24 with slides by Kip Irvine.
Assembly Language for Intel-Based Computers Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may modify and copy.
CT215: Assembly Language Programming
Assembly Language for Intel-Based Computers, 4 th Edition Unpacked and Packed Integers (c) Pearson Education, All rights reserved. You may modify.
Assembly Language for x86 Processors 6th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may modify and copy.
Chapter 7: Integer Arithmetic. 2 Chapter Overview Shift and Rotate Instructions Shift and Rotate Applications Multiplication and Division Instructions.
Arithmetic Flags and Instructions Chapter 7 S. Dandamudi.
Irvine, Kip R. Assembly Language for Intel-Based Computers. Chapter 7: Integer Arithmetic Slides to Accompany Assembly Language for Intel-Based Computers,
Assembly Language for Intel-Based Computers, 5 th Edition Chapter 7: Integer Arithmetic (c) Pearson Education, All rights reserved. You may.
Assembly Language for x86 Processors 7th Edition
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.
K.K. Leung Fall 2008Introductory Pentium Programming1 Pentium Architecture: Introductory Programming Kin K. Leung
Multiplication and Division instructions Dr.Hadi AL Saadi.
Computer Architecture and Assembly Language
Data Transfers, Addressing, and Arithmetic
Assembly Language for Intel-Based Computers, 5th Edition
Assembly Language for x86 Processors 7th Edition
Basic Assembly Language
Multiplication and Division Instructions
CS-401 Computer Architecture & Assembly Language Programming
4.2 Arithmetic Instructions
INSTRUCTION SET OF 8086 PAWAN KUMAR SINGH.
X86’s instruction sets.
Chapter 4: Instructions
Computer Organization and Assembly Languages Yung-Yu Chuang 2005/11/17
Morgan Kaufmann Publishers Computer Organization and Assembly Language
Microprocessor and Assembly Language
Assembly Language for Intel-Based Computers, 4th Edition
Assembly Language for Intel-Based Computers, 4th Edition
Assembly Language for Intel-Based Computers, 5th Edition
Shift, Multiply, and Divide
Computer Architecture and System Programming Laboratory
EECE.3170 Microprocessor Systems Design I
Chapter 5 Arithmetic and Logic Instructions
Multiplication and Division Instructions
Multiplication and Division Instructions
Division instruction.
Computer Architecture and System Programming Laboratory
Presentation transcript:

Multiplication and Division Instructions MUL Instruction IMUL Instruction DIV Instruction Signed Integer Division CBW, CWD, CDQ Instructions IDIV Instruction Implementing Arithmetic Expressions Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

MUL Instruction In 32-bit mode, MUL (unsigned multiply) instruction multiplies an 8-, 16-, or 32-bit operand by either AL, AX, or EAX. The instruction formats are: MUL r/m8 MUL r/m16 MUL r/m32 Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

MUL Examples 100h * 2000h, using 16-bit operands: .data val1 WORD 2000h val2 WORD 100h .code mov ax,val1 mul val2 ; DX:AX = 00200000h, CF=1 The Carry flag indicates whether or not the upper half of the product contains significant digits. mov eax,12345h mov ebx,1000h mul ebx ; EDX:EAX = 0000000012345000h, CF=0 12345h * 1000h, using 32-bit operands: Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IMUL Instruction IMUL (signed integer multiply ) multiplies an 8-, 16-, or 32-bit signed operand by either AL, AX, or EAX Preserves the sign of the product by sign-extending it into the upper half of the destination register The Overflow flag indicates whether or not the upper half of the product contains significant digits. Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IMUL Examples Multiply 10 * 3, using 8-bit operands: mov al,10 mov bl,3 imul bl ; AX = 001Eh (or +30), OF=0 Multiply10 * (-3), using 8-bit operands: mov al,10 mov bl,-3 imul bl ; AX = FFE2h (or -30), OF=0 In both cases, OF == 0 Meaning that AH is a sign extension of value in AL AH can be ignored! Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IMUL Instruction Example: multiply 48 * 4, using 8-bit operands: mov al,48 mov bl,4 imul bl ; AX = 00C0h (or +192), OF=1 OF=1 because AH is NOT a sign extension of AL Can’t ignore AH!!! (AL, by itself, would be incorrectly interpreted as -64) Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Same Example Example: multiply 48 * 4, using 16-bit operands: mov ax,48 mov bx,4 imul bx ; DX:AX = 000000C0h (or +192), OF=0 OF=0 because AH is a sign extension of AL can ignore DX!!! Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IMUL Examples Multiply 4,823,424 * -423: Example: Multiply mov eax,4823424 mov ebx,-423 imul ebx ; EDX:EAX = FFFFFFFF86635D80h, OF=0 OF=0 because EDX is a sign extension of EAX. Example: Multiply Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Two Operand Versions Both MUL and IMUL have versions that take two operands for 16 and 32 bit multiplications (not the 8 bit version!) The first operand is a register that is used for the multiplicand (instead of AX or EAX) The second operand is the multiplier, as shown before Result gets truncated to the size of the destination register!!! Be sure to check CF and OF!!! mov cx,10 ; cx is used mov bx,-3 ; instead of ax imul cx,bx Note: there are also three operand versions! Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

DIV Instruction The DIV (unsigned divide) instruction performs 8-bit, 16-bit, and 32-bit division on unsigned integers A single operand is supplied (register or memory operand), which is assumed to be the divisor Instruction formats: DIV reg/mem8 DIV reg/mem16 DIV reg/mem32 Default Operands: Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

DIV Examples Divide 8003h by 100h, using 16-bit operands: mov dx,0 ; clear dividend, high mov ax,8003h ; set dividend, low mov cx,100h ; divisor div cx ; AX = 0080h, DX = 3 Same division, using 32-bit operands: mov edx,0 ; clear dividend, high mov eax,8003h ; set dividend, low mov ecx,100h ; divisor div ecx ; EAX = 00000080h, DX = 3 Example: Primes Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Signed Integer Division (IDIV) Signed integers must be sign-extended before division takes place fill high byte/word/doubleword with a copy of the low byte/word/doubleword's sign bit For example, the high byte contains a copy of the sign bit from the low byte: Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

CBW, CWD, CDQ Instructions The CBW, CWD, and CDQ instructions provide important sign-extension operations: CBW (convert byte to word) extends AL into AH CWD (convert word to doubleword) extends AX into DX CDQ (convert doubleword to quadword) extends EAX into EDX Example: .data dwordVal SDWORD -101 ; FFFFFF9Bh .code mov eax,dwordVal cdq ; EDX:EAX = FFFFFFFFFFFFFF9Bh Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IDIV Instruction IDIV (signed divide) performs signed integer division Same syntax and operands as DIV instruction Example: 8-bit division of –48 by 5 mov al,-48 cbw ; extend AL into AH mov bl,5 idiv bl ; AL = -9, AH = -3 Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

IDIV Examples Example: 16-bit division of –48 by 5 mov ax,-48 cwd ; extend AX into DX mov bx,5 idiv bx ; AX = -9, DX = -3 Example: 32-bit division of –48 by 5 mov eax,-48 cdq ; extend EAX into EDX mov ebx,5 idiv ebx ; EAX = -9, EDX = -3 Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Divide Overflow An overflow condition is created when the result is too large to fit in the destination operand mov ax, 0FFFh ; (4095) mov bl, 02h    div bl  ; (4095/2 = 2047, R= 1) 2047 = 07FFh - won't fit in AL - DIVIDE OVERFLOW!!! Divide overflow causes program to abort One solution is to use larger operands!!! Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Unsigned Arithmetic Expressions Some good reasons to learn how to implement integer expressions: Learn how compilers do it Test your understanding of MUL, IMUL, DIV, IDIV Check for overflow (Carry and Overflow flags) Example: var4 = (var1 + var2) * var3 ; Assume unsigned operands mov eax,var1 add eax,var2 ; EAX = var1 + var2 mul var3 ; EAX = EAX * var3 jc TooBig ; check for carry mov var4,eax ; save product Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Signed Arithmetic Expressions (1 of 2) Example: eax = (-var1 * var2) + var3 mov eax,var1 neg eax imul var2 jo TooBig ; check for overflow add eax,var3 Example: var4 = (var1 * 5) / (var2 – 3) mov eax,var1 ; left side mov ebx,5 imul ebx ; EDX:EAX = product mov ebx,var2 ; right side sub ebx,3 idiv ebx ; EAX = quotient mov var4,eax Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.

Signed Arithmetic Expressions (2 of 2) Example: var4 = (var1 * -5) / (-var2 % var3); mov eax,var2 ; begin right side neg eax cdq ; sign-extend dividend idiv var3 ; EDX = remainder mov ebx,edx ; EBX = right side mov eax,-5 ; begin left side imul var1 ; EDX:EAX = left side idiv ebx ; final division mov var4,eax ; quotient Sometimes it's easiest to calculate the right-hand term of an expression first. Irvine, Kip R. Assembly Language for x86 Processors 7/e, 2015.