开始时,我有一个CPU核作为编写共享数据的编写器,一个核心作为读取器来读取共享数据。
我需要读者回写一些数据来分享数据。
我知道rcu_read_lock()/rcu_read_unlock()用于读者获取共享数据。但我不确定读者回信分享数据会不会引起什么问题?
在读者中:
rcu_read_lock();
//get shared data
//modify the data
rcu_assign_pointer(ptr1, ptr2)
rcu_read_unlock();这个代码有效吗?
发布于 2017-10-01 07:21:28
RCU的一个相当基本的特性是多个写入器之间的协调通过另一种机制来处理,例如传统的锁。RCU将确保读者看到数据的一致视图,并且他们使用的指针在完成之前不会被释放,但是它不会对来自不同线程的多个更新同时进行排序。
RCU确实保证了一个人可以从读者状态升级到作者状态。这可能是通过获得一个自旋锁,当它是实现一个更新是必需的。在调用synchronize_rcu之前,必须退出rcu_read_lock/rcu_read_unlock块,但是call_rcu可能会在块内排队回调。
不允许在rcu_read_lock/rcu_read_unlock块中阻塞,因此使用阻塞互斥来管理写入器内部的互斥将无法工作。
https://stackoverflow.com/questions/46509679
复制相似问题