Search code examples
assemblyx86masmirvine32carryflag

Carry Flag Assembly Language


Why is the Carry Flag set at 255 in this code

INCLUDE Irvine32.inc
.data
.code
main PROC

;adding 1 to 255 rolls AL over to zero:
mov al,255
add al,1    ; AL=0, CF=1 (unsigned overflow)
call DumpRegs

;subtracting larger number from smaller:
sub al,1    ; AL=255, CF=1
call DumpRegs

;subtracting 1 from 255
sub al,1    ; AL=254, CF=0
call DumpRegs

exit
main ENDP
END main

Maybe I am getting Overflow and carry mixed up, but since 1111 1111 is 255 in binary, shouldn't the carry only be set at 256?


Solution

  • There are two flags used to track when a value overflows.

    One is the unsigned overflow, CF, and the other is the signed overflow OF.

    The CF flag is set when you do an addition that goes over the maximum value a register can hold. In your case any addition that goes over 255.

    For subtractions, same thing, the other way around. If you subtract and it goes under 0, then you get a carry.

    The CF flag allows you to do additions on very large numbers without the need for specialized code:

    add eax, ebx
    adc ecx, edx
    

    This adds two 32 bit numbers together (eax and ebx) and then another set of 32 bit numbers (ecx, edx) taking the carry in account. The result is ebx/edx representing a 64 bit number. You can use that for numbers of any size (i.e. you could write code to add two numbers of 1024 bits each.)

    If your number is unsigned, you could add a jc overflow at the end, if it jumps, then you have an overflow (your number requires 65 bits after the addition.)

    The OF flag is always set, however, it is generally only used on the last addition to know whether you had an overflow in the event your number is signed. If your number is always unsigned, then OF is never used in your code (obviously, the processor always set OF no matter what since it does not know whether you are working with a signed or unsigned number.)

    So in our previous addition, you would do:

    add eax, ebx
    adc ecx, edx
    jo overflow
    

    When the jump to overflow happens, your 64 bit addition does not fit a 64 bit number. You would need 65 bits. That can be used to generate an exception and let the user know that his math is incorrect. The OF flag, of course, would work on AL in which case that value is viewed as a number between -128 and +127. If an add generates a number larger than 127, or a subtract a number smaller than -128, then OF gets set.