2020-06-27 19:32:24 +00:00
|
|
|
_Multiply::
|
2014-05-22 22:13:20 +00:00
|
|
|
ld a, $8
|
|
|
|
ld b, a
|
|
|
|
xor a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hProduct], a
|
|
|
|
ldh [hMultiplyBuffer], a
|
|
|
|
ldh [hMultiplyBuffer+1], a
|
|
|
|
ldh [hMultiplyBuffer+2], a
|
|
|
|
ldh [hMultiplyBuffer+3], a
|
2015-07-26 22:19:34 +00:00
|
|
|
.loop
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplier]
|
2014-05-22 22:13:20 +00:00
|
|
|
srl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplier], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
|
2015-07-26 22:19:34 +00:00
|
|
|
jr nc, .smallMultiplier
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplyBuffer+3]
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplicand+2]
|
2014-05-22 22:13:20 +00:00
|
|
|
add c
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplyBuffer+3], a
|
|
|
|
ldh a, [hMultiplyBuffer+2]
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplicand+1]
|
2014-05-22 22:13:20 +00:00
|
|
|
adc c
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplyBuffer+2], a
|
|
|
|
ldh a, [hMultiplyBuffer+1]
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplicand] ; (aliases: hMultiplicand)
|
2014-05-22 22:13:20 +00:00
|
|
|
adc c
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplyBuffer+1], a
|
|
|
|
ldh a, [hMultiplyBuffer]
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hProduct] ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
|
2014-05-22 22:13:20 +00:00
|
|
|
adc c
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplyBuffer], a
|
2015-07-26 21:04:24 +00:00
|
|
|
.smallMultiplier
|
2014-05-22 22:13:20 +00:00
|
|
|
dec b
|
2015-07-26 21:04:24 +00:00
|
|
|
jr z, .done
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hMultiplicand+2]
|
2014-05-22 22:13:20 +00:00
|
|
|
sla a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplicand+2], a
|
|
|
|
ldh a, [hMultiplicand+1]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplicand+1], a
|
|
|
|
ldh a, [hMultiplicand]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hMultiplicand], a
|
|
|
|
ldh a, [hProduct]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hProduct], a
|
2015-07-26 22:19:34 +00:00
|
|
|
jr .loop
|
2015-07-26 21:04:24 +00:00
|
|
|
.done
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
|
|
|
|
2020-06-27 19:32:24 +00:00
|
|
|
_Divide::
|
2014-05-22 22:13:20 +00:00
|
|
|
xor a
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDivideBuffer]
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDividend+1] ; (aliases: hMultiplicand)
|
2014-05-22 22:13:20 +00:00
|
|
|
sub c
|
|
|
|
ld d, a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDivisor] ; (aliases: hDivisor, hMultiplier, hPowerOf10)
|
2014-05-22 22:13:20 +00:00
|
|
|
ld c, a
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDividend], a ; (aliases: hProduct, hPastLeadingZeros, hQuotient)
|
2014-05-22 22:13:20 +00:00
|
|
|
ld a, d
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDividend+1], a ; (aliases: hMultiplicand)
|
|
|
|
ldh a, [hDivideBuffer+4]
|
2014-05-22 22:13:20 +00:00
|
|
|
inc a
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDivideBuffer+4]
|
2014-05-22 22:13:20 +00:00
|
|
|
sla a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDivideBuffer+4], a
|
|
|
|
ldh a, [hDivideBuffer+3]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDivideBuffer+3], a
|
|
|
|
ldh a, [hDivideBuffer+2]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDivideBuffer+2], a
|
|
|
|
ldh a, [hDivideBuffer+1]
|
2014-05-22 22:13:20 +00:00
|
|
|
rl a
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDivideBuffer]
|
|
|
|
ldh [hDivisor], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
|
2014-05-22 22:13:20 +00:00
|
|
|
xor a
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh a, [hDivisor] ; (aliases: hDivisor, hMultiplier, hPowerOf10)
|
2014-05-22 22:13:20 +00:00
|
|
|
srl a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDivisor], a ; (aliases: hDivisor, hMultiplier, hPowerOf10)
|
|
|
|
ldh a, [hDivideBuffer]
|
2014-05-22 22:13:20 +00:00
|
|
|
rr a
|
2020-07-06 23:03:05 +00:00
|
|
|
ldh [hDivideBuffer], a
|
2022-07-11 01:11:03 +00:00
|
|
|
jr .loop
|
|
|
|
.done
|
2020-07-06 23:03:05 +00:00
|
|
|
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
|