对int、iret和栈的深入理解

我们以一个程序来展开讨论:用7ch中断例程完成loop指令的功能,在屏幕中间显示80个"!"

1.程序框架如下

assume cs:code
code segment
start:
	mov ax,0b800h	;向8086CPU显存的地址
	mov di,160*12	;显示位置
	mov bx,offset s-offset se	;跳转的位移
	mov cx,80	;循环次数
s:
	mov byte ptr es:[di],'!'
	add di,2
	int 7ch	;进入中断处理程序
se:	nop
	mov ax,4c00h
	int 21h

code ends
end start

2.中断处理程序的功能如下:

1)dec cx

2)如果(cx)!=0,转到标号s处执行,否则向下执行

那么如何实现到目的地址s的转移?

1)转移到s显然应设(CS)=s的段地址,(IP)=s的偏移地址

2)那么中断程序如何得到s的段地址和偏移地址?

3)现在知道,可以从栈中直接和间接获得s的段地址和偏移地址,那么如何用他们设置CS:IP?

7c的中断程序如下:

lp:
	push bp
	mov bp,sp
	dec cx
	jcxz lpret
	add [bp+2],bx
lpret:
	pop bp
	iret

这里跟高级语言里面函数调用栈帧很相似,后面我会专门更新一篇介绍函数调用栈帧的文章。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值