关于ret指令和retf指令
在这里主要是想做个记录
- ret指令是用栈中的数据,修改IP的内容,从而实现了近转移(就是只修改IP)
- retf指令是用栈中的数据,修改CS和IP的内容,从而实现了远转移(就是修改了CS和IP)
当CPU执行指令ret的时候,会进行下面的操作
- 1、(IP)= ((ss *16)+(sp))
- 2、(sp)=(sp)+2
当CPU执行指令retf的时候相当于进行了下面的操作
- 1、(IP)= ((ss *16)+(sp))
- 2、(sp)=(sp)+2
- 3、(CS)=((ss *16)+(sp))
- 4、(sp)=(sp)+2
其实就相当于CPU在执行ret指令的时候就是在执行下面的汇编语句
pop IP
CPU在执行retf指令的时候其实就是在执行下面的汇编语句
pop IP
pop CS
关于下面的程序的执行过程
assume cs:code
stack segment
db 16 dup(0)
stack ends
code segment
mov ax,4c00h
int 21h
start:mov ax,stack
mov ss,ax
mov sp,16
mov ax,0
push ax
mov bx,0
ret
code ends
end start
当执行到ret指令的时候的寄存器的值,这里ret指令还没有执行
执行完ret指令的值
关于retf指令的程序
assume cs:code
stack segment
db 16 dup(0)
stack ends
code segment
mov ax,4c00h
int 21h
start:mov ax,stack
mov ss,ax
mov sp,16
mov ax,0
push cs
push ax
mov bx,0
retf
code ends
end start
CS和IP入栈完毕
执行完毕