aboutsummaryrefslogtreecommitdiffstats
path: root/channels
diff options
context:
space:
mode:
authoroej <oej@f38db490-d61c-443f-a65b-d21fe96a405b>2006-05-17 19:27:15 +0000
committeroej <oej@f38db490-d61c-443f-a65b-d21fe96a405b>2006-05-17 19:27:15 +0000
commit243a5c2a23cc73345a4f18bebf80760a4f8b4163 (patch)
treec2179297b45c5ed8bea3912198bc8e4fa8040efe /channels
parent8414901dba0d0e67fd7a4bb62a05056d7882eb99 (diff)
Issue #7176 - Crash in expire_register
(We need to find out what's causing peer to be undefined, so this is just a bandaid, not a real fix) git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.2@27927 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_sip.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c
index 7fbbd7d93..6eb47c0c6 100644
--- a/channels/chan_sip.c
+++ b/channels/chan_sip.c
@@ -525,7 +525,7 @@ struct sip_auth {
#define SIP_REALTIME (1 << 11) /*!< Flag for realtime users */
#define SIP_USECLIENTCODE (1 << 12) /*!< Trust X-ClientCode info message */
#define SIP_OUTGOING (1 << 13) /*!< Is this an outgoing call? */
-#define SIP_SELFDESTRUCT (1 << 14)
+#define SIP_SELFDESTRUCT (1 << 14) /*!< This is an autocreated peer */
#define SIP_DYNAMIC (1 << 15) /*!< Is this a dynamic peer? */
/* --- Choices for DTMF support in SIP channel */
#define SIP_DTMF (3 << 16) /*!< three settings, uses two bits */
@@ -5639,17 +5639,24 @@ static void destroy_association(struct sip_peer *peer)
static int expire_register(void *data)
{
struct sip_peer *peer = data;
+
+ if (!peer) /* Hmmm. We have no peer. Weird. */
+ return 0;
memset(&peer->addr, 0, sizeof(peer->addr));
destroy_association(peer);
manager_event(EVENT_FLAG_SYSTEM, "PeerStatus", "Peer: SIP/%s\r\nPeerStatus: Unregistered\r\nCause: Expired\r\n", peer->name);
- register_peer_exten(peer, 0);
+ register_peer_exten(peer, 0); /* Remove regexten */
peer->expire = -1;
ast_device_state_changed("SIP/%s", peer->name);
+
+ /* Do we need to release this peer from memory?
+ Only for realtime peers and autocreated peers
+ */
if (ast_test_flag(peer, SIP_SELFDESTRUCT) || ast_test_flag((&peer->flags_page2), SIP_PAGE2_RTAUTOCLEAR)) {
- peer = ASTOBJ_CONTAINER_UNLINK(&peerl, peer);
+ peer = ASTOBJ_CONTAINER_UNLINK(&peerl, peer); /* Remove from peer list */
ASTOBJ_UNREF(peer, sip_destroy_peer);
}