Multithreading 如何知道程序中已经获取了自旋锁或其他锁(如互斥锁或信号量)。但是没有被释放?
在我的项目中,程序流总是挂起在一个地方。 当我调试它时,我发现使用了一些复杂的锁定机制。 一种自旋锁和互斥锁Multithreading 如何知道程序中已经获取了自旋锁或其他锁(如互斥锁或信号量)。但是没有被释放?,multithreading,linux-kernel,kernel,multiprocessing,kernel-module,Multithreading,Linux Kernel,Kernel,Multiprocessing,Kernel Module,在我的项目中,程序流总是挂起在一个地方。 当我调试它时,我发现使用了一些复杂的锁定机制。 一种自旋锁和互斥锁 如何识别程序中已获取但未分别释放的自旋锁或其他锁(如互斥锁、信号量)的数量?是否希望此功能仅用于调试目的?如果是这样,请在启用DEBUG_互斥锁和DEBUG_自旋锁配置选项的情况下重建内核。有了这些选项,内核本身将断言关于互斥锁和自旋锁使用的许多事情。例如,它将检查当它使用互斥锁时没有线程被终止。也可以启用LOCKDEP。“复杂的锁定机制”应该是一个红色标志。如果锁定非常复杂,导致死锁,
如何识别程序中已获取但未分别释放的自旋锁或其他锁(如互斥锁、信号量)的数量?是否希望此功能仅用于调试目的?如果是这样,请在启用
DEBUG_互斥锁
和DEBUG_自旋锁
配置选项的情况下重建内核。有了这些选项,内核本身将断言关于互斥锁和自旋锁使用的许多事情。例如,它将检查当它使用互斥锁时没有线程被终止。也可以启用LOCKDEP。“复杂的锁定机制”应该是一个红色标志。如果锁定非常复杂,导致死锁,则可能需要重新考虑同步方案。