https://origsvn.digium.com/svn/asterisk/branches/1.8
........
r313001 | alecdavis | 2011-04-07 22:19:31 +1200 (Thu, 07 Apr 2011) | 13 lines
Fix ISDN calling subaddr User Specified Odd/Even Flag
Calculation of the Odd/Even flag was wrong.
Implement correct algo, and set odd/even=0 if data would be truncated.
Only allow automatic calculation of the O/E flag, don't let dialplan influence.
(closes issue #19062)
Reported by: festr
Patches:
bug19062.diff2.txt uploaded by alecdavis (license 585)
Tested by: festr, alecdavis, rmudgett
........
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@313005
65c4cc65-6c06-0410-ace0-
fbb531ad65f3
int length = ast_pri_pack_hex_string(pri_subaddress->data,
ast_subaddress->str, sizeof(pri_subaddress->data));
- pri_subaddress->length = length;
- pri_subaddress->odd_even_indicator = (length & 1);
+ pri_subaddress->length = length; /* packed data length */
+
+ length = strlen(ast_subaddress->str);
+ if (length > 2 * sizeof(pri_subaddress->data)) {
+ pri_subaddress->odd_even_indicator = 0;
+ } else {
+ pri_subaddress->odd_even_indicator = (length & 1);
+ }
pri_subaddress->valid = 1;
}
}
s++;
/* prefix */
/* 'n' = NSAP */
- /* 'U' = odd, 'u'= even */
+ /* 'u' = User Specified */
/* Default = NSAP */
switch (*s) {
case 'U':
- dialed_subaddress.odd_even_indicator = 1;
- /* fall through */
case 'u':
s++;
dialed_subaddress.type = 2;