comparison gsm-fw/g23m-aci/aci/plmn_decoder.c @ 775:eedbf248bac0

gsm-fw/g23m-aci subtree: initial import from LoCosto source
author Michael Spacefalcon <msokolov@ivan.Harhan.ORG>
date Sun, 12 Oct 2014 01:45:14 +0000
parents
children
comparison
equal deleted inserted replaced
774:40a721fd9854 775:eedbf248bac0
1 /* plmn_decoder.cpp : Defines the entry point for the console application. */
2
3 #include <assert.h>
4 #include <stdio.h>
5 #include <stddef.h>
6 #include <stdlib.h>
7 #include <string.h>
8
9 #ifdef TI_PS_OP_OPN_TAB_ROMBASED
10 #ifndef CMH_PLMN_DECODER_C
11 #define CMH_PLMN_DECODER_C
12 #endif
13
14 #include "aci_all.h"
15
16 /*==== INCLUDES ===================================================*/
17
18 #include "aci_cmh.h"
19 #include "ati_cmd.h"
20 #include "aci_cmd.h"
21 #include "aci_mem.h"
22 #include "pcm.h"
23
24 #ifdef TI_PS_OP_OPN_TAB_ROMBASED
25 #include "rom_tables.h"
26 #endif /* TI_PS_OP_OPN_TAB_ROMBASED */
27
28
29 #ifdef FAX_AND_DATA
30 #include "aci_fd.h"
31 #endif /* of #ifdef FAX_AND_DATA */
32
33 #include "aci.h"
34 #include "psa.h"
35 #include "psa_mm.h"
36 #include "psa_sim.h"
37 #include "psa_util.h"
38 #include "cmh.h"
39
40
41
42 #define PLMN_LONGNAME_LOOKUP 0xff
43
44 EXTERN void cmhSIM_getMncMccFrmPLMNsel( const UBYTE* ntry,
45 SHORT* mcc,
46 SHORT* mnc );
47
48 /* NHK:
49 * Once the tables plmn_compressed, plmn_dict_offset and plmn_dict go to ROM, their names below should match corresponding ROM addresses
50 * KSR: Moved to g23m\condat\com\src\drivers\rom_tables.c
51 */
52
53 /*
54 +----------------------------------------------------------------------------+
55 | PROJECT : GSM-PS (6147) MODULE : MM_MM |
56 | STATE : code ROUTINE : cmhMM_CompLongLength |
57 +----------------------------------------------------------------------------+
58
59 PURPOSE : This function gets the compressed length of the longName
60 from a compressed PLMN entry.
61
62 */
63 LOCAL USHORT cmhMM_CompLongLength (const UBYTE *plmn_comp_entry)
64 {
65 UBYTE length_byte;
66
67 length_byte = *(plmn_comp_entry + 3);
68
69 return ((length_byte >> 3) & 0x1f) + 1;
70 }
71
72 /*
73 +----------------------------------------------------------------------------+
74 | PROJECT : GSM-PS (6147) MODULE : MM_MM |
75 | STATE : code ROUTINE : cmhMM_CompShrtLength |
76 +----------------------------------------------------------------------------+
77
78 PURPOSE : This function gets the compressed length of the shrtName
79 from a compressed PLMN entry.
80
81 */
82 LOCAL USHORT cmhMM_CompShrtLength (const UBYTE *plmn_comp_entry)
83 {
84 UBYTE length_byte;
85
86 length_byte = *(plmn_comp_entry + 3);
87
88 return ((length_byte ) & 0x07) + 1;
89 }
90
91
92 /*
93 +----------------------------------------------------------------------------+
94 | PROJECT : GSM-PS (6147) MODULE : MM_MM |
95 | STATE : code ROUTINE : cmhMM_PlmnEntryLength |
96 +----------------------------------------------------------------------------+
97
98 PURPOSE : This function gets the length of a compressed PLMN entry.
99
100 */
101 GLOBAL USHORT cmhMM_PlmnEntryLength (const UBYTE *plmn_comp_entry)
102 {
103 return (4 + cmhMM_CompLongLength (plmn_comp_entry)
104 + cmhMM_CompShrtLength (plmn_comp_entry));
105 }
106
107
108 /*
109 +----------------------------------------------------------------------------+
110 | PROJECT : GSM-PS (6147) MODULE : MM_MM |
111 | STATE : code ROUTINE : cmhMM_Decompress |
112 +----------------------------------------------------------------------------+
113
114 PURPOSE : This function decompresses a compressed string.
115 If the decompressed string is the long PLMN name the longName
116 parameter is NULL, when the decompressed string is the short
117 PLMN name the longName parameter is the previously decompressed
118 PLMN long name, as in some cases the short PLMN name consists of
119 parts of the long PLMN name lookups within the decompressed long
120 name will be done when advised to do so by the compressed byte
121 string.
122 On success the function returns with zero, on detection of an
123 internal error a negative value is returned.
124
125 */
126 LOCAL SHORT cmhMM_Decompress (char *decomp_string,
127 const char *longName,
128 const UBYTE *comp_string,
129 USHORT comp_length)
130 {
131 USHORT offset;
132 USHORT length;
133
134 while (comp_length > 0)
135 {
136 if (*comp_string < 128)
137 {
138 /* GSM default alphabet. Take character 1:1 */
139 *decomp_string = *comp_string;
140 decomp_string++;
141 }
142 else if (*comp_string EQ PLMN_LONGNAME_LOOKUP)
143 {
144 if ((longName EQ NULL) OR (comp_length <= 1))
145 {
146 TRACE_ERROR ("Cannot process longName lookup");
147 return -1;
148 }
149
150 /* Decoding short name. Lookup into long name */
151
152 /* Skip PLMN_LONGNAME_LOOKUP */
153 comp_string++;
154 comp_length--;
155
156 /* Get offset and length of substring in long name */
157 offset = (*comp_string >> 3) & 0x1f;
158 length = (*comp_string & 0x07) + 1;
159 memcpy (decomp_string, longName + offset, length);
160 decomp_string += length;
161 }
162 else
163 {
164 /* Dictionary lookup */
165
166 /* Get offset of dictionary entry */
167 offset = *(ptr_plmn_dict_offset + (*comp_string - 128));
168
169 /* Get length of dictionary entry */
170 length = *(ptr_plmn_dict_offset + (*comp_string - 128 + 1)) - offset;
171 memcpy (decomp_string, ptr_plmn_dict + offset, length);
172 decomp_string += length;
173 }
174 comp_string++;
175 comp_length--;
176 }
177 decomp_string = '\0';
178 return 0;
179 }
180
181
182 /*
183 +----------------------------------------------------------------------------+
184 | PROJECT : GSM-PS (6147) MODULE : MM_MM |
185 | STATE : code ROUTINE : cmhMM_decodePlmn |
186 +----------------------------------------------------------------------------+
187
188 PURPOSE : This function decodes a compressed PLMN entry into a decompressed
189 T_OPER_ENTRY structure. On success this function returns with
190 zero, if during decompression an internal error is detected the
191 function returns with a negative value.
192
193 */
194 GLOBAL SHORT cmhMM_decodePlmn (T_OPER_ENTRY *oper, const UBYTE *plmn_comp_entry)
195 {
196 SHORT mcc; /* Mobile Country Code */
197 SHORT mnc; /* Mobile Network Code */
198 USHORT comp_Length; /* Compressed string length */
199 SHORT result; /* Decompression result */
200 const UBYTE *comp_ptr; /* Compressed PLMNs pointer */
201
202 memset (oper, 0, sizeof (T_OPER_ENTRY));
203
204 cmhSIM_getMncMccFrmPLMNsel (plmn_comp_entry, &mcc, &mnc);
205 oper->mcc = mcc;
206 oper->mnc = mnc;
207
208 if (mcc EQ -1)
209 return -1; /* Got end of list, not processing further */
210
211 /* Decompress longName */
212 comp_ptr = plmn_comp_entry + 4;
213 comp_Length = cmhMM_CompLongLength (plmn_comp_entry);
214 result = cmhMM_Decompress (oper->longName, NULL,
215 comp_ptr, comp_Length);
216 if (result < 0)
217 return result;
218
219 /* Decompress shrtName */
220 comp_ptr += comp_Length;
221 comp_Length = cmhMM_CompShrtLength (plmn_comp_entry);
222 result = cmhMM_Decompress (oper->shrtName, oper->longName,
223 comp_ptr, comp_Length);
224 return result;
225 }
226
227 #endif