大学微机原理软件实验报告.doc

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
信息与通信工程学院 微机原理软件实验报告 实验一 DEBUG的使用 一、实验目的: 1.掌握汇编程序的编辑,编译,连接和执行的全过程; 2.学习和掌握用DEBUG调试程序的方法. 二、实验内容: 1.用编辑软件,输入以下汇编语言源程序: DAT SEGMENT A DB 20 ;(自定) B DB 15 ;(自定) Y DB 3 DUP(0) Z DB 0,0 DAT ENDS STA SEGMENT STACK DW 50 DUP(?) STA ENDS COD SEGMENT ASSUME CS:COD,DS:DAT STAR PROC FAR PUSH DS XOR AX,AX PUSH AX MOV AX,DAT MOV DS,AX MOV AX,STA MOV SS,AX MOV AL,A MOV Z,AL MOV Z+1,AL CALL SUB1 MOV AL,B MOV Z,AL MOV Z+1,AL CALL SUB1 MOV AL,A MOV Z,AL MOV AL,B MOV Z+1,AL CALL SUB1 ADD WORD PTR Y,AX ADC BYTE PTR[Y+2],0 RET STAR ENDP SUB1 PROC MOV AL,Z MOV AH,Z+1 MUL AH ADD WORD PTR Y,AX ADC BYTE PTR[Y+2],0 RET SUB1 ENDP COD ENDS END STAR 2.通过编译,连接形成可执行文件. 3.用 DEBUG 将可执行文件调入,并进行调试. (1)用 D 命令观察数据区在内存中的具体内容,记录单元 A 和 B 的具体地址. (2)用 U 命令对目标代码反汇编,观察反汇编后的结果.注意发现源程序的起始 位置, 并记录这个起始地址. (3)用 T 命令作单步跟踪调试.比较每条指令执行后的结果和原来的理解是否 一致.得出程序运行的结果:它们是写在什么单元,具体内容是什么; 并判断结果是否正确. (4)在子程序 SUB1 的入口处设一断点,用 G 命令执行程序. 在断点处观察堆 栈的内容,比较堆栈的内容和程序返回地址是否一致. (5)用 E 命令修改单元 A,B 的内容,重新执行程序,并记录结果. (6)用 M 命令和 A 命令对程序进行修改: 将主程序中最后两条指令 (ADD 和 ADC) 修改为一条 CALL SUB1 指令,重新执行程序. (7)退出 DEBUG. 4.重新使用编辑软件,把源程序最后一句中的 STAR 去掉.再次生成可执行文件, 并用 DEBUG 调入内存.当使用 U 命令时,显示的结果与前一次(未加 STAR) 的结果有何不同? 三、预习题: 1.熟悉常用的 DEBUG 命令. 2.阅读并分析程序的功能. 3.若 SS=2000H,SP=FFFFH, 向堆栈中压入 4 字节数据后,如何用 D 命令显示压入堆栈的内容? 答:使用debug 指令“d 2000:0000”即可显示压入堆栈的内容,这是因为SP+1 会溢出,变成0000。 四、实验过程 如上图,通过masm和link命令程序编译连接成功。 进入debug中,用u命令查看反编译结果。得出A的地址为:0B88:0000,值为1BH,即十进制的27D;B的地址为:0B88:0001,值为33,即十进制的51D。 Y的偏移地址为0002H,Z的偏移地址为0005H。DATA段基地址为0B88H。 SUB1子程序段入口地址为003F。 如上图所示,用E命令将A和B的值由1EH,33H改为10H,20H,通过d命令

文档评论(0)

追风少年 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档