TREE RCU实现之三 —— 定期调用

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

 

       上一节,介绍过了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在线的时候。
                  * 
                  */                
               
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值