Hi, you patch looks good but please fix indentation...
Index: gateway/gw/smsc/smsc_at.c =================================================================== RCS file: /home/cvs/gateway/gw/smsc/smsc_at.c,v retrieving revision 1.29 diff -u -b -B -u -r1.29 smsc_at.c --- gateway/gw/smsc/smsc_at.c 24 Apr 2006 21:32:01 -0000 1.29 +++ gateway/gw/smsc/smsc_at.c 9 May 2006 12:03:22 -0000 @@ -2649,13 +2649,20 @@ ); /* grab the digits from the MSISDN and encode as swapped semi-octets */ - while (octstr_len(temp)) { + while ((out)&&(octstr_len(temp))) { kill extra '()' and put space between checks, while (out !+ NULL && ...) int digit1, digit2; /* get the first two digit */ digit1 = octstr_get_char(temp,0) - 48; - if ((digit2 = octstr_get_char(temp,1) - 48) < 0) + digit2 = octstr_get_char(temp,1) - '0'; + if (digit2 < 0) digit2 = 0x0F; + if((digit1>=0)&&(digit1<16)&&(digit2<16)) { ditto octstr_append_char(out, (digit2 << 4) | digit1); if you at it, please kill tab and replace with spaces + } + else { + O_DESTROY(out); + out = NULL; + } octstr_delete(temp, 0, 2); ditto } Andrija Petrovic wrote: > smsc_at does not check the digits of the address field in the function > at2_format_address_field > So, if the recipient's address contains a non-numeric string (e.g. 'Info > Service'), and that's quite possible, > the octstr assertion crashes the bearerbox during octstr_append_char. > > Added sanity check on digits before calling the octstr_append_char. > > cheers, > Andrija -- Thanks, Alex