ARM除以10保存余数和商

时间:2013-03-06 06:20:10

标签: arm

这是CS2400 MSU Denver的家庭作业问题

您好,

我有一个程序可以读取用户的密钥,直到他们输入非HEX字符或输入最多8个HEX字符。当输入密钥时,我通过将sum寄存器乘以16并添加新的十六进制值来保持用户输入的十六进制值之和。

这部分都很好,花花公子,没有必要帮助。我无法在HEX中获取最终结果,并将其转换为DEC。我知道我需要除以10只是我不知道如何才能做到这一点。

请帮我确定如何除以10并保存商和余数。感谢。

AREA HW6, CODE
ENTRY

Divsor  EQU 10  
MAIN
MOV R1, #0          ; Clear register to be used as symbols received     counter
MOV     R2, #0              ; Clear register to be used as temp result
LDR R4, =DecStr     ; Load address of DecStr
LDR R5, =TwosComp       ; Load address of TwosComp
LDR R6, =RvsDecStr
BL  READ_CHARS      ; Read characters from the keyboard
BL  TO_DECIMAL      ; Is R2 negative ?
SWI     0x11


READ_CHARS
CMP     R1, #8          ; Check if necessary to read another key
BEQ DONE_READ_CHAR      ; User has entered 8 hex symbols

SWI 4           ; [R0] <--- Key from keyboard (ASCII)

CMP R0, #'0'        ; Verify digit is valid 
BLO DONE_READ_CHARS 

CMP R0, #'9'        ; Verify digit is valid 
BHI     CHECK_HEX       

SUB R0, R0, #'0'        ; Obtain Hex equivalent of ASCII char 0-9   
B   STORE_INPUT     

CHECK_HEX
CMP     R0, #'A'
BLO DONE_READ_CHARS         ; Invalid Hex symbol
CMP R0, #'F'
BHI DONE_READ_CHARS     ; Invalid Hex symbol    

SUB     R0, R0, #'A'
ADD R0, R0, #0xA        ; Adding ten to receive Hex equivalent of ASCII A-F

STORE_INPUT
MOV R3, R2, LSL#4       ; *16
ADD R2, R3, R0      ; Add valid Hex symbol to temp result
ADD     R1, R1, #1      ; Increase symbol's recieved counter
B   READ_CHARS      ; Get next key

DONE_READ_CHARS
MOV     PC, LR          ; Return to BL READ_CHARS ( MAIN )

TO_DECIMAL
TST     R2, #2, 2
BEQ POSITIVE
STRB    #'-', [R4], #1      ; Store - as first byte in DecStr
MVN R2, R2          ; [R2] <-  1's complement of R2
ADD R2, R2, #1      ; [R2] <-  2's complement of R2
POSITVE
STR R2, [R5]        ; Store all entered hex values in memory at TwosComp

LDR     R7, [R5]        ; Initial quotient 
udiv10
LDRB    R7, [R5], #1        ; Load a byte of TwosComp 
CMP R7, #0
BEQ DONE_TO_DECIMAL

DONE_TO_DECIMAL
MOV PC, LR

AREA data1, DATA    
TwosComp 
DCD 0

DecStr  % 12

RvsDecStr
% 11

ALLIGN
END

1 个答案:

答案 0 :(得分:1)

你可以通过轻松地减去和移动像基本划分来做到这一点。此网站上还有许多分区算法和Google

How does one do integer (signed or unsigned) division on ARM?

Assembly mod algorithm on processor with no division operator

但是如果您只想将十六进制转换为十进制,那么double dabble可能符合您的需要。它将数字转换为打包的BCD而不进行任何划分