debug利用CPU提供的单步中断功能
- 程序的正常执行
- 取指令
- 改变CS:IP
- 执行指令
- 取指令
- 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
- 标志寄存器入栈TF和IF设置0
设置TF = 0很重要,否则不停产生单步中断不断循环,TF置为0不允许单步中断了
- CS和IP入栈
- (IP) = (1 * 4) (CS) = (1 * 4 + 2)
- 中断不响应的情况
- 执行向SS寄存器发送数据,即使产生中断,CPU不响应
- SS和SP同步完成
SS和SP联合指向栈顶,设置要同时完成
- 强行插入指令把ss和sp割裂开,自动执行了下一条指令