FreeCalypso > hg > freecalypso-sw
comparison gsm-fw/L1/cfile/l1_afunc.c @ 544:96a96ec34139
gsm-fw/L1/cfile: initial import from LoCosto source
author | Michael Spacefalcon <msokolov@ivan.Harhan.ORG> |
---|---|
date | Sun, 03 Aug 2014 06:06:45 +0000 |
parents | |
children | c7e53436c451 |
comparison
equal
deleted
inserted
replaced
543:2dccd2b4e5a2 | 544:96a96ec34139 |
---|---|
1 /************* Revision Controle System Header ************* | |
2 * GSM Layer 1 software | |
3 * L1_AFUNC.C | |
4 * | |
5 * Filename l1_afunc.c | |
6 * Copyright 2003 (C) Texas Instruments | |
7 * | |
8 ************* Revision Controle System Header *************/ | |
9 | |
10 #define L1_AFUNC_C | |
11 | |
12 #include "l1_macro.h" | |
13 #include "l1_confg.h" | |
14 | |
15 #if (CODE_VERSION == SIMULATION) | |
16 #include <string.h> | |
17 #include "l1_types.h" | |
18 #include "sys_types.h" | |
19 #include "l1_const.h" | |
20 #include "l1_signa.h" | |
21 #if TESTMODE | |
22 #include "l1tm_defty.h" | |
23 #endif | |
24 #if (AUDIO_TASK == 1) | |
25 #include "l1audio_const.h" | |
26 #include "l1audio_cust.h" | |
27 #include "l1audio_defty.h" | |
28 #endif | |
29 #if (L1_GTT == 1) | |
30 #include "l1gtt_const.h" | |
31 #include "l1gtt_defty.h" | |
32 #endif | |
33 #if (L1_MIDI == 1) | |
34 #include "l1midi_defty.h" | |
35 #endif | |
36 #if (L1_MP3 == 1) | |
37 #include "l1mp3_defty.h" | |
38 #endif | |
39 //ADDED FOR AAC | |
40 #if (L1_AAC == 1) | |
41 #include "l1aac_defty.h" | |
42 #endif | |
43 #include "l1_defty.h" | |
44 #include "cust_os.h" | |
45 #include "l1_msgty.h" | |
46 #include "l1_varex.h" | |
47 #include "l1_proto.h" | |
48 #include "l1_tabs.h" | |
49 #include "l1_time.h" | |
50 #if L1_GPRS | |
51 #include "l1p_cons.h" | |
52 #include "l1p_msgt.h" | |
53 #include "l1p_deft.h" | |
54 #include "l1p_vare.h" | |
55 #endif | |
56 #else | |
57 #include <string.h> | |
58 #include "l1_types.h" | |
59 #include "sys_types.h" | |
60 #include "l1_const.h" | |
61 #include "l1_signa.h" | |
62 #include "l1_time.h" | |
63 | |
64 #if TESTMODE | |
65 #include "l1tm_defty.h" | |
66 #endif | |
67 #if (AUDIO_TASK == 1) | |
68 #include "l1audio_const.h" | |
69 #include "l1audio_cust.h" | |
70 #include "l1audio_defty.h" | |
71 #endif | |
72 #if (L1_GTT == 1) | |
73 #include "l1gtt_const.h" | |
74 #include "l1gtt_defty.h" | |
75 #endif | |
76 #if (L1_MP3 == 1) | |
77 #include "l1mp3_defty.h" | |
78 #endif | |
79 #if (L1_MIDI == 1) | |
80 #include "l1midi_defty.h" | |
81 #endif | |
82 //ADDED FOR AAC | |
83 #if (L1_AAC == 1) | |
84 #include "l1aac_defty.h" | |
85 #endif | |
86 #include "l1_defty.h" | |
87 #include "cust_os.h" | |
88 #include "l1_msgty.h" | |
89 #include "l1_varex.h" | |
90 #include "l1_proto.h" | |
91 #include "l1_tabs.h" | |
92 #if L1_GPRS | |
93 #include "l1p_cons.h" | |
94 #include "l1p_msgt.h" | |
95 #include "l1p_deft.h" | |
96 #include "l1p_vare.h" | |
97 #endif | |
98 #if (GSM_IDLE_RAM > 1) | |
99 #if (OP_L1_STANDALONE == 1) | |
100 #include "csmi_simul.h" | |
101 #else | |
102 #include "csmi/csmi.h" | |
103 #endif | |
104 #endif | |
105 #endif | |
106 | |
107 | |
108 #if (OP_L1_STANDALONE == 1) | |
109 #if (ANLG_FAM == 11) | |
110 #include "bspTwl3029_Madc.h" | |
111 #endif | |
112 #endif | |
113 | |
114 #if (L1_MADC_ON == 1) | |
115 #if (OP_L1_STANDALONE == 1) | |
116 #if (RF_FAM == 61) | |
117 #include "drp_api.h" | |
118 #include "l1_rf61.h" | |
119 #include <string.h> | |
120 extern T_DRP_SRM_API* drp_srm_api; | |
121 #endif | |
122 #if (ANLG_FAM == 11) | |
123 BspTwl3029_MadcResults l1_madc_results; | |
124 void l1a_madc_callback(void); | |
125 #endif | |
126 #endif | |
127 #endif //L1_MADC_ON | |
128 | |
129 | |
130 | |
131 /*-------------------------------------------------------*/ | |
132 /* l1a_reset_ba_list() */ | |
133 /*-------------------------------------------------------*/ | |
134 /* */ | |
135 /* Description: */ | |
136 /* ------------ */ | |
137 /* This function resets the BA list content. */ | |
138 /* */ | |
139 /*-------------------------------------------------------*/ | |
140 void l1a_reset_ba_list() | |
141 { | |
142 UWORD8 i; | |
143 | |
144 // Rem: this reset function do not touch the "ba_id", "nbr_carrier" and | |
145 // "radio_freq" fields. | |
146 | |
147 //!!! remove this initialization when BA list handling changed for dedic mode | |
148 if(l1a_l1s_com.mode != I_MODE) | |
149 { | |
150 l1a_l1s_com.ba_list.next_to_ctrl = 0; // Carrier for next power measurement control. | |
151 l1a_l1s_com.ba_list.next_to_read = 0; // Carrier for next power measurement result. | |
152 l1a_l1s_com.ba_list.first_index = 0; // First BA index measured in current session. | |
153 } | |
154 | |
155 // Reset of "ms_ctrl, ms_ctrl_d, msctrl_dd" is done at L1 startup | |
156 // and when SYNCHRO task is executed. | |
157 | |
158 l1a_l1s_com.ba_list.np_ctrl = 0; // PCH burst number. | |
159 | |
160 | |
161 for(i=0; i<C_BA_PM_MEAS; i++) // 2 measurements / PCH frame... | |
162 { | |
163 l1a_l1s_com.ba_list.used_il [i] = l1_config.params.il_min; // IL used in CTRL phase for AGC setting. | |
164 l1a_l1s_com.ba_list.used_il_d [i] = l1_config.params.il_min; // ... 1 frame delay. | |
165 l1a_l1s_com.ba_list.used_il_dd[i] = l1_config.params.il_min; // ... 2 frames delay, used in READ phase. | |
166 | |
167 l1a_l1s_com.ba_list.used_lna [i] = FALSE; // LNA used in CTRL phase for AGC setting. | |
168 l1a_l1s_com.ba_list.used_lna_d [i] = FALSE; // ... 1 frame delay. | |
169 l1a_l1s_com.ba_list.used_lna_dd[i] = FALSE; // ... 2 frames delay, used in READ phase. | |
170 } | |
171 | |
172 for(i=0; i<32+1; i++) | |
173 { | |
174 l1a_l1s_com.ba_list.A[i].acc = 0; // Reset IL accumulation. | |
175 } | |
176 } | |
177 | |
178 /*-------------------------------------------------------*/ | |
179 /* l1a_reset_full_list() */ | |
180 /*-------------------------------------------------------*/ | |
181 /* */ | |
182 /* Description: */ | |
183 /* ------------ */ | |
184 /* This function resets the FULL list content. */ | |
185 /* */ | |
186 /*-------------------------------------------------------*/ | |
187 void l1a_reset_full_list() | |
188 { | |
189 UWORD16 i; | |
190 | |
191 // Init power measurement multi_session process | |
192 l1a_l1s_com.full_list.meas_1st_pass_ctrl = 1; // Set 1st pass flag for power measurement session in ctrl. | |
193 l1a_l1s_com.full_list.meas_1st_pass_read = 1; // Set 1st pass flag for power measurement session in read. | |
194 l1a_l1s_com.full_list.nbr_sat_carrier_ctrl = 0; // Clear number of saturated carrier in ctrl. | |
195 l1a_l1s_com.full_list.nbr_sat_carrier_read = 0; // Clear number of saturated carrier in read. | |
196 | |
197 // Set global parameters for full list measurement. | |
198 l1a_l1s_com.full_list.next_to_ctrl = 0; // Set next carrier to control to 1st one. | |
199 l1a_l1s_com.full_list.next_to_read = 0; // Set next carrier to control to 1st one. | |
200 | |
201 // Reset Pipeline | |
202 // Note: l1a_l1s_com.full_list.ms_ctrl_d is reset at the end of l1_meas_manager() | |
203 l1a_l1s_com.full_list.ms_ctrl_dd = 0; | |
204 l1a_l1s_com.full_list.ms_ctrl_d = 0; | |
205 | |
206 // Reset the FULL LIST. | |
207 #if (L1_FF_MULTIBAND == 0) | |
208 for(i=0; i<l1_config.std.nbmax_carrier; i++) | |
209 #else | |
210 for(i=0; i< NBMAX_CARRIER; i++) | |
211 #endif | |
212 { | |
213 l1a_l1s_com.full_list.sat_flag[i] = 0; // Reset sat_flag | |
214 } | |
215 | |
216 #if L1_GPRS | |
217 // Reset PPCH burst ctrl indication | |
218 l1pa_l1ps_com.cr_freq_list.pnp_ctrl = 0; | |
219 #endif | |
220 } | |
221 | |
222 #if ((L1_EOTD == 1) && (L1_EOTD_QBIT_ACC == 1)) | |
223 /*-------------------------------------------------------*/ | |
224 /* l1a_add_time_delta() */ | |
225 /*-------------------------------------------------------*/ | |
226 /* */ | |
227 /* Description: */ | |
228 /* ------------ */ | |
229 /* This function shifts a given cell timing (given as a */ | |
230 /* couple [time_alignmt, fn_offset]) by adding */ | |
231 /* a specified new time_alignmt offset (+ve or -ve */ | |
232 /* between -4999 and +4999 qb) */ | |
233 /* to that timing. */ | |
234 /* */ | |
235 /*-------------------------------------------------------*/ | |
236 void l1a_add_time_delta(UWORD32 * time_alignmt, UWORD32 * fn_offset, WORD32 delta) | |
237 { | |
238 WORD32 new_time_alignmt = *time_alignmt + delta; | |
239 UWORD32 new_fn_offset = *fn_offset; | |
240 | |
241 if(new_time_alignmt < 0) | |
242 { | |
243 new_time_alignmt += TPU_CLOCK_RANGE; | |
244 new_fn_offset = (new_fn_offset + 1) % MAX_FN; | |
245 } | |
246 else if(new_time_alignmt >= TPU_CLOCK_RANGE) | |
247 { | |
248 new_time_alignmt -= TPU_CLOCK_RANGE; | |
249 new_fn_offset = (new_fn_offset - 1 + MAX_FN) % MAX_FN; | |
250 } | |
251 | |
252 *time_alignmt = new_time_alignmt; | |
253 *fn_offset = new_fn_offset; | |
254 } | |
255 | |
256 /*-------------------------------------------------------*/ | |
257 /* l1a_compensate_sync_ind() */ | |
258 /*-------------------------------------------------------*/ | |
259 /* */ | |
260 /* Description: */ | |
261 /* ------------ */ | |
262 /* Attempts to modify the time_alignmt and fn_offset */ | |
263 /* fields of an MPHC_NCELL_SYNC_IND message based on */ | |
264 /* E-OTD cross-correlation information in order to */ | |
265 /* post-correct the result. This can be used to form a */ | |
266 /* quater-bit alignment with slow drifting neighbours */ | |
267 /* */ | |
268 /*-------------------------------------------------------*/ | |
269 void l1a_compensate_sync_ind(T_MPHC_NCELL_SYNC_IND * msg) | |
270 { | |
271 | |
272 // This process can only be applied to SBCONF messages | |
273 // with good SCH decodes and valid EOTD results. | |
274 // | |
275 // a_eotd_crosscor [0] [1] [2] [3] [4] [5] [6] [7] [8] | |
276 // | |
277 // <------ Peak Range -----> | |
278 // | |
279 // As long as the cross-correlation peak lies in the range | |
280 // [1] to [7] then we can examine the slope of the correlation | |
281 // points on either side of the peak in order to perform a | |
282 // positive or negative QB shift. | |
283 | |
284 if((msg->sb_flag) && (msg->eotd_data_valid)) | |
285 { | |
286 WORD16 peak_index = msg->d_eotd_max - msg->d_eotd_first; | |
287 | |
288 if((peak_index >= 1) && (peak_index <= 7)) | |
289 { | |
290 UWORD32 a_power[9]; | |
291 UWORD32 pre_power, post_power, thresh_power; | |
292 UWORD32 i; | |
293 WORD32 shift = 0; | |
294 | |
295 // Calculate the normalised power of the cross-correlation samples | |
296 // in a_eotd_crosscor. This could be improved to only calculate | |
297 // the terms for [peak_index-1] [peak_index] [peak_index+1] if | |
298 // the algorithm proves viable in the long term. | |
299 | |
300 // Normalised power[i] = real[i]^2 + imag[i]^2 | |
301 | |
302 for(i=0; i<9; ++i) | |
303 { | |
304 // | |
305 // Awkward looking code to square values as our compiler / assembler | |
306 // gets the following construct wrong. Very strange... | |
307 // | |
308 // UWORD32 real = ... | |
309 // real *= real; <-- Assembler allocates registers incorrectly here | |
310 // | |
311 | |
312 UWORD32 real = msg->a_eotd_crosscor[2*i] * msg->a_eotd_crosscor[2*i]; | |
313 UWORD32 imag = msg->a_eotd_crosscor[(2*i)+1] * msg->a_eotd_crosscor[(2*i)+1]; | |
314 | |
315 // Sum of the squares... | |
316 | |
317 a_power[i] = real + imag; | |
318 } | |
319 | |
320 // By inspection of practical examples, it appears that (peak power/3) | |
321 // is a good threshold on which to compare the shape of the slope. | |
322 | |
323 thresh_power = a_power[peak_index] / 3; | |
324 pre_power = a_power[peak_index-1]; | |
325 post_power = a_power[peak_index+1]; | |
326 | |
327 // Decision on whether the gradient of the slope of the crosscor points | |
328 // on either side of the peak is large enough to cause a (max) +/- 1QB shift | |
329 // to the time_alignmt field. | |
330 | |
331 if( (pre_power < thresh_power) && (post_power > thresh_power) ) | |
332 { | |
333 // Right skew on the cross corrrelation - shift time_alignmt | |
334 // to be one greater | |
335 | |
336 shift = 1; | |
337 } | |
338 else if ( (pre_power > thresh_power) && (post_power < thresh_power) ) | |
339 { | |
340 // Left skew on the cross correlation - shift time_alignmt | |
341 // to be one less | |
342 | |
343 shift = -1; | |
344 } | |
345 | |
346 l1a_add_time_delta( &(msg->time_alignmt), | |
347 &(msg->fn_offset), | |
348 shift ); | |
349 | |
350 } | |
351 } | |
352 } | |
353 #endif | |
354 | |
355 /*-------------------------------------------------------*/ | |
356 /* l1a_add_time_for_nb() */ | |
357 /*-------------------------------------------------------*/ | |
358 /* */ | |
359 /* Description: */ | |
360 /* ------------ */ | |
361 /* This function shift a given cell timing (given as a */ | |
362 /* couple [time_alignmt, fn_offset]) by adding */ | |
363 /* "SB_MARGIN - NB_MARGIN" */ | |
364 /* to that timing. */ | |
365 /* */ | |
366 /*-------------------------------------------------------*/ | |
367 void l1a_add_time_for_nb(UWORD32 *time_alignmt, UWORD32 *fn_offset) | |
368 { | |
369 // Add "SB_MARGIN - NB_MARGIN" qbit to "fn_offset" and "time_alignmt". | |
370 // Pay attention to the modulos. | |
371 | |
372 *time_alignmt += (SB_MARGIN - NB_MARGIN); | |
373 if(*time_alignmt >= TPU_CLOCK_RANGE) | |
374 { | |
375 *time_alignmt -= TPU_CLOCK_RANGE; | |
376 *fn_offset = (*fn_offset + MAX_FN - 1) % MAX_FN; | |
377 } | |
378 } | |
379 | |
380 /*-------------------------------------------------------*/ | |
381 /* l1a_add_timeslot() */ | |
382 /*-------------------------------------------------------*/ | |
383 /* */ | |
384 /* Description: */ | |
385 /* ------------ */ | |
386 /* This function shift a given cell timing (given as a */ | |
387 /* couple [time_alignmt, fn_offset]) by adding a number */ | |
388 /* of TIMESLOT (given as "tn") to that timing. */ | |
389 /* */ | |
390 /*-------------------------------------------------------*/ | |
391 void l1a_add_timeslot(UWORD32 *time_alignmt, UWORD32 *fn_offset, UWORD8 tn) | |
392 { | |
393 // Add "tn" timeslot to "fn_offset" and "time_alignmt". | |
394 // Pay attention to the modulos. | |
395 | |
396 *time_alignmt += tn * BP_DURATION; | |
397 if(*time_alignmt >= TPU_CLOCK_RANGE) | |
398 { | |
399 *time_alignmt -= TPU_CLOCK_RANGE; | |
400 *fn_offset = (*fn_offset + MAX_FN - 1) % MAX_FN; | |
401 } | |
402 } | |
403 | |
404 /*-------------------------------------------------------*/ | |
405 /* l1a_sub_time_for_nb() */ | |
406 /*-------------------------------------------------------*/ | |
407 /* */ | |
408 /* Description: */ | |
409 /* ------------ */ | |
410 /* This function shift a given cell timing (given as a */ | |
411 /* couple [time_alignmt, fn_offset]) by substacting */ | |
412 /* "SB_MARGIN - NB_MARGIN" */ | |
413 /* to that timing. */ | |
414 /* */ | |
415 /*-------------------------------------------------------*/ | |
416 void l1a_sub_time_for_nb(UWORD32 *time_alignmt, UWORD32 *fn_offset) | |
417 { | |
418 WORD32 new_time_alignmt; | |
419 | |
420 // Sub "SB_MARGIN - NB_MARGIN" qbit to "fn_offset" and "time_alignmt". | |
421 // Pay attention to the modulos. | |
422 | |
423 new_time_alignmt = *time_alignmt - (SB_MARGIN - NB_MARGIN); | |
424 if(new_time_alignmt < 0) | |
425 { | |
426 new_time_alignmt += TPU_CLOCK_RANGE; | |
427 *fn_offset = (*fn_offset + 1) % MAX_FN; | |
428 } | |
429 *time_alignmt = new_time_alignmt; | |
430 } | |
431 | |
432 /*-------------------------------------------------------*/ | |
433 /* l1a_sub_timeslot() */ | |
434 /*-------------------------------------------------------*/ | |
435 /* */ | |
436 /* Description: */ | |
437 /* ------------ */ | |
438 /* This function shift a given cell timing (given as a */ | |
439 /* couple [time_alignmt, fn_offset]) by substracting a */ | |
440 /* number of TIMESLOT (given as "tn") to that timing. */ | |
441 /* */ | |
442 /*-------------------------------------------------------*/ | |
443 void l1a_sub_timeslot(UWORD32 *time_alignmt, UWORD32 *fn_offset, UWORD8 tn) | |
444 { | |
445 WORD32 new_time_alignmt; | |
446 | |
447 // Sub "tn" timeslot to "fn_offset" and "time_alignmt". | |
448 // Pay attention to the modulos. | |
449 new_time_alignmt = *time_alignmt - (tn * BP_DURATION); | |
450 if(new_time_alignmt < 0) | |
451 { | |
452 new_time_alignmt += TPU_CLOCK_RANGE; | |
453 *fn_offset = (*fn_offset + 1) % MAX_FN; | |
454 } | |
455 *time_alignmt = new_time_alignmt; | |
456 } | |
457 | |
458 /*-------------------------------------------------------*/ | |
459 /* l1a_correct_timing() */ | |
460 /*-------------------------------------------------------*/ | |
461 /* */ | |
462 /* Description: */ | |
463 /* ------------ */ | |
464 /* */ | |
465 /*-------------------------------------------------------*/ | |
466 #if (L1_12NEIGH == 1) | |
467 void l1a_correct_timing (UWORD8 neigh_id,UWORD32 time_alignmt,UWORD32 fn_offset) | |
468 { | |
469 // Save timing information in case of future handovers. | |
470 l1a_l1s_com.nsync.list[neigh_id].time_alignmt_mem = time_alignmt; | |
471 l1a_l1s_com.nsync.list[neigh_id].fn_offset_mem = fn_offset; | |
472 | |
473 // Sub the serving cell timeslot number to the Neigh./Serving timing | |
474 // difference to format it for L1S use. | |
475 l1a_sub_timeslot(&time_alignmt, &fn_offset, l1a_l1s_com.dl_tn); | |
476 l1a_sub_time_for_nb(&time_alignmt, &fn_offset); | |
477 | |
478 // Save neighbor information in the neighbor confirmation cell structure. | |
479 l1a_l1s_com.nsync.list[neigh_id].time_alignmt = time_alignmt; | |
480 l1a_l1s_com.nsync.list[neigh_id].fn_offset = fn_offset; | |
481 } | |
482 #endif | |
483 | |
484 /*-------------------------------------------------------*/ | |
485 /* l1a_compute_Eotd_data() */ | |
486 /*-------------------------------------------------------*/ | |
487 /* */ | |
488 /* Description: */ | |
489 /* ------------ */ | |
490 /* */ | |
491 /*-------------------------------------------------------*/ | |
492 #if ((L1_12NEIGH ==1) && (L1_EOTD == 1)) | |
493 void l1a_compute_Eotd_data( UWORD8 *first_scell, UWORD8 neigh_id, UWORD32 SignalCode, xSignalHeaderRec *msg) | |
494 { | |
495 WORD32 ta_sb_neigh; | |
496 UWORD32 fn_sb_neigh; | |
497 WORD16 d_eotd_first; | |
498 WORD32 toa_correction; | |
499 UWORD32 timetag; | |
500 | |
501 // SB case ..... | |
502 if (SignalCode == L1C_SB_INFO) | |
503 { | |
504 fn_sb_neigh = ((T_L1C_SB_INFO *)(msg->SigP))->fn_sb_neigh; | |
505 d_eotd_first= ((T_L1C_SB_INFO *)(msg->SigP))->d_eotd_first; | |
506 toa_correction = ((T_L1C_SB_INFO *)(msg->SigP))->toa_correction; | |
507 } | |
508 // SBCONF case ..... | |
509 else | |
510 { | |
511 fn_sb_neigh = ((T_L1C_SBCONF_INFO *)(msg->SigP))->fn_sb_neigh; | |
512 d_eotd_first= ((T_L1C_SBCONF_INFO *)(msg->SigP))->d_eotd_first; | |
513 toa_correction = ((T_L1C_SBCONF_INFO *)(msg->SigP))->toa_correction; | |
514 } | |
515 | |
516 // compute the true Serving/Neighbor time difference. | |
517 // 1) update time_alignmt with (23bit - d_eotd_first) delta | |
518 // 2) Add the serving cell timeslot number to the Serving/Neighbor time difference. | |
519 ta_sb_neigh = l1a_l1s_com.nsync.list[neigh_id].time_alignmt; | |
520 ta_sb_neigh += (d_eotd_first - (23))*4 + | |
521 (l1a_l1s_com.dl_tn * 625); | |
522 | |
523 // for Serving cell, timetag reference is 0 | |
524 if (*first_scell == TRUE) | |
525 { | |
526 l1a_l1s_com.nsync.fn_sb_serv = fn_sb_neigh; | |
527 l1a_l1s_com.nsync.ta_sb_serv = ta_sb_neigh; | |
528 | |
529 timetag = 0; | |
530 } | |
531 else | |
532 { | |
533 UWORD32 delta_fn; | |
534 WORD32 delta_qbit; | |
535 | |
536 delta_fn = (fn_sb_neigh - l1a_l1s_com.nsync.fn_sb_serv + MAX_FN)%MAX_FN; | |
537 delta_qbit = ta_sb_neigh - l1a_l1s_com.nsync.ta_sb_serv; | |
538 | |
539 // Set timetag | |
540 timetag = (delta_fn*5000) + (WORD32)(delta_qbit) + toa_correction; | |
541 | |
542 #if (CODE_VERSION == SIMULATION) | |
543 #if (TRACE_TYPE==5) | |
544 ((T_MPHC_NCELL_SYNC_IND *)(msg->SigP))->delta_fn = delta_fn; | |
545 ((T_MPHC_NCELL_SYNC_IND *)(msg->SigP))->delta_qbit = delta_qbit; | |
546 #endif | |
547 #endif | |
548 } | |
549 // Set timetag | |
550 ((T_MPHC_NCELL_SYNC_IND *)(msg->SigP))->timetag = timetag; | |
551 | |
552 } | |
553 #endif | |
554 | |
555 /*-------------------------------------------------------*/ | |
556 /* l1a_get_free_dedic_set() */ | |
557 /*-------------------------------------------------------*/ | |
558 /* Parameters : */ | |
559 /* Return : */ | |
560 /* Functionality : */ | |
561 /*-------------------------------------------------------*/ | |
562 T_DEDIC_SET *l1a_get_free_dedic_set() | |
563 { | |
564 T_DEDIC_SET *fset; | |
565 UWORD8 i; | |
566 | |
567 // Get free set pointer. | |
568 if(l1a_l1s_com.dedic_set.aset == &(l1a_l1s_com.dedic_set.set[0])) | |
569 fset = &(l1a_l1s_com.dedic_set.set[1]); | |
570 else | |
571 fset = &(l1a_l1s_com.dedic_set.set[0]); | |
572 | |
573 // Clear free set. | |
574 fset->achan_ptr = NULL; | |
575 fset->chan1.desc.channel_type = INVALID_CHANNEL; | |
576 fset->chan1.desc_bef_sti.channel_type = INVALID_CHANNEL; | |
577 fset->chan2.desc.channel_type = INVALID_CHANNEL; | |
578 fset->chan2.desc_bef_sti.channel_type = INVALID_CHANNEL; | |
579 | |
580 fset->ma.alist_ptr = NULL; | |
581 fset->ma.freq_list.rf_chan_cnt = 0; | |
582 fset->ma.freq_list_bef_sti.rf_chan_cnt = 0; | |
583 | |
584 // Starting time. | |
585 fset->serv_sti_fn = -1; | |
586 fset->neig_sti_fn = -1; | |
587 | |
588 // Frequency redefinition flag. | |
589 fset->freq_redef_flag = FALSE; | |
590 | |
591 // Timing Advance | |
592 fset->timing_advance = 0; | |
593 fset->new_timing_advance = 0; | |
594 | |
595 // TXPWR | |
596 fset->new_target_txpwr = NO_TXPWR; | |
597 | |
598 // Cell Information | |
599 l1a_reset_cell_info(&(fset->cell_desc)); | |
600 | |
601 // Cipering. | |
602 fset->a5mode = 0; // Ciphering OFF. | |
603 | |
604 // Clear O&M test variables. | |
605 fset->dai_mode = 0; // No DAI test. | |
606 fset->chan1.tch_loop = 0; // No TCH loop on chan1. | |
607 fset->chan2.tch_loop = 0; // No TCH loop on chan2. | |
608 | |
609 // For handover... | |
610 fset->ho_acc = 0; | |
611 fset->ho_acc_to_send = 0; | |
612 fset->t3124 = 0; | |
613 | |
614 #if ((REL99 == 1) && (FF_BHO == 1)) | |
615 // For blind handover... | |
616 fset->report_time_diff = FALSE; | |
617 fset->nci = FALSE; | |
618 fset->report_time_diff = FALSE; | |
619 fset->real_time_difference = 0; | |
620 fset->HO_SignalCode = 0; | |
621 #endif | |
622 | |
623 // Reset DPAGC fifo | |
624 for(i=0;i<DPAGC_FIFO_LEN;i++) | |
625 { | |
626 fset->G_all[i] = 200; | |
627 fset->G_DTX[i] = 200; | |
628 } | |
629 | |
630 // Reset DTX_ALLOWED field. | |
631 fset->dtx_allowed = FALSE; | |
632 | |
633 #if IDS | |
634 // clear ids_mode: default value = speech mode | |
635 fset->ids_mode = 0; | |
636 #endif | |
637 | |
638 #if (AMR == 1) | |
639 // Clear the AMR ver 1.0 network settings | |
640 fset->amr_configuration.noise_suppression_bit = FALSE; | |
641 fset->amr_configuration.initial_codec_mode_indicator = FALSE; | |
642 fset->amr_configuration.initial_codec_mode = 0; | |
643 fset->amr_configuration.active_codec_set = 0; | |
644 fset->amr_configuration.threshold[0] = 0; | |
645 fset->amr_configuration.threshold[1] = 0; | |
646 fset->amr_configuration.threshold[2] = 0; | |
647 fset->amr_configuration.hysteresis[0] = 0; | |
648 fset->amr_configuration.hysteresis[1] = 0; | |
649 fset->amr_configuration.hysteresis[2] = 0; | |
650 fset->cmip = C_AMR_CMIP_DEFAULT; | |
651 #endif | |
652 return(fset); | |
653 } | |
654 | |
655 /*-------------------------------------------------------*/ | |
656 /* l1a_fill_bef_sti_param() */ | |
657 /*-------------------------------------------------------*/ | |
658 /* Parameters : */ | |
659 /* Return : */ | |
660 /* Functionality : */ | |
661 /*-------------------------------------------------------*/ | |
662 void l1a_fill_bef_sti_param(T_DEDIC_SET *set_ptr, BOOL start_time_present) | |
663 { | |
664 if(start_time_present == TRUE) | |
665 // There is a STARTING TIME field... | |
666 { | |
667 if((set_ptr->ma.freq_list_bef_sti.rf_chan_cnt != 0) || | |
668 (set_ptr->chan1.desc_bef_sti.channel_type != INVALID_CHANNEL) || | |
669 (set_ptr->chan2.desc_bef_sti.channel_type != INVALID_CHANNEL)) | |
670 // There is at least one "bef_sti" parameter given for this channel. | |
671 // Other empty parameters must be filled with the according "AFTER STARTING TIME" parameters. | |
672 { | |
673 // Fill "chan1.desc_bef_sti" | |
674 if(set_ptr->chan1.desc_bef_sti.channel_type == INVALID_CHANNEL) | |
675 set_ptr->chan1.desc_bef_sti = set_ptr->chan1.desc; | |
676 | |
677 // Fill "chan2.desc_bef_sti" | |
678 if(set_ptr->chan2.desc_bef_sti.channel_type == INVALID_CHANNEL) | |
679 set_ptr->chan2.desc_bef_sti = set_ptr->chan2.desc; | |
680 | |
681 // Fill "freq_list_bef_sti" | |
682 if(set_ptr->ma.freq_list_bef_sti.rf_chan_cnt == 0) | |
683 set_ptr->ma.freq_list_bef_sti = set_ptr->ma.freq_list; | |
684 } | |
685 } | |
686 } | |
687 | |
688 /*-------------------------------------------------------*/ | |
689 /* l1a_decode_starting_time() */ | |
690 /*-------------------------------------------------------*/ | |
691 /* Parameters : */ | |
692 /* Return : */ | |
693 /* Functionality : */ | |
694 /*-------------------------------------------------------*/ | |
695 WORD32 l1a_decode_starting_time(T_STARTING_TIME coded_starting_time) | |
696 { | |
697 WORD32 starting_time; | |
698 | |
699 if(coded_starting_time.start_time_present == TRUE ) | |
700 // A starting time is present. | |
701 // --------------------------- | |
702 { | |
703 WORD32 tp1 = coded_starting_time.start_time.n32; | |
704 WORD32 t2 = coded_starting_time.start_time.n26; | |
705 WORD32 t3 = coded_starting_time.start_time.n51; | |
706 | |
707 // Compute STI. | |
708 starting_time = 51*((26 + t3 - t2) % 26) + t3 + (51*26*tp1) ; | |
709 } | |
710 else | |
711 { | |
712 starting_time = -1; | |
713 } | |
714 | |
715 return(starting_time); | |
716 } | |
717 | |
718 /*-------------------------------------------------------*/ | |
719 /* l1a_reset_cell_info() */ | |
720 /*-------------------------------------------------------*/ | |
721 /* Parameters : */ | |
722 /* Return : */ | |
723 /* Functionality : */ | |
724 /*-------------------------------------------------------*/ | |
725 void l1a_reset_cell_info(T_CELL_INFO *cell_info) | |
726 { | |
727 cell_info->bsic = 0; | |
728 cell_info->fn_offset = 0; | |
729 cell_info->time_alignmt = 0; | |
730 cell_info->meas.acc = 0; | |
731 cell_info->meas.nbr_meas = 0; | |
732 cell_info->attempt_count = 0; | |
733 cell_info->si_bit_map = 0; | |
734 | |
735 cell_info->traffic_meas.input_level = l1_config.params.il_min; | |
736 cell_info->traffic_meas_beacon.input_level = l1_config.params.il_min; | |
737 cell_info->traffic_meas.lna_off = FALSE; | |
738 cell_info->traffic_meas_beacon.lna_off = FALSE; | |
739 | |
740 cell_info->buff_beacon[0] = cell_info->buff_beacon[1] = cell_info->buff_beacon[2] = | |
741 cell_info->buff_beacon[3] = l1_config.params.il_min; | |
742 | |
743 #if L1_GPRS | |
744 cell_info->transfer_meas.input_level = l1_config.params.il_min; | |
745 cell_info->transfer_meas.lna_off = FALSE; | |
746 cell_info->pb = 0; | |
747 #endif | |
748 } | |
749 | |
750 /*-------------------------------------------------------*/ | |
751 /* l1a_send_confirmation() */ | |
752 /*-------------------------------------------------------*/ | |
753 /* Parameters : */ | |
754 /* Return : */ | |
755 /* Functionality : */ | |
756 /*-------------------------------------------------------*/ | |
757 void l1a_send_confirmation(UWORD32 SignalCode, UWORD8 queue_type) | |
758 { | |
759 xSignalHeaderRec *msg; | |
760 | |
761 msg = os_alloc_sig(0); | |
762 DEBUGMSG(status,NU_ALLOC_ERR) | |
763 msg->SignalCode = (int)SignalCode; | |
764 | |
765 #if (TRACE_TYPE==1) || (TRACE_TYPE==4) | |
766 l1_trace_message(msg); | |
767 #endif | |
768 | |
769 | |
770 #if (OP_L1_STANDALONE == 1) | |
771 os_send_sig(msg, queue_type); | |
772 #else | |
773 os_send_sig(msg, ((T_ENUM_OS_QUEUE)queue_type)); //omaps00090550 | |
774 #endif | |
775 | |
776 | |
777 DEBUGMSG(status,NU_SEND_QUEUE_ERR) | |
778 } | |
779 | |
780 /*-------------------------------------------------------*/ | |
781 /* l1a_send_result() */ | |
782 /*-------------------------------------------------------*/ | |
783 /* Parameters : */ | |
784 /* Return : */ | |
785 /* Functionality : */ | |
786 /*-------------------------------------------------------*/ | |
787 void l1a_send_result(UWORD32 SignalCode, xSignalHeaderRec *msg, UWORD8 queue) | |
788 { | |
789 // Set flag to avoid the FREE(msg) in L1ASYNC. | |
790 l1a.l1_msg_forwarded = TRUE; | |
791 | |
792 msg->SignalCode = (int)SignalCode; | |
793 | |
794 // May not be necessary -> to check | |
795 | |
796 #if (GSM_IDLE_RAM > 1) | |
797 if (!READ_TRAFFIC_CONT_STATE) | |
798 { | |
799 CSMI_TrafficControllerOn(); | |
800 } | |
801 #endif | |
802 | |
803 #if (TRACE_TYPE==1) || (TRACE_TYPE==4) | |
804 l1_trace_message(msg); | |
805 #endif | |
806 | |
807 #if (OP_L1_STANDALONE == 1) | |
808 os_send_sig(msg, queue); | |
809 #else | |
810 os_send_sig(msg, ((T_ENUM_OS_QUEUE)queue)); //omaps00090550 | |
811 #endif | |
812 | |
813 | |
814 DEBUGMSG(status,NU_SEND_QUEUE_ERR) | |
815 } | |
816 | |
817 /*-------------------------------------------------------*/ | |
818 /* l1a_encode_rxqual() */ | |
819 /*-------------------------------------------------------*/ | |
820 /* Parameters : */ | |
821 /* Return : */ | |
822 /* Functionality : */ | |
823 /*-------------------------------------------------------*/ | |
824 UWORD8 l1a_encode_rxqual (UWORD32 inlevel) | |
825 { | |
826 enum qual_thr | |
827 { | |
828 thr_0_2 = 4, | |
829 thr_0_4 = 8, | |
830 thr_0_8 = 16, | |
831 thr_1_6 = 32, | |
832 thr_3_2 = 64, | |
833 thr_6_4 = 128, | |
834 thr_12_8 = 256 | |
835 }; | |
836 | |
837 UWORD8 rxqual; | |
838 | |
839 if (inlevel < thr_0_2) rxqual = 0; | |
840 else | |
841 if (inlevel < thr_0_4) rxqual = 1; | |
842 else | |
843 if (inlevel < thr_0_8) rxqual = 2; | |
844 else | |
845 if (inlevel < thr_1_6) rxqual = 3; | |
846 else | |
847 if (inlevel < thr_3_2) rxqual = 4; | |
848 else | |
849 if (inlevel < thr_6_4) rxqual = 5; | |
850 else | |
851 if (inlevel < thr_12_8) rxqual = 6; | |
852 else rxqual = 7; | |
853 | |
854 return((UWORD8) rxqual); | |
855 } | |
856 | |
857 /*-------------------------------------------------------*/ | |
858 /* l1a_report_failling_ncell_sync() */ | |
859 /*-------------------------------------------------------*/ | |
860 /* Parameters : */ | |
861 /* Return : */ | |
862 /* Functionality : */ | |
863 /*-------------------------------------------------------*/ | |
864 void l1a_report_failling_ncell_sync(UWORD32 SignalCode, UWORD8 neigh_id) | |
865 { | |
866 xSignalHeaderRec *msg; | |
867 | |
868 // Send MPHC_NCELL_SYNC_IND message to L3 with a FAILLURE indication. | |
869 msg = os_alloc_sig(sizeof(T_MPHC_NCELL_SYNC_IND)); | |
870 DEBUGMSG(status,NU_ALLOC_ERR) | |
871 | |
872 msg->SignalCode = SignalCode; | |
873 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->sb_flag = FALSE; | |
874 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->radio_freq = l1a_l1s_com.nsync.list[neigh_id].radio_freq; | |
875 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->bsic = 0; | |
876 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->fn_offset = 0; | |
877 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->time_alignmt = 0; | |
878 | |
879 // For trace/debug only | |
880 ((T_MPHC_NCELL_SYNC_IND*)(msg->SigP))->neigh_id = neigh_id; | |
881 | |
882 #if (TRACE_TYPE==1) || (TRACE_TYPE==4) | |
883 l1_trace_message(msg); | |
884 #endif | |
885 | |
886 os_send_sig(msg, RRM1_QUEUE); | |
887 DEBUGMSG(status,NU_SEND_QUEUE_ERR) | |
888 } | |
889 | |
890 | |
891 /*-------------------------------------------------------*/ | |
892 /* l1a_clip_txpwr() */ | |
893 /*-------------------------------------------------------*/ | |
894 /* Parameters : */ | |
895 /* Return : */ | |
896 /* Functionality : */ | |
897 /*-------------------------------------------------------*/ | |
898 #if (L1_FF_MULTIBAND == 0) | |
899 | |
900 UWORD8 l1a_clip_txpwr (UWORD8 supplied_txpwr, UWORD16 radio_freq) | |
901 { | |
902 #define txpwr_to_compare(pwr) ((pwr<=l1_config.std.txpwr_turning_point)? pwr+32:pwr) | |
903 | |
904 switch(l1_config.std.id) | |
905 { | |
906 case GSM: | |
907 case GSM_E: | |
908 { | |
909 // Clip LOW according to powerclass_band1. | |
910 if ( supplied_txpwr < MIN_TXPWR_GSM[l1a_l1s_com.powerclass_band1]) | |
911 return(MIN_TXPWR_GSM[l1a_l1s_com.powerclass_band1]); | |
912 | |
913 // Clip HIGH according to GSM spec. 05.05. | |
914 if ( supplied_txpwr > l1_config.std.max_txpwr_band1) | |
915 return(l1_config.std.max_txpwr_band1); | |
916 } | |
917 break; | |
918 | |
919 case PCS1900: | |
920 { | |
921 // Clip LOW according to powerclass_band1. | |
922 if ( txpwr_to_compare(supplied_txpwr) < | |
923 txpwr_to_compare(MIN_TXPWR_PCS[l1a_l1s_com.powerclass_band1]) ) | |
924 return(MIN_TXPWR_PCS[l1a_l1s_com.powerclass_band1]); | |
925 | |
926 // Clip HIGH according to GSM spec. 05.05. | |
927 if ( txpwr_to_compare(supplied_txpwr) > | |
928 txpwr_to_compare(l1_config.std.max_txpwr_band1) ) | |
929 return(l1_config.std.max_txpwr_band1); | |
930 } | |
931 break; | |
932 | |
933 case DCS1800: | |
934 { | |
935 // Clip LOW according to powerclass_band1. | |
936 if ( txpwr_to_compare(supplied_txpwr) < | |
937 txpwr_to_compare(MIN_TXPWR_DCS[l1a_l1s_com.powerclass_band1]) ) | |
938 return(MIN_TXPWR_DCS[l1a_l1s_com.powerclass_band1]); | |
939 | |
940 // Clip HIGH according to GSM spec. 05.05. | |
941 if ( txpwr_to_compare(supplied_txpwr) > | |
942 txpwr_to_compare(l1_config.std.max_txpwr_band1) ) | |
943 return(l1_config.std.max_txpwr_band1); | |
944 } | |
945 break; | |
946 | |
947 case GSM850: | |
948 { | |
949 // Clip LOW according to powerclass_band1. | |
950 if ( txpwr_to_compare(supplied_txpwr) < | |
951 txpwr_to_compare(MIN_TXPWR_GSM850[l1a_l1s_com.powerclass_band1]) ) | |
952 return(MIN_TXPWR_GSM850[l1a_l1s_com.powerclass_band1]); | |
953 | |
954 // Clip HIGH according to GSM spec. 05.05. | |
955 if ( txpwr_to_compare(supplied_txpwr) > | |
956 txpwr_to_compare(l1_config.std.max_txpwr_band1) ) | |
957 return(l1_config.std.max_txpwr_band1); | |
958 } | |
959 break; | |
960 | |
961 case DUAL: | |
962 case DUALEXT: | |
963 { | |
964 // Test which Band is used: GSM or DCS 1800 | |
965 if (radio_freq >= l1_config.std.first_radio_freq_band2) | |
966 { | |
967 // Clip LOW according to powerclass_band1. | |
968 if ( txpwr_to_compare(supplied_txpwr) < | |
969 txpwr_to_compare(MIN_TXPWR_DCS[l1a_l1s_com.powerclass_band2]) ) | |
970 return(MIN_TXPWR_DCS[l1a_l1s_com.powerclass_band2]); | |
971 | |
972 // Clip HIGH according to GSM spec. 05.05. | |
973 if ( txpwr_to_compare(supplied_txpwr) > | |
974 txpwr_to_compare(l1_config.std.max_txpwr_band2) ) | |
975 return(l1_config.std.max_txpwr_band2); | |
976 } | |
977 else | |
978 { | |
979 // Clip LOW according to powerclass_band1. | |
980 if ( supplied_txpwr < MIN_TXPWR_GSM[l1a_l1s_com.powerclass_band1]) | |
981 return(MIN_TXPWR_GSM[l1a_l1s_com.powerclass_band1]); | |
982 | |
983 // Clip HIGH according to GSM spec. 05.05. | |
984 if ( supplied_txpwr > l1_config.std.max_txpwr_band1) | |
985 return(l1_config.std.max_txpwr_band1); | |
986 } | |
987 } | |
988 break; | |
989 | |
990 | |
991 case DUAL_US: | |
992 { | |
993 // Test which Band is used: GSM 850 or PCS1900 | |
994 if (radio_freq >= l1_config.std.first_radio_freq_band2) | |
995 { | |
996 // Clip LOW according to powerclass_band1. | |
997 if ( txpwr_to_compare(supplied_txpwr) < | |
998 txpwr_to_compare(MIN_TXPWR_PCS[l1a_l1s_com.powerclass_band2]) ) | |
999 return(MIN_TXPWR_PCS[l1a_l1s_com.powerclass_band2]); | |
1000 | |
1001 // Clip HIGH according to GSM spec. 05.05. | |
1002 if ( txpwr_to_compare(supplied_txpwr) > | |
1003 txpwr_to_compare(l1_config.std.max_txpwr_band2) ) | |
1004 return(l1_config.std.max_txpwr_band2); | |
1005 } | |
1006 else | |
1007 { | |
1008 // Clip LOW according to powerclass_band1. | |
1009 if ( supplied_txpwr < MIN_TXPWR_GSM850[l1a_l1s_com.powerclass_band1]) | |
1010 return(MIN_TXPWR_GSM850[l1a_l1s_com.powerclass_band1]); | |
1011 | |
1012 // Clip HIGH according to GSM spec. 05.05. | |
1013 if ( supplied_txpwr > l1_config.std.max_txpwr_band1) | |
1014 return(l1_config.std.max_txpwr_band1); | |
1015 } | |
1016 } | |
1017 break; | |
1018 | |
1019 | |
1020 default: // should never occur | |
1021 { | |
1022 return(supplied_txpwr); | |
1023 } | |
1024 // omaps00090550 break; | |
1025 } | |
1026 return(supplied_txpwr); | |
1027 } | |
1028 | |
1029 #else /*L1_FF_MULTIBAND = 1 below */ | |
1030 | |
1031 UWORD8 l1a_clip_txpwr (UWORD8 supplied_txpwr, UWORD16 radio_freq) | |
1032 { | |
1033 | |
1034 | |
1035 UWORD8 physical_band_id = 0; | |
1036 physical_band_id = l1_multiband_radio_freq_convert_into_physical_band_id(radio_freq); | |
1037 #define txpwr_to_compare(pwr) ((pwr<= multiband_rf[physical_band_id].tx_turning_point)? pwr+32:pwr) | |
1038 switch(multiband_rf[physical_band_id].gsm_band_identifier) | |
1039 { | |
1040 case RF_GSM900: | |
1041 { | |
1042 | |
1043 // Clip LOW according to powerclass_band1. | |
1044 if ( supplied_txpwr < MIN_TXPWR_GSM[l1a_l1s_com.powerclass[physical_band_id]]) | |
1045 return(MIN_TXPWR_GSM[l1a_l1s_com.powerclass[physical_band_id]]); | |
1046 | |
1047 // Clip HIGH according to GSM spec. 05.05. | |
1048 if ( supplied_txpwr > multiband_rf[physical_band_id].max_txpwr) | |
1049 return(multiband_rf[physical_band_id].max_txpwr); | |
1050 break; | |
1051 }/*case GSM900*/ | |
1052 | |
1053 case RF_PCS1900: | |
1054 { | |
1055 // Clip LOW according to powerclass_band1. | |
1056 if ( txpwr_to_compare(supplied_txpwr) < | |
1057 txpwr_to_compare(MIN_TXPWR_PCS[l1a_l1s_com.powerclass[physical_band_id]]) ) | |
1058 return(MIN_TXPWR_PCS[l1a_l1s_com.powerclass[physical_band_id]]); | |
1059 | |
1060 // Clip HIGH according to GSM spec. 05.05. | |
1061 if ( txpwr_to_compare(supplied_txpwr) > | |
1062 txpwr_to_compare(multiband_rf[physical_band_id].max_txpwr) ) | |
1063 return(multiband_rf[physical_band_id].max_txpwr); | |
1064 break; | |
1065 }/*case PCS1900*/ | |
1066 | |
1067 case RF_DCS1800: | |
1068 { | |
1069 // Clip LOW according to powerclass_band1. | |
1070 if ( txpwr_to_compare(supplied_txpwr) < | |
1071 txpwr_to_compare(MIN_TXPWR_DCS[l1a_l1s_com.powerclass[physical_band_id]]) ) | |
1072 return(MIN_TXPWR_DCS[l1a_l1s_com.powerclass[physical_band_id]]); | |
1073 | |
1074 // Clip HIGH according to GSM spec. 05.05. | |
1075 if ( txpwr_to_compare(supplied_txpwr) > | |
1076 txpwr_to_compare(multiband_rf[physical_band_id].max_txpwr) ) | |
1077 return(multiband_rf[physical_band_id].max_txpwr); | |
1078 break; | |
1079 }/*case DCS1800*/ | |
1080 | |
1081 case RF_GSM850: | |
1082 { | |
1083 // Clip LOW according to powerclass_band1. | |
1084 if ( txpwr_to_compare(supplied_txpwr) < | |
1085 txpwr_to_compare(MIN_TXPWR_GSM850[l1a_l1s_com.powerclass[physical_band_id]]) ) | |
1086 return(MIN_TXPWR_GSM850[l1a_l1s_com.powerclass[physical_band_id]]); | |
1087 | |
1088 // Clip HIGH according to GSM spec. 05.05. | |
1089 if ( txpwr_to_compare(supplied_txpwr) > | |
1090 txpwr_to_compare(multiband_rf[physical_band_id].max_txpwr) ) | |
1091 return(multiband_rf[physical_band_id].max_txpwr); | |
1092 break; | |
1093 }/*case GSM850*/ | |
1094 | |
1095 default: // should never occur | |
1096 { | |
1097 l1_multiband_error_handler(); | |
1098 return(supplied_txpwr); | |
1099 break; | |
1100 } /*default*/ | |
1101 | |
1102 }/*switch(multiband_rfphysical_band_id].gsm_band_identifier)*/ | |
1103 return(supplied_txpwr); | |
1104 | |
1105 } | |
1106 | |
1107 #endif /*L1_FF_MULTIBAND */ | |
1108 | |
1109 | |
1110 //MADC | |
1111 | |
1112 #if (L1_MADC_ON == 1) | |
1113 #if (OP_L1_STANDALONE == 1) | |
1114 #if (ANLG_FAM == 11) | |
1115 void l1a_madc_callback(void) | |
1116 { | |
1117 char str[40]; | |
1118 | |
1119 | |
1120 | |
1121 xSignalHeaderRec *adc_msg; | |
1122 UWORD16 *adc_result; | |
1123 UWORD16 *madc_results; | |
1124 volatile UWORD16 *drp_temp_results; | |
1125 | |
1126 #if (RF_FAM == 61) | |
1127 drp_temp_results =(volatile UWORD16 *) (&drp_srm_api->inout.temperature.output); //omaps00090550 | |
1128 #endif | |
1129 | |
1130 #if 0 | |
1131 sprintf(str, "Temp Measure %x ", drp_temp_results); | |
1132 | |
1133 //L1_trace_string ("Temp Meas\n"); | |
1134 L1_trace_string(str); | |
1135 #endif | |
1136 | |
1137 #if 0 | |
1138 int i; | |
1139 | |
1140 adc_msg = os_alloc_sig(sizeof(BspTwl3029_MadcResults) + sizeof(UWORD16)); | |
1141 adc_result = &((BspTwl3029_MadcResults*)(adc_msg->SigP))->adc1; | |
1142 madc_results =& l1_madc_results.adc1; | |
1143 | |
1144 //TEMP_MEAS: DRP | |
1145 #if (RF_FAM == 61) | |
1146 drp_temp_results =& (drp_srm_api->inout.temperature.output); | |
1147 #endif | |
1148 | |
1149 //copy the measured values into the the message structure. | |
1150 memcpy(adc_result,madc_results,11*sizeof(UWORD16));//11 madc | |
1151 adc_result[11] = *drp_temp_results; // 1 temp meas | |
1152 /* | |
1153 for (i=0;i<11;i++) | |
1154 adc_result[i] = madc_results[i]; | |
1155 */ | |
1156 //Send the message | |
1157 adc_msg->SignalCode = CST_ADC_RESULT; | |
1158 os_send_sig(adc_msg, RRM1_QUEUE); | |
1159 #endif | |
1160 } | |
1161 #endif // ANLG_FAM == 11 | |
1162 #endif //OP_L1_STANDALONE | |
1163 #endif // L1_MADC_ON | |
1164 | |
1165 //============================================================================================== | |
1166 |