cpubbs论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

LabVIEW+单片机学习套件全套教程资料下载[免费]LabVIEW论坛精华列表贴USB0816数据采集卡《LabVIEW宝典》
LabWindows/CVI论坛精华贴NET0816以太网数据采集卡RC0210远程设备授权系统 关闭关停锁定打开设备 户外分布式数据采集
NET1624低速高精度以太网数据采集卡WIFI0824SD无线WIFI网络数据采集卡脱机运行 SD存储 小尺寸微型 串口采集远程采集 安卓 手持移动采集 纪录仪
查看: 1332|回复: 0

任意长度的乘法程序(ASM) [转]

[复制链接]
发表于 2004-11-6 02:25:54 | 显示全部楼层 |阅读模式
<>M_0 EQU 20H ;低位在低地址 被乘数
N_0 EQU 30H ;M_0+5 ;低位在低地址 乘数
X_0 EQU 40H ;N_0+5 ;低位在低地址 积



;现在的程序检查完了,没有问题。
;傲气雄鹰2002.3.31
;-------------------------------
;入口:MMULD ;任意长度的乘法程序。
;堆栈深度:进入MMULD后还需要6个字节深度。其中保存特殊寄存
;器3个,保存B用了1个,调用AADDC_A用了2个,一共用了
;6个字节。
;影响:该程序影响R0-R6所有的寄存器的值。
LEN EQU 05H ;被乘长度,现在的长度=5,可以定义为任意长度。
LEN_ EQU 05H ;乘数长度,现在的长度=5,可以定义为任意长度。
;-------------------------------
MMULD: PUSH PSW
PUSH ACC
PUSH B

MOV A,#LEN ;将结果清空。
ADD A,#LEN_
MOV R1,A
MOV R0,#X_0
MMULD_1:MOV @R0,#00H
INC R0
DJNZ R1,MMULD_1

MOV R2,#00H
MOV R3,#00H
MOV R0,#M_0 ;被乘数
MOV R1,#N_0 ;乘数
MMULD_LOOP_1:
MOV A,@R0
MOV B,@R1
MUL AB
PUSH B
LCALL AADDC_A ;保存到低位
POP B
LCALL AADDC_B ;保存到高位
INC R0
INC R2
CJNE R2,#LEN,MMULD_LOOP_1 ;被乘长度
MOV R0,#M_0
MOV R2,#00H
INC R1
INC R3
CJNE R3,#LEN_,MMULD_LOOP_1 ;乘数长度
POP B
POP ACC
POP PSW
RET
;将ACC加入到结果中。地址为X_0+R2+R3
AADDC_A:
MOV R6,A ;DATA SAVE TO R6。 ;加数在R6中
MOV A,R0
MOV R4,A ;R0   SAVE TO R4
MOV A,#X_0
ADD A,R2
ADD A,R3
MOV R0,A ;被加数放入[R0]
MOV A,#LEN
MOV B,#LEN_
ADD A,B
CLR C
SUBB A,R2
CLR C
SUBB A,R3
MOV R5,A ;长度在R5中
LJMP AADDC
AADDC_B:MOV R6,B ;DATA SAVE TO R6。 ;加数在R6中
MOV A,R0
MOV R4,A ;R0   SAVE TO R4
MOV A,#X_0
ADD A,R2
ADD A,R3
INC A
MOV R0,A ;被加数放入[R0]
MOV A,#LEN
MOV B,#LEN_
ADD A,B
CLR C
SUBB A,R2
CLR C
SUBB A,R3
MOV R5,A ;长度在R5中
LJMP AADDC
AADDC: CLR C ;入口条件:字节数在R5中 ;被加数在[R0]中
;加数在R6中
AADDC_1:MOV A,@R0 ;出口信息:和在[R0]中
ADDC A,R6 ;按字节相加
MOV @R0,A ;和存回[R0]中
MOV R6,#00H
INC R0
DJNZ R5,AADDC_1 ;处理完所有字节
MOV A,R4
MOV R0,A
RET
;-----------------------------------------------------</P>
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|cpubbs论坛. ( 粤ICP备09171248号 )

GMT+8, 2025-4-4 13:56 , Processed in 0.469649 second(s), 7 queries , Gzip On, File On.

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表