如果(在多核系统上)我想让内核模块功能一次只能由一个内核运行,我应该使用什么?也就是说,避免两个核心同时运行相同的功能;aka,其中一个核心应该等待另一个核心完成运行该功能。
互斥体?自旋锁?还有什么?
如果(在多核系统上)我想让内核模块功能一次只能由一个内核运行,我应该使用什么?也就是说,避免两个核心同时运行相同的功能;aka,其中一个核心应该等待另一个核心完成运行该功能。
互斥体?自旋锁?还有什么?
由于 rakib 已经建议使用自旋锁,我将进一步解释如何使用它们。
设置自旋锁后,例如
static DEFINE_SPINLOCK(your_lock);
您可以简单地使用 spin_lock_irqsave/spin_lock_irqrestore 包装函数的内容,例如:
static void function_to_protect()
{
unsigned int flags;
spin_lock_irqsave(&your_lock, flags);
/* function body here */
spin_lock_ireqrestore(&your_lock, flags);
}
如果您确定您的锁不会被中断处理程序触及,您可以选择使用重量较轻的函数 spin_lock 和 spin_unlock 并省略 flags 变量。
参考:https ://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/spinlocks.txt
您需要使用 spinlock() 的变体,即 raw_spin_lock_irqsave()、raw_spin_lock_irqrestore() ( https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/include/linux/spinlock. h#n188),而不是 mutex() ,因为它们可以睡眠,因此它们可能会在其他一些 CPU 上唤醒。自旋锁将确保您的代码不会被其他内核执行。它在 Linux 内核树的 Documentation/spinlock.txt ( https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/Documentation/spinlocks.txt )中有很好的记录。