上一节,介绍过了RCU实现中用到的主要函数。不过还需要定期的运行这些函数,整个机制才完整。
RCU的实现是通过在update_process_times() 中调用rcu_check_callbacks()来达到这个目的的。每个CPU都会定期的调用update_process_times()。rcu_check_callbacks()会去检查当前的RCU机制中是否有需要处理的内容,如当前CPU需要开启一个新的宽限期,当前CPU上的宽限期还没有处理完成。如果有需要处理的内容,将触发一个软件中断,真正的操作由软件中断触发的rcu_process_callbacks()来完成。
rcu_check_callbacks
void rcu_check_callbacks(int cpu, int user)
{
trace_rcu_utilization("Start scheduler-tick");
increment_cpu_stall_ticks();
if (user || rcu_is_cpu_rrupt_from_idle()) {
/*
* 如果是从用户模式或者是idle模式调用该函数,
* 那么这个CPU是静止状态。
*
* 此处不需要内存屏障。因为rcu_sched_qs()和
* and rcu_bh_qs()支处理CPU自身的局部变量,
* 其它CPU不会访问和修改,至少当CPU在线的时候。
*
*/

本文介绍了Linux内核中RCU(Read-Copy Update)机制如何通过定期调用rcu_check_callbacks()确保机制的完整性。rcu_check_callbacks在update_process_times()中被调用,每个CPU周期性执行。当有RCU内容待处理时,它触发软件中断,由rcu_process_callbacks()完成实际操作。rcu_pending()检查并决定是否需要调用invoke_rcu_core()启动软中断处理任务。
最低0.47元/天 解锁文章
384

被折叠的 条评论
为什么被折叠?



