semaphore.h

来自「linux 内核源代码」· C头文件 代码 · 共 156 行

H
156
字号
/* semaphore.h: semaphores for the FR-V * * Copyright (C) 2003 Red Hat, Inc. All Rights Reserved. * Written by David Howells (dhowells@redhat.com) * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version * 2 of the License, or (at your option) any later version. */#ifndef _ASM_SEMAPHORE_H#define _ASM_SEMAPHORE_H#define RW_LOCK_BIAS		 0x01000000#ifndef __ASSEMBLY__#include <linux/linkage.h>#include <linux/wait.h>#include <linux/spinlock.h>#include <linux/rwsem.h>/* * the semaphore definition * - if counter is >0 then there are tokens available on the semaphore for down to collect * - if counter is <=0 then there are no spare tokens, and anyone that wants one must wait * - if wait_list is not empty, then there are processes waiting for the semaphore */struct semaphore {	unsigned		counter;	spinlock_t		wait_lock;	struct list_head	wait_list;#ifdef CONFIG_DEBUG_SEMAPHORE	unsigned		__magic;#endif};#ifdef CONFIG_DEBUG_SEMAPHORE# define __SEM_DEBUG_INIT(name) , (long)&(name).__magic#else# define __SEM_DEBUG_INIT(name)#endif#define __SEMAPHORE_INITIALIZER(name,count) \{ count, SPIN_LOCK_UNLOCKED, LIST_HEAD_INIT((name).wait_list) __SEM_DEBUG_INIT(name) }#define __DECLARE_SEMAPHORE_GENERIC(name,count) \	struct semaphore name = __SEMAPHORE_INITIALIZER(name,count)#define DECLARE_MUTEX(name) __DECLARE_SEMAPHORE_GENERIC(name,1)static inline void sema_init (struct semaphore *sem, int val){	*sem = (struct semaphore) __SEMAPHORE_INITIALIZER(*sem, val);}static inline void init_MUTEX (struct semaphore *sem){	sema_init(sem, 1);}static inline void init_MUTEX_LOCKED (struct semaphore *sem){	sema_init(sem, 0);}extern void __down(struct semaphore *sem, unsigned long flags);extern int  __down_interruptible(struct semaphore *sem, unsigned long flags);extern void __up(struct semaphore *sem);static inline void down(struct semaphore *sem){	unsigned long flags;#ifdef CONFIG_DEBUG_SEMAPHORE	CHECK_MAGIC(sem->__magic);#endif	spin_lock_irqsave(&sem->wait_lock, flags);	if (likely(sem->counter > 0)) {		sem->counter--;		spin_unlock_irqrestore(&sem->wait_lock, flags);	}	else {		__down(sem, flags);	}}static inline int down_interruptible(struct semaphore *sem){	unsigned long flags;	int ret = 0;#ifdef CONFIG_DEBUG_SEMAPHORE	CHECK_MAGIC(sem->__magic);#endif	spin_lock_irqsave(&sem->wait_lock, flags);	if (likely(sem->counter > 0)) {		sem->counter--;		spin_unlock_irqrestore(&sem->wait_lock, flags);	}	else {		ret = __down_interruptible(sem, flags);	}	return ret;}/* * non-blockingly attempt to down() a semaphore. * - returns zero if we acquired it */static inline int down_trylock(struct semaphore *sem){	unsigned long flags;	int success = 0;#ifdef CONFIG_DEBUG_SEMAPHORE	CHECK_MAGIC(sem->__magic);#endif	spin_lock_irqsave(&sem->wait_lock, flags);	if (sem->counter > 0) {		sem->counter--;		success = 1;	}	spin_unlock_irqrestore(&sem->wait_lock, flags);	return !success;}static inline void up(struct semaphore *sem){	unsigned long flags;#ifdef CONFIG_DEBUG_SEMAPHORE	CHECK_MAGIC(sem->__magic);#endif	spin_lock_irqsave(&sem->wait_lock, flags);	if (!list_empty(&sem->wait_list))		__up(sem);	else		sem->counter++;	spin_unlock_irqrestore(&sem->wait_lock, flags);}static inline int sem_getcount(struct semaphore *sem){	return sem->counter;}#endif /* __ASSEMBLY__ */#endif

⌨️ 快捷键说明

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