详解汇编里的单步中断-T使用寄存器标志位TF和IF

debug利用CPU提供的单步中断功能

  • 程序的正常执行
  1. 取指令
  2. 改变CS:IP
  3. 执行指令
  4. 取指令
  • DEBUG提供单步中断的中断处理程序,显示所有寄存器的内容后等待输入命令

使用-T命令,debug将TF标志设为1,使CPU工作在单步中断的方式下

  • 自定义单步中断处理程序,实现特殊功能

单步中断的处理与过程

    • TF陷阱标志(trap flag):用于调试的单步方式操作
    • TF = 1时每条指令执行后产生陷阱,由系统控制计算机
    • TF = 0时CPU正常工作
    • IF中断标志(interrupt flag)
    • IF = 1允许CPU响应可屏蔽中断请求
    • IF = 0关闭中断
  • CPU在执行完一条指令后,如果检测到标志寄存器的TF位为1,则产生单步中断(中断类型码为1),引发中断过程,执行中断处理程序
  1. 取得标志类型码1
  2. 标志寄存器入栈TF和IF设置0

设置TF = 0很重要,否则不停产生单步中断不断循环,TF置为0不允许单步中断了

  1. CS和IP入栈
  2. (IP) = (1 * 4) (CS) = (1 * 4 + 2)

  • 中断不响应的情况
  • 执行向SS寄存器发送数据,即使产生中断,CPU不响应
  • SS和SP同步完成
    在这里插入图片描述

SS和SP联合指向栈顶,设置要同时完成

  • 强行插入指令把ss和sp割裂开,自动执行了下一条指令
    在这里插入图片描述
发布了251 篇原创文章 · 获赞 28 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/xiong_xin/article/details/103606302
今日推荐