2005-04-17 02:20:36 +04:00
/*
2005-11-02 06:58:39 +03:00
* Copyright ( c ) 2000 - 2002 , 2005 Silicon Graphics , Inc .
* All Rights Reserved .
2005-04-17 02:20:36 +04:00
*
2005-11-02 06:58:39 +03:00
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License as
2005-04-17 02:20:36 +04:00
* published by the Free Software Foundation .
*
2005-11-02 06:58:39 +03:00
* This program is distributed in the hope that it would be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
2005-04-17 02:20:36 +04:00
*
2005-11-02 06:58:39 +03:00
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write the Free Software Foundation ,
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA
2005-04-17 02:20:36 +04:00
*/
# ifndef __XFS_SUPPORT_SEMA_H__
# define __XFS_SUPPORT_SEMA_H__
# include <linux/time.h>
# include <linux/wait.h>
# include <asm/atomic.h>
# include <asm/semaphore.h>
/*
* sema_t structure just maps to struct semaphore in Linux kernel .
*/
typedef struct semaphore sema_t ;
# define init_sema(sp, val, c, d) sema_init(sp, val)
# define initsema(sp, val) sema_init(sp, val)
# define initnsema(sp, val, name) sema_init(sp, val)
# define psema(sp, b) down(sp)
# define vsema(sp) up(sp)
# define valusema(sp) (atomic_read(&(sp)->count))
# define freesema(sema)
/*
* Map cpsema ( try to get the sema ) to down_trylock . We need to switch
* the return values since cpsema returns 1 ( acquired ) 0 ( failed ) and
* down_trylock returns the reverse 0 ( acquired ) 1 ( failed ) .
*/
# define cpsema(sp) (down_trylock(sp) ? 0 : 1)
/*
* Didn ' t do cvsema ( sp ) . Not sure how to map this to up / down / . . .
* It does a vsema if the values is < 0 other wise nothing .
*/
# endif /* __XFS_SUPPORT_SEMA_H__ */