Solved

explanation required

Posted on 2011-03-03
5
375 Views
Last Modified: 2012-06-27
I went through the following question / answer :

Assume that AX = BBBBh  and BX = BBBBh. What will be the contents
   of the AX register after the instruction:

      ADD AL,BL

   is executed.

   A. BBBBh    B. BBF6h   C. BB76h    D. BB78h    E. None of these

   Answer: C

   What will the condition code bits be after the instruction is
   executed.

   A. SF=0 ZF=0 OF=0 CF=1      B. SF=0 ZF=0 OF=1 CF=1

   C. SF=0 ZF=1 OF=0 CF=1      D. SF=1 ZF=0 OF=1 CF=1    E. None of the above

   Answer: B


I didn't understand why the OF is set to 1 can someone explain to me that ?

Thanks.
0
Comment
Question by:bachra04
  • 3
  • 2
5 Comments
 
LVL 53

Expert Comment

by:Infinity08
ID: 35031669
>> I didn't understand why the OF is set to 1 can someone explain to me that ?

OF is the overflow flag, and it is set if the previous instruction caused an (arithmetic) overflow.

In this case, ADD AL,BL caused an overflow, so the flag is set.
0
 
LVL 2

Author Comment

by:bachra04
ID: 35031964
I understand that :

BBh + BBh caused a carry that's why CF is set ;

But what confuses me is when do we say that there is Overflow; do you mean every time we have a carry we'll have overflow ?
Is there a case when we have overflow and not a carry ? or vice versa ?

Thanks
0
 
LVL 53

Accepted Solution

by:
Infinity08 earned 500 total points
ID: 35032253
There is an important distinction between the carry flag (CF) and the overflow flag (OF) :

CF : set if the LSB (least significant bit) of the neighboring more significant value would have been set by the instruction (useful for unsigned accition eg.)
OF : set if the MSB (most significant bit) changes due to the instruction (useful for signed addition eg.)

For example (in binary) :

        11111111 + 11111111 = 111111110

so, there is carry (because an extra 9th bit is set), but there is no overflow (because the 8th bit hasn't changed - it was 1 before and after).

And also :

        01111111 + 01111111 = 11111110

so there is no carry (the result still fits in the 8 bits), but there is overflow (because the 8th bit has changed from 0 to 1).
0
 
LVL 2

Author Comment

by:bachra04
ID: 35034040
Can the carry flag be set 1 in a substraction operation :

e.g : sub 11h, 44h
0
 
LVL 53

Expert Comment

by:Infinity08
ID: 35034149
>> Can the carry flag be set 1 in a substraction operation :

In the case of a subtraction, the CF is set in case of what is called a borrow :

        00000001 - 00000010 = 11111111

In order for this (unsigned) subtraction to work, we need a borrow, to add a 9th 1 bit to the first operand :

        100000001 - 00000010 = 11111111

so the CF flag is set.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Converting Native Code to VB or C# 9 1,420
Intel DX58SO board 7 869
How to Replace 2003 failover Cluster node 4 355
Wondows Handles 4 405
This article shows gives you an overview on SQL Server 2016 row level security. You will also get to know the usages of row-level-security and how it works
An analysis of the phishing scam that has been affecting Google users, along with steps to take for protection, as well as what to do if you receive one of the emails.
This is used to tweak the memory usage for your computer, it is used for servers more so than workstations but just be careful editing registry settings as it may cause irreversible results. I hold no responsibility for anything you do to the regist…
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…

920 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now