当前位置: 首页 > news >正文

微网站 制作平台广州电商聚集地

微网站 制作平台,广州电商聚集地,装修网站设计平台,网页设计图片透明度怎么设置原文网址#xff1a;https://lwn.net/Articles/93617 原文作者#xff1a;Corbet 原文时间#xff1a;2004年7月14日 内核提供了一种用于实现引用计数的简单机制kref#xff1b;该机制是今年3月份完成的。kref机制的核心思想是#xff0c;提供支持原子操作的计数器https://lwn.net/Articles/93617 原文作者Corbet 原文时间2004年7月14日 内核提供了一种用于实现引用计数的简单机制kref该机制是今年3月份完成的。kref机制的核心思想是提供支持原子操作的计数器用于对未决引用【outstanding references】进行计数。如果计数器数值为零内核不再需要引用对象了引用对象可以被释放掉。 kref机制的函数很简单在引用对象数据结构内直接包含一个struct kref计数器或struct kref *计数器指针在引用对象被操作之前调用kref_get函数引用计数器递增。 struct kref *kref_get(struct kref *kref) {WARN_ON(!atomic_read(kref-refcount));atomic_inc(kref-refcount);return kref; } 在对对象操作完成之后调用kref_put函数引用计数器递减如果计数器数值为零就调用回调函数释放引用对象相关资源。 void kref_put(struct kref *kref) {if (atomic_dec_and_test(kref-refcount)) {kref-release(kref); //release函数是回调函数} } 对引用计数refcount域进行原子操作使得上述两个函数可以安全地在多CPU或抢断环境下直接调用也就是说在这两个环境下引用计数器的数值总能获得正确的结果。但是如果两个内核线程在使用kref机制时存在下面情况kref机制也会出错。 内核线程1内核线程2 /* In kref_get() */ WARN_ON(!atomic_read(kref-refcount)); kref_put(kref); atomic_inc(kref-refcount); return kref; 在上面的例子中内核线程1在调用atomic_inc之前的那一刻被引用对象的相关资源很可能被释放掉了。kref代码强制要求对同一个引用对象不允许kref_get和kref_put并行运行。也就是说这种强制性要求上述两个函数都需要用锁来避免对同一个引用对象的并行访问。 但是关注高可扩展性的程序员经常会使用免锁算法。因为在线程数量比较大的时候锁往往会成为性能瓶颈因此尽可能不用锁内核的可扩展性会更好。这也是内核提供seqlock和RCU这两种技术的原因。kref机制对锁机制的需求使得seqlock和RCU很难派上用途。 Ravikiran G Thirumalai最近提交了一份题为“Refcounting of objects part of a lockfree collection”的补丁实现了一个新的锁机制refcount_t用于对象的免锁管理。并用大量篇幅介绍了和RCU一起工作时引用计数过程所有补丁构建了一种类似kref的数据类型这种数据类型不需要用锁就能避免前面提到的竞争问题。 伴随并行写的过程【as currently written】kref_get首先检查引用计数数值如果计数数值为零表示对象已经被释放了。当前的实现是检查到数值为零时仅仅是抱怨一下【我理解为信息输出而不做更多的处理】有人可能要说了这种情况下应该做进一步的处理才好。然而真正的问题是对引用计数的测试和递增如果不能在一个原子操作中实现那么在这两个操作之间就有可能插入其他操作。Ravikiran的补丁通过提供另一个XXXX_get函数来解决这个问题 static inline int refcount_get_rcu(refcount_t *rc){int c, old;c atomic_read(rc-count);while ( c (old cmpxchg(rc-count.counter, c, c1)) ! c) c old;return c;} 上面函数的核心是cmpxchg函数这是一个内联汇编函数可以直接使用CPU的cmpxchg指令。这个函数的原型是 int cmpxchg(int *location, int old, int new); cmpxchg函数实现了以下基本功能 1用原子操作实现比较location内存单元数值和old变量数值如果两者数值相等将location内存单元设置为new变量数值。 2如果上述原子操作成功即判断两者数值相等后location内存单元被修改cmpxchg函数返回old变量数值如果上述原子操作不成功cmpxchg返回location内存单元的数值。 cmpxchg指令是CPU提供的测试-设置原子指令。用cmpxchg实现的XXXX_get函数在不用锁的情况下就可以实现引用计数器的获取。 这里还是有点小问题。考虑一种情况内核线程2对引用计数对象释放后又重新使用该对象然后内核线程1才试图去获取引用计数。在这种情况下内核线程1可能看到的是一个随机的引用计数就误以为成功获取了引用计数。引入RCU机制可以避免这种情况发生。引用对象的释放是通过RCU回调函数来实现这样一来引用对象就不会被真正释放直到每一个处理器都发生了调度。只要内核线程能通过指针找到引用对象那么这个对象就一直存在即使对象的引用计数数值为零。经过一个完整静默期没有内核线程去访问这样的指针了引用对象才会被安全地删除。 另一个潜在的问题是并不是所有的体系结构都提供cmpxchg原子指令。针对这样的系统Ravikiran用到了一个从未见过但相当巧妙的方案用到了自旋锁的哈希数组如果你们好奇就自己去看补丁好了。 这些努力都是值得的这个技术已经用于文件描述符查找了tiobench测试性能提高了13% ~ 21%。内核系统里还有类似kref API一样的对象也有创建新的引用计数API。因此补丁还可能会重写。
http://www.w-s-a.com/news/641725/

相关文章:

  • 建设外国商城网站网站服务器 虚拟主机
  • 天河网站建设开发电子商务公司名字大全
  • 站长推荐为何用wdcp建立网站连不上ftp
  • 云南旅行社网站开发学编程多久可以写游戏辅助
  • 推广网站的步骤网站备案号中信息有变
  • 优秀企业建站织梦能不能做门户网站
  • 广东省建设局官方网站wordpress 自动安装 插件怎么用
  • 哪类小网站容易做h5页面制作代码
  • 北京网站建设公司华网百度热搜seo
  • 小清新博客网站中山做网站公司
  • 美团做团购网站如何新建自己的网站
  • 安卓软件制作网站电子商务网站建设实训总结报告
  • 肃宁网站制作价格外国设计师素材网站
  • 自已建网站用jsp做的可运行的网站
  • 外贸建站代理网站建设设计公司哪家好
  • 普升高端品牌网站建设台州中兴建设咨询有限公司网站
  • 模板演示网站移动网站开发公司
  • 网站管理办法制度公司招聘信息
  • 宜昌市建设监理协会网站免备案免费域名
  • 河北省建设银行网站首页备案号怎么放到网站
  • 做电脑网站用什么软件有哪些wordpress版权修改
  • 加强部门网站建设工作wordpress文章页横幅
  • 中英网站怎么做wordpress本地音乐
  • 万网提供的网站建设服务的具体项目祥云平台网站建设
  • ftp网站怎么看后台的代码网站 制作软件
  • 网站开发软件教程网站tag 怎么实现
  • 中国建设监理协会化工监理协会网站彩票站自己做网站吗
  • 170个可带链接锚文本外链的网站论坛微信上如何创建小程序
  • 用js来做网站亳州建设局网站
  • 做网站的公司利润多少呢纺织厂网站模板