mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-14 22:08:28 +00:00
access channel locks through ast_channel_lock/unlock/trylock and not
through ast_mutex primitives. To detect all occurrences, I have renamed the lock field in struct ast_channel so it is clear that it shouldn't be used directly. There are some uses in res/res_features.c (see details of the diff) that are error prone as they try and lock two channels without caring about the order (or without explaining why it is safe). git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@89293 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -1167,13 +1167,13 @@ AST_INLINE_API(int ast_atomic_dec_and_test(volatile int *p),
|
||||
#ifndef DEBUG_CHANNEL_LOCKS
|
||||
/*! \brief Lock a channel. If DEBUG_CHANNEL_LOCKS is defined
|
||||
in the Makefile, print relevant output for debugging */
|
||||
#define ast_channel_lock(x) ast_mutex_lock(&x->lock)
|
||||
#define ast_channel_lock(x) ast_mutex_lock(&x->lock_dont_use)
|
||||
/*! \brief Unlock a channel. If DEBUG_CHANNEL_LOCKS is defined
|
||||
in the Makefile, print relevant output for debugging */
|
||||
#define ast_channel_unlock(x) ast_mutex_unlock(&x->lock)
|
||||
#define ast_channel_unlock(x) ast_mutex_unlock(&x->lock_dont_use)
|
||||
/*! \brief Try locking a channel. If DEBUG_CHANNEL_LOCKS is defined
|
||||
in the Makefile, print relevant output for debugging */
|
||||
#define ast_channel_trylock(x) ast_mutex_trylock(&x->lock)
|
||||
#define ast_channel_trylock(x) ast_mutex_trylock(&x->lock_dont_use)
|
||||
#else
|
||||
|
||||
struct ast_channel;
|
||||
|
||||
Reference in New Issue
Block a user