linux – 嵌套的spin_lock_irqsave
发布时间:2020-12-13 19:52:11 所属栏目:Linux 来源:网络整理
导读:如果代码如下 void test(void){ spin_lock_irqsave(lock1,flag); ... func1(); ... spin_unlock_irqrestore(lock1,flag);}void func1(void){ spin_lock_irqsave(lock2,flag); ... spin_unlock_irqrestore(lock2,flag);} 代码会有任何问题吗?当在func1中调用
如果代码如下
void test(void) { spin_lock_irqsave(&lock1,flag); ... func1(); ... spin_unlock_irqrestore(&lock1,flag); } void func1(void) { spin_lock_irqsave(&lock2,flag); ... spin_unlock_irqrestore(&lock2,flag); } 代码会有任何问题吗?当在func1中调用spin_unlock_irqrestore时,是否已启用中断?我想要实现的是test()例程可以在没有调度程序或中断的任何中断的情况下执行.非常感谢 解决方法
据我在文档中发现,并且我没有完全耗尽我的搜索,该标志将保存设置不同标志的位的状态,然后关闭中断,然后在结束时恢复它.如果通过第一次调用测试关闭了中断,然后再进行一次调用,我会假设(并且没有任何迹象表明我已经发现)将关闭中断,存储标志并将其恢复到func内( )然后将它们恢复到状态标志已经测试.
只有在测试功能后才能重新启用中断. 我会说你唯一的问题是你不能在两个函数中使用相同的标志变量,否则你将覆盖内部调用中的第一个,然后重置它,如果你的调用之间的任何标志发生了变化,你可以重置外一个到错误的状态. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |