对linux rcu机制的理解

对linux rcu机制的理解

ID:47142049

大小:540.00 KB

页数:6页

时间:2019-08-11

对linux rcu机制的理解_第1页
对linux rcu机制的理解_第2页
对linux rcu机制的理解_第3页
对linux rcu机制的理解_第4页
对linux rcu机制的理解_第5页
资源描述:

《对linux rcu机制的理解》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、对linuxrcu机制的理解RCU(Read-copyupdate)锁机制是kernel2.6的重大进步,使用rcu可以获得比使用rwlock更高的性能,而且代码简单,不易死锁。Linux文档如下描述:SothetypicalRCUupdatesequencegoessomethinglikethefollowing:a.Removepointerstoadatastructure,sothatsubsequentreaderscannotgainareferencetoit.b.WaitforallpreviousreaderstocompletetheirRCUread-sidec

2、riticalsections.c.Atthispoint,therecannotbeanyreaderswhoholdreferencestothedatastructure,soitnowmaysafelybereclaimed(e.g.,kfree()d).如上所述,RCU原理其实很简单,现在假设你自己要实现一个基于rcu原理的模型。假定cpu处理报文的过程是原子的,这样可以认为处理完一个报文就经过了一个quiescentstate,RCU引用的过时数据就可以释放了。接收报文开始进入一个新的周期,当发送报文后,标记一个周期的结束。假设有8个cpu,轮流处理报文,而报文处理依赖的信

3、息存储在共享内存中。那末,现在的问题是:请用rcu机制实现共享内存的释放。假设所有的cpu处理一个报文结束,就代表一个graceperiod(因为只有处理报文时才会使用共享内存),即每个cpu都经过了一个quiscentstate.那么现在就有三个问题:1.如何确定所有的cpu都经过了一个quiscentstate?2.在rcu处理时,如何保证别的cpu不对要释放的数据操作?3.在rcu处理后,如何开启和判断下一个rcu周期?带着这三个问题,我们可以看一下linux是如何实现rcu机制的。以下的分析是基于linux-2.6.27代码:Rcu有两个重要的数据结构:/*Globalcont

4、rolvariablesforrcupdatecallbackmechanism.*/structrcu_ctrlblk{longcur;/*Currentbatchnumber.*/longcompleted;/*Numberofthelastcompletedbatch*/intnext_pending;/*Isthenextbatchalreadywaiting?*/intsignaled;spinlock_tlock____cacheline_internodealigned_in_smp;cpumask_tcpumask;/*CPUsthatneedtoswitchinord

5、er*//*forcurrentbatchtoproceed.*/}____cacheline_internodealigned_in_smp;上述结构是rcu全局控制结构structrcu_data{/*1)quiescentstatehandling:*/longquiescbatch;/*Batch#forgraceperiod*/intpassed_quiesc;/*User-mode/idleloopetc.*/intqs_pending;/*corewaitsforquiescstate*//*2)batchhandling*/longbatch;/*Batch#forcu

6、rrentRCUbatch*/structrcu_head*nxtlist;structrcu_head**nxttail;longqlen;/*#ofqueuedcallbacks*/structrcu_head*curlist;structrcu_head**curtail;structrcu_head*donelist;structrcu_head**donetail;longblimit;/*Upperlimitonaprocessedbatch*/intcpu;structrcu_headbarrier;};上述结构是每个cpu用的rcu数据结构。DECLARE_PER_CP

7、U(structrcu_data,rcu_data);staticstructrcu_ctrlblkrcu_ctrlblk={.cur=-300,.completed=-300,.lock=__SPIN_LOCK_UNLOCKED(&rcu_ctrlblk.lock),.cpumask=CPU_MASK_NONE,};Linux在rcu代码中声明了两个全局变量,一个是rcu_data,每个cpu一个;一个是rcu_ctrlblk,全局一个。Li

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。