上一节,介绍过了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在线的时候。
*
*/
rcu