[svn-commits] mmichelson: trunk r175121 - in /trunk: include/asterisk/astobj2.h main/astobj2.c
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Thu Feb 12 10:28:06 CST 2009
Author: mmichelson
Date: Thu Feb 12 10:28:06 2009
New Revision: 175121
URL: http://svn.digium.com/svn-view/asterisk?view=rev&rev=175121
Log:
Make lock information for ao2_trylock be more useful and gnarly
Core show locks information involving an ao2_trylock did not
show the function that called ao2_trylock, but would instead
show ao2_trylock as the source of the lock. This is not useful
when trying to debug locking issues.
One bizarre note is that this logic is already in 1.4 but somehow
did not get merged to trunk or the 1.6.X branches.
Modified:
trunk/include/asterisk/astobj2.h
trunk/main/astobj2.c
Modified: trunk/include/asterisk/astobj2.h
URL: http://svn.digium.com/svn-view/asterisk/trunk/include/asterisk/astobj2.h?view=diff&rev=175121&r1=175120&r2=175121
==============================================================================
--- trunk/include/asterisk/astobj2.h (original)
+++ trunk/include/asterisk/astobj2.h Thu Feb 12 10:28:06 2009
@@ -478,7 +478,12 @@
* \param a A pointer to the object we want to lock.
* \return 0 on success, other values on error.
*/
+#ifndef DEBUG_THREADS
int ao2_trylock(void *a);
+#else
+#define ao2_trylock(a) _ao2_trylock(a, __FILE__, __PRETTY_FUNCTION__, __LINE__, #a)
+int _ao2_trylock(void *a, const char *file, const char *func, int line, const char *var);
+#endif
/*! \brief
* Return the lock address of an object
Modified: trunk/main/astobj2.c
URL: http://svn.digium.com/svn-view/asterisk/trunk/main/astobj2.c?view=diff&rev=175121&r1=175120&r2=175121
==============================================================================
--- trunk/main/astobj2.c (original)
+++ trunk/main/astobj2.c Thu Feb 12 10:28:06 2009
@@ -188,14 +188,23 @@
#endif
}
+#ifndef DEBUG_THREADS
int ao2_trylock(void *user_data)
+#else
+int _ao2_trylock(void *user_data, const char *file, const char *func, int line, const char *var)
+#endif
{
struct astobj2 *p = INTERNAL_OBJ(user_data);
int ret;
if (p == NULL)
return -1;
- ret = ast_mutex_trylock(&p->priv_data.lock);
+#ifndef DEBUG_THREADS
+ ret = ast_mutex_trylock(&p->priv_data.lock);
+#else
+ ret = __ast_pthread_mutex_trylock(file, line, func, var, &p->priv_data.lock);
+#endif
+
#ifdef AO2_DEBUG
if (!ret)
ast_atomic_fetchadd_int(&ao2.total_locked, 1);
More information about the svn-commits
mailing list