/*
Unix SMB / CIFS implementation .
Samba mutex / lock functions
Copyright ( C ) Andrew Tridgell 2003
Copyright ( C ) James J Myers 2003
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 .
This program is distributed in the hope that it will 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 .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
static smb_mutex_t mutex_list [ MUTEX_MAX ] ;
/* the registered mutex handlers */
static struct {
const char * name ;
struct mutex_ops ops ;
} mutex_handlers ;
int mutex_lock_by_id ( enum mutex_id id , const char * name )
{
return mutex_lock ( & mutex_list [ id ] , name ) ;
}
int mutex_unlock_by_id ( enum mutex_id id , const char * name )
{
return mutex_unlock ( & mutex_list [ id ] , name ) ;
}
int mutex_init ( smb_mutex_t * mutex , const char * name )
{
if ( mutex_handlers . ops . mutex_init ) {
return mutex_handlers . ops . mutex_init ( mutex , name ) ;
}
return 0 ;
}
int mutex_destroy ( smb_mutex_t * mutex , const char * name )
{
if ( mutex_handlers . ops . mutex_destroy ) {
return mutex_handlers . ops . mutex_destroy ( mutex , name ) ;
}
return 0 ;
}
int mutex_lock ( smb_mutex_t * mutex , const char * name )
{
if ( mutex_handlers . ops . mutex_lock ) {
return mutex_handlers . ops . mutex_lock ( mutex , name ) ;
}
return 0 ;
}
int mutex_unlock ( smb_mutex_t * mutex , const char * name )
{
if ( mutex_handlers . ops . mutex_unlock ) {
return mutex_handlers . ops . mutex_unlock ( mutex , name ) ;
}
return 0 ;
}
/* read/write lock routines */
int rwlock_init ( smb_rwlock_t * rwlock , const char * name )
{
if ( mutex_handlers . ops . rwlock_init ) {
return mutex_handlers . ops . rwlock_init ( rwlock , name ) ;
}
return 0 ;
}
int rwlock_destroy ( smb_rwlock_t * rwlock , const char * name )
{
if ( mutex_handlers . ops . rwlock_destroy ) {
return mutex_handlers . ops . rwlock_destroy ( rwlock , name ) ;
}
return 0 ;
}
int rwlock_lock_write ( smb_rwlock_t * rwlock , const char * name )
{
if ( mutex_handlers . ops . rwlock_lock_write ) {
return mutex_handlers . ops . rwlock_lock_write ( rwlock , name ) ;
}
return 0 ;
}
int rwlock_lock_read ( smb_rwlock_t * rwlock , const char * name )
{
if ( mutex_handlers . ops . rwlock_lock_read ) {
return mutex_handlers . ops . rwlock_lock_read ( rwlock , name ) ;
}
return 0 ;
}
int rwlock_unlock ( smb_rwlock_t * rwlock , const char * name )
{
if ( mutex_handlers . ops . rwlock_unlock ) {
return mutex_handlers . ops . rwlock_unlock ( rwlock , name ) ;
}
return 0 ;
}
/*
register a set of mutex / rwlock handlers .
Should only be called once in the execution of smbd .
*/
BOOL register_mutex_handlers ( const char * name , struct mutex_ops * ops )
{
if ( mutex_handlers . name ! = NULL ) {
/* it's already registered! */
DEBUG ( 2 , ( " mutex handler '%s' already registered - failed '%s' \n " ,
mutex_handlers . name , name ) ) ;
return False ;
}
mutex_handlers . name = name ;
mutex_handlers . ops = * ops ;
if ( mutex_handlers . ops . mutex_init ) {
enum mutex_id id ;
for ( id = 0 ; id < MUTEX_MAX ; id + + ) {
mutex_handlers . ops . mutex_init ( & mutex_list [ id ] , " mutex_list " ) ;
}
}
DEBUG ( 2 , ( " mutex handler '%s' registered \n " , name ) ) ;
return True ;
}