当前位置:网站首页>kernel问题定位手段总结
kernel问题定位手段总结
2022-08-04 22:50:00 【szembed】
从事kernel底层研发工作,最基础的调试工具就是仿真器,仿真器功能非常强大,可以让研发人员很容易的查看内存、查看函数调用栈、查看内存属性、查看当前寄存器值、设置函数断点、设置内存读写断点等等,那么在没有仿真器的情况下,同样也有很多问题定位手段:
内存被踩
1)kasan:Kasan 是 Kernel Address Sanitizer 的缩写,它是一个动态检测内存错误的工具,主要功能是检查内存越界访问和使用已释放的内存问题。使用方法可参考https://cloud.tencent.com/developer/article/1518011
说明:kasan带有一定的局限性,如果并不是越界和use-after-free的问题导致,则无法检查出来。适用于固定位置踩和飞踩等问题。
2)将被踩地址属性改为只读(只适用于当前CPU自己代码踩自己内存,如果是被其他子系统踩,则需要通过其他手段)
用户态可使用mprotect函数,:https://blog.csdn.net/Roland_Sun/article/details/33728955
内核态可通过set_memory_ro/set_memory_rw函数来设置目标内存属性
查看调用栈
在kernel的dump_stack.c文件中,有一个dump_stack的函数,该函数可把函数调用栈打印出来,因此在需要查看函数调用栈的地方调用该函数以达到查看目的,还有WARN系列函数
异常时主动复位
此处方法较多,有BUG()、BUG_ON(condition)、panic()、kernel_restart()等
持续更新。。。。。
边栏推荐
猜你喜欢
随机推荐
【游戏建模模型制作全流程】ZBrush蜥蜴模型雕刻教程
go语言的日志实现(打印日志、日志写入文件、日志切割)
被领导拒绝涨薪申请,跳槽后怒涨9.5K,这是我的心路历程
CS8416国产替代DP8416 数字音频接收器
【无标题】
The Record of Reminding myself
DREAMWEAVER8 part of the problem solution
Community Sharing|Tencent Overseas Games builds game security operation capabilities based on JumpServer
[Mock Interview - 10 Years of Work] Are more projects an advantage?
SSM整合完整流程讲解
深度学习 RNN架构解析
字节跳动秋招提前批高频面试问题汇总!(内附答案!)
go语言的time包介绍
2022精选最新金融银行面试真题——附带答案
边缘检测——(纯享版)
今天又做了三个梦,其中一个梦梦里的我还有意识会思考?
How to make a video gif?Try this video making gif artifact
线性DP(下)
typeScript-promise
Pytest学习-Fixture




![[Mock Interview - 10 Years of Work] Are more projects an advantage?](/img/fa/2652629d1ff4653aca0d626ac89bf8.jpg)




