我有一个Linux内核驱动程序和一个与之交互的用户应用程序。内核驱动程序中有一个死锁。我在名为“ lockdep ” 的linux内核中遇到了这个功能。我能够对其进行配置并重新编译内核(并且我确实在/ 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
它打印的日志将包含导致死锁的功能/文件。
而已!