KGTP、linux内核、GDB的系统结构

KGTP是一个内核中的gdb stub,用于抓取内核数据并与GDB交互。用户通过GDB命令行与KGTP通信,内核中的kprobe功能在指定点捕获信息。kprobe利用int 3陷阱执行预处理和后处理函数,允许在不修改内核代码的情况下收集数据。
摘要由CSDN通过智能技术生成

KGTP、linux内核、GDB的系统结构

如果用一句话给KGTP新用户总结,那我就会说,这三者的关系就是,用户通过GDB提供的命令行接口与驻扎在内核空间KGTP通信,使这个内核模块抓取制定的数据并归还给GDB,GDB最后展示给最终用户。

如果还有人不懂,那么我可以这样再深入一点,KGTP实际就是一个gdb stub(关于stub中文资料就比较多了),只不过它不是放在嵌入式板子上做调试用的,而是跑在内核里面抓数据用的。KGTP基本实现了GDB手册这一章要求这一章的命令。另一个CSDN夏令营项目"给RT-Thread添加GDB stub支持“也是在RT-Thread上实现一个stub,不过这个stub主要为了为了完成调试功能。

这个系统架构可以用如下图表示:




接下来我从下至上粗略讲解各个模块实现原理


1.内核对KGTP的支持

内核自2.6早期版本开始引入kprobe功能,Document/kprobe.txt这片文档解释了kprobe功能、原理以及API。传统上内核程序开发者使用printk记录某一时刻内核的某些数据。而为了添加新的printk,需要修改内核源码,还可能需要重启机器,有了kprobe,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值