[asterisk-commits] russell: branch 1.4 r46883 - in /branches/1.4:
./ main/callerid.c
asterisk-commits at lists.digium.com
asterisk-commits at lists.digium.com
Thu Nov 2 07:02:38 MST 2006
Author: russell
Date: Thu Nov 2 08:02:37 2006
New Revision: 46883
URL: http://svn.digium.com/view/asterisk?rev=46883&view=rev
Log:
Add the missing call to free described in issue #8268. Also, add a bunch of
missing calls to free in callerid_feed_jp().
Modified:
branches/1.4/ (props changed)
branches/1.4/main/callerid.c
Propchange: branches/1.4/
------------------------------------------------------------------------------
Binary property 'branch-1.2-merged' - no diff available.
Modified: branches/1.4/main/callerid.c
URL: http://svn.digium.com/view/asterisk/branches/1.4/main/callerid.c?rev=46883&r1=46882&r2=46883&view=diff
==============================================================================
--- branches/1.4/main/callerid.c (original)
+++ branches/1.4/main/callerid.c Thu Nov 2 08:02:37 2006
@@ -300,12 +300,13 @@
buf[x+cid->oldlen/2] = AST_XLAW(ubuf[x]);
while (mylen >= 160) {
- b = b2 = 0 ;
+ b = b2 = 0;
olen = mylen;
res = fsk_serie(&cid->fskd, buf, &mylen, &b);
if (mylen < 0) {
ast_log(LOG_ERROR, "fsk_serie made mylen < 0 (%d)\n", mylen);
+ free(obuf);
return -1;
}
@@ -313,6 +314,7 @@
if (res < 0) {
ast_log(LOG_NOTICE, "fsk_serie failed\n");
+ free(obuf);
return -1;
}
@@ -384,6 +386,7 @@
cid->len = b;
if ( (cid->len+2) >= sizeof( cid->rawdata ) ) {
ast_log(LOG_WARNING, "too long caller id string\n" ) ;
+ free(obuf);
return -1;
}
cid->rawdata[cid->pos++] = b;
@@ -406,6 +409,7 @@
cid->sawflag = 12;
if ( cid->crc != 0 ) {
ast_log(LOG_WARNING, "crc checksum error\n" ) ;
+ free(obuf);
return -1;
}
/* extract caller id data */
@@ -515,6 +519,7 @@
break ;
}
}
+ free(obuf);
return 1;
break;
default:
@@ -563,6 +568,7 @@
buf += (olen - mylen);
if (res < 0) {
ast_log(LOG_NOTICE, "fsk_serie failed\n");
+ free(obuf);
return -1;
}
if (res == 1) {
More information about the asterisk-commits
mailing list