news 2026/5/25 14:03:51

汇编:改写中断例程-以int9为例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
汇编:改写中断例程-以int9为例
assume cs:code stack segment db 128 dup(0) ; 定义栈段,大小128字节 stack ends code segment start: ;设置各段地址 mov ax,stack mov ss,ax mov sp,128 ; 栈顶指向栈段末尾(128字节栈,sp初始为128) push cs pop ds ; 让ds = cs(代码段和数据段同段,方便访问自定义中断例程 mov ax,0 mov es,ax ; es指向0段(中断向量表所在的段) ;安装新程序(自定义int9程序安装在0:204位置处) mov si,offset int9 ; si = 自定义int9例程的偏移地址 mov di,204h ; di = 0段204H(新例程的存放地址) mov cx,offset int9end - offset int9 ;cx = 新例程的字节长度 cld ; 方向标志DF=0(串操作时si/di递增) rep movsb ; 循环复制:将cs:[si]的内容复制到es:[di],共cx字节 ;将原中断地址保存在0:200单元处 push es:[9*4] pop es:[200H] push es:[9*4+2] pop es:[202H] ;将自定义的int9程序所在地址CS:IP写入---向量表中,向量表触发时就转到0:204处的自定义int9处 cli ; 关中断(禁止CPU响应外部中断,防止修改向量时被打断) mov word ptr es:[9*4],204H ; int9偏移地址 = 204H(新例程偏移) mov word ptr es:[9*4+2],0 ; int9段地址 = 0(新例程段地址) sti ; 开中断(恢复中断响应) mov ax,4c00h int 21h ;定义新中断例程 int9: push ax push bx push cx push es in al,60H pushf ;仅将标志位寄存器压入栈中 ;调用旧中断例程 call dword ptr cs:[200h] ;调用原系统向量表保存的CS:IP地址,并执行; ;处理F1键 cmp al,3BH jne int9ret mov ax,0B800H mov es,ax mov bx,1 mov cx,2000 s: inc byte ptr es:[bx] add bx,2 loop s int9ret: pop es pop cx pop bx pop ax iret int9end:nop code ends end start

关键知识点:

在 Intel 8086 CPU 中,IRET(Interrupt Return,中断返回)是一条用于从中断服务程序(ISR, Interrupt Service Routine)返回到被中断程序的指令。


一、功能说明

IRET指令的主要作用是恢复被中断时的程序执行上下文。它会从堆栈中弹出以下内容(按顺序):

  1. IP(Instruction Pointer)—— 返回地址的偏移部分
  2. CS(Code Segment)—— 返回地址的段部分
  3. FLAGS(标志寄存器)—— 恢复中断前的标志状态(包括 IF、TF 等)

注意:8086 是实模式处理器,不支持保护模式下的特权级切换,因此IRET在 8086 中只处理上述三个寄存器。


二、堆栈操作(执行 IRET 时)

假设堆栈指针为 SP,堆栈向下增长(向低地址方向),执行IRET相当于以下操作:

POP IP POP CS POP FLAGS

即:

  • 从 [SP] 弹出 IP(2 字节)
  • 从 [SP+2] 弹出 CS(2 字节)
  • 从 [SP+4] 弹出 FLAGS(2 字节)
  • 最终 SP 增加 6(因为弹出了 3 个字,每个 2 字节)

三、使用场景

IRET必须用在中断服务例程的末尾,用于:

  • 软件中断(如 INT 21h)
  • 硬件中断(如 IRQ0 对应的 INT 08h)
  • 异常处理(如除零异常 INT 0)

例如:

; 中断服务程序示例 my_isr: push ax push dx ; ... 中断处理代码 ... pop dx pop ax iret ; 返回到被中断的程序

注意:在进入 ISR 时,CPU 自动将 FLAGS、CS、IP 压入堆栈;因此必须用IRET返回,不能用RET,否则无法恢复 FLAGS,可能导致中断系统异常(如 IF 标志未恢复,导致后续中断被屏蔽)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/26 6:36:42

NCMconverter音频格式转换工具:解锁ncm文件的全新使用体验

NCMconverter音频格式转换工具:解锁ncm文件的全新使用体验 【免费下载链接】NCMconverter NCMconverter将ncm文件转换为mp3或者flac文件 项目地址: https://gitcode.com/gh_mirrors/nc/NCMconverter NCMconverter是一款专为解决ncm格式音频文件兼容性问题而设…

作者头像 李华
网站建设 2026/5/26 7:13:03

5.React状态管理

多更新的组件状态 在组件状态中,我们了解到了React中组件的状态及其用法。组件状态的主要作用就是由状态设置触发组件的局部UI渲染,状态用法也很简单。 有时候有些组件对于状态的更新操作很多,这就让我们很难短时间理清组件更新逻辑。示例如…

作者头像 李华
网站建设 2026/5/25 23:24:06

Wan2.2-T2V-A14B支持多种艺术风格迁移的实现方式

Wan2.2-T2V-A14B:如何实现多艺术风格视频生成 在短视频内容爆炸式增长的今天,品牌方、创作者和影视团队面临的最大挑战之一不再是“有没有创意”,而是“如何快速、低成本地将创意可视化”。传统视频制作流程动辄数周周期、高昂成本&#xff0…

作者头像 李华
网站建设 2026/5/25 19:08:35

哔哩下载姬实战手册:从零到精通的B站视频管理技巧

还记得那个让你抓狂的场景吗?收藏夹里心爱的视频突然下架,精心整理的UP主内容无法离线观看,或者急需某个视频素材却发现网络不稳定。这些痛点正是哔哩下载姬要帮你解决的现实问题。 【免费下载链接】downkyi 哔哩下载姬downkyi,哔…

作者头像 李华