汇编语言系列文章仅作为实验报告和汇编学习参考,不作为任何技术文章,还望大佬们勿喷。

1. 实验名称

搭建汇编语言的开发环境,熟悉汇编程序开发的基本步骤,掌握基本的调试操作。

2. 实验要求

基于VISUAL STUDIO 平台,结合MASM32的汇编器,构建IA-32汇编语言的开发环境。

3. 实验内容

  1. VC6平台下的汇编语言开发环境搭建(使用MASM32的汇编器+VC6)
    1. 配置IDE环境:
    • 在VC的tools/option/Directories页面中添加Irvine32.inc等所在的目录到include files中; 添加Irvine32.lib等所在的目录到library files
    • 将masm32中的ml.exe和ml.err拷贝到VC的Microsoft Visual Studio\VC98\Bin目录中
    1. 创建与配置project:
    • 新建VC的win32 console类型空工程
    • 创建一个asm后缀的文件,并把汇编代码(教材第85页addsub3.asm)输入该文件中,然后将该asm文件添加到Source Files
    • 选中asm文件,在project settings/Custom Build页面中命令行加:ml /c /coff /Fo$(TargetDir)$(InputName).obj $(InputPath)
    • 输出中加上:$(TargetDir)$(InputName).obj
    • “Project setting”页面的”link”选项卡中“object/library module ”中加入irvine32.lib
  2. 汇编与链接不带输出的加减法程序(即教材第85页addsubTest.asm);
  3. 在程序最后加入调用DumpRegs过程的语句,以输出各寄存器的值。
  4. 以单步执行的方式调试该程序,查看每步结果,并解释每步结果,并写成注释。(特别注意对标志位的影响)
  5. (可选)尝试修改程序。
  6. (可选)单步跟踪课件中4.3.3节的程序“ptr应用示例”,结合VC6的内存查看功能(通过菜单viewdebug windowsMemory调出内存查看窗口)理解每步的执行结果。(注意课件中只是大部分代码,请补全头文件以及程序退出宏。)

4. 实验步骤或源代码、结果

1. 实验步骤

  1. 汇编与链接不带输出的加减法程序

【汇编语言实验一】搭建开发环境 - 图1

  1. 在程序最后加入调用DumpRegs过程的语句,以输出各寄存器的值

【汇编语言实验一】搭建开发环境 - 图2

  1. 以单步执行的方式调试该程序,查看每步结果,并解释每步结果,并写成注释。

【汇编语言实验一】搭建开发环境 - 图3

  1. EIP指向下一条将要执行指令的地址,即00401010所在的mov指令。

【汇编语言实验一】搭建开发环境 - 图4

  1. mov指令把1000h赋给ax寄存器,ax=1000h所以EAX变为了906E1000。

【汇编语言实验一】搭建开发环境 - 图5

  1. inc指令把ax加1,所以ax的地址从1000变成了1001。

【汇编语言实验一】搭建开发环境 - 图6

  1. dec指令把ax减1,所以ax的地址从1001变成了1000。

【汇编语言实验一】搭建开发环境 - 图7

  1. mov指令把SDWORD类型的Xval赋给eax,由于Xval的大小是26,16进制下是1A,所以EAX为0000001A。

【汇编语言实验一】搭建开发环境 - 图8

  1. neg指令把EAX转换成二进制补码,将操作数的符号取反,00000000000000000000000000011010是正数,二进制补码就是其本身,全部取反得再加1到11111111111111111111111111100110,即FFFFFFE6,十进制为-26。

【汇编语言实验一】搭建开发环境 - 图9

  1. mov指令把SDWORD类型的Yval赋给ebx,由于Yval大小是30,30的16进制就是1E,ebx的值为0000001E。

【汇编语言实验一】搭建开发环境 - 图10

  1. sub指令把ebx的值减去Zval的值,由于Zval是SDWORD,且大小是40,40的16进制为28,Yval-Zval即0000001E+FFFFFFD8=FFFFFFF6,所以ebx的值为FFFFFFF6。

【汇编语言实验一】搭建开发环境 - 图11

  1. add指令把ebx的值加到eax上,FFFFFFF6+FFFFFFE6=FFFFFFDC,它的补码的10进制为-36,所以Rval的值就是ax的值,为DC。

