call_rcu_bh与call_rcu哪个速度快
时间: 2023-08-05 21:02:25 浏览: 105
在执行速度方面,通常来说 call_rcu() 的速度会比 call_rcu_bh() 快一些。这是因为 call_rcu_bh() 要求在中断上下文中执行,需要先禁止本地 bottom half,并在最近一次调用 local_bh_disable() 之后才会执行回调函数,因此会产生一定的延迟。
而 call_rcu() 可以在任何上下文中调用,不需要等待中断上下文,因此执行速度相对较快。但是,需要注意的是,由于 call_rcu() 的回调函数是在 RCU 读取者完成读取之后执行,因此需要等待一定时间才能执行回调函数,这可能会影响到系统的响应时间和吞吐量。
总之,在使用 call_rcu_bh() 和 call_rcu() 时,应该根据具体的场景和需求选择合适的 API,以实现最优的性能和效果。
相关问题
call_rcu_bh与call_rcu区别
call_rcu_bh() 和 call_rcu() 都是 Linux 内核中的 RCU(Read-Copy-Update)机制的 API,它们都用于异步执行回调函数以实现内存释放等功能。它们的区别在于:
1. 执行上下文不同:call_rcu_bh() 只能在中断上下文(bottom half)中调用,而 call_rcu() 可以在任何上下文中调用。
2. 内存回收的时机不同:call_rcu_bh() 的回调函数会在最近一次调用 local_bh_disable() 之后执行,通常用于处理网络中断;而 call_rcu() 的回调函数会在当前 RCU 读取者完成读取之后执行,通常用于处理内核模块的卸载。
因此,在使用 RCU 机制时,应根据具体的场景和需求选择适当的 API。
linux call_rcu注册在哪个链表上,其回调函数在哪被调用
在Linux内核中,使用`call_rcu()`函数注册的RCU回调函数将被添加到全局的RCU回调队列`rcu_callback_list`中。该队列是一个环形链表,被定义在`rcu.h`中。
当RCU grace period结束时,内核会在softirq上下文中调用`rcu_process_callbacks()`函数来处理`rcu_callback_list`中的回调函数。这个函数会遍历`rcu_callback_list`,依次调用每个回调函数来完成RCU的回调操作。因此,`call_rcu()`的回调函数将在`rcu_process_callbacks()`函数中被调用。
阅读全文