pokered/engine/math/multiply_divide.asm

144 lines
3.1 KiB
NASM
Raw Permalink Normal View History

_Multiply::
2014-05-22 22:13:20 +00:00
ld a, $8
ld b, a
xor a
ldh [hProduct], a
ldh [hMultiplyBuffer], a
ldh [hMultiplyBuffer+1], a
ldh [hMultiplyBuffer+2], a
ldh [hMultiplyBuffer+3], a
.loop
ldh a, [hMultiplier]
2014-05-22 22:13:20 +00:00
srl a
ldh [hMultiplier], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
jr nc, .smallMultiplier
ldh a, [hMultiplyBuffer+3]
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hMultiplicand+2]
2014-05-22 22:13:20 +00:00
add c
ldh [hMultiplyBuffer+3], a
ldh a, [hMultiplyBuffer+2]
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hMultiplicand+1]
2014-05-22 22:13:20 +00:00
adc c
ldh [hMultiplyBuffer+2], a
ldh a, [hMultiplyBuffer+1]
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hMultiplicand] ; (aliases: hMultiplicand)
2014-05-22 22:13:20 +00:00
adc c
ldh [hMultiplyBuffer+1], a
ldh a, [hMultiplyBuffer]
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hProduct] ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
2014-05-22 22:13:20 +00:00
adc c
ldh [hMultiplyBuffer], a
.smallMultiplier
2014-05-22 22:13:20 +00:00
dec b
jr z, .done
ldh a, [hMultiplicand+2]
2014-05-22 22:13:20 +00:00
sla a
ldh [hMultiplicand+2], a
ldh a, [hMultiplicand+1]
2014-05-22 22:13:20 +00:00
rl a
ldh [hMultiplicand+1], a
ldh a, [hMultiplicand]
2014-05-22 22:13:20 +00:00
rl a
ldh [hMultiplicand], a
ldh a, [hProduct]
2014-05-22 22:13:20 +00:00
rl a
ldh [hProduct], a
jr .loop
.done
ldh a, [hMultiplyBuffer+3]
ldh [hProduct+3], a
ldh a, [hMultiplyBuffer+2]
ldh [hProduct+2], a
ldh a, [hMultiplyBuffer+1]
ldh [hProduct+1], a
ldh a, [hMultiplyBuffer]
ldh [hProduct], a
2014-05-22 22:13:20 +00:00
ret
_Divide::
2014-05-22 22:13:20 +00:00
xor a
ldh [hDivideBuffer], a
ldh [hDivideBuffer+1], a
ldh [hDivideBuffer+2], a
ldh [hDivideBuffer+3], a
ldh [hDivideBuffer+4], a
2014-05-22 22:13:20 +00:00
ld a, $9
ld e, a
2022-07-11 01:11:03 +00:00
.loop
ldh a, [hDivideBuffer]
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hDividend+1] ; (aliases: hMultiplicand)
2014-05-22 22:13:20 +00:00
sub c
ld d, a
ldh a, [hDivisor] ; (aliases: hDivisor, hMultiplier, hPowerOf10)
2014-05-22 22:13:20 +00:00
ld c, a
ldh a, [hDividend] ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
2014-05-22 22:13:20 +00:00
sbc c
2022-07-11 01:11:03 +00:00
jr c, .next
ldh [hDividend], a ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
2014-05-22 22:13:20 +00:00
ld a, d
ldh [hDividend+1], a ; (aliases: hMultiplicand)
ldh a, [hDivideBuffer+4]
2014-05-22 22:13:20 +00:00
inc a
ldh [hDivideBuffer+4], a
2022-07-11 01:11:03 +00:00
jr .loop
.next
2014-05-22 22:13:20 +00:00
ld a, b
cp $1
2022-07-11 01:11:03 +00:00
jr z, .done
ldh a, [hDivideBuffer+4]
2014-05-22 22:13:20 +00:00
sla a
ldh [hDivideBuffer+4], a
ldh a, [hDivideBuffer+3]
2014-05-22 22:13:20 +00:00
rl a
ldh [hDivideBuffer+3], a
ldh a, [hDivideBuffer+2]
2014-05-22 22:13:20 +00:00
rl a
ldh [hDivideBuffer+2], a
ldh a, [hDivideBuffer+1]
2014-05-22 22:13:20 +00:00
rl a
ldh [hDivideBuffer+1], a
2014-05-22 22:13:20 +00:00
dec e
2022-07-11 01:11:03 +00:00
jr nz, .next2
2014-05-22 22:13:20 +00:00
ld a, $8
ld e, a
ldh a, [hDivideBuffer]
ldh [hDivisor], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
2014-05-22 22:13:20 +00:00
xor a
ldh [hDivideBuffer], a
ldh a, [hDividend+1] ; (aliases: hMultiplicand)
ldh [hDividend], a ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
ldh a, [hDividend+2]
ldh [hDividend+1], a ; (aliases: hMultiplicand)
ldh a, [hDividend+3]
ldh [hDividend+2], a
2022-07-11 01:11:03 +00:00
.next2
2014-05-22 22:13:20 +00:00
ld a, e
cp $1
2022-07-11 01:11:03 +00:00
jr nz, .okay
2014-05-22 22:13:20 +00:00
dec b
2022-07-11 01:11:03 +00:00
.okay
ldh a, [hDivisor] ; (aliases: hDivisor, hMultiplier, hPowerOf10)
2014-05-22 22:13:20 +00:00
srl a
ldh [hDivisor], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
ldh a, [hDivideBuffer]
2014-05-22 22:13:20 +00:00
rr a
ldh [hDivideBuffer], a
2022-07-11 01:11:03 +00:00
jr .loop
.done
ldh a, [hDividend+1] ; (aliases: hMultiplicand)
ldh [hRemainder], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
ldh a, [hDivideBuffer+4]
ldh [hQuotient+3], a
ldh a, [hDivideBuffer+3]
ldh [hQuotient+2], a
ldh a, [hDivideBuffer+2]
ldh [hQuotient+1], a ; (aliases: hMultiplicand)
ldh a, [hDivideBuffer+1]
ldh [hDividend], a ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
2014-05-22 22:13:20 +00:00
ret