【汇编语言实验一】搭建开发环境 - 图12

  1. mov指令把1赋给了cx,所以cx的值为0001,此时ZR=0。

【汇编语言实验一】搭建开发环境 - 图13

  1. sub指令cx的值减1,cx的值变为0000,此时零标志位ZR=1。

【汇编语言实验一】搭建开发环境 - 图14

  1. mov指令把0FFFFh赋给ax,所以ax的值为FFFF。

【汇编语言实验一】搭建开发环境 - 图15

  1. inc指令把ax的值加1,即FFFF加上1,会进位,得到0000。此时ZR=1。

【汇编语言实验一】搭建开发环境 - 图16

  1. move指令把0赋给cx,所以cx的值为0000,PL=0。

【汇编语言实验一】搭建开发环境 - 图17

  1. sub指令把cx的值加1,cx的值为0001,此时符号标志位PL=1。

【汇编语言实验一】搭建开发环境 - 图18

  1. mov指令把7FFF赋给ax,所以ax的值为7FFF。

【汇编语言实验一】搭建开发环境 - 图19

  1. add指令把ax的值加2,ax的值变成8001,此时PL=1。

【汇编语言实验一】搭建开发环境 - 图20

  1. move指令把0FF赋给al,al的值为FF,ax的值为80FF,CY=0。

【汇编语言实验一】搭建开发环境 - 图21

  1. add指令把al的值加1,al变成00,此时进位,所以进位标识符CY=1。

【汇编语言实验一】搭建开发环境 - 图22

  1. move指令把+127赋给al,al的值变成7F,此时OV=0。

【汇编语言实验一】搭建开发环境 - 图23

  1. add指令把al的值加1,al的值变成80,此时溢出,溢出标志位OV=1。

【汇编语言实验一】搭建开发环境 - 图24

  1. move指令把-128赋给al,al的值变成80。

【汇编语言实验一】搭建开发环境 - 图25

  1. sub指令把al的值减1,al的值变成7F,此时溢出,溢出标志位OV=1。

2. 实验源代码、结果

加上注释后代码是:

  1. ;加法和减法 (AddSubTest.asm)
  2. include Irvine32.inc
  3. .data
  4. Rval SDWORD ?
  5. Xval SDWORD 26
  6. Yval SDWORD 30
  7. Zval SDWORD 40
  8. .code
  9. main PROC
  10. ;INCDEC
  11. mov ax, 1000h ; ax = 1000h
  12. inc ax ; ax = 1001h
  13. dec ax ; ax = 1000h
  14. ; 表达式:Rval=-Xval+(Yval-Zval)
  15. mov eax, Xval ; eax = 0000001a
  16. neg eax ; -26
  17. mov ebx, Yval
  18. sub ebx, Zval ; -10
  19. add eax, ebx ; -36
  20. ; 零标志位示例
  21. mov cx, 1 ; ZR = 0
  22. sub cx, 1 ; ZR = 1
  23. mov ax, 0FFFFh ;
  24. inc ax ; ZR = 1
  25. ; 符号标志位示例
  26. mov cx, 0 ; PL = 0
  27. sub cx, 1 ; PL = 1
  28. mov ax, 7FFFh
  29. add ax, 2 ; PL = 1
  30. ; 进位标志位示例
  31. mov al, 0FFh ; CY = 0, AL = FF
  32. add al, 1 ; CY = 1, AL = 00
  33. ; 溢出标志位示例
  34. mov al, +127 ; OV = 0
  35. add al, 1 ; OV = 1
  36. mov al, -128
  37. sub al, 1 ; OV = 1
  38. CALL DumpRegs
  39. INVOKE ExitProcess, 0
  40. main ENDP
  41. END main

5. 实验结论和心得体会

  • 再次加深了对通用寄存器和状态标志位的认识;
  • 建工程时一定要建windows console application,不然编译时会报错;
  • 调试时要注意寄存器和标志位,只要一步一步对应着看,就能只能其工作的原理;
  • 在写汇编代码时,代码段是必须有有的,报错时要读懂报错缘由,注意解决报错原因;
  • 对于一些常用的操作指令要牢记,并且要理解其内容和作用。