我正在为linux内核开发一个补丁。我必须使用多个列表,并且我必须保护它们不受多核机器上并发修改的影响。我正在尝试使用自旋锁来实现这个目标,但是有一些事情我不能理解。我必须锁定列表的条目(我使用的是链表的linux默认实现),可能会发生这样的情况:一个进程调用syscall来删除列表中的一个元素,而相同的元素被锁定,因为实际上正在对它进行一些修改。如果我在列表条目中插入一个自旋锁,当有人在它上面进行自旋锁定时,如果进程设法删除它,会发生什么??我应该锁定整个列表吗?我正在寻找一段代码,可以解释如何处理这种情况。
例如,这段代码不应该工作(参见最后一行代码的注释):
struct list
我有一个线程需要被阻塞,直到另一个线程中发生了什么事情。这听起来很典型,我有这个解决方案。
//thread 1
mux.lock();
//send work to another thread
mux.lock(); //will likely block which I want
//thread 2
//get the work sent over from thread 1
//work on it, then
mux.unlock(); //unblock thread 1 - all good
这看起来在Linux上运行得很好,而且它不需要条件变量--除了C++标准说在同一线程
My system is a embedded linux system(running kernel version 2.6.18). A client process send data to mysql server. The data will be stored in mysql database at a RAID5 assembled by four disks. The IO pressure(wa%) is always above 20% , mysql CPU utilization is very high.
运行5或6小时后,系统进入软锁定状态。堆栈信息是关于释放物理