aboutsummaryrefslogtreecommitdiffstats
path: root/channels
diff options
context:
space:
mode:
authorrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2009-03-20 17:09:32 +0000
committerrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2009-03-20 17:09:32 +0000
commit2e66dae356e89e110bf80ff5371312280cf1cb22 (patch)
tree90a0472f6ed2eafb542431db1b95f845a50f99aa /channels
parent801b84b2e90f228ff49c932b2f79255dce0921f6 (diff)
Merged revisions 183560 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ................ r183560 | russell | 2009-03-20 12:00:58 -0500 (Fri, 20 Mar 2009) | 10 lines Merged revisions 183559 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r183559 | russell | 2009-03-20 11:53:25 -0500 (Fri, 20 Mar 2009) | 2 lines Fix a crash in IAX2 registration handling found during load testing with dvossel. ........ ................ git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.2@183564 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_iax2.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c
index bda25b237..b2559a02f 100644
--- a/channels/chan_iax2.c
+++ b/channels/chan_iax2.c
@@ -6682,15 +6682,20 @@ static int register_verify(int callno, struct sockaddr_in *sin, struct iax_ies *
ast_devstate_changed(AST_DEVICE_UNKNOWN, "IAX2/%s", p->name); /* Activate notification */
return_unref:
- ast_string_field_set(iaxs[callno], peer, peer);
- /* Choose lowest expiry number */
- if (expire && (expire < iaxs[callno]->expiry))
- iaxs[callno]->expiry = expire;
+ if (iaxs[callno]) {
+ ast_string_field_set(iaxs[callno], peer, peer);
+
+ /* Choose lowest expiry number */
+ if (expire && (expire < iaxs[callno]->expiry)) {
+ iaxs[callno]->expiry = expire;
+ }
+ }
res = 0;
- if (p)
+ if (p) {
peer_unref(p);
+ }
return res;
}