bro*_*oot 12 c linux kernel deadlock linux-kernel
我有一个Linux内核驱动程序和一个与之交互的用户应用程序.内核驱动程序中存在死锁.我在Linux内核中遇到了这个名为" lockdep "的功能.我能够配置它并重新编译我的内核(我确实在/ proc中看到了lockdep文件夹).但我不知道如何推断此工具的输出或如何使用此工具调试驱动程序.任何帮助将非常感谢.谢谢!
bro*_*oot 22
要启用lockdep功能,请通过menuconfig编辑.config文件:
make menuconfig
Run Code Online (Sandbox Code Playgroud)
并在黑客选项中启用以下内容:
1. [*] Detect Hard and Soft Lockups
2. [*] Detect Hung Tasks
3. [*] RT Mutex debugging, deadlock detection
4. -*- Spinlock and rw-lock debugging: basic checks
5. -*- Mutex debugging: basic checks
6. -*- Lock debugging: detect incorrect freeing of live locks
7. [*] Lock debugging: prove locking correctness
8. [*] Lock usage statistics
Run Code Online (Sandbox Code Playgroud)
重新编译内核:
make ARCH=i386 -j4 //whatever your arch is
Run Code Online (Sandbox Code Playgroud)
现在,启动新的内核映像,在/ proc下你应该看到以下新文件夹:
/proc/lockdep
/proc/lockdep_chains
/proc/lockdep_stat
/proc/locks
/proc/lock_stats
Run Code Online (Sandbox Code Playgroud)
现在,插入您认为导致错误的模块,并使用您的用户应用程序(或用于运行驱动程序模块的任何方式)访问它.如果应用程序死锁(挂起),请执行以下操作:
ps -aux | grep <app_name>
Run Code Online (Sandbox Code Playgroud)
你应该看到你的应用程序的+ D(不间断睡眠)状态,做一个:
dmesg
Run Code Online (Sandbox Code Playgroud)
它打印的日志将包含导致死锁的函数/文件.
而已!
| 归档时间: |
|
| 查看次数: |
20897 次 |
| 最近记录: |