如何在linux内核中使用lockdep功能进行死锁检测
发布时间:2020-12-14 02:23:42 所属栏目:Linux 来源:网络整理
导读:我有一个 linux内核驱动程序和一个用户应用程序与它进行交互.内核驱动程序中有一个死锁.我在linux内核中被称为“ lockdep”的这个功能.我能够配置它并重新编译我的内核(我看到/ proc中的lockdep文件夹).但是我不知道如何推断这个工具的输出,或者如何使用这个
我有一个
linux内核驱动程序和一个用户应用程序与它进行交互.内核驱动程序中有一个死锁.我在linux内核中被称为“
lockdep”的这个功能.我能够配置它并重新编译我的内核(我看到/ proc中的lockdep文件夹).但是我不知道如何推断这个工具的输出,或者如何使用这个工具调试驱动程序.任何帮助将不胜感激.
谢谢! 解决方法
要启用lockdep功能,请通过menuconfig编辑.config文件:
make menuconfig 并在黑客选项中启用以下内容: 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 重新编译内核: make ARCH=i386 -j4 //whatever your arch is 现在,启动新的内核映像,在/ proc下,您应该会看到以下新文件夹: /proc/lockdep /proc/lockdep_chains /proc/lockdep_stat /proc/locks /proc/lock_stats 现在,插入您认为导致错误的模块,并使用用户应用程序访问它(或用于运行驱动程序模块的任何方式).如果应用程序死锁(挂起),请执行以下操作: ps -aux | grep <app_name> 您应该看到您的应用程序的D(不间断睡眠)状态,请执行以下操作: dmesg 打印的日志将包括导致死锁的功能/文件. 而已! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |