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

建设银行网站苹果电脑石家庄新闻网头条新闻

建设银行网站苹果电脑,石家庄新闻网头条新闻,济南行知做网站,wordpress注册默认密码在前面呢,我们已经讲过了自旋锁以及信号量了,那么今天呢,我们来看看互斥量: 互斥量mutex的实现: mutex的内核结构体: 初始化mutex之后,就可以使用mutex_lock函数或其他衍生版本来获取信号量&a…

在前面呢,我们已经讲过了自旋锁以及信号量了,那么今天呢,我们来看看互斥量:

互斥量mutex的实现:

mutex的内核结构体:

初始化mutex之后,就可以使用mutex_lock函数或其他衍生版本来获取信号量,使用mutex_unlock函数释放信号量。我们只分析mutex_lock、mutex_unlock函数的实现。

这里要堪误一下:前面我们说mutex中的owner是用来记录获得mutex的进程,以后必须由它来释放mutex。这是错的!

从上面的代码可知,owner并不一定存在!

owner有2个用途:debug(CONFIG_DEBUG_MUTEXES)或spin_on_owner(CONFIG_MUTEX_SPIN_ON_OWNER)。

什么叫spin on owner?

我们使用mutex的目的一般是用来保护一小段代码,这段代码运行的时间很快。这意味着一个获得mutex的进程,可能很快就会释放掉mutex。

针对这点可以进行优化,特别是当前获得mutex的进程是在别的CPU上运行、并且“”是唯一等待这个mutex的进程。在这种情况下,那“”就原地spin等待吧:懒得去休眠了,休眠又唤醒就太慢了。

所以,mutex是做了特殊的优化,比semaphore效率更高。但是在代码上,并没有要求“谁获得mutex,就必须由谁释放mutex”,只是在使用惯例上是“谁获得mutex,就必须由谁释放mutex”。

下面的话,我们来看看内核给mutex提供的函数:

mutex_lock函数的实现:

fastpath:

mutex的设计非常精巧,比semaphore复杂,但是更高效。

首先要知道mutex的操作函数中有fastpath、slowpath两条路径(快速、慢速):如果fastpath成功,就不必使用slowpath。

怎么理解?

这需要把metex中的count值再扩展一下,之前说它只有1、0两个取值,1表示unlocked,0表示locked,还有一类值“负数”表示“locked,并且可能有其他程序在等待”。

代码如下:

先看看fastpath的函数:__mutex_fastpath_lock,这个函数在下面2个文件中都有定义:

所以,对于ARMv6以下的架构,使用include/asm-generic/mutex-xchg.h中的__mutex_fastpath_lock函数;对于ARMv6及以上的架构,使用include/asm-generic/mutex-dec.h中的__mutex_fastpath_lock函数。这2个文件中的__mutex_fastpath_lock函数是类似的,mutex-dec.h中的代码如下:

大部分情况下,mutex当前值都是1,所以通过fastpath函数可以非常快速地获得mutex。

slowpath:

如果mutex当前值是0或负数,则需要调用__mutex_lock_slowpath慢慢处理:可能会休眠等待。

① 分析第一段代码:

② 分析第二段代码:

③ 分析第三段代码:

这个wait_list是FIFO(Firt In Firs Out),谁先排队,谁就可以先得到mutex。

④ 分析第四段代码:for循环,这是重点

⑤ 分析第五段代码:收尾工作

mutex_unlock函数的实现:

mutex_unlock函数中也有fastpath、slowpath两条路径(快速、慢速):如果fastpath成功,就不必使用slowpath。

代码如下:

fastpath:

所以,对于ARMv6以下的架构,使用include/asm-generic/mutex-xchg.h中的__mutex_fastpath_lock函数;对于ARMv6及以上的架构,使用include/asm-generic/mutex-dec.h中的__mutex_fastpath_lock函数。这2个文件中的__mutex_fastpath_lock函数是类似的,mutex-dec.h中的代码如下:

大部分情况下,加1后mutex的值都是1,表示无人等待mutex,所以通过fastpath函数直接增加mutex的count值为1就可以了。

如果mutex的值加1后还是小于等于0,就表示有人在等待mutex,需要去wait_list把它取出唤醒,这需要用到slowpath的函数:__mutex_unlock_slowpath。

slowpath:

如果mutex当前值是0或负数,则需要调用__mutex_unlock_slowpath慢慢处理:需要唤醒其他进程。

__mutex_unlock_common_slowpath函数代码如下,主要工作就是从wait_list中取出并唤醒第1个进程:

那么到这里,我们互斥量就讲完啦,完结,撒花(doge.)

http://www.dtcms.com/wzjs/153546.html

相关文章:

  • 免费网站建设代理长尾关键词排名系统
  • 公司网站建设哪儿济南兴田德润实惠吗网站制作app
  • 养殖网站 模板西安seo服务外包
  • 鼓楼做网站价格搜索引擎优化的英文缩写是什么
  • wordpress建站 客户端临沂做网络优化的公司
  • 网站开发颜色代码写文章在哪里发表挣钱
  • 购物网站开发背景及意义宁波网站快速优化
  • 网站设计论文摘要百度网盘客服人工电话
  • 网奇e游通旅游网站微信客户管理
  • 做网站一般收取多少钱如何做好线上推广和引流
  • 网站 建设 方案深圳全网推广平台
  • 语言互动网站建设百度推广代理商加盟
  • 关于建设人才网站的竞争对手分析关键词排名seo优化
  • 公司做网站最好软文代写兼职
  • 广告公司寮步网站建设哪家好在哪里可以找到网站
  • 第一次做网站时是怎样的心情天津百度分公司
  • 郑州做网站的论坛推广产品的渠道
  • 城市规划做底图的网站爱站网官网查询域名
  • 全校网站建设与管理b2b国际贸易平台
  • 多语言网站建设价格广州营销优化
  • 手机p2p网站图片外链
  • 搜狐做app的网站长沙网站开发制作
  • 网站制作代理今日新闻最新头条10条内容
  • 做网站除了有服务器还需要什么问题武汉seo搜索优化
  • 大连网站建设怎么做如何快速提升网站关键词排名
  • 北京免费网站建设模板引擎搜索大全
  • 做调查问卷赚钱哪个网站好宁海关键词优化怎么优化
  • 免费做网站手机软件上海排名优化seo
  • 张家界网站开发360社区app
  • wordpress漫画站产品市场调研怎么做