/* 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 02139, USA. xrdp: A Remote Desktop Protocol server. Copyright (C) Jay Sorg 2005-2008 session manager linux only */ #include "sesman.h" #include #include extern struct config_sesman* g_cfg; pthread_mutex_t lock_chain; /* session chain lock */ pthread_mutexattr_t lock_chain_attr; /* mutex attributes */ pthread_mutex_t lock_config; /* configuration access lock */ pthread_mutexattr_t lock_config_attr; /* mutex attributes */ static tbus g_sync_mutex; static tbus g_sync_sem; sem_t lock_socket; void DEFAULT_CC lock_init(void) { /* initializing socket lock */ sem_init(&lock_socket, 0, 1); /* initializing chain lock */ pthread_mutexattr_init(&lock_chain_attr); pthread_mutex_init(&lock_chain, &lock_chain_attr); /* initializing config lock */ pthread_mutexattr_init(&lock_config_attr); pthread_mutex_init(&lock_config, &lock_config_attr); g_sync_mutex = tc_mutex_create(); g_sync_sem = tc_sem_create(0); } /******************************************************************************/ void DEFAULT_CC lock_chain_acquire(void) { /*lock the chain*/ LOG_DBG(&(g_cfg->log), "lock_chain_acquire()"); pthread_mutex_lock(&lock_chain); } /******************************************************************************/ void DEFAULT_CC lock_chain_release(void) { /*unlock the chain*/ LOG_DBG(&(g_cfg->log), "lock_chain_release()"); pthread_mutex_unlock(&lock_chain); } /******************************************************************************/ void DEFAULT_CC lock_socket_acquire(void) { /* lock socket variable */ LOG_DBG(&(g_cfg->log), "lock_socket_acquire()"); sem_wait(&lock_socket); } /******************************************************************************/ void DEFAULT_CC lock_socket_release(void) { /* unlock socket variable */ LOG_DBG(&(g_cfg->log), "lock_socket_release()"); sem_post(&lock_socket); } /******************************************************************************/ void APP_CC lock_sync_acquire(void) { /* lock sync variable */ LOG_DBG(&(g_cfg->log), "lock_sync_acquire()"); tc_mutex_lock(g_sync_mutex); } /******************************************************************************/ void APP_CC lock_sync_release(void) { /* unlock socket variable */ LOG_DBG(&(g_cfg->log), "lock_socket_release()"); tc_mutex_unlock(g_sync_mutex); } /******************************************************************************/ void APP_CC lock_sync_sem_acquire(void) { /* dec sem */ LOG_DBG(&(g_cfg->log), "lock_sync_dec()"); tc_sem_dec(g_sync_sem); } /******************************************************************************/ void APP_CC lock_sync_sem_release(void) { /* inc sem */ LOG_DBG(&(g_cfg->log), "lock_sync_inc()"); tc_sem_inc(g_sync_sem); }