Chinaunix首页 | 论坛 | 博客
  • 博客访问: 364880
  • 博文数量: 135
  • 博客积分: 425
  • 博客等级: 下士
  • 技术积分: 599
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-19 21:10
文章分类
文章存档

2014年(3)

2013年(79)

2012年(53)

分类:

2012-12-26 09:24:53

down_interruptible()是处理信号量的函数。他的返回值有三种 1. “0” 2. “-ETIME”3.“-EINTR”

0 代表正常返回

-ETIME 等待超时

-EINTR 中断

 

函数的运作方式:

如果sem->count >0 (信号量允许访问)        

返回0 (正常返回)

否则进行等待。

内核源码为

点击(此处)折叠或打开

  1. int down_interruptible(struct semaphore *sem)
  2. {
  3.  unsigned long flags;
  4.  int result = 0;

  5.  spin_lock_irqsave(&sem->lock, flags);//信号量自旋锁
  6.  if (likely(sem->count > 0))
  7.   sem->count--;
  8.  else
  9.   result = __down_interruptible(sem);//进入等待
  10.  spin_unlock_irqrestore(&sem->lock, flags);

  11.  return result;
  12. }

__down_interruptible()

调用__down_common()

__down_common()中有for循环

当有中断信号时 返回 -EINTR ,当等待超时时返回 -ETIME.

信号量变为可访问状态时 返回0

顺便提一下,信号的信号量是不同的,需要区分。


形象说明:

你放学回家,饿了,想吃饭,跑到厨房去看看有没有吃的(吃的是信号量),如果有现成的吃的(信号没被占用),你立刻进去吃(返回0),如果老妈正在做(信号量在使用中),你就说跟老妈说做好好后喊醒他,你先去睡会(睡眠),同时,房间有个闹钟(其他信号),如果饭还没做好时,闹钟响了,你就醒了(返回-EINTR),不然就最后等到老妈做好饭叫醒你(同样返回0),超时状态未考虑。

阅读(881) | 评论(0) | 转发(0) |
0

上一篇:elf格式分析

下一篇:Linux oops信息的分析

给主人留下些什么吧!~~