第4章总结:
伪指令:
assume;segment,ends;end;(假设;段开始及结束;程序结束);
程序编辑到连接执行的简化操作:
masm c:\1;
link 1;
1
关于操作系统的外壳:
任何通用的操作系统都要提供一个成为shell(外壳)的程序,用户使用这个程序来操作计算机系统进行工作。DOS中的命令解释器command.com程序就是DOS系统的shell;
如果用户要执行一个程序,则输入该程序的可执行文件名,cmd根据文件名找到可执行文件后,将其加载入内存,设置cs:ip指向程序的入口。此后cmd暂停执行,cpu运行程序;
汇编程序从写出到执行的过程:
编程–>1.asm–>编译–>1.obj–>连接–>1.exe–>加载–>内存中
(edit)------------>(masm)------->(link)----------->(cmd)---->(CPU)
DOS中.exe文件的程序加载过程:
找到内存中一段起始地址为SA:0的容量足够大的空闲内存区;在前256个字节中创建psp区域(程序段前缀,用来和DOS通信),在第256个字节开始放入程序。
空闲内存区 SA:0
psp区 SA:0
程序区:SA+10 : 0
之后cmd将内存区的段地址SA放入寄存器ds中,偏移地址为0,设置CS:IP指向程序入口,即SA+10:0处,将程序长度放入cx中(以字节为单位),再初始化其他相关寄存器。
**
实验3
**
assume cs:codesg
codesg segment
mov ax,2000h
mov ss,ax
mov sp,10h
pop ax
pop bx
push ax
push bx
pop ax
pop bx
mov ax,4c00h
int 21h
codesg ends
end
debug t1.exe
##仅出示变化的寄存器及栈顶数据;
-r: ax=ffff,bx=0000,cx=13,ip=0,ds=075a,ss=0769,cs=076a,sp=0;
-t -d -r:
ax=2000,ip=3,ss:sp=076a; #(此处ss:sp表示所指单元数据;)
-t -d -r:
ss=2000,sp=10,ip=8;ss:sp=076a;
-t -d -r:
ax=0750,ip=9,sp=12,ss:sp=7202;
-t -d -r:
bx=0755,ip=a,sp=14,ss:sp=0753;
-t -d -r:
ip=b,sp=12,ss:sp=076a;
-t -d -r:
ip=c,sp=10,ss:sp=7202;
-t -d -r:
ax=0755,ip=d,sp=12,ss:sp=076a;
-t -d -r:
bx=0750,ip=e,sp=14,ss:sp=0753;
-t :
ax=4c00h;
-p
Program terminated normally
查看PSP的头两个字节,确为CD 20;