⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 semaphore-helper.h

📁 嵌入式系统设计与实例开发实验教材二源码 多线程应用程序设计 串行端口程序设计 AD接口实验 CAN总线通信实验 GPS通信实验 Linux内核移植与编译实验 IC卡读写实验 SD驱动使
💻 H
字号:
#ifndef __ASM_SH_SEMAPHORE_HELPER_H#define __ASM_SH_SEMAPHORE_HELPER_H/* * SMP- and interrupt-safe semaphores helper functions. * * (C) Copyright 1996 Linus Torvalds * (C) Copyright 1999 Andrea Arcangeli *//* * These two _must_ execute atomically wrt each other. * * This is trivially done with load_locked/store_cond, * which we have.  Let the rest of the losers suck eggs. */static __inline__ void wake_one_more(struct semaphore * sem){	atomic_inc((atomic_t *)&sem->sleepers);}static __inline__ int waking_non_zero(struct semaphore *sem){	unsigned long flags;	int ret = 0;	spin_lock_irqsave(&semaphore_wake_lock, flags);	if (sem->sleepers > 0) {		sem->sleepers--;		ret = 1;	}	spin_unlock_irqrestore(&semaphore_wake_lock, flags);	return ret;}/* * waking_non_zero_interruptible: *	1	got the lock *	0	go to sleep *	-EINTR	interrupted * * We must undo the sem->count down_interruptible() increment while we are * protected by the spinlock in order to make atomic this atomic_inc() with the * atomic_read() in wake_one_more(), otherwise we can race. -arca */static __inline__ int waking_non_zero_interruptible(struct semaphore *sem,						struct task_struct *tsk){	unsigned long flags;	int ret = 0;	spin_lock_irqsave(&semaphore_wake_lock, flags);	if (sem->sleepers > 0) {		sem->sleepers--;		ret = 1;	} else if (signal_pending(tsk)) {		atomic_inc(&sem->count);		ret = -EINTR;	}	spin_unlock_irqrestore(&semaphore_wake_lock, flags);	return ret;}/* * waking_non_zero_trylock: *	1	failed to lock *	0	got the lock * * We must undo the sem->count down_trylock() increment while we are * protected by the spinlock in order to make atomic this atomic_inc() with the * atomic_read() in wake_one_more(), otherwise we can race. -arca */static __inline__ int waking_non_zero_trylock(struct semaphore *sem){	unsigned long flags;	int ret = 1;	spin_lock_irqsave(&semaphore_wake_lock, flags);	if (sem->sleepers <= 0)		atomic_inc(&sem->count);	else {		sem->sleepers--;		ret = 0;	}	spin_unlock_irqrestore(&semaphore_wake_lock, flags);	return ret;}#endif /* __ASM_SH_SEMAPHORE_HELPER_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -