当前位置: 首页 > news >正文

汇编:改写中断例程-以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 标志未恢复,导致后续中断被屏蔽)。

http://www.jsqmd.com/news/74032/

相关文章:

  • 技术变革引领行业新趋势:探索人工智能在现代产业中的深度融合与创新应用
  • 【Redis】Redis下载安装图文教程(Win和Linux版)超详细
  • 鸽姆(GG3M)公司估值与财务预测报告:从多元生态到文明央行的价值跃迁
  • DeepSeek-R1大模型深度解析:突破128K上下文壁垒的技术架构创新
  • 师妹新做的产品没做高低温测试,导致全部召回......
  • Wan2.2-T2V-A14B支持跨模态检索吗?以图搜视频功能设想
  • 邪修版——MDK 工程结构菜鸟快速入门实战指南(上)
  • AI市场舆情分析:解锁增长密码,洞悉未来商机
  • Windows右键菜单革命:从混乱到高效的终极解决方案
  • GOT-OCR-2-GUI工具全解析:本地化部署指南与功能进阶攻略
  • 智谱AI轻量级大模型GLM-4.5-Air深度解析:MoE架构如何平衡性能与部署效率
  • Linux文件传输优化
  • 腾讯混元70亿参数模型Hunyuan-7B-Instruct开源:超长上下文与高效部署能力引领行业新突破
  • 基于YOLO11-C3k2-AdditiveBlock-CGLU的呼吸气瓶设备组件自动检测与识别系统
  • VSCode支持量子模拟的5个你必须知道的功能(第4个极少人掌握)
  • 从入门到进阶 | 哪些企业适合采用SD-WAN?
  • 网站缓存生效检测(详细教程)
  • Wan2.2-T2V-A14B如何应对沙漠地貌随风变化的纹理更新
  • Wan2.2-T2V-A14B在AI写作助手中的情节可视化延伸功能
  • 可视化技术架构与行业应用解析 | 图扑工业数字孪生
  • Wan2.2-T2V-A14B模型许可证类型说明及其商业授权条款
  • 如何设计一个优秀的接口?统一结果返回值
  • LVGL9.5 设置背景图片的方法
  • BetterGI:原神智能辅助工具终极使用指南
  • 多模态大模型技术突破:Qwen3-VL全系列深度解析与本地化部署指南
  • Wan2.2-T2V-A14B如何实现服装材质的真实感渲染?
  • 校运会管理系统(11447)
  • Qwen-Image-Edit-Rapid-AIO全版本解析:从多模态融合到专业化模型演进之路
  • 基于图像处理的海洋生物海鲜识别算法设计
  • 地平线首届技术生态大会擘画智驾产业新范式