comparison src/g23m-aci/aci/ati_prs.c @ 1:d393cd9bb723

src/g23m-*: initial import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 04:40:46 +0000
parents
children
comparison
equal deleted inserted replaced
0:b6a5e36de839 1:d393cd9bb723
1 /*
2 +-----------------------------------------------------------------------------
3 | Project : GSM-F&D (8411)
4 | Modul : ATI
5 +-----------------------------------------------------------------------------
6 | Copyright 2002 Texas Instruments Berlin, AG
7 | All rights reserved.
8 |
9 | This file is confidential and a trade secret of Texas
10 | Instruments Berlin, AG
11 | The receipt of or possession of this file does not convey
12 | any rights to reproduce or disclose its contents or to
13 | manufacture, use, or sell anything it may describe, in
14 | whole, or in part, without the specific written consent of
15 | Texas Instruments Berlin, AG.
16 +-----------------------------------------------------------------------------
17 | Purpose : AT Command parameter parser
18 +-----------------------------------------------------------------------------
19 */
20
21 #ifndef ATI_PRS_C
22 #define ATI_PRS_C
23
24 #include "aci_all.h"
25
26 #include <stdio.h>
27 #include <stdarg.h>
28 #include <ctype.h>
29
30 #include "aci_cmh.h"
31 #include "ati_cmd.h"
32 #include "aci_cmd.h"
33 #include "aci_prs.h"
34
35 #ifdef GPRS
36 #include "gaci_cmh.h"
37 #endif /* GPRS */
38
39 #include "aci_lst.h"
40 #include "ati_int.h"
41
42 #ifdef OPTION_RELATIVE
43 LOCAL ULONG offset;
44 #endif
45
46 static UBYTE parse_index = 0;
47 /*
48 +--------------------------------------------------------------------+
49 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
50 | STATE : code ROUTINE : parseBin |
51 +--------------------------------------------------------------------+
52
53 PURPOSE : parse binary value
54
55 */
56
57 GLOBAL char *parseBin (int digits, char *b, SHORT *i)
58 {
59 int found = 0;
60
61 *i = 0;
62 while (digits-- AND *b >= '0' AND *b <= '1')
63 {
64 found++;
65 *i *= 2;
66 *i += *b - '0';
67 b++;
68 }
69
70 return ((found) ? b : 0);
71 }
72
73
74 /*
75 +--------------------------------------------------------------------+
76 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
77 | STATE : code ROUTINE : parseHex |
78 +--------------------------------------------------------------------+
79
80 PURPOSE : parse hexadecimal value
81
82 */
83
84 GLOBAL char *parseHex (int digits, char *b, UBYTE *i)
85 {
86 int found = 0;
87
88 *i = 0;
89 while (digits-- AND ((*b >= '0' AND *b <= '9') OR
90 (*b >= 'a' AND *b <= 'f') OR
91 (*b >= 'A' AND *b <= 'F')))
92 {
93 found++;
94 *i *= 16;
95 if (*b >= '0' AND *b <= '9')
96 *i += *b - '0';
97 if (*b >= 'a' AND *b <= 'f')
98 *i += *b - 'a' + 10;
99 if (*b >= 'A' AND *b <= 'F')
100 *i += *b - 'A' + 10;
101 b++;
102 }
103
104 return ((found AND found <= 2) ? b : 0);
105 }
106
107 /*
108 +--------------------------------------------------------------------+
109 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
110 | STATE : code ROUTINE : parseHexToLong |
111 +--------------------------------------------------------------------+
112
113 PURPOSE : parse hexadecimal value
114
115 */
116
117 GLOBAL char *parseHexToLong (int digits, char *b, LONG *i)
118 {
119 *i = 0;
120 while (digits-- AND ((*b >= '0' AND *b <= '9') OR
121 (*b >= 'a' AND *b <= 'f') OR
122 (*b >= 'A' AND *b <= 'F')))
123 {
124 *i *= 16;
125 if (*b >= '0' AND *b <= '9')
126 *i += *b - '0';
127 if (*b >= 'a' AND *b <= 'f')
128 *i += *b - 'a' + 10;
129 if (*b >= 'A' AND *b <= 'F')
130 *i += *b - 'A' + 10;
131 b++;
132 }
133
134 return ( digits EQ 0 ? 0 : b );
135 }
136
137 /*
138 +--------------------------------------------------------------------+
139 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
140 | STATE : code ROUTINE : parseEnum |
141 +--------------------------------------------------------------------+
142
143 PURPOSE : parse enum value
144
145 */
146
147 GLOBAL char *parseEnum (int digits, char *b, int *i)
148 {
149 int found = 0;
150
151 *i = 0;
152 while (digits-- AND *b >= '0' AND *b <= '9')
153 {
154 found++;
155 *i *= 10;
156 *i += *b - '0';
157 b++;
158 }
159
160 return ((found) ? b : 0);
161 }
162
163 /*
164 +--------------------------------------------------------------------+
165 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
166 | STATE : code ROUTINE : parseShort |
167 +--------------------------------------------------------------------+
168
169 PURPOSE : parse Short value
170
171 */
172
173 GLOBAL char *parseShort (int digits, char *b, SHORT *i)
174 {
175 int found = 0;
176
177 *i = 0;
178 while (digits-- AND *b >= '0' AND *b <= '9')
179 {
180 found++;
181 *i *= 10;
182 *i += *b - '0';
183 b++;
184 }
185
186 return ((found) ? b : 0);
187 }
188
189 /*
190 +--------------------------------------------------------------------+
191 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
192 | STATE : code ROUTINE : parseStr |
193 +--------------------------------------------------------------------+
194
195 PURPOSE : parse string value
196
197 */
198
199 GLOBAL char *parseStr (int digits, char *b, char *s)
200 {
201 int found = 0;
202
203 *s = 0;
204 if (*b NEQ '"')
205 return 0;
206 b++;
207 while (digits-- AND *b AND *b >= 0x20)
208 {
209 found++;
210 if (*b EQ '"')
211 {
212 *s = 0;
213 b++;
214 break;
215 }
216 if (*b EQ '\\')
217 {
218 b = parseHex(2,b+1,(UBYTE *) s); /* ES!! ZERO ? */
219 if (!b)
220 return 0;
221 s++;
222 }
223 else
224 *s++ = *b++;
225 }
226 if(*(b-1) NEQ '"')
227 return 0;
228 *s = 0; /* zero terminated */
229
230 return ((found) ? b : 0);
231 }
232
233 /*
234 +--------------------------------------------------------------------+
235 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
236 | STATE : code ROUTINE : parseZStr |
237 +--------------------------------------------------------------------+
238
239 PURPOSE : parse string value
240
241 */
242
243 GLOBAL char *parseZStr (int digits, char *b, char *s)
244 {
245 int found = 0;
246
247 *s = 0;
248 if (*b NEQ '"')
249 return 0;
250 b++;
251 while (digits--)
252 {
253 found++;
254 if (*b EQ '"')
255 {
256 *s = 0;
257 b++;
258 break;
259 }
260 if (*b EQ '\\')
261 {
262 b = parseHex(2,b+1,(UBYTE *) s); /* ES!! ZERO ? */
263 if (!b)
264 return 0;
265 s++;
266 }
267 else
268 *s++ = *b++;
269 }
270 if(*(b-1) NEQ '"')
271 return 0;
272 *s = 0; /* zero terminated */
273
274 return ((found) ? b : 0);
275 }
276
277 /*
278 +--------------------------------------------------------------------+
279 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
280 | STATE : code ROUTINE : parseNStr |
281 +--------------------------------------------------------------------+
282
283 PURPOSE : parse string value and if not numeric returns error
284
285 */
286
287 GLOBAL char *parseNStr (int digits, char *b, char *s)
288 {
289 int found = 0;
290
291 *s = 0;
292 if (*b NEQ '"')
293 return 0;
294 b++;
295 while (digits-- AND *b AND *b >= 0x20)
296 {
297 found++;
298 if (*b EQ '"')
299 {
300 *s = 0;
301 b++;
302 break;
303 }
304 if (*b EQ '\\')
305 {
306 b = parseHex(2,b+1,(UBYTE *) s); /* ES!! ZERO ? */
307 if (!b)
308 return 0;
309 s++;
310 }
311 if ( *b > '9' OR *b < '0') return 0; /*check if numeric value*/
312 else
313 *s++ = *b++;
314 }
315 if(*(b-1) NEQ '"')
316 return 0;
317 *s = 0; /* zero terminated */
318
319 return ((found) ? b : 0);
320 }
321
322 /*
323 +--------------------------------------------------------------------+
324 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
325 | STATE : code ROUTINE : parseASCII |
326 +--------------------------------------------------------------------+
327
328 PURPOSE : parse ASCII value
329
330 */
331
332 GLOBAL char *parseASCII (int digits, char *b, char *i)
333 {
334 int found = 0;
335
336 *i = 0;
337 while (digits-- AND *b NEQ ' ' AND *b NEQ ',' AND *b NEQ ';' )
338 {
339 found++;
340 *i = *b;
341 i++;
342 b++;
343 }
344
345 return ((found) ? b : 0);
346 }
347
348 /*
349 +--------------------------------------------------------------------+
350 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
351 | STATE : code ROUTINE : parseQASCII |
352 +--------------------------------------------------------------------+
353
354 PURPOSE : parse ASCII value and terminate with 0
355
356 */
357
358 GLOBAL char *parseQASCII (int digits, char *b, char *i)
359 {
360 int found = 0;
361
362 *i = 0;
363 while (digits-- AND *b NEQ ',' AND *b NEQ ';' AND *b NEQ '\0')
364 {
365 found++;
366 *i = *b;
367 i++;
368 b++;
369 }
370
371 if (found)
372 {
373 *i = 0;
374 return (b);
375 }
376
377 return (NULL);
378 }
379
380
381 /*
382 +--------------------------------------------------------------------+
383 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
384 | STATE : code ROUTINE : parseStrLen |
385 +--------------------------------------------------------------------+
386
387 PURPOSE : parse sting, return length and startpoint
388
389 */
390
391 GLOBAL char *parseStrLen (USHORT *len, char *b, char **p)
392 {
393 *len = 0;
394 if( *b EQ '"' )
395 b++;
396
397 /* Check if the string is a null string like "" */
398 if( *b EQ '"' )
399 {
400 b++;
401
402 /* return new buffer position without setting p, thereby omitting the parameter */
403 return b;
404 }
405
406 *p = b;
407
408 while ( *b NEQ '\0' AND *b NEQ ',' AND *b NEQ ';' AND *b NEQ '"' )
409 {
410 (*len)++;
411 b++;
412 }
413
414 if(*b EQ '"')
415 {
416 b++;
417 }
418
419 return ((*len) ? b : 0);
420 }
421
422
423 #ifdef GPRS
424
425 /*
426 +--------------------------------------------------------------------+
427 | PROJECT : UMTS MODULE : ACI_PRS |
428 | STATE : devellopment ROUTINE : parseExpo |
429 +--------------------------------------------------------------------+
430
431 PURPOSE : parse exponential expresion (ex. 2E3)
432
433 */
434
435 GLOBAL char *parseExpo( int digits, char *b, T_PS_ber *e )
436 {
437 BOOL valid = FALSE;
438
439 e->ratio_mant = 0;
440 e->ratio_exp = 0;
441 if( *b EQ '"' ) /* start of string */
442 {
443 b++;
444 while( digits-- AND *b >= '0' AND *b <= '9' )
445 {
446 e->ratio_mant *= 10;
447 e->ratio_mant += *b - '0';
448 b++;
449 }
450 if( *b EQ 'E' )
451 {
452 b++;
453 while( digits-- AND *b >= '0' AND *b <= '9' )
454 {
455 e->ratio_exp *= 10;
456 e->ratio_exp += *b - '0';
457 b++;
458 valid = TRUE;
459 }
460
461 if( *b EQ '"' ) /* end of string */
462 {
463 b++;
464 }
465 else
466 {
467 valid = FALSE;
468 }
469
470 }
471 else
472 {
473 valid = FALSE;
474 }
475 }
476 else
477 {
478 valid = FALSE;
479 }
480
481 return ((valid) ? b : 0);
482
483 } /* END parseExpo(...) */
484
485 /*
486 +--------------------------------------------------------------------+
487 | PROJECT : UMTS MODULE : ACI_PRS |
488 | STATE : Finished ROUTINE : parseCid_list |
489 +--------------------------------------------------------------------+
490
491 PURPOSE : Parse a list of Cids. If the parsing is sucessfull the
492 number of parsed cids is returned otherwise -1 is returned.
493
494 */
495 GLOBAL char *parseCid_list(char *b, U8 *cid_list_length, U8 *cid_list)
496 {
497 U8 no_of_cids;
498 char *end;
499
500 /* Parse all cids into the cid_list */
501 no_of_cids = 0;
502 do
503 {
504
505 /* If it's not the first cid remove the "," */
506 if( no_of_cids )
507 b++;
508
509 /* Set the entry to omitted. */
510 cid_list[no_of_cids] = PDP_CONTEXT_CID_OMITTED;
511
512 /* Parse the value */
513 cid_list[no_of_cids] = (U8) strtol( b, &end, 10 );
514 b = end;
515
516 /* If a cid is omitted no cids must be specified at all. */
517 if( cid_list[no_of_cids] EQ PDP_CONTEXT_CID_OMITTED )
518 {
519 if( no_of_cids NEQ 0 )
520 {
521 /* Don't accept omitted cids inside if it's not the first (ex. 1,,2,3 is not allowed). */
522 cmdCmeError( CME_ERR_OpNotSupp );
523 return( NULL );
524 }
525 /* Break the while */
526 break;
527 }
528 if( (!b) OR
529 (cid_list[no_of_cids] < PDP_CONTEXT_CID_MIN) OR
530 (cid_list[no_of_cids] > PDP_CONTEXT_CID_MAX) OR
531 (no_of_cids >= PDP_CONTEXT_CID_MAX) )
532 {
533 cmdCmeError( CME_ERR_OpNotSupp );
534 return( NULL );
535 }
536 no_of_cids++;
537 }
538
539 while( *b EQ ',' AND
540 no_of_cids < *cid_list_length );
541
542 cid_list[no_of_cids+1] = PDP_CONTEXT_CID_INVALID;
543
544 *cid_list_length = no_of_cids;
545 return( b );
546
547 }
548
549 #endif /* GPRS */
550
551 /*
552 +----------------------------------------------------------------------+
553 | PROJECT : UMTS MODULE : ATI_PRS |
554 | STATE : - ROUTINE : parsePointerToString |
555 -----------------------------------------------------------------------+
556
557 PURPOSE : Parse pointer to input string. returns pointer to end of string.
558
559 */
560 GLOBAL char *parsePointerToString(char chars, char *b, char **p_begin)
561 {
562 if( b AND *b EQ '"' )
563 {
564 b++;
565 *p_begin = b;
566
567 while (chars-- AND *b AND *b NEQ '"')
568 {
569 b++;
570 }
571 if( *b EQ '"' )
572 {
573 b++;
574 }
575 else
576 {
577 if( !chars )
578 {
579 b = NULL;
580 }
581 }
582 }
583
584 return b;
585 }
586
587 /*
588 +----------------------------------------------------------------------+
589 | PROJECT : UMTS MODULE : ATI_PRS |
590 | STATE : - ROUTINE : StrToU16 |
591 -----------------------------------------------------------------------+
592
593 PURPOSE : Parse string value to U16.
594
595 */
596
597 char *StrToU16(char *p_str, U16 *p_result)
598 {
599 U32 val = 0;
600
601 if( p_str )
602 {
603 if( *p_str >= '0' AND *p_str <= '9' )
604 {
605 while( *p_str >= '0' AND *p_str <= '9' )
606 {
607 val *= 10;
608 val += (int)(*p_str - '0');
609 p_str++;
610 }
611 }
612 }
613
614 if( val <= 0xffff ) /* 0xffff = max value of U16 */
615 *p_result = (U16)(val);
616 else
617 p_str = NULL;
618
619 return p_str;
620
621 }
622
623 /*
624 +---------------------------------------------------------------------+
625 | PROJECT : UMTS MODULE : ATI_PRS |
626 | STATE : - ROUTINE : parseDSNP_U16 |
627 ----------------------------------------------------------------------+
628
629 PURPOSE : parse dot-separated numeric parameters from the
630 input string to an array of U8.
631
632 ex. input p_in = "192.124.13.3"
633 output p_out = {192,124,13,3}
634
635 */
636 GLOBAL char *parseDSNP_U16( char blocks, char *p_in, U16 *p_out )
637 {
638 if( p_in AND p_out )
639 {
640 if( *p_in EQ '.' ) p_in++;
641 while( blocks-- AND *p_in NEQ 0x00 )
642 {
643 p_in = StrToU16(p_in, p_out);
644
645 if( p_in AND blocks AND *p_in EQ '.' )
646 {
647 p_in++;
648 p_out++;
649 }
650 else
651 break;
652 }
653 }
654 return p_in;
655 }
656
657 /*
658 +---------------------------------------------------------------------+
659 | PROJECT : UMTS MODULE : ATI_PRS |
660 | STATE : - ROUTINE : parseIPv4Address |
661 ----------------------------------------------------------------------+
662 */
663 GLOBAL char *parseIPv4Address(char *p_in, U8 * p_ip_addr, U8 * is_ip_valid)
664 {
665 U16 ip_addr[4];
666 char i;
667 char *p_out = NULL;
668
669 if( p_in AND p_ip_addr )
670 {
671 p_out = parseDSNP_U16(4, p_in, ip_addr);
672 for(i=0; i<4; i++)
673 {
674 if(ip_addr[i] <= 255)
675 {
676 p_ip_addr[i] = (U8) ip_addr[i];
677 }
678 else
679 {
680 p_out = NULL;
681 }
682
683 }
684 }
685 * is_ip_valid = (p_out NEQ NULL);
686
687 return p_out;
688 }
689
690 /*
691 +---------------------------------------------------------------------+
692 | PROJECT : UMTS MODULE : ATI_PRS |
693 | STATE : - ROUTINE : parseIPv6Address |
694 ----------------------------------------------------------------------+
695 */
696 GLOBAL char *parseIPv6Address(char *p_in, U8 *p_ip_addr, U8 * is_ip_valid)
697 {
698 U16 ip_addr[16];
699 char i;
700 char *p_out = NULL;
701
702 if( p_in AND p_ip_addr )
703 {
704 p_out = parseDSNP_U16(16, p_in, ip_addr);
705 for(i=0; i<16; i++)
706 {
707 if(ip_addr[i] > 255)
708 p_out = NULL;
709 else
710 p_ip_addr[i] = (U8) ip_addr[i];
711 }
712 }
713
714 * is_ip_valid = (p_out NEQ NULL);
715
716 return p_out;
717 }
718
719 /*
720 +--------------------------------------------------------------------+
721 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
722 | STATE : code ROUTINE : parse |
723 +--------------------------------------------------------------------+
724
725 PURPOSE : parse AT command parameter
726
727 */
728
729 GLOBAL char *parse (char *b, char *f, ...)
730 {
731 char fc;
732 USHORT *i;
733
734 #ifdef GPRS
735 U8 *j;
736 #endif /* GPRS */
737 LONG digits = -1;
738 BOOL value_is_valid;
739 /*lint -e516 -e10*/
740 va_list varpars;
741
742 va_start (varpars, f); /* Initialize variable arguments. */
743
744 parse_index=0;
745 while ((fc = *f++) NEQ 0)
746 {
747 parse_index++; /* Save the position of current parsing item */
748 value_is_valid = TRUE;
749 if (islower(fc))
750 {
751 if (*b EQ 0 OR *b EQ ';')
752 {
753 va_end (varpars); /* Reset variable arguments. */
754 return b;
755 }
756 if (*b EQ ',')
757 {
758 b++;
759 value_is_valid = FALSE;
760 }
761 }
762
763 switch (toupper(fc))
764 {
765 case 'B':
766 if (value_is_valid)
767 b = parseBin(-1,b,va_arg (varpars, short*));
768 else
769 (void)va_arg (varpars, short*);
770 break;
771
772 case 'X':
773 if (value_is_valid)
774 b = parseHex(-1,b,va_arg (varpars, unsigned char*));
775 else
776 (void)va_arg (varpars, short*);
777 break;
778
779 case 'Y':
780 if (value_is_valid)
781 b = parseHexToLong(-1,b,va_arg (varpars, long*));
782 else
783 (void)va_arg (varpars, short*);
784 break;
785
786 case 'D':
787 if (value_is_valid)
788 b = parseEnum(-1,b,va_arg (varpars, int*));
789 else
790 (void)va_arg (varpars, int*);
791 break;
792
793 case 'R':
794 if (value_is_valid)
795 b = parseShort(-1,b,va_arg (varpars, short*));
796 else
797 (void)va_arg (varpars, short*);
798 break;
799
800 case 'S':
801 if (value_is_valid)
802 {
803 digits=va_arg (varpars, long);
804 b = parseStr(digits,b,va_arg (varpars, char*));
805 }
806 else
807 {
808 (void)va_arg (varpars, long);
809 (void)va_arg (varpars, char*);
810 }
811 break;
812
813 case 'N':
814 if (value_is_valid)
815 {
816 digits=va_arg (varpars, long);
817 b = parseNStr(digits,b,va_arg (varpars, char*));
818 }
819 else
820 {
821 (void)va_arg (varpars, long);
822 (void)va_arg (varpars, char*);
823 }
824 break;
825
826 case 'Z':
827 if (value_is_valid)
828 {
829 char* c = b;
830 USHORT* plen = NULL;
831
832 char* cmdPtr;
833 USHORT cmdLen;
834
835 digits = va_arg ( varpars, long );
836 cmdLen = va_arg ( varpars, unsigned );
837 cmdPtr = va_arg ( varpars, char* );
838 plen = va_arg ( varpars, unsigned short*);
839 b = parseZStr
840 ( MINIMUM (digits, cmdLen - ( b - cmdPtr )),
841 b, va_arg ( varpars, char* ) );
842
843 if ( plen NEQ NULL )
844 {
845 if ( b NEQ NULL )
846 *plen = b - c - 2; /* a string always includes two characters '"' */
847 else
848 *plen = 0;
849 }
850 }
851 else
852 {
853 (void)va_arg (varpars, long);
854 (void)va_arg (varpars, unsigned short*);
855 (void)va_arg (varpars, char*);
856 }
857 break;
858
859 case 'A':
860 if (value_is_valid)
861 {
862 digits=va_arg (varpars, long);
863 b = parseASCII(digits,b,va_arg (varpars, char*));
864 }
865 else
866 {
867 (void)va_arg (varpars, long);
868 (void)va_arg (varpars, char*);
869 }
870 break;
871
872 case 'Q':
873 if (value_is_valid)
874 {
875 digits=va_arg (varpars, long);
876 b = parseQASCII(digits,b,va_arg (varpars, char*));
877 }
878 else
879 {
880 (void)va_arg (varpars, long);
881 (void)va_arg (varpars, char*);
882 }
883 break;
884
885 case 'L':
886 if (value_is_valid)
887 {
888 i = va_arg(varpars, unsigned short*);
889 b = parseStrLen (i,b,va_arg(varpars, char**));
890 }
891 else
892 {
893 (void)va_arg (varpars, int*);
894 (void)va_arg (varpars, char**);
895 }
896 break;
897
898 #ifdef GPRS
899
900 case 'E':
901 if (value_is_valid)
902 {/*lint -e78 -e26 -e530*/
903 b = parseExpo( -1, b, va_arg(varpars, T_PS_ber*));
904 }
905 else
906 {
907 (void)va_arg (varpars, T_PS_ber*);
908 }
909 break;
910
911 #endif
912
913 case 'C':
914 if (value_is_valid)
915 {
916 b = parseByte( -1, b, va_arg(varpars, unsigned char*));
917 }
918 else
919 {
920 (void)va_arg (varpars, unsigned char*);
921 }
922 break;
923
924 #ifdef GPRS
925
926 case 'I': /* Parse cid_list */
927 if( value_is_valid )
928 {
929 j = va_arg(varpars, unsigned char*);
930
931 b = parseCid_list( b, j, va_arg(varpars, unsigned char*) );
932 }
933 break;
934 #endif /* GPRS */
935
936 case 'P': /* Parse pointer to string */
937 if( value_is_valid )
938 {
939 b = parsePointerToString( (char)-1, b, va_arg(varpars, char**) );
940 }
941 break;
942
943 case '*': /* Parse '*' */
944 if( value_is_valid )
945 {
946 if( *b NEQ '*' )
947 {
948 return 0;
949 }
950 b++;
951 }
952 break;
953
954 case '#': /* Parse '#' */
955 if( value_is_valid )
956 {
957 if( *b NEQ '#' )
958 {
959 return 0;
960 }
961 b++;
962 }
963 break;
964 }
965 if (!b)
966 {
967 va_end (varpars); /* Reset variable arguments. */
968 return 0;
969 }
970
971 if (*f AND *b EQ ',' AND value_is_valid)
972 {
973 b++;
974 }
975 else if (*b AND *b NEQ ';' AND *b NEQ ',' AND value_is_valid) /* if comma or semicolon is missing */
976 {
977 TRACE_EVENT ("missing separator detected, aborting parse!");
978 va_end (varpars);
979 return 0;
980 }
981 }
982 if (*b AND *b NEQ ';')
983 {
984 va_end (varpars); /* Reset variable arguments. */
985 return 0;
986 }
987 va_end (varpars); /* Reset variable arguments. */
988 /*lint +e516 +e10*/
989 return b;
990 }
991
992
993 /*
994 +--------------------------------------------------------------------+
995 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
996 | STATE : code ROUTINE : parse |
997 +--------------------------------------------------------------------+
998
999 PURPOSE : get last parsed index (to determinate which component was malicious)
1000
1001 */
1002
1003 GLOBAL UBYTE get_parse_index ()
1004 {
1005 return parse_index;
1006 }
1007
1008 /*
1009 +--------------------------------------------------------------------+
1010 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
1011 | STATE : code ROUTINE : parseByte(U8) |
1012 +--------------------------------------------------------------------+
1013
1014 PURPOSE : parse U8 value
1015
1016 */
1017
1018 GLOBAL char *parseByte (int digits, char *b, U8 *i)
1019 {
1020 int found = 0;
1021
1022 *i = 0;
1023 while (digits-- AND *b >= '0' AND *b <= '9')
1024 {
1025 found++;
1026 *i *= 10;
1027 *i += *b - '0';
1028 b++;
1029 }
1030
1031 return ((found) ? b : 0);
1032 }
1033
1034 /*
1035 +--------------------------------------------------------------------+
1036 | PROJECT : GSM-F&D (8411) MODULE : ACI_PRS |
1037 | STATE : code ROUTINE : parseTimeStamp |
1038 +--------------------------------------------------------------------+
1039
1040 PURPOSE : Parse time stamp format in "yy/MM/dd,hh:mm:ss±zz"
1041
1042 */
1043
1044 GLOBAL UBYTE parseTimeStamp( char *p_in,U8 *years,U8 *months,U8 *days,
1045 U8 *hrs, U8 *mins,U8 *secs, char *sign, U8 *time_zone )
1046 {
1047 if( p_in[2] NEQ '/' OR p_in[5] NEQ '/' OR p_in[8] NEQ ',' OR p_in[11] NEQ ':' OR p_in[14] NEQ ':' )
1048 {
1049 return NO_TIME_STAMP_FIELD;
1050 }
1051 if(!parseByte (2, &p_in[0], years))
1052 {
1053 return NO_TIME_STAMP_FIELD;
1054 }
1055 if(!parseByte (2, &p_in[3], months))
1056 {
1057 return NO_TIME_STAMP_FIELD;
1058 }
1059 if(!parseByte (2, &p_in[6], days))
1060 {
1061 return NO_TIME_STAMP_FIELD;
1062 }
1063 if(!parseByte (2, &p_in[9], hrs))
1064 {
1065 return NO_TIME_STAMP_FIELD;
1066 }
1067 if(!parseByte (2, &p_in[12], mins))
1068 {
1069 return NO_TIME_STAMP_FIELD;
1070 }
1071 if(!parseByte (2, &p_in[15], secs))
1072 {
1073 return NO_TIME_STAMP_FIELD;
1074 }
1075 *sign = p_in[17];
1076
1077 if(*sign NEQ '+' AND *sign NEQ '-' )
1078 {
1079 return NO_TIME_STAMP_FIELD;
1080 }
1081 if(!parseByte (2, &p_in[18], time_zone))
1082 {
1083 return NO_TIME_STAMP_FIELD;
1084 }
1085
1086 return MAX_TIME_STAMP_FIELDS;
1087 }
1088
1089 #endif /* ATI_PRS_C */