亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? semaphore.c

?? 優龍2410linux2.6.8內核源代碼
?? C
字號:
/* * IA-64 semaphore implementation (derived from x86 version). * * Copyright (C) 1999-2000, 2002 Hewlett-Packard Co *	David Mosberger-Tang <davidm@hpl.hp.com> *//* * Semaphores are implemented using a two-way counter: The "count" * variable is decremented for each process that tries to acquire the * semaphore, while the "sleepers" variable is a count of such * acquires. * * Notably, the inline "up()" and "down()" functions can efficiently * test if they need to do any extra work (up needs to do something * only if count was negative before the increment operation. * * "sleeping" and the contention routine ordering is protected * by the spinlock in the semaphore's waitqueue head. * * Note that these functions are only called when there is contention * on the lock, and as such all this is the "non-critical" part of the * whole semaphore business. The critical part is the inline stuff in * <asm/semaphore.h> where we want to avoid any extra jumps and calls. */#include <linux/sched.h>#include <linux/init.h>#include <asm/errno.h>#include <asm/semaphore.h>/* * Logic: *  - Only on a boundary condition do we need to care. When we go *    from a negative count to a non-negative, we wake people up. *  - When we go from a non-negative count to a negative do we *    (a) synchronize with the "sleepers" count and (b) make sure *    that we're on the wakeup list before we synchronize so that *    we cannot lose wakeup events. */void__up (struct semaphore *sem){	wake_up(&sem->wait);}void __sched __down (struct semaphore *sem){	struct task_struct *tsk = current;	DECLARE_WAITQUEUE(wait, tsk);	unsigned long flags;	tsk->state = TASK_UNINTERRUPTIBLE;	spin_lock_irqsave(&sem->wait.lock, flags);	add_wait_queue_exclusive_locked(&sem->wait, &wait);	sem->sleepers++;	for (;;) {		int sleepers = sem->sleepers;		/*		 * Add "everybody else" into it. They aren't		 * playing, because we own the spinlock in		 * the wait_queue_head.		 */		if (!atomic_add_negative(sleepers - 1, &sem->count)) {			sem->sleepers = 0;			break;		}		sem->sleepers = 1;	/* us - see -1 above */		spin_unlock_irqrestore(&sem->wait.lock, flags);		schedule();		spin_lock_irqsave(&sem->wait.lock, flags);		tsk->state = TASK_UNINTERRUPTIBLE;	}	remove_wait_queue_locked(&sem->wait, &wait);	wake_up_locked(&sem->wait);	spin_unlock_irqrestore(&sem->wait.lock, flags);	tsk->state = TASK_RUNNING;}int __sched __down_interruptible (struct semaphore * sem){	int retval = 0;	struct task_struct *tsk = current;	DECLARE_WAITQUEUE(wait, tsk);	unsigned long flags;	tsk->state = TASK_INTERRUPTIBLE;	spin_lock_irqsave(&sem->wait.lock, flags);	add_wait_queue_exclusive_locked(&sem->wait, &wait);	sem->sleepers ++;	for (;;) {		int sleepers = sem->sleepers;		/*		 * With signals pending, this turns into		 * the trylock failure case - we won't be		 * sleeping, and we* can't get the lock as		 * it has contention. Just correct the count		 * and exit.		 */		if (signal_pending(current)) {			retval = -EINTR;			sem->sleepers = 0;			atomic_add(sleepers, &sem->count);			break;		}		/*		 * Add "everybody else" into it. They aren't		 * playing, because we own the spinlock in		 * wait_queue_head. The "-1" is because we're		 * still hoping to get the semaphore.		 */		if (!atomic_add_negative(sleepers - 1, &sem->count)) {			sem->sleepers = 0;			break;		}		sem->sleepers = 1;	/* us - see -1 above */		spin_unlock_irqrestore(&sem->wait.lock, flags);		schedule();		spin_lock_irqsave(&sem->wait.lock, flags);		tsk->state = TASK_INTERRUPTIBLE;	}	remove_wait_queue_locked(&sem->wait, &wait);	wake_up_locked(&sem->wait);	spin_unlock_irqrestore(&sem->wait.lock, flags);	tsk->state = TASK_RUNNING;	return retval;}/* * Trylock failed - make sure we correct for having decremented the * count. */int__down_trylock (struct semaphore *sem){	unsigned long flags;	int sleepers;	spin_lock_irqsave(&sem->wait.lock, flags);	sleepers = sem->sleepers + 1;	sem->sleepers = 0;	/*	 * Add "everybody else" and us into it. They aren't	 * playing, because we own the spinlock in the	 * wait_queue_head.	 */	if (!atomic_add_negative(sleepers, &sem->count)) {		wake_up_locked(&sem->wait);	}	spin_unlock_irqrestore(&sem->wait.lock, flags);	return 1;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天天色综合天天| 亚洲高清免费观看| 国产一区在线视频| 国产精品国产自产拍在线| 亚洲成人精品一区| 久久婷婷综合激情| 一本大道久久a久久综合婷婷| 久久蜜桃av一区二区天堂| 七七婷婷婷婷精品国产| 国产三级精品视频| 在线观看91精品国产入口| 久久国产精品第一页| 这里只有精品视频在线观看| 毛片不卡一区二区| 亚洲国产精品99久久久久久久久| 韩国一区二区视频| 亚洲精品国产精品乱码不99 | 天天色天天操综合| 欧美亚州韩日在线看免费版国语版| 亚洲欧洲三级电影| 欧美成人r级一区二区三区| 日韩女优av电影在线观看| 97久久精品人人爽人人爽蜜臀| 久久综合国产精品| 国产精品自在在线| 天天综合色天天| 9191国产精品| 91在线观看污| 国产一区在线看| 捆绑调教一区二区三区| 最新久久zyz资源站| 欧美成人欧美edvon| 欧美性感一区二区三区| 91传媒视频在线播放| 亚洲成人免费观看| 亚洲综合色区另类av| **网站欧美大片在线观看| 久久精品人人爽人人爽| 欧美大黄免费观看| 日韩欧美美女一区二区三区| 91视视频在线直接观看在线看网页在线看| 一区二区三区在线视频观看58 | 国产不卡在线视频| 美日韩一区二区三区| 视频一区视频二区中文字幕| 亚洲乱码精品一二三四区日韩在线| 91小视频在线免费看| 成人福利电影精品一区二区在线观看| 中文字幕亚洲区| 91精品国产欧美一区二区18| 色视频一区二区| 99久久精品免费| 成人免费视频视频在线观看免费 | 日韩精品专区在线| 日韩无一区二区| 欧美xxxxxxxxx| 精品精品国产高清a毛片牛牛 | 免费欧美日韩国产三级电影| 亚洲mv在线观看| 亚洲激情图片qvod| 国产精品第13页| 精品国产污污免费网站入口| 欧美电影免费观看高清完整版在线| 成人黄色小视频在线观看| 国产宾馆实践打屁股91| 成人午夜视频网站| 国产欧美日韩在线看| 欧美三级在线播放| 欧美性做爰猛烈叫床潮| 色综合久久久久| 粉嫩av一区二区三区在线播放| 亚洲成av人片在www色猫咪| 亚洲国产视频网站| 日本三级亚洲精品| 亚洲精品亚洲人成人网| 亚洲自拍偷拍欧美| 亚洲一级片在线观看| 国产亚洲短视频| 亚洲欧洲综合另类| 18欧美亚洲精品| 日韩激情在线观看| 国产成人av影院| 美腿丝袜亚洲色图| 麻豆精品久久精品色综合| 石原莉奈在线亚洲三区| 国产精品久久久久婷婷 | 91极品视觉盛宴| 欧美乱妇20p| 26uuu精品一区二区| 日韩欧美中文字幕一区| 久久久www免费人成精品| 亚洲私人黄色宅男| 日韩专区欧美专区| 国产成人av电影免费在线观看| 蜜桃一区二区三区在线| 亚洲妇熟xx妇色黄| 国产一区二区网址| 91成人国产精品| 91香蕉视频在线| 日韩免费看的电影| 综合久久久久久| 国产精品成人在线观看| 久久女同精品一区二区| 亚洲男人的天堂网| 久久国产精品色婷婷| 91天堂素人约啪| 日韩一区二区三区视频在线观看| 制服丝袜亚洲精品中文字幕| 欧美国产日本韩| 日韩成人精品在线观看| 99v久久综合狠狠综合久久| 色婷婷久久久久swag精品| 欧美精选在线播放| 中文字幕一区二区三区四区| 日韩精品一区第一页| 日韩激情av在线| 国产精品一区二区视频| 日本丰满少妇一区二区三区| 久久这里只有精品6| 午夜精彩视频在线观看不卡| 成人性生交大合| 欧美一级一区二区| 亚洲美女一区二区三区| 国产1区2区3区精品美女| 欧美嫩在线观看| 日韩精品在线网站| 亚洲激情在线激情| av男人天堂一区| 日本一区二区视频在线| 久久99久久久久久久久久久| 欧美午夜精品一区二区蜜桃| 成人免费一区二区三区在线观看| 亚洲成人777| 日本乱码高清不卡字幕| 欧美日韩一区二区不卡| 欧美大片国产精品| 日本强好片久久久久久aaa| 色婷婷久久久综合中文字幕| 91久久奴性调教| 国产精品久久久久久久久免费樱桃| 一区二区久久久久| 99久久精品国产精品久久| 欧美经典三级视频一区二区三区| 亚洲一区二区三区四区在线| 99在线精品视频| 国产精品欧美综合在线| 国产999精品久久久久久| 精品国产乱子伦一区| 激情国产一区二区| 精品理论电影在线| 精品亚洲国内自在自线福利| 精品美女在线播放| 国产乱码精品一区二区三区忘忧草 | 亚洲国产精品麻豆| 91精品免费观看| 久久国内精品视频| 久久久www成人免费毛片麻豆 | www.亚洲精品| 一区二区在线电影| 欧美日韩aaaaaa| 国产一区二区三区精品视频| 国产精品日产欧美久久久久| 色狠狠桃花综合| 中文字幕视频一区二区三区久| 麻豆成人综合网| 中文字幕免费在线观看视频一区| 久久er99热精品一区二区| 国产喷白浆一区二区三区| 激情深爱一区二区| 日韩伦理电影网| 91麻豆精品国产无毒不卡在线观看 | 丝袜美腿亚洲综合| 久久亚洲春色中文字幕久久久| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美又粗又大又爽| 九九久久精品视频| 欧美大片在线观看| 国内精品伊人久久久久av一坑| 欧美一区二区视频网站| 午夜伦欧美伦电影理论片| 欧美日韩国产综合一区二区| 国产一区二区久久| 亚洲一区二区成人在线观看| 久久久三级国产网站| 欧美最新大片在线看| 亚洲午夜久久久久久久久久久| 色综合久久综合中文综合网| 蜜芽一区二区三区| 一区在线观看视频| 日韩免费视频一区| 色婷婷av一区二区三区之一色屋| 亚洲免费视频成人| 精品三级在线观看| 在线视频你懂得一区二区三区| 亚洲夂夂婷婷色拍ww47| 国产欧美日韩综合精品一区二区| www.久久精品| 激情欧美日韩一区二区| 亚洲va韩国va欧美va| 综合色天天鬼久久鬼色|