1

由于没有DIV命令,我正在尝试找到如何在 ARM 中进行划分。如果这可以通过浮点数的乘法[/9 = *0.09]、减法或使用库来完成。任何方式都可以。

目前我正在使用这样的循环使用减法进行除法,但我丢失了小数:

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

所以基本上我所做的是温度为 70,减去 32,得到 38。然后在循环中,我每次取 9,直到提醒小于 9。使用正常除法的答案是 4.22222。在这里我得到 5。所以我的结果并不准确。

4

2 回答 2

3

如果您只想将整数值r0除以 9,您可以使用以下方法进行近似:

ldr r3,=0x1C71C71D   # 1C71C71D == (2^32 / 9) + 1
umull   r9,r3,r0,r3

r3现在包含商的整数部分,并r9包含按 2^32 缩放的小数部分。要获得余数,您只需将商的整数部分乘以 9,然后从原始值中减去结果。

于 2013-11-07T19:52:50.817 回答
1

如果将数字除以常数并且需要整数结果,迈克尔的答案是正确的。你不会得到你想要的分数部分。

如果您需要浮点结果,则需要浮点除法功能,这在没有 FPU 的架构上的软件和 asm 中不容易实现。ARMv7及以上默认有FPU/SIMD,部分ARMv6及以下也有FPU,可以直接在硬件上划分

定点解可能更简单,只需像普通整数除法一样除数,但记得在计算后调整结果。当然,定点数不会像浮点数那样有大的动态范围,但在你的情况下,我认为范围就足够了。您也可以将余数乘以 10 n,其中n是您需要的小数点后的位数,然后再次将其除以上述除数以获得小数部分

例如,要获得 3 位精度的 22/9 的结果,请执行以下操作:

22/9   = 2 remains 4
4*10^3 = 4000
4000/9 = 444
→ 22/9 = 2.444

为了获得更高的精度,只需将余数乘以 10 的更大幂

于 2013-11-08T00:53:56.120 回答