I m trying to find how to make a division in ARM since there is no DIV
command. If that can be done by multiplication of a float number [/9 = *0.09]
, by subtraction or by the use of a library. Any way would do.
Currently I am doing division using subtraction using a loop like this but I loose the decimals:
MOV R0,#70 ;Fahrenheit Temperature
SUB R1,R0,#32 ; Subtracting 32
MOV R4,#0 ;Counter
LOOP
ADD R4,R4,#1; Counter+1 ->Is the answer of the division without decimals
SUB R1,#9
CMP R1,#0
BPL LOOP
MOV R1,R4
So basically what I am doing is that I have temperature 70, I subtract 32 and I get 38. Then in the loop I take 9 each time till the reminder is smaller than 9. The answer using normal division is 4.22222. Here I get 5. So my result is not as accurate.
If you just want to divide an integer value in
r0
by 9 you can approximate that with:r3
now contains the integer part of the quotient, andr9
contains the fractional part scaled by 2^32. To get the remainder you'd just multiply the integer part of the quotient by 9 and subtract the result from the original value.Michael's answer is right if you divide the number by a constant and you need an integer result. You won't get the fraction part like you want.
If you need a floating-point result you'll need a floating-point division function, which is not easy to implement in software and asm on architectures without FPU. ARMv7 and above have FPU/SIMD by default, some ARMv6 and below also have FPU so you can divide it directly in hardware
A fixed-point solution may be easier, just divide the number like normal integer division but remember to adjust the result after calculation. Of course fixed-point number won't have large dynamic range like floating-point but in your case I think the range is enough. You can also multiply the remainder by 10n, with
n
is the number of digits after decimal sign you need, then divide it with the above divisor again to get the fractional partFor example to get the result of 22/9 with 3 digits of precision do as follow:
To get more precision, just multiply the remainder with a larger power of 10