存档

作者存档

抓虫日记之 kgdb 和 删除硬断点

2010年10月22日 没有评论

为避免硬/软断点影响kgdb,在kgdb主程序kgdb_cpu_enter运行过程中,所有的断点是被disable的。
对于硬件断点来说,它会显示的调用kgdb_disable_hw_debug()来disable所有的硬件断点,
在kgdb离开时,调用kgdb_correct_hw_break()来使能/增加需要激活的硬件断点。

抓虫日记之 kgdb 与 removed breakpoint

2010年9月21日 没有评论

kgdb_skipexception()函数的引入是为了避免kgdb踩中已经删除的断点而做的特殊处理.
所有删除的断点,必须标记为BP_REMOVED, 否则就会出现kgdb踩中已经删除的断点这情况.

巧用backtrace系列函数,在不具备gdb环境的Linux系统上大致定位段错误位置

2010年8月24日 没有评论

巧用libc backtrace系列函数,在不具备gdb环境的类Linux系统上大致定位段错误位置

分类: LinuxDev 标签:

gdb 和 watchpoint

2010年8月14日 8 条评论

watchpoint,顾名思义,其一般用来观察某个变量/内存地址的状态(也可以是表达式),如可以监控该变量/内存值是否被程序读/写情况。
watchpoint可以看成是一种特殊的”断点”, 其实现一般需要CPU支持硬件断点,如果纯软件实现watchpoint,那好像会很耗CPU.(我没去看gdb的软0watchpoint的实现,有时间得去研究下,不过如果让我来实现这个功能(和同事讨论过),应该是设置watchpoint所在的那个页表为不可读/访问,然后在缺页处理那检测当前的页和地址是否是软设置watchpoint所在的页和watchpoint的地址,如果是,则说明可以假设该watchpoint发生了). 目前支持watchpoint硬件断点的arch有x86,ppc和mips。

分类: gdb 标签: ,

kgdb抓虫日记 – gdb 7.1 不能正常退出KGDB

2010年7月9日 没有评论

gdbserver对于不识别或者不支持的命令,都是返回””空包给gdb的,
所以kgdb也应当返回””空包给gdb,这样问题就解决了.

kgdb内核选项配置

2010年6月28日 没有评论

KGDB内核选项配置

kgdb抓虫日记 – set breakpoint at ppc64

2010年6月28日 没有评论

一般来说,往哪个点设置什么值,是由gdb来主导的,kgdb只是执行相应的动作,既然kgdb是正常执行的,
那也许就意味着是gdb搞错地址了,把module_event函数的地址给取错了,然后触发了这个问题.

kgdb抓虫日记 – kgdboe 与 system hang

2010年6月28日 没有评论

为解决这个bug,前前后后忙了我整整一个星期。虽然最终的问题和kgdb关系不大,但我学到了不少东西,
比如说加深了系统中断的处理实现和mips的很多东西。

kgdb抓虫日记 – kgdb 与 jiffies[softlockup]

2010年6月28日 没有评论

If the sched_clock() was realized based on jiffies, kgdb often
causes softlock warning messages on resuming or detaching from
a debug session.

KGDB 与 指令级单步调试

2010年6月28日 2 条评论

KGDB 单步调试流程(X86,硬单步)

A: KGDB进入调试状态,等待gdb的指令.(陷入调式异常的处理函数,使用轮询方式 来检测gdb端的输入数据)
B: gdb 发送 “s” 指令给 KGDB
C: KGDB 收到”s” 指令后,设置EFLAGS寄存器的TF位,使得当前CPU进入单步调试模式.
D: KGDB退出调式异常处理函数,让系统恢复正常运行
E: CPU执行一条指令后,就会产生单步异常。
F: KGDB陷入调式异常, 发信息通知gdb。
G: KGDB回到 A 状态, 继续等待gdb指令.

分类: 深入kgdb 标签: ,