diff options
author | mmichelson <mmichelson@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-02-12 16:33:24 +0000 |
---|---|---|
committer | mmichelson <mmichelson@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-02-12 16:33:24 +0000 |
commit | cbdacb8c6cbe97eecc8d9e76f5cb9fdeb41ee12c (patch) | |
tree | 7543bc8865015bbb7df550e3c617a37e68fe6cdd /include/asterisk | |
parent | 957e2bd88eb39ccadb31da31886caabefdc3b707 (diff) |
Merged revisions 175121 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk
........
r175121 | mmichelson | 2009-02-12 10:28:06 -0600 (Thu, 12 Feb 2009) | 11 lines
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.
........
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.0@175122 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'include/asterisk')
-rw-r--r-- | include/asterisk/astobj2.h | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/include/asterisk/astobj2.h b/include/asterisk/astobj2.h index 344d15019..540af30ff 100644 --- a/include/asterisk/astobj2.h +++ b/include/asterisk/astobj2.h @@ -211,7 +211,19 @@ int ao2_unlock(void *a); #define ao2_unlock(a) _ao2_unlock(a, __FILE__, __PRETTY_FUNCTION__, __LINE__, #a) int _ao2_unlock(void *a, const char *file, const char *func, int line, const char *var); #endif -int ao2_trylock(void *user_data); + +/*! \brief + * Try locking-- (don't block if fail) + * + * \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 /*! * |