In the following code,
MOV AL,NUMBER1
ADD AL,NUMBER2
MOV AH, 00H
ADC AH, 00H
what are lines 3 and 4 for? What do they do?
Also, why does the code clear AH? (I assume because AL's "ADD" operation may produce carry.)
In the following code,
MOV AL,NUMBER1
ADD AL,NUMBER2
MOV AH, 00H
ADC AH, 00H
what are lines 3 and 4 for? What do they do?
Also, why does the code clear AH? (I assume because AL's "ADD" operation may produce carry.)
To figure this out, start by looking up what each instruction does:
MOV AH, 00H
This MOV
instruction will set the AH
register to 0 without affecting flags.
ADC AH, 00H
This ADC
instruction will add the source operand (0), the carry flag (CF), and the destination operand (AH
), storing the result in the destination operand (AH
).
Symbolically, then, it does: AH = AH + 0 + CF
Remember that the MOV
did not affect the flags, so the value of CF that is used by the ADC
instruction is whatever was set previously by the ADD
instruction (in line 2).
Also, AH
is 0 at this point, so this is really just: AH = CF
.
And now you know what the code does:
It moves NUMBER1
into the AL
register: AL = NUMBER1
It adds NUMBER2
to the AL
register: AL = NUMBER1 + NUMBER2
It clears AH
: AH = 0
It sets AH
equal to CF, as set by the addition of NUMBER1
and NUMBER2
. Thus, AH
will be 1 if the addition required a carry, or 0 otherwise. (AH = CF
)
As for the purpose of this code, it clearly performs a 16-bit addition of two 8-bit numbers. In a pseudo-C, it would basically be:
BYTE NUMBER1;
BYTE NUMBER2;
WORD RESULT = (WORD)NUMBER1 + (WORD)NUMBER2;
where the BYTE-sized inputs are extended to WORDs and added together. Why do this? Well, to handle overflow. If you add together two 8-bit values, the result may be larger than will fit in 8 bits.
The real trick to understanding this may be that the AL
and AH
registers are the lower and upper bits, respectively, of the AX
registers. So immediately after these instructions, you may see AX
being used. This contains the 16-bit result of the addition of NUMBER1
and NUMBER2
.