mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-27 07:58:49 +01:00
call shutdown on cref rather than deleting it; wrap mutex actions with
debugging logfs like those in mlock.h.
This commit is contained in:
parent
ae4821d5f5
commit
cb4db25f27
2 changed files with 64 additions and 6 deletions
|
@ -72,15 +72,16 @@ CRefMgr::~CRefMgr()
|
|||
void
|
||||
CRefMgr::CloseAll()
|
||||
{
|
||||
MutexLock ml( &m_guard );
|
||||
|
||||
/* Get every cref instance, shut it down */
|
||||
|
||||
RWWriteLock rwl( &m_cookieMapRWLock );
|
||||
CookieMap::iterator iter = m_cookieMap.begin();
|
||||
while ( iter != m_cookieMap.end() ) {
|
||||
|
||||
CookieRef* cref = iter->second;
|
||||
delete cref;
|
||||
|
||||
CookieRef* cref = iter->second;
|
||||
{
|
||||
SafeCref scr( cref );
|
||||
scr.Shutdown();
|
||||
}
|
||||
++iter;
|
||||
}
|
||||
|
||||
|
@ -153,7 +154,13 @@ CRefMgr::getMakeCookieRef_locked( const char* cORn, int isCookie, HostID hid,
|
|||
{
|
||||
CookieRef* cref;
|
||||
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "tlm %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_lock( &m_guard );
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "slm %p", &m_guard );
|
||||
#endif
|
||||
|
||||
/* We have a cookie from a new connection. This may be the first time
|
||||
it's been seen, or there may be a game currently in the
|
||||
|
@ -182,6 +189,9 @@ CRefMgr::getMakeCookieRef_locked( const char* cORn, int isCookie, HostID hid,
|
|||
}
|
||||
|
||||
if ( cref == NULL ) {
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_unlock( &m_guard );
|
||||
}
|
||||
|
||||
|
@ -264,11 +274,20 @@ CRefMgr::MakeSocketsIterator()
|
|||
CookieRef*
|
||||
CRefMgr::getCookieRef_locked( CookieID cookieID )
|
||||
{
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "tlm %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_lock( &m_guard );
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "slm %p", &m_guard );
|
||||
#endif
|
||||
|
||||
CookieRef* cref = getCookieRef_impl( cookieID );
|
||||
|
||||
if ( cref == NULL ) {
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_unlock( &m_guard );
|
||||
}
|
||||
|
||||
|
@ -278,7 +297,13 @@ CRefMgr::getCookieRef_locked( CookieID cookieID )
|
|||
CookieRef*
|
||||
CRefMgr::getCookieRef_locked( int socket )
|
||||
{
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "tlm %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_lock( &m_guard );
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "slm %p", &m_guard );
|
||||
#endif
|
||||
CookieRef* cref = NULL;
|
||||
|
||||
CookieMap::iterator iter = m_cookieMap.begin();
|
||||
|
@ -292,6 +317,9 @@ CRefMgr::getCookieRef_locked( int socket )
|
|||
}
|
||||
|
||||
if ( cref == NULL ) {
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_unlock( &m_guard );
|
||||
}
|
||||
|
||||
|
@ -303,12 +331,22 @@ CRefMgr::checkCookieRef_locked( CookieRef* cref )
|
|||
{
|
||||
int exists = 1;
|
||||
assert( cref != NULL );
|
||||
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "tlm %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_lock( &m_guard );
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "slm %p", &m_guard );
|
||||
#endif
|
||||
|
||||
pthread_mutex_t* cref_mutex = m_crefMutexes[cref];
|
||||
logf( XW_LOGINFO, "checkCookieRef_locked: cref_mutex=%p", cref_mutex );
|
||||
|
||||
if ( cref_mutex == NULL ) {
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_unlock( &m_guard );
|
||||
exists = 0;
|
||||
}
|
||||
|
@ -327,8 +365,17 @@ CRefMgr::LockCref( CookieRef* cref )
|
|||
pthread_mutex_init( cref_mutex, NULL );
|
||||
m_crefMutexes[cref] = cref_mutex;
|
||||
}
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "tlm %p", cref_mutex );
|
||||
#endif
|
||||
pthread_mutex_lock( cref_mutex );
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "slm %p", cref_mutex );
|
||||
#endif
|
||||
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", &m_guard );
|
||||
#endif
|
||||
pthread_mutex_unlock( &m_guard );
|
||||
return 1;
|
||||
} /* LockCref */
|
||||
|
@ -337,6 +384,9 @@ void
|
|||
CRefMgr::UnlockCref( CookieRef* cref )
|
||||
{
|
||||
pthread_mutex_t* cref_mutex = m_crefMutexes[cref];
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", cref_mutex );
|
||||
#endif
|
||||
pthread_mutex_unlock( cref_mutex );
|
||||
}
|
||||
|
||||
|
@ -387,6 +437,9 @@ CRefMgr::Delete( CookieRef* cref )
|
|||
}
|
||||
|
||||
pthread_mutex_t* cref_mutex = m_crefMutexes[cref];
|
||||
#ifdef DEBUG_LOCKS
|
||||
logf( XW_LOGINFO, "ULM %p", cref_mutex );
|
||||
#endif
|
||||
pthread_mutex_unlock( cref_mutex );
|
||||
pthread_mutex_destroy( cref_mutex );
|
||||
free( cref_mutex );
|
||||
|
|
|
@ -155,6 +155,11 @@ class SafeCref {
|
|||
m_cref->_Disconnect( socket, hostID );
|
||||
}
|
||||
}
|
||||
void Shutdown() {
|
||||
if ( IsValid() ) {
|
||||
m_cref->_Shutdown();
|
||||
}
|
||||
}
|
||||
void Remove( int socket ) {
|
||||
if ( IsValid() ) {
|
||||
m_cref->_Remove( socket );
|
||||
|
|
Loading…
Add table
Reference in a new issue