09级微机原理课程设计.pdfVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2009 级计算机专业《微机原理与接口技术》课程设计 一、设计任务 题目一 用 16 位乘法指令完成 32 位无符号数乘法(结果 64 位) 使用MUL指令,完成双字无符号数乘法程序。 算法原理 16 位数 16 位数 ※ 16 位数 16 位数 DX AX DX AX DX AX DX AX —————————— P4 p3 p2 p1 设计原理分析: 我的想法是先把 32 位乘数分成高 16 位和低 16 位,分别存放在不同的参数 d1 、d2 中, 被乘数依次分为 d3 和 d4,通过 16 位乘法 MUL指令先让 d4 与 d2 相乘,得到的结果先赋值 给 p1、p2,然后 d1 与 d4 相乘时,得到的结果中 AX 值直接与 p2 相加, DX值先赋值给 p3, 当 d3 与 d2 相乘时, 得到的 AX 与 p2 相加, DX值与 P3相加, 此时需考虑进位, 所以使用 adc 指令进行相加, 当 d3 与 d1 相乘时, DX值先赋给 p4, 将 AX 值与 p3 相加, 此时不需要考虑进 位,但是最好需要对 p4 进行进位考虑, 所以最后加上一条 adc p4,0 指令, 最后调用 dispal 子程序将相乘结果 p4p3p2p1 输出 框图: 开始 被乘数低 16 位与乘数低 6 位相乘 被乘数低 16 位与乘数高 16 位相乘并与上次相乘结果相加 被乘数高 6 位与乘数低 6 位相乘并与上次相乘结果相加 被乘数高 16 位与乘数高 16 位相乘并与上次相乘结果相加 调用输出子程序将乘法结果输出 结束 源程序: data segment d1 dw 1234h; 乘数高 16 位 d2 dw 5678h; 乘数低 16 位 d3 dw 1234h; 被乘数高 16 位 d4 dw 5678h; 被乘数低 16 位 p1 dw ? ; 存放相乘结果 p2 dw ? p3 dw ? p4 dw ? data ends sstack segment stack 'stack'; 定义堆栈段 dw 200h dup(?) sstack ends code segment; 代码段 main proc far assume cs:code,ds:data,ss:sstack start:push ds; 为程序结束做准备 sub ax,ax push ax mov ax,data; 指向数据段 mov ds,ax mov

文档评论(0)

***** + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档