[asterisk-commits] sgriepentrog: branch 1.8 r403853 - /branches/1.8/apps/app_sms.c

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Mon Dec 16 09:18:59 CST 2013


Author: sgriepentrog
Date: Mon Dec 16 09:18:56 2013
New Revision: 403853

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=403853
Log:
app_sms: BufferOverflow when receiving odd length 16 bit message

This patch prevents an infinite loop overwriting memory when
a message is received into the unpacksms16() function, where
the length of the message is an odd number of bytes.

(closes issue ASTERISK-22590)
Reported by: Jan Juergens
Tested by: Jan Juergens


Modified:
    branches/1.8/apps/app_sms.c

Modified: branches/1.8/apps/app_sms.c
URL: http://svnview.digium.com/svn/asterisk/branches/1.8/apps/app_sms.c?view=diff&rev=403853&r1=403852&r2=403853
==============================================================================
--- branches/1.8/apps/app_sms.c (original)
+++ branches/1.8/apps/app_sms.c Mon Dec 16 09:18:56 2013
@@ -696,7 +696,7 @@
 	}
 	while (l--) {
 		int v = *i++;
-		if (l--) {
+		if (l && l--) {
 			v = (v << 8) + *i++;
 		}
 		*o++ = v;
@@ -714,6 +714,7 @@
 	} else if (is8bit(dcs)) {
 		unpacksms8(i, l, udh, udhl, ud, udl, udhi);
 	} else {
+		l += l % 2;
 		unpacksms16(i, l, udh, udhl, ud, udl, udhi);
 	}
 	return l + 1;




More information about the asterisk-commits mailing list