又来造轮子了.
今天的是divdw,是一个不同于8位与16位的div除法的函数,它也是用于除法,但是不会溢出.
代码如下:
assume cs:code
stack segment
dw 0,0,0,0
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,8
;初始化
mov dx,0Fh
mov ax,4240h
mov cx,0Ah
call far ptr divdw
mov ax,4c00h
int 21h
divdw: push bx
push ax
mov ax,dx
mov dx,0
div cx
mov bx,ax
pop ax
push bx
div cx
mov cx,dx
pop dx
pop bx
retf
code ends
end start
因为过于简单就不再累述
直接上轮子:
divdw: push bx
push ax
mov ax,dx
mov dx,0
div cx
mov bx,ax
pop ax
push bx
div cx
mov cx,dx
pop dx
pop bx
retf
使用方式:
- 向dx内存入32位的被除数的高16位
- 向ax内存入32位的被除数的低16位
- 向cx内存入8位的除数
- 确保栈中有4 bytes(=2 words=32bits)剩余
- 结果为:dx储存32位的商的高16位,ax储存32位的商的低16位,cx储存余数
经过多轮测试,目前没有发现bug,如果有路过的大佬发现了啥问题,麻烦指出,不胜感激!