news 2026/6/10 18:49:39

汇编:改写中断例程-以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/6/10 16:30:49

师妹新做的产品没做高低温测试,导致全部召回......

小美是一个硬件工程师,设计了一个反激开关电源,开关电源加了NTC过温保护,如果温度超过一定值,就会触发过温保护。为了方便,NTC采用贴片的,根据公式计算出NTC回路合适的阻值,在常温下NTC上大概10…

作者头像 李华
网站建设 2026/6/10 16:26:39

Wan2.2-T2V-A14B模型许可证类型说明及其商业授权条款

Wan2.2-T2V-A14B 模型许可证与商业授权深度解析 在内容消费日益视频化的今天,企业对高效、低成本、高质量视频生成的需求正以前所未有的速度增长。传统影视制作流程动辄数周、成本高昂,已难以匹配短视频平台、电商广告、全球化营销等场景下“快速试错、高…

作者头像 李华
网站建设 2026/6/10 16:24:12

Wan2.2-T2V-A14B如何应对沙漠地貌随风变化的纹理更新

Wan2.2-T2V-A14B 如何应对沙漠地貌随风变化的纹理更新 在影视预演、数字孪生和虚拟场景构建中,如何让AI生成的自然环境“活”起来,一直是技术攻坚的重点。尤其是像沙漠这类动态性极强的地貌——沙丘随风缓慢迁移,表面纹理在光照与颗粒运动下持…

作者头像 李华
网站建设 2026/6/10 14:07:55

LVGL9.5 设置背景图片的方法

说明LVGL 可以轻松的设置背景图片,API 为 lv_obj_set_style_bg_image_src验证发现,可以设置不同对象的背景图片,比如当前屏幕 lv_screen_active() 的,或者某个控件的,比如一个按钮 Button 的。设置背景图片 lv_obj_set…

作者头像 李华
网站建设 2026/6/10 15:33:05

走进Python的高级世界,你不知道的几个Python技巧

Python高级教程 引言:走进Python的高级世界 Python作为一门简洁优雅的编程语言,其魅力不仅在于易学易用,更在于它强大的高级特性。掌握这些高级特性,能让你的代码更加优雅、高效和强大。本文将带你深入探索Python的高级功能&#…

作者头像 李华
网站建设 2026/6/10 16:50:24

Wan2.2-T2V-A14B如何应对多光源混合照明场景生成

Wan2.2-T2V-A14B 如何应对多光源混合照明场景生成 在高端影视制作和广告创意中,光影从来不只是“照亮画面”的工具——它是情绪的载体、空间的雕塑师,更是真实感的最后一道防线。当镜头扫过一个黄昏中的书房:台灯洒下暖黄光晕,窗外…

作者头像 李华