comparison src/aci2/alr/alr_main.c @ 3:93999a60b835

src/aci2, src/condat2: import of g23m/condat source pieces from TCS211
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 26 Sep 2016 00:29:36 +0000
parents
children
comparison
equal deleted inserted replaced
2:c41a534f33c6 3:93999a60b835
1 /*
2 +-----------------------------------------------------------------------------
3 | Project : GSM-PS
4 | Modul : ALR_MAIN
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 : This Modul defines the functions for the SDL process
18 | Main_Control of the ALR functionality.
19 +-----------------------------------------------------------------------------
20 */
21
22 #ifndef ALR_MAIN_C
23 #define ALR_MAIN_C
24
25 #define ENTITY_PL
26
27 /*==== INCLUDES ===================================================*/
28 #include <string.h>
29 #include <stdlib.h>
30 #include <ctype.h>
31 #include "typedefs.h"
32 #include "message.h"
33 #include "ccdapi.h"
34 #include "vsi.h"
35 #include "custom.h"
36 #include "gsm.h"
37 #include "prim.h"
38 #include "cnf_alr.h"
39 #include "mon_alr.h"
40 #include "pei.h"
41 #include "tok.h"
42 #include "pcm.h"
43
44 #ifdef GPRS
45 #include "alr_gprs.h"
46 #endif
47
48 #if defined (WIN32)
49 #define TRACING
50 #else
51 /* #define TRACING */
52 /* #define DL_TRACE_ENABLED */
53 #endif
54
55 #include "alr.h"
56 #include "alr_em.h"
57
58 #if defined (TRACING)
59 #define ALR_TRACE_MAIN(a) ALR_TRACE(a)
60 #else
61 #define ALR_TRACE_MAIN(a)
62 #endif
63
64 #if defined (TRACING)
65
66 #define ALR_TRACE_MAIN_BSIC_REQ(s) TRACE_EVENT_P1 ("bsic_req state %d",s)
67 #define ALR_TRACE_MAIN_RAND_ACC(s,m) TRACE_EVENT_P2 ("con est on for: %d %d times", s, m);
68 #define ALR_TRACE_MAIN_SCELL(o,s) TRACE_EVENT_P2 ("SC [%d]->[%d]", o, s)
69 #define ALR_TRACE_MAIN_VALID_BLOCK(m) TRACE_EVENT_P1 ("VALID BLOCK %d", m)
70 #define ALR_TRACE_MAIN_SI_UNEQ(c) TRACE_EVENT_P1 ("si uneq %d", c)
71 #define ALR_TRACE_MAIN_CR(m) TRACE_EVENT_P1 ("VALID BLOCK CR %d",m)
72 #define ALR_TRACE_MAIN_RACH(p,t) TRACE_EVENT_P2 ("powerclass gsm %d txpwr %d", p, t)
73 #define ALR_TRACE_MAIN_POWER_CNF { USHORT i; \
74 TRACE_EVENT_P1 ("power cnf: %d channels", mph_power_cnf->num_of_chan)\
75 for (i = 0; i < mph_power_cnf->num_of_chan; i++) { \
76 TRACE_EVENT_P2 ("rx_lev[%4d]= %d", \
77 mph_power_cnf->arfcn[i]&ARFCN_MASK, \
78 mph_power_cnf->rx_lev[i]);} }
79 #define ALR_TRACE_MAIN_RA_CNF(t1,t2,t3) TRACE_EVENT_P3 ("af: %d %d %d", t1,t2,t3)
80
81 #else /* TRACING */
82
83 #define ALR_TRACE_MAIN_BSIC_REQ(s)
84 #define ALR_TRACE_MAIN_RAND_ACC(s,m)
85 #define ALR_TRACE_MAIN_SCELL(o,s)
86 #define ALR_TRACE_MAIN_VALID_BLOCK(m)
87 #define ALR_TRACE_MAIN_SI_UNEQ(c)
88 #define ALR_TRACE_MAIN_CR(m)
89 #define ALR_TRACE_MAIN_RACH(p,t)
90 #define ALR_TRACE_MAIN_POWER_CNF
91 #define ALR_TRACE_MAIN_RA_CNF(t1,t2,t3)
92
93 #endif /* TRACING */
94
95 /*==== EXPORT =====================================================*/
96
97 /*==== PRIVAT =====================================================*/
98
99 /*==== VARIABLES ==================================================*/
100 LOCAL UBYTE from_dedicated = FALSE;
101
102 /*==== FUNCTIONS ==================================================*/
103
104 LOCAL BOOL ma_compare_dedi_sys_buffer (T_MPHC_DATA_IND *mphc_data_ind,
105 UBYTE msg_t);
106 LOCAL void ma_fill_dedi_sys_buffer (T_MPHC_DATA_IND *mphc_data_ind,
107 UBYTE msg_t);
108 LOCAL void ma_stop_rxlev_periodic_req (void);
109 LOCAL BOOL ma_compare_sys_buffer (T_MPHC_DATA_IND *mphc_data_ind,
110 UBYTE msg_t);
111 LOCAL void ma_send_dedi_unitdata (T_MPHC_DATA_IND *data_ind);
112 LOCAL void ma_sync_ind (UBYTE cause, USHORT arfcn);
113 LOCAL void ma_fill_sys_buffer (T_MPHC_DATA_IND *data_ind, UBYTE msg_t);
114 LOCAL void ma_dedi_data_out (T_PH_DATA_IND *data_ind);
115
116 /*
117 +--------------------------------------------------------------------+
118 | PROJECT : GSM-PS (6103) MODULE : ALR_CS |
119 | STATE : code ROUTINE : ma_init |
120 +--------------------------------------------------------------------+
121
122 PURPOSE : Initialize Main Control.
123
124 */
125
126 GLOBAL void ma_init (void)
127 {
128 memset (alr_data, 0, sizeof (T_ALR_DATA));
129 alr_data->state[STATE_MA] = MA_NULL;
130
131 alr_data->mmi = 2; /* EVA 4 Board */
132 alr_data->keypad = 2; /* EVA 4 Board */
133 alr_data->ext_display = FALSE; /* internal display */
134 alr_data->pch_data.last_start_ccch_req.bs_pa_mfrms = NOT_PRESENT_8BIT;
135 ma_clean_sys_buffer (IND_ALL_SI);
136 ma_clean_dedi_sys_buffer ();
137 }
138
139 /*
140 +--------------------------------------------------------------------+
141 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
142 | STATE : code ROUTINE : ma_mph_idle_req |
143 +--------------------------------------------------------------------+
144
145 PURPOSE : Process the primitive MPH_IDLE_REQ.
146
147 */
148
149 UBYTE v_eotd = 0; /* for test automation */
150
151 GLOBAL void ma_mph_idle_req (T_MPH_IDLE_REQ* idle)
152 {
153 if(idle->mod EQ MODE_CELL_SELECTION)
154 alr_data->nc_data.eotd_avail = idle->eotd_avail | v_eotd;
155
156 switch (GET_STATE (STATE_MA))
157 {
158 case MA_DEDICATED:
159 ALR_TRACE_MAIN ("leave dedi");
160 ma_stop_active_procs(DONT_STOP_PCH_READING);
161 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
162 nc_new_serving_cell (idle->arfcn);
163
164 switch(idle->mod)
165 {
166 case MODE_CELL_RESELECTION:
167 ALR_TRACE_MAIN ("CR");
168 trc_state_transition(__LINE__, MA_CELL_RESELECTION);
169 SET_STATE (STATE_MA, MA_CELL_RESELECTION);
170 #ifdef GPRS
171 /*
172 * if going to a PBCCH cell we have to update the
173 * ncell states with GRR
174 */
175 alr_data->nc_sync_with_grr = TRUE;
176 gprs_alr_init();
177 #endif
178 from_dedicated = TRUE;
179 rach_init ();
180 rach_configure_power (idle->power);
181 pch_configure (idle, PGM_REORG);
182 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
183 nc_suspend (); /* to set the nc state */
184 nc_start_reselect (idle->arfcn);
185 break;
186 case MODE_CELL_SELECTION:
187 ALR_TRACE_MAIN ("CS");
188 if (idle->arfcn NEQ alr_data->old_serving_cell)
189 {
190 ALR_TRACE_MAIN ("CS but different cell!!!");
191 }
192 trc_state_transition(__LINE__, MA_IDLE);
193 SET_STATE(STATE_MA, MA_IDLE);
194 nc_suspend(); /* stop dedicated mode activity */
195 nc_add_offset();
196 #ifdef GPRS
197 set_gprs_support(idle->gprs_support);
198 #endif
199 pch_configure (idle, SAVED_PGM);
200 pch_start_ccch_req();
201 cb_start();
202
203 nc_start_monitoring();
204 break;
205 #ifdef GPRS
206 case MODE_CONFIG_PL: /* Cell has PBCCH */
207 ma_stop_active_procs(STOP_PCH_READING);
208 nc_suspend(); /* stop dedicated mode activity */
209 gprs_alr_init();
210 set_gprs_support(idle->gprs_support);
211 alr_data->gprs_data.pbcch = TRUE;
212 nc_add_offset(); /* convert counters */
213
214
215 rach_init ();
216 rach_configure_power (idle->power);
217 pch_configure (idle, PGM_NORMAL);
218 alr_data->nc_sync_with_grr = TRUE;
219 SET_STATE(STATE_MA, MA_IDLE);
220 break;
221 #endif
222 default:
223 break;
224 }
225 break;
226 case MA_CON_EST:
227 #ifdef GPRS
228 if(idle->mod EQ MODE_PACKET_TRANSFER) /* transition to PTM */
229 { /*
230 * NC BCCH reading doesn't need to be stopped, because it has
231 * already been stopped when entering MA_CON_EST
232 */
233 ma_stop_active_procs(STOP_PCH_READING);
234 SET_STATE (STATE_MA, MA_PTM);
235 }
236 else
237 {
238 #endif /* GPRS */
239 ma_stop_active_procs(DONT_STOP_PCH_READING);
240 rach_configure_power (idle->power);
241 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
242 nc_new_serving_cell (idle->arfcn);
243 #ifdef GPRS
244 if(idle->mod EQ MODE_CONFIG_PL)
245 {
246 ma_stop_active_procs(STOP_PCH_READING);
247 gprs_alr_init();
248 set_gprs_support(idle->gprs_support);
249 alr_data->gprs_data.pbcch = TRUE;
250 rach_init ();
251 rach_configure_power (idle->power);
252 pch_configure (idle, PGM_NORMAL);
253 SET_STATE(STATE_MA, MA_IDLE);
254 }
255 else
256 {
257 #endif
258 if (idle->arfcn EQ alr_data->old_serving_cell)
259 {
260 /* coming back after RACH failure */
261 trc_state_transition(__LINE__, MA_IDLE);
262 SET_STATE (STATE_MA, MA_IDLE);
263 #ifdef GPRS
264 set_gprs_support(idle->gprs_support);
265 #endif
266 pch_configure (idle, SAVED_PGM);
267 pch_start_ccch_req();
268 cb_start();
269 nc_start_monitoring();
270 }
271 else
272 {
273 trc_state_transition(__LINE__, MA_CELL_RESELECTION);
274 SET_STATE (STATE_MA, MA_CELL_RESELECTION);
275 #ifdef GPRS
276 /*
277 * if going to a PBCCH cell we have to update the
278 * ncell states with GRR
279 */
280 alr_data->nc_sync_with_grr = TRUE;
281 gprs_alr_init();
282 #endif
283 pch_configure (idle, PGM_REORG);
284 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
285 nc_start_reselect (idle->arfcn);
286 }
287 #ifdef GPRS
288 }
289 }
290 #endif
291 break;
292 case MA_CELL_SELECTION:
293 TRACE_EVENT_P1 ("SC[%u] in use, leave CS", idle->arfcn);
294
295 #ifdef GPRS
296 if(idle->mod EQ MODE_CONFIG_PL)
297 {
298 ma_stop_active_procs(STOP_PCH_READING);
299 gprs_alr_init();
300 set_gprs_support(idle->gprs_support);
301 alr_data->gprs_data.pbcch = TRUE;
302 rach_init ();
303 rach_configure_power (idle->power);
304 nc_new_serving_cell (idle->arfcn);
305 pch_configure (idle, PGM_NORMAL);
306 SET_STATE(STATE_MA, MA_IDLE);
307 break;
308 }
309 #endif
310
311 ALR_EM_CONFIGURE_IDLE_MODE;
312
313 ma_stop_active_procs(DONT_STOP_PCH_READING);
314
315 trc_state_transition(__LINE__, MA_IDLE);
316 SET_STATE (STATE_MA, MA_IDLE);
317 #ifdef GPRS
318 alr_data->nc_sync_with_grr=FALSE;
319 set_gprs_support(idle->gprs_support);
320 #endif
321 rach_configure_power (idle->power);
322 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
323 nc_check_new_ncc_permitted (idle->ncc_permitted);
324 nc_new_serving_cell (idle->arfcn);
325 pch_configure (idle, PGM_REORG_CS);
326 pch_save_pgm(0); /* reset saved pgm to REORG_CS */
327 pch_start_ccch_req();
328 /*
329 * nc_start_monitoring will be called when ncell list from RR
330 * is received
331 */
332 break;
333
334 case MA_IDLE:
335 switch (idle->mod)
336 {
337 #ifdef GPRS
338 case MODE_PACKET_TRANSFER: /* transition to PTM */
339 /*NC BCCH reading will be stopped when leaving idle*/
340 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
341 SET_STATE (STATE_MA, MA_PTM);
342 break;
343 case MODE_CONFIG_PL:
344 ma_stop_active_procs(STOP_PCH_READING|STOP_MEASUREMENTS);
345 gprs_alr_init();
346 set_gprs_support(idle->gprs_support);
347 if(!alr_data->gprs_data.pbcch)
348 { /* PBCCH activated in cell */
349 alr_data->nc_sync_with_grr = TRUE;
350 alr_data->gprs_data.pbcch = TRUE;
351 }
352 /* else */
353 rach_init ();
354 rach_configure_power (idle->power);
355 pch_configure (idle, PGM_NORMAL);
356 SET_STATE(STATE_MA, MA_IDLE);
357 break;
358 #endif /* GPRS */
359
360 case MODE_CELL_RESELECTION:
361 ALR_TRACE_MAIN ("idle mode cr");
362
363 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
364
365 trc_state_transition(__LINE__, MA_CELL_RESELECTION);
366 SET_STATE (STATE_MA, MA_CELL_RESELECTION);
367 #ifdef GPRS
368 /*
369 * if going to a PBCCH cell we have to update the
370 * ncell states with GRR
371 */
372 alr_data->nc_sync_with_grr = TRUE;
373 gprs_alr_init();
374 #endif
375 rach_init ();
376 rach_configure_power (idle->power);
377 TRACE_EVENT("IDLE_REQ : Cell found after CR");
378 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
379 // nc_check_new_ncc_permitted(idle->ncc_permitted);
380 nc_new_serving_cell (idle->arfcn);
381 pch_configure (idle, PGM_REORG);
382 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
383 nc_start_reselect (idle->arfcn);
384 break;
385 #ifdef GPRS
386 case MODE_CELL_RESELECTION_SYNC_ONLY:
387 if(alr_data->gprs_data.pbcch)
388 {
389 alr_data->gprs_data.sync_only=1;
390 alr_data->gprs_data.ptm=0;
391 ma_stop_active_procs(STOP_PCH_READING);
392 trc_state_transition(__LINE__, MA_CELL_RESELECTION);
393 SET_STATE (STATE_MA, MA_CELL_RESELECTION);
394 nc_new_serving_cell (idle->arfcn);
395 nc_start_reselect (idle->arfcn);
396 }
397 break;
398 #endif
399 case MODE_SYS_INFO_CHANGE:
400 ALR_TRACE_MAIN ("idle mode sys info changed");
401 rach_init ();
402 rach_configure_power (idle->power);
403
404 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
405 nc_check_new_ncc_permitted (idle->ncc_permitted);
406
407 if((idle->tn/2) NEQ
408 (alr_data->pch_data.pl_idle.ccch_group)
409 #ifdef GPRS
410 OR alr_data->gprs_data.pbcch
411 #endif
412 )
413 {
414 /* stop CCCH reading beforehand */
415 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
416 #ifdef GPRS
417 gprs_alr_init();
418 set_gprs_support(idle->gprs_support);
419 #endif
420 pch_configure (idle, PGM_REORG_CS);
421 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
422 pch_start_ccch_req();
423
424 nc_start_monitoring ();
425 }
426 else
427 {
428 #ifdef GPRS
429 if(idle->reorg_only EQ NORMAL_PGM AND
430 alr_data->gprs_data.ign_pgm EQ TRUE)
431 {
432 /*
433 * use last page mode read on PCH
434 * when the NON_DRX_TIMER has expired
435 */
436 pch_configure (idle, SAVED_PGM);
437 pch_start_ccch_req();
438 alr_data->gprs_data.ign_pgm = FALSE;
439 }
440 else if(alr_data->gprs_data.ign_pgm EQ FALSE)
441 {
442 set_gprs_support(idle->gprs_support);
443 if(gprs_alr_is_supported())
444 {
445 gprs_alr_init();
446 set_gprs_support(idle->gprs_support);
447 ma_stop_scell_bcch_req();
448 }
449 #endif
450 pch_save_pgm(0); /* save current pgm */
451 pch_configure (idle, SAVED_PGM);
452 pch_start_ccch_req();
453 #ifdef GPRS
454 }
455 /* other case should not happen */
456 #endif
457
458 }
459 break;
460 case MODE_CELL_SELECTION:
461 /* XXX does not seem to be used by RR*/
462 break;
463 default:
464 break;
465 }
466 break;
467 case MA_CELL_RESELECTION:
468 switch(idle->mod)
469 {
470 case MODE_CELL_SELECTION:
471
472 ALR_TRACE_MAIN ("from cr use cell");
473 /* we have found a suitable cell */
474 ma_stop_active_procs(DONT_STOP_PCH_READING);
475 rach_init ();
476 rach_configure_power (idle->power);
477 TRACE_EVENT("IDLE_REQ : PM config after CR");
478 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
479 nc_check_new_ncc_permitted (idle->ncc_permitted);
480 if (from_dedicated)
481 {
482 from_dedicated = FALSE;
483 nc_add_offset ();
484 }
485 pch_configure (idle, SAVED_PGM);
486 pch_start_ccch_req();
487
488 trc_state_transition(__LINE__, MA_IDLE);
489 SET_STATE (STATE_MA, MA_IDLE);
490 #ifdef GPRS
491 alr_data->nc_sync_with_grr=FALSE;
492 set_gprs_support(idle->gprs_support);
493 #endif
494
495 /*
496 * resume neighbourcell operation
497 */
498 nc_start_monitoring ();
499 break;
500 case MODE_CELL_RESELECTION:
501 /* the last cell wasn't the right one, try again */
502 ma_stop_active_procs(STOP_PCH_READING);/* don´t forget to stop all processes */
503 #ifdef GPRS
504 gprs_alr_init();
505 #endif
506 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
507 // nc_check_new_ncc_permitted (idle->ncc_permitted);
508 nc_new_serving_cell (idle->arfcn);
509 pch_configure (idle, PGM_REORG);
510 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
511 nc_start_reselect (idle->arfcn);
512 break;
513 #ifdef GPRS
514 case MODE_CONFIG_PL:
515 ma_stop_active_procs(STOP_PCH_READING);
516 if (from_dedicated) from_dedicated = FALSE;
517
518 gprs_alr_init();
519 set_gprs_support(idle->gprs_support);
520 alr_data->gprs_data.pbcch = TRUE;
521 rach_init ();
522 rach_configure_power (idle->power);
523 pch_configure (idle, PGM_NORMAL);
524 SET_STATE(STATE_MA, MA_IDLE);
525 break;
526 #endif
527 default:
528 break;
529 }
530 break;
531 #ifdef GPRS
532 case MA_PTM:
533 /* back to packet idle */
534 ma_stop_active_procs(DONT_STOP_PCH_READING);
535 rach_configure_power (idle->power);
536 alr_data->bs_pa_mfrms = idle->bs_pa_mfrms;
537 nc_new_serving_cell (idle->arfcn);
538 nc_suspend();
539 if (idle->arfcn EQ alr_data->old_serving_cell)
540 {
541 trc_state_transition(__LINE__, MA_IDLE);
542 SET_STATE(STATE_MA, MA_IDLE);
543 #ifdef GPRS
544 set_gprs_support(idle->gprs_support);
545 #endif
546
547 if(idle->reorg_only EQ REORG_ONLY)
548 {
549 pch_configure (idle, PGM_REORG_CS);
550 alr_data->gprs_data.ign_pgm = TRUE;
551 }
552 else
553 {
554 pch_configure (idle, SAVED_PGM);
555 alr_data->gprs_data.ign_pgm = FALSE;
556 }
557 pch_start_ccch_req();
558 cb_start();
559 nc_start_monitoring();
560 }
561 else
562 {
563 trc_state_transition(__LINE__, MA_CELL_RESELECTION);
564 SET_STATE (STATE_MA, MA_CELL_RESELECTION);
565 #ifdef GPRS
566 /*
567 * if going to a PBCCH cell we have to update the
568 * ncell states with GRR
569 */
570 alr_data->nc_sync_with_grr = TRUE;
571 gprs_alr_init();
572 #endif
573 pch_configure (idle, PGM_REORG);
574 pch_save_pgm(PGM_REORG_CS); /* reset saved pgm to REORG_CS */
575 nc_start_reselect (idle->arfcn);
576 }
577 break;
578 #endif
579 default:
580 break;
581 }
582 PFREE (idle);
583 }
584
585
586 /*
587 +--------------------------------------------------------------------+
588 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
589 | STATE : code ROUTINE : ma_mph_neighbourcell_req |
590 +--------------------------------------------------------------------+
591
592 PURPOSE : Process the primitive MPH_NEIGHBOURCELL_REQ.
593
594 */
595
596 GLOBAL void ma_mph_neighbourcell_req (T_MPH_NEIGHBOURCELL_REQ* mph_neighbourcell_req)
597 {
598 switch (GET_STATE (STATE_MA))
599 {
600 case MA_IDLE:
601 case MA_DEDICATED:
602 #ifdef GPRS
603 case MA_PTM:
604 #endif
605 nc_ncell_list (mph_neighbourcell_req);
606
607 ALR_EM_CONFIGURE_NEIGHBOUERCELL_LIST;
608
609 break;
610
611 default:
612 break;
613 }
614 PFREE (mph_neighbourcell_req);
615 }
616
617
618 /*
619 +--------------------------------------------------------------------+
620 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
621 | STATE : code ROUTINE : ma_mph_dedicated_req |
622 +--------------------------------------------------------------------+
623
624 PURPOSE : Process the primitive MPH_DEDICATED_REQ.
625
626 */
627
628 GLOBAL void ma_mph_dedicated_req (T_MPH_DEDICATED_REQ* dedi)
629 {
630 switch (GET_STATE (STATE_MA))
631 {
632 case MA_CON_EST:
633 ALR_TRACE_MAIN ("dedi on");
634
635 ma_stop_active_procs (STOP_PCH_READING);
636 trc_state_transition(__LINE__, MA_DEDICATED);
637 SET_STATE (STATE_MA, MA_DEDICATED);
638 dedi_req (dedi);
639 ma_clean_dedi_sys_buffer ();
640 nc_start_dedicated (dedi->tr_para.pwrc, dedi->tr_para.dtx);
641 break;
642
643 case MA_DEDICATED:
644 dedi_req (dedi);
645 break;
646
647 default:
648 break;
649 }
650 PFREE (dedi);
651 }
652
653
654 /*
655 +--------------------------------------------------------------------+
656 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
657 | STATE : code ROUTINE : ma_mph_dedicated_fail_req |
658 +--------------------------------------------------------------------+
659
660 PURPOSE : Process the primitive MPH_DEDICATED_FAIL_REQ.
661
662 */
663
664 GLOBAL void ma_mph_dedicated_fail_req (T_MPH_DEDICATED_FAIL_REQ* mph_dedicated_fail_req)
665 {
666 dedi_fail_req ();
667 PFREE (mph_dedicated_fail_req);
668 }
669
670
671 /*
672 +--------------------------------------------------------------------+
673 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
674 | STATE : code ROUTINE : ma_mph_ciphering_req |
675 +--------------------------------------------------------------------+
676
677 PURPOSE : Process the primitive MPH_CIPHERING_REQ.
678
679 */
680
681 GLOBAL void ma_mph_ciphering_req (T_MPH_CIPHERING_REQ* mph_ciphering_req)
682 {
683 dedi_ciph_req (mph_ciphering_req);
684 PFREE(mph_ciphering_req);
685 }
686
687 /*
688 +--------------------------------------------------------------------+
689 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
690 | STATE : code ROUTINE : ma_mph_freq_redef_req |
691 +--------------------------------------------------------------------+
692
693 PURPOSE : Process the primitive MPH_FREQ_REDEF_REQ.
694
695 */
696
697 GLOBAL void ma_mph_freq_redef_req (T_MPH_FREQ_REDEF_REQ* mph_freq_redef_req)
698 {
699 dedi_freq_redef_req(mph_freq_redef_req);
700 PFREE(mph_freq_redef_req);
701 }
702
703 /*
704 +--------------------------------------------------------------------+
705 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
706 | STATE : code ROUTINE : ma_mph_channel_mode_req |
707 +--------------------------------------------------------------------+
708
709 PURPOSE : Process the primitive MPH_CHANNEL_MODE_REQ.
710
711 */
712
713 GLOBAL void ma_mph_channel_mode_req (T_MPH_CHANNEL_MODE_REQ* mph_channel_mode_req)
714 {
715 dedi_chan_mode_req (mph_channel_mode_req);
716 PFREE(mph_channel_mode_req);
717 }
718
719
720 /*
721 +--------------------------------------------------------------------+
722 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
723 | STATE : code ROUTINE : ma_mph_deactivate_req |
724 +--------------------------------------------------------------------+
725
726 PURPOSE : Process the primitive MPH_DEACTIVATE_REQ.
727
728 */
729
730 GLOBAL void ma_mph_deactivate_req (T_MPH_DEACTIVATE_REQ* mph_deactivate_req)
731 {
732 UBYTE flags = 0;
733 PREUSE (mph_deactivate_req, mphc_deactivate_req, MPHC_DEACTIVATE_REQ);
734
735 if (alr_data->pch_data.last_start_ccch_req.bs_pa_mfrms NEQ NOT_PRESENT_8BIT)
736 flags |= STOP_PCH_READING;
737
738 switch (GET_STATE(STATE_MA))
739 {
740 case MA_CELL_SELECTION:
741 case MA_CELL_RESELECTION:
742 case MA_CON_EST:
743 case MA_DEDICATED:
744 #ifdef GPRS
745 case MA_PTM:
746 #endif
747 break;
748 case MA_IDLE:
749 #ifdef GPRS
750 if (alr_data->gprs_data.pbcch EQ TRUE)
751 break;
752 #endif
753 /*lint -fallthrough*/
754 default:
755 flags |= STOP_MEASUREMENTS;
756 break;
757 }
758
759 ma_stop_active_procs(flags);
760
761 ALR_EM_DEACTIVATE_L1;
762
763 /*
764 * There is no activation request for ALR. Therefore ALR is prepared
765 * here for the next powering on by stopping really all running processes
766 * and reinitialising the state variables.
767 */
768 nc_stop ();
769
770 cb_init ();
771 cs_init ();
772 pch_init ();
773 dedi_init ();
774 SET_STATE(STATE_MA, MA_NULL); /* it isn't clear whether the whole ma_init() should be performed */
775 ma_clean_sys_buffer (IND_ALL_SI);
776 ma_clean_dedi_sys_buffer ();
777
778 PSENDX(L1, mphc_deactivate_req);
779 }
780
781
782 /*
783 +--------------------------------------------------------------------+
784 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
785 | STATE : code ROUTINE : ma_mph_classmark_req |
786 +--------------------------------------------------------------------+
787
788 PURPOSE : Process the primitive MPH_CLASSMARK_REQ.
789
790 */
791
792 GLOBAL void ma_mph_classmark_req (T_MPH_CLASSMARK_REQ* classmark)
793 {
794 rach_configure_class (classmark->classmark.pclass,
795 classmark->classmark.pclass2);
796
797 ALR_EM_CONFIGURE_CLASSMARK;
798
799 PFREE (classmark);
800 }
801
802
803 /*
804 +--------------------------------------------------------------------+
805 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
806 | STATE : code ROUTINE : ma_mph_ext_meas_req |
807 +--------------------------------------------------------------------+
808
809 PURPOSE : Process the primitive MPH_EXT_MEAS_REQ.
810
811 */
812
813 GLOBAL void ma_mph_ext_meas_req (T_MPH_EXT_MEAS_REQ* mph_ext_meas_req)
814 {
815 /* Process CS must be state CS_NULL (no Cell Selection active) */
816
817 if ( GET_STATE ( STATE_CS ) EQ CS_NULL )
818 {
819 mph_ext_meas_req->pch_interrupt = NO_PCH_INTERRUPT;
820
821 /* alr_data->cs_data.mph_ext_meas_req must be NULL */
822
823 if ( IS_EXT_MEAS_RUNNING ) /*alr_data->cs_data.mph_ext_meas_req NEQ NULL*/
824 {
825 PFREE ( alr_data->cs_data.mph_ext_meas_req );
826 }
827 alr_data->cs_data.mph_ext_meas_req = mph_ext_meas_req;
828 alr_data->cs_data.ext_meas_state_pend = CS_NULL;
829
830 ma_mph_power_req((T_MPH_POWER_REQ*) mph_ext_meas_req);
831 }
832 else
833 {
834 PALLOC ( mph_ext_meas_cnf, MPH_EXT_MEAS_CNF );
835 mph_ext_meas_cnf->num_of_chan = 0;
836 PSENDX ( RR, mph_ext_meas_cnf );
837
838 PFREE (mph_ext_meas_req);
839 }
840 }
841
842 /*
843 +--------------------------------------------------------------------+
844 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
845 | STATE : code ROUTINE : ma_mph_tch_loop_req |
846 +--------------------------------------------------------------------+
847
848 PURPOSE : Process the primitive MPH_TCH_LOOP_REQ.
849
850 */
851
852 GLOBAL void ma_mph_tch_loop_req (T_MPH_TCH_LOOP_REQ* mph_tch_loop_req)
853 {
854 dedi_tch_loop_req (mph_tch_loop_req);
855 PFREE(mph_tch_loop_req);
856 }
857
858
859 /*
860 +--------------------------------------------------------------------+
861 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
862 | STATE : code ROUTINE : ma_mph_dai_req |
863 +--------------------------------------------------------------------+
864
865 PURPOSE : Process the primitive MPH_DAI_REQ.
866
867 */
868
869 GLOBAL void ma_mph_dai_req (T_MPH_DAI_REQ* mph_dai_req)
870 {
871 dedi_dai_req (mph_dai_req);
872 PFREE(mph_dai_req);
873 }
874
875 /*
876 +--------------------------------------------------------------------+
877 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
878 | STATE : code ROUTINE : ma_mph_cbch_req |
879 +--------------------------------------------------------------------+
880
881 PURPOSE : Process the primitive MPH_CBCH_REQ.
882
883 */
884
885
886 GLOBAL void ma_mph_cbch_req (T_MPH_CBCH_REQ* cbch_req)
887 {
888 cb_mph_cbch_req( &cbch_req->cbch);
889 PFREE (cbch_req);
890 }
891
892 /*
893 +--------------------------------------------------------------------+
894 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
895 | STATE : code ROUTINE : ma_mph_identity_req |
896 +--------------------------------------------------------------------+
897
898 PURPOSE : Process the primitive MPH_IDENTITY_REQ.
899
900 */
901
902 GLOBAL void ma_mph_identity_req (T_MPH_IDENTITY_REQ* mph_identity_req)
903 {
904 pch_identity_req (mph_identity_req);
905 PFREE (mph_identity_req);
906 }
907
908 /*
909 +--------------------------------------------------------------------+
910 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
911 | STATE : code ROUTINE : ma_mph_sync_req |
912 +--------------------------------------------------------------------+
913
914 PURPOSE : Process the primitive MPH_SYNC_REQ.
915
916 */
917
918 GLOBAL void ma_mph_sync_req (T_MPH_SYNC_REQ* mph_sync_req)
919 {
920 switch (mph_sync_req->cs)
921 {
922 case CS_CLEAN_SYS_INFO:
923 /*
924 * clean stored system information messages to force
925 * sending to RR.
926 */
927 ma_clean_dedi_sys_buffer ();
928 break;
929
930 case CS_STOP_BCCH_READING:
931 switch (GET_STATE (STATE_MA))
932 {
933 case MA_CELL_SELECTION:
934 cs_stop ();
935 break;
936 case MA_IDLE:
937 nc_stop_rr_activity (FALSE);
938 break;
939 }
940 break;
941
942 case CS_STOP_PLMN_SEARCH:
943 switch (GET_STATE (STATE_MA))
944 {
945 case MA_CELL_SELECTION:
946 cs_stop ();
947 break;
948 case MA_IDLE:
949 /*
950 * PLMN search is stopped. If mobile was in REORG before
951 * PLMN search, this is set again after finishing all BCCH reading.
952 */
953 if(alr_data->pch_data.pl_idle.page_mode EQ PGM_REORG_NC_SYNC)
954 {
955 alr_data->pch_data.pl_idle.page_mode = page_mode_before_hplmn_search;
956 pch_start_ccch_req ();
957 ALR_TRACE_MAIN ("PLMN search complete - REORG reestablished");
958 }
959 cs_stop ();
960 nc_stop_rr_activity (TRUE);
961 break;
962 }
963 break;
964 case CS_STOP_PLMN_SEARCH_AND_DEACTIVATE:
965 switch (GET_STATE (STATE_MA))
966 {
967 case MA_CELL_SELECTION:
968 cs_stop ();
969 break;
970 case MA_IDLE:
971 /*
972 * If mobile was in REORG before PLMN search, this is set again after
973 * finishing PLMN search. L1 is not configured, because PCH reading
974 * is stopped anyway
975 */
976 if(alr_data->pch_data.pl_idle.page_mode EQ PGM_REORG_NC_SYNC)
977 {
978 alr_data->pch_data.pl_idle.page_mode = page_mode_before_hplmn_search;
979 ALR_TRACE_MAIN ("PLMN search complete - REORG reestablished");
980 }
981 cs_stop ();
982 nc_stop_rr_activity (TRUE);
983 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
984 break;
985 }
986 {
987 PALLOC(deact_req, MPHC_DEACTIVATE_REQ);
988 PSENDX(L1, deact_req);
989 }
990 break;
991 #ifdef GPRS
992 case CS_START_PCCO:
993 alr_data->gprs_data.pcco_active = TRUE;
994 if ( GET_STATE(STATE_MA) EQ MA_PTM )
995 {
996 ma_stop_active_procs(STOP_MEASUREMENTS |STOP_PCH_READING);
997 SET_STATE(STATE_MA, MA_IDLE);
998 }
999 break;
1000 #endif
1001 case CS_RXLEV_VAL_REQ:
1002 switch (GET_STATE(STATE_MA))
1003 {
1004 #ifdef GPRS
1005 case MA_PTM:
1006 case MA_IDLE:
1007 break;
1008 #endif /* GPRS */
1009 case MA_DEDICATED:
1010 /* EMO */
1011 break;
1012 }
1013 break;
1014 default:
1015 break;
1016 }
1017
1018 PFREE (mph_sync_req);
1019 }
1020
1021 /*
1022 +--------------------------------------------------------------------+
1023 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1024 | STATE : code ROUTINE : ma_mph_clean_buf_req |
1025 +--------------------------------------------------------------------+
1026
1027 PURPOSE : Process the primitive MPH_CLEAN_BUF_REQ.
1028
1029 */
1030
1031 GLOBAL void ma_mph_clean_buf_req (T_MPH_CLEAN_BUF_REQ* mph_clean_buf_req)
1032 {
1033 ma_clean_sys_buffer(mph_clean_buf_req->si_to_clean);
1034 PFREE(mph_clean_buf_req);
1035 }
1036
1037 /*
1038 +--------------------------------------------------------------------+
1039 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1040 | STATE : code ROUTINE : ma_mph_stop_dedi_req |
1041 +--------------------------------------------------------------------+
1042
1043 PURPOSE : Process the primitive MPH_STOP_DEDICATED_REQ.
1044
1045 */
1046 GLOBAL void ma_mph_stop_dedi_req(T_MPH_STOP_DEDICATED_REQ *stop_dedi)
1047 {
1048 dedi_stop();
1049 PFREE(stop_dedi);
1050 }
1051
1052 /*
1053 +--------------------------------------------------------------------+
1054 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1055 | STATE : code ROUTINE : ma_mph_power_req |
1056 +--------------------------------------------------------------------+
1057
1058 PURPOSE : Process the primitive MPH_POWER_REQ and MPH_EXT_MEAS_REQ.
1059
1060 */
1061
1062 GLOBAL void ma_mph_power_req(T_MPH_POWER_REQ* mph_power_req)
1063 {
1064 if ( D_OPC(mph_power_req) EQ MPH_POWER_REQ && IS_EXT_MEAS_RUNNING )
1065 {
1066 PALLOC ( mph_power_cnf, MPH_POWER_CNF );
1067 mph_power_cnf->num_of_chan = 0;
1068 PSENDX ( RR, mph_power_cnf );
1069 TRACE_ERROR ( "Cell Sel during Ext Meas");
1070 PFREE (mph_power_req);
1071 return;
1072 }
1073
1074 if (mph_power_req->freq_bands EQ 0)
1075 {
1076 TRACE_ERROR ("MPH_POWER_REQ with freq_bands=0 (Invalid value)!");
1077 TRACE_ASSERT (mph_power_req->freq_bands EQ 0);
1078 }
1079
1080 if(!IS_EXT_MEAS_RUNNING)
1081 {
1082 /* CSI-LLD Section : 4.1.3.4.2.2 */
1083 if(alr_data->cs_data.p_power_req NEQ NULL)
1084 {
1085 TRACE_ERROR("MPH_POWER_REQ buffer leakage");
1086 PFREE(alr_data->cs_data.p_power_req);
1087 }
1088 /* Store the MPH_POWER_REQ pointer for later usage */
1089 alr_data->cs_data.p_power_req = mph_power_req;
1090 }
1091
1092 alr_data->cs_data.freq_bands = mph_power_req->freq_bands;
1093
1094 ALR_EM_POWER_MEASSUREMENT_REQUEST;
1095
1096 switch (mph_power_req->pch_interrupt)
1097 {
1098 case NO_PCH_INTERRUPT:
1099 /*
1100 * Full list power measurements without changing the current state
1101 */
1102 alr_data->plmn_search_running = TRUE;
1103 nc_suspend();
1104 cs_power_req (NO_PCH_INTERRUPT);
1105 break;
1106 case PCH_INTERRUPT:
1107 /*
1108 * Full list power measurements for Cell Selection
1109 */
1110 alr_data->plmn_search_running = FALSE;
1111 #ifdef GPRS
1112 gprs_alr_init();
1113 #endif
1114 switch (GET_STATE(STATE_MA))
1115 {
1116 case MA_NULL:
1117 case MA_CELL_SELECTION:
1118 ma_stop_active_procs(DONT_STOP_PCH_READING);
1119 SET_STATE(STATE_MA, MA_CELL_SELECTION);
1120 cs_power_req (PCH_INTERRUPT);
1121 break;
1122 case MA_CELL_RESELECTION:
1123 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
1124 nc_stop();
1125 SET_STATE(STATE_MA, MA_CELL_SELECTION);
1126 cs_power_req (PCH_INTERRUPT);
1127 break;
1128 case MA_CON_EST:
1129 case MA_DEDICATED:
1130 case MA_IDLE:
1131 #ifdef GPRS
1132 case MA_PTM:
1133 alr_data->nc_sync_with_grr = TRUE;
1134 #endif
1135 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS);
1136 /*
1137 * call this explicitly here, because stop_active_procs only
1138 * suspends ncell procedures
1139 */
1140 nc_stop();
1141 SET_STATE(STATE_MA, MA_CELL_SELECTION);
1142 cs_power_req (PCH_INTERRUPT);
1143 break;
1144 default:
1145 if(!IS_EXT_MEAS_RUNNING)
1146 {
1147 PFREE (mph_power_req);
1148 alr_data->cs_data.p_power_req = NULL;
1149 TRACE_ERROR ("MPH_POWER_REQ received in invalid MA state");
1150 }
1151 break;
1152 }
1153 break;
1154 default:
1155 if(!IS_EXT_MEAS_RUNNING)
1156 {
1157 PFREE (mph_power_req);
1158 alr_data->cs_data.p_power_req = NULL;
1159 TRACE_ERROR ("MPH_POWER_REQ: Invalid search type");
1160 }
1161 break;
1162 }
1163 }
1164
1165 /*
1166 +--------------------------------------------------------------------+
1167 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1168 | STATE : code ROUTINE : ma_mph_bsic_req |
1169 +--------------------------------------------------------------------+
1170
1171 PURPOSE : Process the primitive MPH_BSIC_REQ.
1172
1173 */
1174
1175 GLOBAL void ma_mph_bsic_req (T_MPH_BSIC_REQ* mph_bsic_req)
1176 {
1177 ALR_TRACE_MAIN_BSIC_REQ (GET_STATE(STATE_MA));
1178
1179 #ifdef GPRS
1180 if(alr_data->gprs_data.pcco_active)
1181 {
1182 cs_bsic_req(mph_bsic_req);
1183 PFREE (mph_bsic_req);
1184 return;
1185 }
1186 #endif
1187
1188 switch (GET_STATE (STATE_MA))
1189 {
1190 case MA_CELL_SELECTION:
1191 cs_bsic_req (mph_bsic_req);
1192 break;
1193 case MA_IDLE:
1194 nc_bsic_req (mph_bsic_req);
1195 break;
1196 #ifdef GPRS
1197 case MA_DEDICATED:
1198
1199 ma_stop_active_procs(STOP_PCH_READING | STOP_MEASUREMENTS); /* DEDI-state is now DEDI_INACTIVE */
1200 /* DEDI-state is now DEDI_INACTIVE */
1201 SET_STATE(STATE_NC, NC_NULL);
1202 #ifdef NOT_YET
1203 nc_suspend(); /* stop dedicated mode activity */
1204 #endif
1205
1206 SET_STATE(STATE_MA, MA_CELL_SELECTION);
1207 cs_bsic_req (mph_bsic_req);
1208 break;
1209 #endif
1210 default:
1211 break;
1212 }
1213
1214 PFREE (mph_bsic_req);
1215 }
1216
1217
1218 /*
1219 +--------------------------------------------------------------------+
1220 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1221 | STATE : code ROUTINE : ma_mph_meas_rep_req |
1222 +--------------------------------------------------------------------+
1223
1224 PURPOSE : Process the primitive MPH_MEAS_REP_REQ.
1225 */
1226
1227 #ifdef GPRS
1228 GLOBAL void ma_mph_meas_rep_req(T_MPH_MEAS_REP_REQ * mph_meas_rep_req)
1229 {
1230 USHORT i;
1231 TRACE_EVENT("mph_meas_rep_req");
1232
1233
1234 switch(mph_meas_rep_req->cause)
1235 {
1236 case NC_START_MEAS:
1237 /*
1238 * Reset nc mease results database
1239 */
1240 for(i=0;i<=BA_LIST_SIZE;i++)
1241 {
1242 alr_data->nc_data.cell[i].nc_rxlev = 0;
1243 alr_data->nc_data.cell[i].c_nc_rxlev = 0;
1244 }
1245 /*
1246 * activate rx_lev averaging when NC=1 or NC=2
1247 */
1248 alr_data->nwctrl_meas_active = TRUE;
1249 break;
1250 case NC_REPORT_MEAS:
1251 /*
1252 * Calculate rx_lev average and send the report to RR. RR forwards this to GRR
1253 */
1254 if(alr_data->nwctrl_meas_active)
1255 {
1256 PALLOC(mph_meas_rep_cnf, MPH_MEAS_REP_CNF);
1257 memset(mph_meas_rep_cnf,0,sizeof(T_MPH_MEAS_REP_CNF));
1258 nc_build_nwctrl_rr_report(mph_meas_rep_cnf);
1259 PSENDX ( RR, mph_meas_rep_cnf);
1260 for(i=0;i<=BA_LIST_SIZE;i++)
1261 {
1262 alr_data->nc_data.cell[i].nc_rxlev = 0;
1263 alr_data->nc_data.cell[i].c_nc_rxlev = 0;
1264 }
1265 }
1266 break;
1267 case NC_STOP_MEAS:
1268 /*
1269 * De-activate rx_lev averaging for Network control
1270 */
1271 alr_data->nwctrl_meas_active = FALSE;
1272 break;
1273 default:
1274 break;
1275 }
1276 PFREE(mph_meas_rep_req);
1277 }
1278 #endif
1279
1280
1281 /*
1282 +--------------------------------------------------------------------+
1283 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1284 | STATE : code ROUTINE : ma_mph_random_access_req |
1285 +--------------------------------------------------------------------+
1286
1287 PURPOSE : Process the primitive MPH_RANDOM_ACCESS_REQ.
1288
1289 */
1290
1291 GLOBAL void ma_mph_random_access_req (T_MPH_RANDOM_ACCESS_REQ* mph_random_access_req)
1292 {
1293 switch (GET_STATE (STATE_MA))
1294 {
1295 case MA_IDLE:
1296 ALR_TRACE_MAIN_RAND_ACC(alr_data->serving_cell, mph_random_access_req->send_mode.no);
1297
1298 /*
1299 * suspend neighbour cell procedures
1300 */
1301 ma_stop_active_procs(DONT_STOP_PCH_READING | STOP_MEASUREMENTS);
1302 SET_STATE (STATE_MA, MA_CON_EST);
1303 /*
1304 * switch to full downlink CCCH listening
1305 */
1306 pch_save_pgm(0);
1307 pch_configure(NULL, PGM_REORG_CS);
1308 pch_start_ccch_req ();
1309 /*
1310 * Send uplink Random Bursts
1311 */
1312 rach_random_req (mph_random_access_req);
1313 break;
1314 #ifdef GPRS
1315 case MA_PTM:
1316 ma_stop_active_procs(DONT_STOP_PCH_READING| STOP_MEASUREMENTS);
1317 // nc_suspend(); gprs_alr_nc_leave_ptm();
1318 SET_STATE (STATE_MA, MA_CON_EST);
1319 /*
1320 * switch to full downlink CCCH listening
1321 */
1322 /*pch_save_pgm(0);*/
1323 pch_configure(NULL, PGM_REORG_CS);
1324 pch_start_ccch_req ();
1325 /*
1326 * Send uplink Random Bursts
1327 */
1328 rach_random_req (mph_random_access_req);
1329 break;
1330 #endif
1331 case MA_CON_EST:
1332 SET_STATE (STATE_MA, MA_CON_EST);
1333 rach_random_req (mph_random_access_req);
1334 break;
1335
1336 default:
1337 break;
1338 }
1339
1340 PFREE (mph_random_access_req);
1341 }
1342
1343 /*
1344 +--------------------------------------------------------------------+
1345 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1346 | STATE : code ROUTINE : ma_mph_mph_emo_req |
1347 +--------------------------------------------------------------------+
1348
1349 PURPOSE : Process the primitive MPH_MPH_EMO_REQ.
1350
1351 */
1352
1353 GLOBAL void ma_mph_emo_req (T_MPH_EMO_REQ *mph_emo_req)
1354 {
1355 switch (GET_STATE (STATE_MA))
1356 {
1357 case MA_DEDICATED:
1358 {
1359 UBYTE i,n;
1360 USHORT *radio_freq;
1361 USHORT *arfcn;
1362 USHORT sc = alr_data->serving_cell;
1363 BOOL sc_ok;
1364 PALLOC (mphc_update_ba_list, MPHC_UPDATE_BA_LIST);
1365
1366 alr_data->dedi_data.emo_ba_id = mph_emo_req->ba_id;
1367
1368 n = mph_emo_req->c_arfcn;
1369 if ( n >= BA_LIST_SIZE )
1370 n = BA_LIST_SIZE;
1371
1372 /*
1373 * Initialize the outgoing primitive MPHC_UPDATE_BA_LIST.
1374 */
1375
1376 radio_freq = &mphc_update_ba_list->chan_list.radio_freq[0];
1377 arfcn = &mph_emo_req->arfcn[0];
1378 sc_ok = FALSE;
1379
1380 for ( i = 0; i < n; i++ )
1381 {
1382 radio_freq[i] = ARFCN_TO_L1 (arfcn[i]);
1383 if ( radio_freq[i] EQ sc )
1384 {
1385 sc_ok = TRUE;
1386 }
1387 }
1388 if ( !sc_ok AND n < BA_LIST_SIZE ) /* add the serving cell ARFCN */
1389 {
1390 radio_freq[n++] = sc;
1391 }
1392 mphc_update_ba_list->num_of_chans = n;
1393 mphc_update_ba_list->pwrc = alr_data->nc_data.pwrc;
1394 mphc_update_ba_list->dtx_allowed = alr_data->nc_data.dtx;
1395 mphc_update_ba_list->ba_id = mph_emo_req->ba_id;
1396
1397 PSENDX (L1, mphc_update_ba_list);
1398
1399 break;
1400 }
1401 }
1402 PFREE (mph_emo_req);
1403 }
1404 /*
1405 +--------------------------------------------------------------------+
1406 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1407 | STATE : code ROUTINE : ma_mph_mph_emo_req |
1408 +--------------------------------------------------------------------+
1409
1410 PURPOSE : Process the primitive MPH_MPH_EMO_REQ.
1411
1412 */
1413
1414 GLOBAL void ma_mph_ncell_pos_req (T_MPH_NCELL_POS_REQ *mph_ncell_pos_req)
1415 {
1416 nc_ncell_pos_req(mph_ncell_pos_req);
1417 }
1418 /* ------------------------------------------------------------------
1419 * ------------------------------------------------------------------
1420 * Functions for the lower layer(MPHC) primitive processing
1421 * ------------------------------------------------------------------
1422 * ------------------------------------------------------------------
1423 */
1424
1425
1426 /*
1427 +--------------------------------------------------------------------+
1428 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1429 | STATE : code ROUTINE : ma_mphc_rxlev_con |
1430 +--------------------------------------------------------------------+
1431
1432 PURPOSE : Process the primitive MPHC_RXLEV_CON.
1433
1434 */
1435
1436 GLOBAL void ma_mphc_rxlev_ind (T_MPHC_RXLEV_IND* rxlev_ind)
1437 {
1438 USHORT cs_state = GET_STATE (STATE_CS);
1439 switch (cs_state)
1440 {
1441 default:
1442 TRACE_EVENT_P1 ("wrong CS state (%u) in ma_mphc_rxlev_ind()", cs_state);
1443 /*lint -fallthrough*/
1444 case CS_ACTIVE_MEASURE:
1445 SET_STATE(STATE_CS, CS_MEASURED);
1446 break;
1447 }
1448
1449 ALR_EM_FIELDSTRENGTH_MEASUREMENT_CONFIRM;
1450 cs_rxlev_ind (rxlev_ind);
1451 PFREE (rxlev_ind);
1452 }
1453
1454 /*
1455 +--------------------------------------------------------------------+
1456 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1457 | STATE : code ROUTINE : ma_mphc_stop_rxlev_con |
1458 +--------------------------------------------------------------------+
1459
1460 PURPOSE : Process the primitive MPHC_RXLEV_CON.
1461
1462 */
1463
1464 GLOBAL void ma_mphc_stop_rxlev_cnf (T_MPHC_STOP_RXLEV_CON * rxlev_cnf)
1465 {
1466 if ( IS_EXT_MEAS_RUNNING )
1467 {
1468 nc_stop_ext_meas_ind();
1469 alr_data->cs_data.ext_meas_state_pend = CS_NULL;
1470 }
1471 PFREE(rxlev_cnf);
1472 }
1473
1474
1475 /*
1476 +--------------------------------------------------------------------+
1477 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1478 | STATE : code ROUTINE : ma_stop_cnf |
1479 +--------------------------------------------------------------------+
1480
1481 PURPOSE : Processes the primitives MPHC_STOP_*_CON.
1482
1483 */
1484
1485 GLOBAL void ma_mphc_empty_cnf (void *cnf)
1486 {
1487 PFREE (cnf);
1488 }
1489
1490 /*
1491 +--------------------------------------------------------------------+
1492 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1493 | STATE : code ROUTINE : ma_mphc_network_sync_ind |
1494 +--------------------------------------------------------------------+
1495
1496 PURPOSE : Process the primitive MPHC_NETWORK_SYNC_IND.
1497
1498 */
1499
1500 GLOBAL void ma_mphc_network_sync_ind (T_MPHC_NETWORK_SYNC_IND* sync_ind)
1501 {
1502 TIMERSTOP(TIM_NW_SYNC_GUARD);
1503 cs_network_sync_ind (sync_ind);
1504 PFREE(sync_ind);
1505 }
1506
1507 #if defined(STOP_SYNC_TASK)
1508 /*
1509 +----------------------------------------------------------------------------+
1510 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1511 | STATE : code ROUTINE : ma_mphc_stop_network_sync_req |
1512 +----------------------------------------------------------------------------+
1513
1514 PURPOSE : Process the primitive MPHC_STOP_NETWORK_SYNC_REQ.
1515
1516 */
1517
1518 GLOBAL void ma_cs_stop_network_sync_req(void)
1519 {
1520 if (alr_data->cs_data.sync_active)
1521 {
1522 PALLOC (stop_sync_task, MPHC_STOP_NETWORK_SYNC_REQ); /* T_MPHC_STOP_NETWORK_SYNC_REQ */
1523 TRACE_EVENT ("STOP_NETWORK_SYNC_REQ");
1524 PSENDX(L1, stop_sync_task);
1525 }
1526 }
1527
1528 /*
1529 +----------------------------------------------------------------------------+
1530 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1531 | STATE : code ROUTINE : ma_mphc_stop_network_sync_cnf |
1532 +----------------------------------------------------------------------------+
1533
1534 PURPOSE : Process the primitive MPHC_STOP_NETWORK_SYNC_CON.
1535
1536 */
1537
1538 GLOBAL void ma_mphc_stop_network_sync_cnf(T_MPHC_STOP_NETWORK_SYNC_CON *stop_network_sync_cnf)
1539 {
1540 alr_data->cs_data.sync_active = FALSE;
1541 switch(GET_STATE(STATE_CS))
1542 {
1543 case CS_STOP_SYNC:
1544 SET_STATE (STATE_CS, CS_STOP_SYNC_DONE);
1545 cs_bsic_req(NULL);
1546 break;
1547
1548 case CS_NW_SYNC_TIMEOUT:
1549 /* Inform RR that no BCCH was found */
1550 SET_STATE (STATE_CS, CS_ACTIVE_SYNC);
1551
1552 {
1553 PALLOC (mph_bsic_cnf, MPH_BSIC_CNF);
1554 mph_bsic_cnf->cs = CS_NO_BCCH_AVAIL;
1555 PSENDX (RR, mph_bsic_cnf);
1556 }
1557 break;
1558
1559 default:
1560 break;
1561 }
1562
1563 PFREE(stop_network_sync_cnf);
1564 }
1565 #endif /* STOP_SYNC_TASK */
1566
1567 /*
1568 +--------------------------------------------------------------------+
1569 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1570 | STATE : code ROUTINE : ma_mphc_new_scell_cnf |
1571 +--------------------------------------------------------------------+
1572
1573 PURPOSE : Process the primitive MPHC_NEW_SCELL_CON.
1574
1575 */
1576
1577 GLOBAL void ma_mphc_new_scell_cnf (T_MPHC_NEW_SCELL_CON* new_scell_cnf)
1578 {
1579 /* we have a new serving cell */
1580 vsi_t_sleep(VSI_CALLER 10);
1581
1582 switch (GET_STATE(STATE_MA))
1583 {
1584 case MA_CELL_SELECTION:
1585 /*
1586 * we are synchronized to the new cell
1587 * now read the BCCH to check if the cell
1588 * is suitable
1589 */
1590 cs_read_scell_bcch ();
1591 break;
1592 case MA_CELL_RESELECTION:
1593 ALR_TRACE_MAIN ("new sc in cr");
1594 if (alr_data->old_serving_cell NEQ alr_data->serving_cell)
1595 {
1596 ALR_TRACE_MAIN_SCELL(alr_data->old_serving_cell, alr_data->serving_cell);
1597 ALR_TRACE_MAIN ("update timebase");
1598 /*
1599 * update the timebase now
1600 */
1601 nc_update_list (alr_data->serving_cell);
1602 /*
1603 * removing of the old serving cell only just if
1604 * RR gives a positive receipt for cell selection.
1605 * obsolet: nc_update_serving_cell (alr_data->old_serving_cell);
1606 */
1607
1608 /*
1609 * In case the serving cell has been changed, the last CCCH configuration
1610 * is not valid anymore! It will delete now, so that the sucessful
1611 * comparison inside ma_pch_start_ccch_req() will not prevent a new
1612 * CCCH configuration of L1.
1613 */
1614 memset (&alr_data->pch_data.last_start_ccch_req, 0,
1615 sizeof (alr_data->pch_data.last_start_ccch_req));
1616 }
1617 #ifdef GPRS
1618 if(alr_data->gprs_data.sync_only)
1619 {
1620 PALLOC(sync, MPH_SYNC_IND);
1621 sync->cs = CS_SCELL_IS_SYNCED;
1622 alr_data->gprs_data.sync_only=0;
1623 SET_STATE(STATE_MA, MA_IDLE);
1624 PSENDX (RR, sync);
1625 }
1626 else
1627 {
1628 #endif
1629 pch_start_ccch_req();
1630 #ifdef GPRS
1631 }
1632 #endif
1633 break;
1634 case MA_IDLE:
1635 ALR_TRACE_MAIN ("new sc in idle");
1636 if (alr_data->old_serving_cell NEQ alr_data->serving_cell)
1637 nc_update_list (alr_data->serving_cell);
1638 break;
1639 case MA_CON_EST:
1640 break;
1641 default:
1642 break;
1643 }
1644
1645 PFREE (new_scell_cnf);
1646 }
1647
1648 /*
1649 +--------------------------------------------------------------------+
1650 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1651 | STATE : code ROUTINE : ma_mphc_ncell_bcch_ind |
1652 +--------------------------------------------------------------------+
1653
1654 PURPOSE : Process the primitive MPHC_NCELL_BCCH_IND.
1655
1656 */
1657
1658 GLOBAL void ma_mphc_ncell_bcch_ind (T_MPHC_NCELL_BCCH_IND* ncell_bcch_ind)
1659 {
1660 nc_bcch_ind (ncell_bcch_ind);
1661 PFREE (ncell_bcch_ind);
1662 }
1663
1664 /*
1665 +--------------------------------------------------------------------+
1666 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1667 | STATE : code ROUTINE : ma_mphc_ncell_sync_ind |
1668 +--------------------------------------------------------------------+
1669
1670 PURPOSE : Process the primitive MPHC_NCELL_SYNC_IND.
1671
1672 */
1673
1674 GLOBAL void ma_mphc_ncell_sync_ind (T_MPHC_NCELL_SYNC_IND* ncell_sync_ind)
1675 {
1676 nc_sync_ind (ncell_sync_ind);
1677 PFREE (ncell_sync_ind);
1678 }
1679
1680 /*
1681 +--------------------------------------------------------------------+
1682 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1683 | STATE : code ROUTINE : ma_mphc_stop_ncell_sync_cnf |
1684 +--------------------------------------------------------------------+
1685
1686 PURPOSE : Process the primitive MPHC_NCELL_SYNC_IND.
1687
1688 */
1689
1690 GLOBAL void ma_mphc_stop_ncell_sync_cnf (T_MPHC_STOP_NCELL_SYNC_CON *cnf )
1691 {
1692 if ( IS_EXT_MEAS_RUNNING )
1693 {
1694 nc_stop_ext_meas_ind();
1695 alr_data->cs_data.ext_meas_state_pend = CS_NULL;
1696 }
1697 PFREE (cnf);
1698 }
1699
1700 /*
1701 +--------------------------------------------------------------------+
1702 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1703 | STATE : code ROUTINE : ma_mphc_ncell_bcch_ind |
1704 +--------------------------------------------------------------------+
1705
1706 PURPOSE : Process the primitive MPHC_RXLEV_PERIODIC_IND.
1707
1708 */
1709
1710 GLOBAL void ma_mphc_rxlev_periodic_ind (T_MPHC_RXLEV_PERIODIC_IND*
1711 rxlev_periodic_ind)
1712 {
1713 switch (GET_STATE (STATE_MA))
1714 {
1715 case MA_CELL_RESELECTION:
1716 case MA_CON_EST:
1717 case MA_IDLE:
1718 nc_report (rxlev_periodic_ind);
1719 PSIGNAL (hCommDL, PH_TRACE_IND, NULL);
1720 alr_trc_read (8);
1721 break;
1722
1723 default:
1724 break;
1725 }
1726 PFREE (rxlev_periodic_ind);
1727 }
1728
1729 /*
1730 +--------------------------------------------------------------------+
1731 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1732 | STATE : code ROUTINE : ma_mphc_ra_cnf |
1733 +--------------------------------------------------------------------+
1734
1735 PURPOSE : Process the primitive MPHC_RA_CON.
1736
1737 */
1738
1739 GLOBAL void ma_mphc_ra_cnf (T_MPHC_RA_CON* ra_cnf)
1740 {
1741 switch (GET_STATE (STATE_MA))
1742 {
1743 case MA_CON_EST:
1744 rach_ra_cnf (ra_cnf);
1745 break;
1746 default:
1747 break;
1748 }
1749 PFREE (ra_cnf);
1750 }
1751
1752 /*
1753 +--------------------------------------------------------------------+
1754 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
1755 | STATE : code ROUTINE : ma_trc_data_ind |
1756 +--------------------------------------------------------------------+
1757
1758 PURPOSE : Trace the primitive MPHC_DATA_IND.
1759
1760 configure the output with the following command:
1761 CONFIG TRC_DATA_IND=n
1762
1763 the available decimal values of the bit mask 'n' are:
1764 ID_TRC_DATA_IND_ALL 255
1765 ID_TRC_DATA_IND_VALID 127
1766 ID_TRC_DATA_IND_INVALID 128
1767 ID_TRC_DATA_IND_BCCH 1 normal and extended BCCH
1768 ID_TRC_DATA_IND_PCH 2 normal and extended PCH
1769 ID_TRC_DATA_IND_CCCH 4
1770 ID_TRC_DATA_IND_CBCH 8
1771 ID_TRC_DATA_IND_SCCH 16 SACCH and SDCCH
1772 ID_TRC_DATA_IND_FCCH 32 full and half rate FACCH
1773 ID_TRC_DATA_IND_STATE 64 MA status
1774
1775 ID_TRC_DATA_IND_INIT 63 all valid frames without stati
1776 ID_TRC_DATA_IND_INIT2 31 ... without FACCH
1777 */
1778 #if !defined(NCONFIG)
1779 static void ma_trc_data_ind(T_MPHC_DATA_IND* data_ind)
1780 {
1781 char *msg_s = "";
1782 UBYTE msg_t = 0;
1783
1784 if (data_ind->error_flag NEQ VALID_BLOCK)
1785 {
1786 if (v_mon_trc_data_ind & ID_TRC_DATA_IND_INVALID)
1787 {
1788 #if !defined(DL_TRACE_ENABLED)
1789 SYST_TRACE ("invalid block");
1790 #else /* !DL_TRACE_ENABLED */
1791 DL_OFFLINE_TRACE ("invalid block");
1792 #endif /* !DL_TRACE_ENABLED */
1793 }
1794 return;
1795 }
1796
1797 switch (data_ind->l2_channel)
1798 {
1799 case L2_CHANNEL_SACCH:
1800 case L2_CHANNEL_SDCCH:
1801 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_SCCH) EQ 0)
1802 msg_t = (UBYTE)-1;
1803 break;
1804 case L2_CHANNEL_FACCH_H:
1805 case L2_CHANNEL_FACCH_F:
1806 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_FCCH) EQ 0)
1807 msg_t = (UBYTE)-1;
1808 break;
1809 case L2_CHANNEL_CCCH:
1810 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_CCCH) EQ 0)
1811 return;
1812 break;
1813 case L2_CHANNEL_NBCCH:
1814 case L2_CHANNEL_EBCCH:
1815 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_BCCH) EQ 0)
1816 msg_t = (UBYTE)-1;
1817 break;
1818 case L2_CHANNEL_PCH:
1819 case L2_CHANNEL_EPCH:
1820 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_PCH) EQ 0)
1821 msg_t = (UBYTE)-1;
1822 break;
1823 case L2_CHANNEL_CBCH:
1824 if ((v_mon_trc_data_ind & ID_TRC_DATA_IND_CBCH) EQ 0)
1825 msg_t = (UBYTE)-1;
1826 break;
1827 default:
1828 msg_t = (UBYTE)-1;
1829 SYST_TRACE_P((SYST, "trc_data_ind %02x ch=%d",
1830 v_mon_trc_data_ind, data_ind->l2_channel));
1831 break;
1832 }
1833
1834 if (msg_t)
1835 {
1836 return;
1837 }
1838
1839 if (data_ind->error_flag EQ VALID_BLOCK)
1840 {
1841 msg_t = data_ind->l2_frame.content[SI_CONTENTS_MSG_T];
1842 switch (msg_t)
1843 {
1844 case D_IMM_ASSIGN:
1845 msg_s = "IMM_ASS";
1846 break;
1847 case D_IMM_ASSIGN_EXT:
1848 msg_s = "IMM_ASS_EXT";
1849 break;
1850 case D_IMM_ASSIGN_REJ:
1851 msg_s = "IMM_ASS_REJ";
1852 break;
1853 case D_PAG_REQ_1:
1854 msg_s = "PAG1";
1855 break;
1856 case D_PAG_REQ_2:
1857 msg_s = "PAG2";
1858 break;
1859 case D_PAG_REQ_3:
1860 msg_s = "PAG3";
1861 break;
1862 case D_SYS_INFO_1:
1863 msg_s = "SI 1";
1864 break;
1865 case D_SYS_INFO_2:
1866 msg_s = "SI 2";
1867 break;
1868 case D_SYS_INFO_2BIS:
1869 msg_s = "SI 2bis";
1870 break;
1871 case D_SYS_INFO_2TER:
1872 msg_s = "SI 2ter";
1873 break;
1874 case D_SYS_INFO_3:
1875 msg_s = "SI 3";
1876 /*
1877 TRACE_EVENT_P8 ("SI3: lai=%x%x%x %x%x%x %02x%02x",
1878 data_ind->l2_frame.content[5]&0x0f,
1879 data_ind->l2_frame.content[5]>>4,
1880 data_ind->l2_frame.content[6]&0x0f,
1881
1882 data_ind->l2_frame.content[7]&0x0f,
1883 data_ind->l2_frame.content[7]>>4,
1884 data_ind->l2_frame.content[6]>>4,
1885
1886 data_ind->l2_frame.content[8],
1887 data_ind->l2_frame.content[9]);
1888 */
1889 break;
1890 case D_SYS_INFO_4:
1891 msg_s = "SI 4";
1892 /*
1893 TRACE_EVENT_P8 ("SI4: lai=%x%x%x %x%x%x %02x%02x",
1894 data_ind->l2_frame.content[3]&0x0f,
1895 data_ind->l2_frame.content[3]>>4,
1896 data_ind->l2_frame.content[4]&0x0f,
1897
1898 data_ind->l2_frame.content[5]&0x0f,
1899 data_ind->l2_frame.content[5]>>4,
1900 data_ind->l2_frame.content[4]>>4,
1901
1902 data_ind->l2_frame.content[6],
1903 data_ind->l2_frame.content[7]);
1904 */
1905 break;
1906 case D_SYS_INFO_5:
1907 msg_s = "SI 5";
1908 break;
1909 case D_SYS_INFO_5BIS:
1910 msg_s = "SI 5bis";
1911 break;
1912 case D_SYS_INFO_5TER:
1913 msg_s = "SI 5ter";
1914 break;
1915 case D_SYS_INFO_6:
1916 msg_s = "SI 6";
1917 break;
1918 #ifdef GPRS
1919 case D_SYS_INFO_13:
1920 msg_s = "SI 13";
1921 break;
1922 #endif /* GPRS */
1923 default:
1924 if (data_ind->l2_channel EQ L2_CHANNEL_CBCH)
1925 msg_s = "CBCH";
1926 else
1927 msg_s = 0;
1928 break;
1929 }
1930 }
1931
1932 #if !defined(DL_TRACE_ENABLED)
1933 if (msg_s)
1934 {
1935 if (v_mon_trc_data_ind & ID_TRC_DATA_IND_STATE)
1936 {
1937 SYST_TRACE_P((SYST, "[%u] %s %s",
1938 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK,
1939 msg_s, STATE_MA_NAME[GET_STATE (STATE_MA)]));
1940 }
1941 else
1942 {
1943 SYST_TRACE_P((SYST, "[%u] %s",
1944 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK, msg_s));
1945 }
1946 }
1947 else
1948 {
1949 /* protocol discriminator */
1950 UBYTE pd = data_ind->l2_frame.content[SI_CONTENTS_MSG_T-1];
1951 char buf[47];
1952
1953 if (v_mon_trc_data_ind & ID_TRC_DATA_IND_STATE)
1954 {
1955 SYST_TRACE_P((SYST, "[%u] unknown %02x (PD%02x, ch=%d) %s",
1956 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK, msg_t, pd,
1957 data_ind->l2_channel, STATE_MA_NAME[GET_STATE (STATE_MA)]));
1958 }
1959 else
1960 {
1961 SYST_TRACE_P((SYST, "[%u] unknown %02x (PD%02x, ch=%d)",
1962 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK,
1963 msg_t, pd, data_ind->l2_channel));
1964 }
1965 for (pd=0; pd<23; pd++)
1966 sprintf (buf+(pd<<1), "%02x", (UBYTE)data_ind->l2_frame.content[pd]);
1967 SYST_TRACE(buf);
1968 }
1969 #else /* !DL_TRACE_ENABLED */
1970 {
1971 if (msg_s)
1972 {
1973 if (v_mon_trc_data_ind & ID_TRC_DATA_IND_STATE)
1974 {
1975 sprintf (dl_trace_buf, "[%u] %s %s",
1976 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK,
1977 msg_s, STATE_MA_NAME[GET_STATE (STATE_MA)]);
1978 }
1979 else
1980 {
1981 sprintf (dl_trace_buf, "[%u] %s",
1982 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK, msg_s);
1983 }
1984 }
1985 else
1986 {
1987 /* protocol discriminator */
1988 UBYTE pd = data_ind->l2_frame.content[SI_CONTENTS_MSG_T-1];
1989
1990 sprintf (dl_trace_buf, "[%u] unknown %02x (PD%02x, ch=%d)",
1991 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK,
1992 msg_t, pd, data_ind->l2_channel);
1993 }
1994 DL_OFFLINE_TRACE (dl_trace_buf);
1995 }
1996 #endif /* !DL_TRACE_ENABLED */
1997 }
1998
1999 /*
2000 +--------------------------------------------------------------------+
2001 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2002 | STATE : code ROUTINE : trc_state_transition |
2003 +--------------------------------------------------------------------+
2004
2005 PURPOSE : Traces state transition
2006
2007 */
2008
2009
2010 #if !defined(NTRACE) && defined(TRACE_STATE_TRANSITION)
2011 void trc_state_transition(int line, UBYTE newstate)
2012 {
2013 #if defined(DL_TRACE_ENABLED)
2014 sprintf (dl_trace_buf, "%s->%s (#%u)",
2015 STATE_MA_NAME[GET_STATE (STATE_MA)], STATE_MA_NAME[newstate], line);
2016 DL_OFFLINE_TRACE (dl_trace_buf);
2017 #else /* DL_TRACE_ENABLED */
2018 SYST_TRACE_P((SYST, "%s->%s (#%u)",
2019 STATE_MA_NAME[GET_STATE (STATE_MA)], STATE_MA_NAME[newstate], line));
2020 #endif /* DL_TRACE_ENABLED */
2021 }
2022 #endif /* !NTRACE && TRACE_STATE_TRANSITION */
2023 #endif /* !NCONFIG */
2024
2025 /*
2026 +--------------------------------------------------------------------+
2027 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2028 | STATE : code ROUTINE : trc_paging |
2029 +--------------------------------------------------------------------+
2030
2031 PURPOSE : Traces state transition
2032
2033 */
2034
2035
2036 #if !defined(NTRACE) && 0
2037 void trc_paging(T_MPHC_DATA_IND* data_ind)
2038 {
2039 if ((data_ind->error_flag EQ VALID_BLOCK) AND
2040 ((data_ind->l2_channel EQ L2_CHANNEL_PCH) OR
2041 (data_ind->l2_channel EQ L2_CHANNEL_EPCH)))
2042 {
2043 char *str;
2044
2045 switch (data_ind->l2_frame.content[SI_CONTENTS_MSG_T]) // SI_CONTENTS_MSG_T=2
2046 {
2047 case D_PAG_REQ_1:
2048 str="D_PAG_REQ_1";
2049 break;
2050 case D_PAG_REQ_2:
2051 str="D_PAG_REQ_2";
2052 break;
2053 case D_PAG_REQ_3:
2054 str="D_PAG_REQ_3";
2055 break;
2056 default:
2057 str = NULL;
2058 break;
2059 }
2060
2061 if (str)
2062 {
2063 /* TRACE_BINDUMP first available with FRAME_2.9.18 */
2064 TRACE_BINDUMP(hCommPL ,TC_EVENT, str, data_ind->l2_frame.content,
2065 MAX_L2_FRAME_SIZE);
2066 }
2067 }
2068
2069 }
2070 #endif /* !NTRACE */
2071
2072 /*
2073 +--------------------------------------------------------------------+
2074 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2075 | STATE : code ROUTINE : ma_mphc_data_ind |
2076 +--------------------------------------------------------------------+
2077
2078 PURPOSE : Process the primitive MPHC_DATA_IND.
2079
2080 */
2081
2082 GLOBAL void ma_mphc_data_ind (T_MPHC_DATA_IND* data_ind)
2083 {
2084 UBYTE msg_t;
2085
2086 alr_trc_read (1);
2087
2088 #if !defined(NTRACE) && 0
2089 trc_paging(data_ind);
2090 #endif /* !NTRACE */
2091
2092 #if !defined(NCONFIG)
2093 if (v_mon_trc_data_ind)
2094 ma_trc_data_ind(data_ind);
2095
2096 /* IOT and FT trace */
2097 if (data_ind->l2_channel NEQ L2_CHANNEL_CBCH AND
2098 data_ind->l2_channel NEQ L2_CHANNEL_SACCH)
2099 {
2100 char *str;
2101
2102 switch (data_ind->l2_frame.content[SI_CONTENTS_MSG_T])
2103 {
2104 case D_SYS_INFO_1:
2105 str="D_SYS_INFO_1";
2106 break;
2107 case D_SYS_INFO_2:
2108 str="D_SYS_INFO_2";
2109 break;
2110 case D_SYS_INFO_2BIS:
2111 str="D_SYS_INFO_2BIS";
2112 break;
2113 case D_SYS_INFO_2TER:
2114 str="D_SYS_INFO_2TER";
2115 break;
2116 case D_SYS_INFO_3:
2117 str="D_SYS_INFO_3";
2118 break;
2119 case D_SYS_INFO_4:
2120 str="D_SYS_INFO_4";
2121 break;
2122 #ifdef GPRS
2123 case D_SYS_INFO_13:
2124 str="D_SYS_INFO_13";
2125 break;
2126 #endif
2127 case D_IMM_ASSIGN:
2128 str="D_IMM_ASSIGN";
2129 break;
2130 case D_IMM_ASSIGN_EXT:
2131 str="D_IMM_ASSIGN_EXT";
2132 break;
2133 case D_IMM_ASSIGN_REJ:
2134 str="D_IMM_ASSIGN_REJ";
2135 break;
2136 case D_PAG_REQ_1:
2137 str="PAG_REQ_1 DL";
2138 break;
2139 case D_PAG_REQ_2:
2140 str="PAG_REQ_2 DL";
2141 break;
2142 case D_PAG_REQ_3:
2143 str="PAG_REQ_3 DL";
2144 break;
2145 default:
2146 str = NULL;
2147 break;
2148 }
2149 if (str)
2150 {
2151 TRACE_USER_CLASS_P3 (TC_USER4, "[%u] %s %svalid block",
2152 ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK, str,
2153 data_ind->error_flag EQ VALID_BLOCK ? "" : "in");
2154
2155 TRACE_BINDUMP(hCommPL , TC_USER4, str, data_ind->l2_frame.content,
2156 ((data_ind->error_flag EQ VALID_BLOCK) ? MAX_L2_FRAME_SIZE : 0));
2157 }
2158 }
2159 #endif /* !NCONFIG */
2160
2161
2162 if (data_ind->l2_channel EQ L2_CHANNEL_CBCH)
2163 {
2164 cb_data_ind (data_ind);
2165 }
2166 else
2167 {
2168 if (data_ind->error_flag EQ VALID_BLOCK AND
2169 data_ind->l2_channel EQ L2_CHANNEL_SACCH)
2170 {
2171 /*
2172 * store Timing Advance contained in every decodable downlink SACCH frame
2173 */
2174 nc_store_tav((USHORT)(data_ind->l2_frame.content[1] & 63));
2175 }
2176
2177 msg_t = data_ind->l2_frame.content[SI_CONTENTS_MSG_T];
2178 switch (GET_STATE (STATE_MA))
2179 {
2180 case MA_NULL:
2181 /*
2182 * no message expected
2183 */
2184 break;
2185 case MA_CELL_SELECTION:
2186 if (data_ind->error_flag EQ VALID_BLOCK)
2187 {
2188 ALR_TRACE_MAIN_VALID_BLOCK(msg_t);
2189
2190 switch (msg_t)
2191 {
2192 case D_SYS_INFO_1:
2193 case D_SYS_INFO_2:
2194 case D_SYS_INFO_2BIS:
2195 case D_SYS_INFO_2TER:
2196 case D_SYS_INFO_3:
2197 case D_SYS_INFO_4:
2198 #ifdef GPRS
2199 case D_SYS_INFO_13:
2200 #endif
2201 switch(data_ind->l2_channel)
2202 {
2203 case L2_CHANNEL_NBCCH:
2204 if (data_ind->tc EQ 0 AND msg_t NEQ D_SYS_INFO_1)
2205 ma_sync_ind (CS_SYS_INFO_1_NOT_NEEDED,
2206 ARFCN_TO_G23(data_ind->radio_freq));
2207 /*lint -fallthrough*/
2208 case L2_CHANNEL_EBCCH:
2209 ma_send_unitdata (data_ind);
2210 ma_fill_sys_buffer (data_ind, msg_t);
2211
2212 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2213 cs_increment_bfc();
2214
2215 break;
2216 default:
2217 ALR_TRACE_MAIN ("stray SI");
2218 break;
2219 }
2220 break;
2221 default:
2222 break;
2223 }
2224 }
2225 else
2226 {
2227 ALR_TRACE_MAIN ("INVALID BLOCK");
2228 if (data_ind->l2_channel EQ L2_CHANNEL_NBCCH OR
2229 data_ind->l2_channel EQ L2_CHANNEL_EBCCH)
2230 {
2231 ma_error_ind (CS_BCCH_READ_ERROR,
2232 ARFCN_TO_G23(data_ind->radio_freq));
2233 cs_decrement_bfc();
2234 }
2235 }
2236 break;
2237 case MA_IDLE:
2238 if (data_ind->error_flag EQ VALID_BLOCK)
2239 {
2240 switch (msg_t)
2241 {
2242 case D_SYS_INFO_2:
2243 /*
2244 * setting ncc permitted directly after receive sys info 2
2245 */
2246 nc_check_new_ncc_permitted (data_ind->l2_frame.content[SI_CONTENTS_MSG_T+17]);
2247 /*lint -fallthrough*/
2248 case D_SYS_INFO_1:
2249 case D_SYS_INFO_2BIS:
2250 case D_SYS_INFO_2TER:
2251 case D_SYS_INFO_3:
2252 case D_SYS_INFO_4:
2253 if(data_ind->l2_channel NEQ L2_CHANNEL_NBCCH)
2254 {
2255 ALR_TRACE_MAIN ("stray SI");
2256 }
2257
2258 if (data_ind->tc EQ 0 AND msg_t NEQ D_SYS_INFO_1)
2259 {
2260 ma_sync_ind (CS_SYS_INFO_1_NOT_NEEDED,
2261 ARFCN_TO_G23(data_ind->radio_freq));
2262 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_1_READ;
2263 }
2264
2265 if( alr_data->pch_data.reorg_bcch_reading EQ TRUE)
2266 {
2267 if(msg_t EQ D_SYS_INFO_1)
2268 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_1_READ;
2269 else if(msg_t EQ D_SYS_INFO_2)
2270 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_2_READ;
2271 else if(msg_t EQ D_SYS_INFO_3)
2272 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_3_READ;
2273 else if(msg_t EQ D_SYS_INFO_4)
2274 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_4_READ;
2275 #ifdef GPRS
2276 if( !gprs_alr_is_supported() )
2277 #endif
2278 {
2279 if( (alr_data->pch_data.si_bitmap & ALL_SI_READ_EXCEPT_SI13)
2280 EQ ALL_SI_READ_EXCEPT_SI13)
2281 {
2282 alr_data->pch_data.reorg_bcch_reading = FALSE;
2283 if((alr_data->pch_data.pl_idle.page_mode EQ PGM_NORMAL) OR
2284 (alr_data->pch_data.pl_idle.page_mode EQ PGM_EXTENDED))
2285 {
2286 sc_start_periodic();
2287 }
2288 }
2289 }
2290 }
2291 if (!ma_compare_sys_buffer (data_ind, msg_t))
2292 {
2293 ALR_TRACE_MAIN_SI_UNEQ(data_ind->l2_channel);
2294
2295 ma_send_unitdata (data_ind);
2296 ma_fill_sys_buffer (data_ind, msg_t);
2297
2298 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2299
2300 }
2301 break;
2302 #ifdef GPRS
2303 case D_SYS_INFO_13:
2304 if(gprs_alr_is_supported())
2305 {
2306 alr_data->pch_data.si_bitmap |= SYSTEM_INFO_13_READ;
2307 alr_data->pch_data.reorg_bcch_reading = FALSE;
2308 }
2309 if(! pch_mode_reorg() AND gprs_alr_is_supported())
2310 {
2311 /* stop scell BCCH */
2312 ma_stop_scell_bcch_req();
2313 }
2314 ma_send_unitdata (data_ind);
2315 ma_fill_sys_buffer (data_ind, msg_t);
2316
2317 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2318
2319 ALR_TRACE_MAIN ("SI13");
2320 break;
2321 #endif /* GPRS */
2322
2323 case D_PAG_REQ_1:
2324 ALR_TRACE_MAIN("PG1");
2325
2326 pch_check_pag_1 (data_ind);
2327
2328 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2329 {
2330 /*
2331 * check only if it is the own paging group
2332 */
2333 #ifdef GPRS
2334 gprs_check_page_mode(data_ind);
2335 #else
2336 pch_check_page_mode (data_ind);
2337 #endif /* GPRS */
2338 pch_increment_dlt ();
2339 }
2340 break;
2341 case D_PAG_REQ_2:
2342 ALR_TRACE_MAIN ("PG2");
2343 if (alr_data->pch_data.pl_idle.page_mode EQ PGM_NORMAL)
2344 {
2345 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2346 pch_check_pag_2 (data_ind);
2347 else
2348 {
2349 ALR_TRACE_MAIN ("PCH block skipped");
2350 }
2351 }
2352 else
2353 pch_check_pag_2 (data_ind);
2354 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2355 {
2356 /* check only if it is the own paging group */
2357 #ifdef GPRS
2358 gprs_check_page_mode(data_ind);
2359 #else
2360 pch_check_page_mode (data_ind);
2361 #endif /* GPRS */
2362 pch_increment_dlt ();
2363 }
2364 break;
2365 case D_PAG_REQ_3:
2366 ALR_TRACE_MAIN ("PG3");
2367
2368 if (alr_data->pch_data.pl_idle.page_mode EQ PGM_NORMAL)
2369 {
2370 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2371 pch_check_pag_3 (data_ind);
2372 else
2373 {
2374 ALR_TRACE_MAIN ("PCH block skipped");
2375 }
2376 }
2377 else
2378 pch_check_pag_3 (data_ind);
2379 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2380 {
2381 /* check only if it is the own paging group */
2382 #ifdef GPRS
2383 gprs_check_page_mode(data_ind);
2384 #else
2385 pch_check_page_mode (data_ind);
2386 #endif/* GPRS */
2387 pch_increment_dlt ();
2388 }
2389 break;
2390 case D_IMM_ASSIGN:
2391 #ifdef GPRS
2392 gprs_alr_check_downlink_assign(data_ind);
2393 /*lint -fallthrough*/
2394 #endif
2395 case D_IMM_ASSIGN_EXT:
2396 case D_IMM_ASSIGN_REJ:
2397 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2398 {
2399 /* check only if it is the own paging group */
2400 #ifdef GPRS
2401 gprs_check_page_mode(data_ind);
2402 #else
2403 pch_check_page_mode (data_ind);
2404 #endif /* GPRS */
2405 pch_increment_dlt ();
2406 }
2407 break;
2408 default:
2409 break;
2410 } /* message type */
2411 }
2412 else
2413 {
2414 /*
2415 * invalid block
2416 */
2417 ALR_TRACE_MAIN ("INVALID");
2418 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2419 pch_decrement_dlt ();
2420 }
2421 break;
2422 #ifdef GPRS
2423 case MA_PTM:
2424 if (data_ind->error_flag EQ VALID_BLOCK)
2425 {
2426 switch (msg_t)
2427 {
2428 case D_SYS_INFO_2:
2429 /*
2430 * setting ncc permitted directly after receive sys info 2
2431 */
2432 nc_check_new_ncc_permitted (data_ind->l2_frame.content[SI_CONTENTS_MSG_T+17]);
2433 /*lint -fallthrough*/
2434 case D_SYS_INFO_1:
2435 case D_SYS_INFO_2BIS:
2436 case D_SYS_INFO_2TER:
2437 case D_SYS_INFO_3:
2438 case D_SYS_INFO_4:
2439 if(data_ind->l2_channel NEQ L2_CHANNEL_NBCCH)
2440 {
2441 ALR_TRACE_MAIN ("stray SI");
2442 }
2443 if (data_ind->tc EQ 0 AND msg_t NEQ D_SYS_INFO_1)
2444 ma_sync_ind (CS_SYS_INFO_1_NOT_NEEDED,
2445 ARFCN_TO_G23(data_ind->radio_freq));
2446 if (!ma_compare_sys_buffer (data_ind, msg_t))
2447 {
2448 ALR_TRACE_MAIN_SI_UNEQ(data_ind->l2_channel);
2449
2450 ma_send_unitdata (data_ind);
2451 ma_fill_sys_buffer (data_ind, msg_t);
2452
2453 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2454
2455 }
2456 break;
2457 case D_SYS_INFO_13:
2458 /* stop scell BCCH */
2459 ma_stop_scell_bcch_req();
2460
2461 ma_send_unitdata (data_ind);
2462
2463 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2464
2465 ma_fill_sys_buffer (data_ind, msg_t);
2466 break;
2467 case D_PAG_REQ_1:
2468 ALR_TRACE_MAIN("PG1");
2469
2470 pch_check_pag_1 (data_ind);
2471
2472 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2473 {
2474 /*
2475 * check only if it is the own paging group
2476 */
2477 //pch_increment_dlt ();
2478 }
2479 break;
2480 case D_PAG_REQ_2:
2481 pch_check_pag_2 (data_ind);
2482 //pch_increment_dlt ();
2483
2484 break;
2485 case D_PAG_REQ_3:
2486 pch_check_pag_3 (data_ind);
2487 //pch_increment_dlt ();
2488 break;
2489 default:
2490 break;
2491 }
2492 }
2493 break;
2494 #endif /* GPRS */
2495 case MA_CELL_RESELECTION:
2496 if (data_ind->error_flag EQ VALID_BLOCK)
2497 {
2498 ALR_TRACE_MAIN_CR(msg_t);
2499
2500 switch (msg_t)
2501 {
2502 case D_IMM_ASSIGN:
2503 #ifdef GPRS
2504 TRACE_EVENT_P1 ("downlink assign %02x", data_ind->l2_frame.content[3]);
2505 gprs_alr_check_downlink_assign(data_ind);
2506 /*lint -fallthrough*/
2507 #endif
2508 case D_IMM_ASSIGN_EXT:
2509 case D_IMM_ASSIGN_REJ:
2510 break;
2511 case D_PAG_REQ_1:
2512 ALR_TRACE_MAIN ("PG1");
2513 pch_check_pag_1 (data_ind);
2514 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2515 {
2516 pch_increment_dlt ();
2517 pch_check_page_mode_cr (data_ind);
2518 }
2519 break;
2520 case D_PAG_REQ_2:
2521 ALR_TRACE_MAIN ("PG2");
2522 pch_check_pag_2 (data_ind);
2523 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2524 {
2525 pch_increment_dlt ();
2526 pch_check_page_mode_cr (data_ind);
2527 }
2528 break;
2529 case D_PAG_REQ_3:
2530 ALR_TRACE_MAIN ("PG3");
2531 pch_check_pag_3 (data_ind);
2532 if (data_ind->l2_channel EQ L2_CHANNEL_PCH)
2533 {
2534 pch_increment_dlt ();
2535 pch_check_page_mode_cr (data_ind);
2536 }
2537 break;
2538 case D_SYS_INFO_1:
2539 case D_SYS_INFO_2:
2540 case D_SYS_INFO_2BIS:
2541 case D_SYS_INFO_2TER:
2542 case D_SYS_INFO_3:
2543 case D_SYS_INFO_4:
2544 #ifdef GPRS
2545 case D_SYS_INFO_13:
2546 #endif
2547 ALR_TRACE_MAIN ("cr si");
2548 if (data_ind->tc EQ 0 AND msg_t NEQ D_SYS_INFO_1)
2549 ma_sync_ind (CS_SYS_INFO_1_NOT_NEEDED, ARFCN_TO_G23(data_ind->radio_freq));
2550 ma_send_unitdata (data_ind);
2551 ma_fill_sys_buffer (data_ind, msg_t);
2552
2553 ALR_EM_IDLE_MODE_BCCH_PARAMETER_CHANGED;
2554
2555 /*
2556 * When having received all SI in cell reselection state RR will
2557 * send an MPH_IDLE_REQ and ALR will send an MPHC_START_CCCH_REQ
2558 * This is not a good timing for FTA 20.19 because L1 is then
2559 * unable to detect a paging for some blocks. The test device will
2560 * not send the paging near the SI3. Therefore the
2561 * MPHC_START_CCCH_REQ is sent here (and may be overwritten be the
2562 * later when ALR receives the MPH_IDLE_REQ with other parameters).
2563 */
2564 if (msg_t EQ D_SYS_INFO_3 AND
2565 alr_data->pch_data.imsi[0] AND
2566 ARFCN_TO_G23(data_ind->radio_freq) EQ alr_data->serving_cell)
2567 pch_config_resel(data_ind);
2568 break;
2569 default:
2570 break;
2571 }
2572 }
2573 else /* invalid block */
2574 {
2575 if (data_ind->l2_channel EQ L2_CHANNEL_NBCCH OR
2576 data_ind->l2_channel EQ L2_CHANNEL_EBCCH)
2577 {
2578 ALR_TRACE_MAIN ("INVALID BLOCK");
2579 ma_error_ind (CS_BCCH_READ_ERROR,
2580 ARFCN_TO_G23(data_ind->radio_freq));
2581 cs_decrement_bfc();
2582 }
2583 }
2584
2585 break;
2586 case MA_CON_EST:
2587 if (data_ind->error_flag EQ VALID_BLOCK)
2588 {
2589 switch (msg_t)
2590 {
2591 case D_IMM_ASSIGN:
2592 case D_IMM_ASSIGN_EXT:
2593 case D_IMM_ASSIGN_REJ:
2594 ALR_TRACE_MAIN ("IA");
2595 ma_send_unitdata (data_ind);
2596 break;
2597 #ifdef GPRS
2598 case D_PAG_REQ_1:
2599 pch_check_pag_1 (data_ind);
2600 break;
2601 case D_PAG_REQ_2:
2602 pch_check_pag_2 (data_ind);
2603 break;
2604 case D_PAG_REQ_3:
2605 pch_check_pag_3 (data_ind);
2606 break;
2607 #endif /* GPRS */
2608 default:
2609 break;
2610 }
2611 }
2612 break;
2613 case MA_DEDICATED:
2614 if (data_ind->error_flag EQ VALID_BLOCK)
2615 {
2616 switch (data_ind->l2_channel)
2617 {
2618 case L2_CHANNEL_SACCH:
2619 if ((data_ind->l2_frame.content[3] & 0xEF) EQ 3) /* layer 2 Control field octet */
2620 {
2621 /*
2622 * check control field of l2 header
2623 * UI Frame received
2624 */
2625 UBYTE msg_t = data_ind->l2_frame.content[6]; /* layer 3 Message Type octet */
2626
2627 switch (msg_t)
2628 {
2629 case D_SYS_INFO_6:
2630 /*
2631 * setting ncc permitted directly after receive sys info 6
2632 */
2633 nc_check_new_ncc_permitted (data_ind->l2_frame.content[15]);
2634
2635 /*lint -fallthrough*/
2636 case D_SYS_INFO_5:
2637 case D_SYS_INFO_5BIS:
2638 case D_SYS_INFO_5TER:
2639
2640 if (!ma_compare_dedi_sys_buffer (data_ind, msg_t))
2641 {
2642 ma_send_dedi_unitdata (data_ind);
2643 ma_fill_dedi_sys_buffer (data_ind, msg_t);
2644 }
2645 break;
2646
2647 case D_EXT_MEAS_ORDER:
2648 ma_send_dedi_unitdata (data_ind);
2649 break;
2650
2651 default:
2652 break;
2653 }
2654 }
2655 else
2656 {
2657 /*
2658 * no unacknowledged frame or short PD header (format type Bter)
2659 * must be handled by DL
2660 * is forwarded in original primitive format
2661 */
2662 ma_dedi_data_out ((T_PH_DATA_IND *)data_ind);
2663 data_ind = NULL; /* must not be freed by ALR */
2664 }
2665 dedi_increment_rlt ();
2666 break;
2667 default:
2668 break;
2669 } /*l2_channel*/
2670 }
2671 else
2672 {
2673 /* invalid block */
2674 if (data_ind->l2_channel EQ L2_CHANNEL_SACCH)
2675 dedi_decrement_rlt ();
2676 }
2677 break;
2678 default:
2679 break;
2680 }
2681 }
2682
2683 if (data_ind)
2684 {
2685 PFREE (data_ind);
2686 }
2687 }
2688
2689
2690 /*
2691 +----------------------------------------------------------------------+
2692 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2693 | STATE : code ROUTINE : ma_mphc_change_frequency_cnf |
2694 +----------------------------------------------------------------------+
2695
2696 PURPOSE : Process the primitive MPHC_CHANGE_FREQUENCY_CON.
2697
2698 */
2699
2700 GLOBAL void ma_mphc_change_frequency_cnf (T_MPHC_CHANGE_FREQUENCY_CON* change_frequency_cnf)
2701 {
2702 PFREE (change_frequency_cnf);
2703 dedi_change_freq_cnf ();
2704 }
2705
2706 /*
2707 +--------------------------------------------------------------------+
2708 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2709 | STATE : code ROUTINE : ma_mphc_async_ho_cnf |
2710 +--------------------------------------------------------------------+
2711
2712 PURPOSE : Process the primitive MPHC_ASYNC_HO_CNF.
2713
2714 */
2715
2716 GLOBAL void ma_mphc_async_ho_cnf (T_MPHC_ASYNC_HO_CON* async_ho_cnf)
2717 {
2718 PFREE (async_ho_cnf);
2719 dedi_async_ho_cnf ();
2720 }
2721
2722 /*
2723 +---------------------------------------------------------------------+
2724 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2725 | STATE : code ROUTINE : ma_mphc_channel_assign_cnf |
2726 +---------------------------------------------------------------------+
2727
2728 PURPOSE : Process the primitive MPHC_CHANNEL_ASSIGN_CON.
2729
2730 */
2731
2732 GLOBAL void ma_mphc_channel_assign_cnf (T_MPHC_CHANNEL_ASSIGN_CON* channel_assign_cnf)
2733 {
2734 PFREE (channel_assign_cnf);
2735 #if defined(DL_TRACE_ENABLED)
2736 DL_OFFLINE_TRACE ("MPHC_CHANNEL_ASSIGN_CON");
2737 #else
2738 SYST_TRACE ("dedi chan ass con");
2739 #endif /* DL_TRACE_ENABLED */
2740 dedi_chan_ass_cnf ();
2741 }
2742
2743 /*
2744 +--------------------------------------------------------------------+
2745 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2746 | STATE : code ROUTINE : ma_mphc_handover_fail_cnf |
2747 +--------------------------------------------------------------------+
2748
2749 PURPOSE : Process the primitive MPHC_HANDOVER_FAIL_CON.
2750
2751 */
2752
2753 GLOBAL void ma_mphc_handover_fail_cnf (T_MPHC_HANDOVER_FAIL_CON* handover_fail_cnf)
2754 {
2755 PFREE (handover_fail_cnf);
2756 dedi_ho_fail_cnf ();
2757 }
2758
2759 /*
2760 +--------------------------------------------------------------------+
2761 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2762 | STATE : code ROUTINE : ma_mphc_immed_assign_cnf |
2763 +--------------------------------------------------------------------+
2764
2765 PURPOSE : Process the primitive MPHC_IMMED_ASSIGN_CON.
2766
2767 */
2768
2769 GLOBAL void ma_mphc_immed_assign_cnf (T_MPHC_IMMED_ASSIGN_CON* immed_assign_cnf)
2770 {
2771 PFREE (immed_assign_cnf);
2772 #if defined(DL_TRACE_ENABLED)
2773 DL_OFFLINE_TRACE ("MPHC_IMMED_ASSIGN_CON");
2774 #endif /* DL_TRACE_ENABLED */
2775 dedi_imm_ass_cnf ();
2776 }
2777
2778 /*
2779 +--------------------------------------------------------------------+
2780 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2781 | STATE : code ROUTINE : ma_mphc_pre_sync_ho_cnf |
2782 +--------------------------------------------------------------------+
2783
2784 PURPOSE : Process the primitive MPHC_PRE_SYNC_HO_CON.
2785
2786 */
2787
2788 GLOBAL void ma_mphc_pre_sync_ho_cnf (T_MPHC_PRE_SYNC_HO_CON* pre_sync_ho_cnf)
2789 {
2790 PFREE (pre_sync_ho_cnf);
2791 dedi_pre_sync_ho_cnf ();
2792 }
2793
2794
2795 /*
2796 +--------------------------------------------------------------------+
2797 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2798 | STATE : code ROUTINE : ma_mphc_sync_ho_cnf |
2799 +--------------------------------------------------------------------+
2800
2801 PURPOSE : Process the primitive MPHC_SYNC_HO_CON.
2802
2803 */
2804
2805 GLOBAL void ma_mphc_sync_ho_cnf (T_MPHC_SYNC_HO_CON* sync_ho_cnf)
2806 {
2807 PFREE (sync_ho_cnf);
2808 dedi_sync_ho_cnf ();
2809 }
2810
2811 /*
2812 +--------------------------------------------------------------------+
2813 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2814 | STATE : code ROUTINE : ma_mphc_ta_fail_ind |
2815 +--------------------------------------------------------------------+
2816
2817 PURPOSE : Process the primitive MPHC_TA_FAIL_IND.
2818
2819 */
2820
2821 GLOBAL void ma_mphc_ta_fail_ind (T_MPHC_TA_FAIL_IND* ta_fail_ind)
2822 {
2823 PFREE (ta_fail_ind);
2824 dedi_ta_fail_ind ();
2825 }
2826
2827 /*
2828 +-----------------------------------------------------------------------+
2829 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
2830 | STATE : code ROUTINE : ma_mphc_handover_finished_ind |
2831 +-----------------------------------------------------------------------+
2832
2833 PURPOSE : Process the primitive MPHC_HANDOVER_FINISHED.
2834
2835 */
2836
2837 GLOBAL void ma_mphc_handover_finished_ind (T_MPHC_HANDOVER_FINISHED* ho_finished)
2838 {
2839 dedi_ho_finished (ho_finished->cause);
2840 PFREE (ho_finished);
2841 }
2842
2843 /*
2844 +--------------------------------------------------------------------+
2845 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2846 | STATE : code ROUTINE : ma_mphc_meas_report_ind_emo|
2847 +--------------------------------------------------------------------+
2848
2849 PURPOSE : Process the primitive MPHC_MEAS_REPORT for
2850 Extended Measurement procedure.
2851
2852 */
2853
2854 LOCAL BOOL ma_mphc_meas_report_ind_emo (T_MPHC_MEAS_REPORT* mphc_meas_report)
2855 {
2856 UBYTE emo_ba_id = alr_data->dedi_data.emo_ba_id;
2857 UBYTE rep_ba_id = mphc_meas_report->ba_id;
2858
2859 if ( INRANGE(RR_BA_LOW,rep_ba_id,RR_BA_HIGH) AND
2860 mphc_meas_report->meas_valid )
2861 {
2862 if ( rep_ba_id EQ emo_ba_id )
2863 {
2864 T_ncell_meas *ncell_meas = &mphc_meas_report->ncell_meas;
2865 T_res_list *res_list = &ncell_meas->res_list[0];
2866 T_meas_results *meas_results;
2867 USHORT k,n;
2868 UBYTE nmax;
2869
2870 PALLOC (mph_emo_meas_ind, MPH_EMO_MEAS_IND);
2871
2872 meas_results = &mph_emo_meas_ind->meas_results[0];
2873
2874 mph_emo_meas_ind->ba_id = mphc_meas_report->ba_id;
2875 mph_emo_meas_ind->dtx = mphc_meas_report->dtx_used;
2876
2877 nmax = sizeof mph_emo_meas_ind->meas_results /
2878 sizeof mph_emo_meas_ind->meas_results[0];
2879
2880 if ( mphc_meas_report->no_of_ncells_meas > nmax )
2881 mphc_meas_report->no_of_ncells_meas = nmax;
2882
2883 n = mph_emo_meas_ind->c_meas_results = mphc_meas_report->no_of_ncells_meas;
2884 for ( k = 0; k < n; k++ )
2885 {
2886 SHORT rx_lev = (SHORT)res_list[k].rxlev_acc /
2887 (BYTE) res_list[k].rxlev_nbr_meas;
2888
2889 if ( rx_lev < 0 )
2890 rx_lev = 0;
2891
2892 meas_results[k].rx_lev = (UBYTE) rx_lev;
2893 meas_results[k].arfcn = ARFCN_TO_G23 ( res_list[k].bcch_freq );
2894 }
2895
2896 PSENDX(RR, mph_emo_meas_ind);
2897 }
2898 return TRUE; /* primitive handled */
2899 }
2900
2901 return FALSE; /* indicate that the primitive has not been handled */
2902 }
2903
2904 /*
2905 +--------------------------------------------------------------------+
2906 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2907 | STATE : code ROUTINE : ma_mphc_meas_report_ind |
2908 +--------------------------------------------------------------------+
2909
2910 PURPOSE : Process the primitive MPHC_MEAS_REPORT.
2911
2912 */
2913
2914 GLOBAL void ma_mphc_meas_report_ind (T_MPHC_MEAS_REPORT* report)
2915 {
2916 switch (GET_STATE (STATE_MA))
2917 {
2918 case MA_DEDICATED:
2919
2920 if (report->meas_valid)
2921 {
2922 if ( ma_mphc_meas_report_ind_emo ( report ) )
2923 {
2924 PFREE ( report ); /*report isn't used any more*/
2925 return;
2926 }
2927 nc_report_dedicated (report);
2928 }
2929 else
2930 {
2931 PALLOC (rr_report, MPH_MEASUREMENT_IND);
2932 memset (rr_report, 0, sizeof (T_MPH_MEASUREMENT_IND));
2933
2934 #ifdef GPRS
2935 rr_report->gprs_sync = NORMAL_MEAS_REP;
2936 #endif
2937
2938 if (alr_data->nc_data.update)
2939 nc_fill_report_sc_dedi (rr_report, 0);
2940 ma_nc_report_res (rr_report);
2941 }
2942 alr_data->nc_data.update = FALSE;
2943 break;
2944 default:
2945 break;
2946 }
2947
2948 PFREE (report);
2949 }
2950
2951 /*
2952 +--------------------------------------------------------------------+
2953 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2954 | STATE : code ROUTINE : mphc_adc_ind |
2955 +--------------------------------------------------------------------+
2956
2957 PURPOSE : Process the primitive CST_ADC_RESULT.
2958 */
2959
2960
2961 GLOBAL void ma_mphc_adc_ind (T_MPHC_ADC_IND *adc_results)
2962 {
2963
2964 PALLOC (adc_data, CST_ADC_IND);
2965
2966 adc_data->adc_values[0] = adc_results->adc_results[0];
2967 adc_data->adc_values[1] = adc_results->adc_results[1];
2968 adc_data->adc_values[2] = adc_results->adc_results[2];
2969 adc_data->adc_values[3] = adc_results->adc_results[3];
2970 adc_data->adc_values[4] = adc_results->adc_results[4];
2971 adc_data->adc_values[5] = adc_results->adc_results[5];
2972 adc_data->adc_values[6] = adc_results->adc_results[6];
2973 adc_data->adc_values[7] = adc_results->adc_results[7];
2974 adc_data->adc_values[8] = adc_results->adc_results[8];
2975
2976 PSENDX (CST, adc_data);
2977 PFREE (adc_results);
2978
2979 }
2980
2981 /* -------------------------------------------------------------------
2982 * -------------------------------------------------------------------
2983 * SIGNAL Processing functions
2984 * These are called by the other ALR processes
2985 * -------------------------------------------------------------------
2986 * -------------------------------------------------------------------
2987 */
2988
2989 /*
2990 +--------------------------------------------------------------------+
2991 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
2992 | STATE : code ROUTINE : ma_rach_ra_req |
2993 +--------------------------------------------------------------------+
2994
2995 PURPOSE : Process the signal rach_ra_req from SDL process
2996 RACH_Control.
2997
2998 */
2999
3000 GLOBAL void ma_rach_ra_req (T_MPHC_RA_REQ * mph_ra_req)
3001 {
3002 ALR_TRACE_MAIN_RACH (mph_ra_req->powerclass_gsm, mph_ra_req->txpwr);
3003
3004 TRACE_BINDUMP(hCommPL,
3005 TC_USER4,
3006 "CHANNEL_REQ UL",
3007 &mph_ra_req->channel_request,
3008 sizeof(mph_ra_req->channel_request));
3009
3010 PSENDX (L1, mph_ra_req);
3011 }
3012
3013 /*
3014 +--------------------------------------------------------------------+
3015 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3016 | STATE : code ROUTINE : ma_cs_power_cnf |
3017 +--------------------------------------------------------------------+
3018
3019 PURPOSE : Sends the power measurement results to RR.
3020
3021 */
3022
3023 GLOBAL void ma_cs_power_cnf (T_MPH_POWER_CNF *mph_power_cnf)
3024 {
3025 #if 0 || defined(TRACING)
3026 int i;
3027 TRACE_EVENT_P1 ("mph_power_cnf: %u freq.", mph_power_cnf->num_of_chan);
3028
3029 for (i = 0; i < mph_power_cnf->num_of_chan AND i<10; i++)
3030 TRACE_EVENT_P3("[%u] std=%u rx_lev=%u",
3031 mph_power_cnf->arfcn[i]&ARFCN_MASK,
3032 STD_GET_FROM_ARFCN(mph_power_cnf->arfcn[i]),
3033 mph_power_cnf->rx_lev[i]);
3034 #endif /* TRACING */
3035
3036 if ( IS_EXT_MEAS_RUNNING ) /*alr_data->cs_data.mph_ext_meas_req NEQ NULL */
3037 {
3038 D_OPC ( mph_power_cnf ) = MPH_EXT_MEAS_CNF;
3039 }
3040
3041 PSENDX (RR, mph_power_cnf);
3042 }
3043
3044 /*
3045 +--------------------------------------------------------------------+
3046 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3047 | STATE : code ROUTINE : ma_cs_rxlev_req |
3048 +--------------------------------------------------------------------+
3049
3050 PURPOSE : Process the signal cs_rxlev_req from SDL process
3051 Cell_Selection.
3052
3053 */
3054
3055 GLOBAL void ma_cs_rxlev_req (void)
3056 {
3057 T_POWER_MEAS* power_meas = NULL;
3058
3059 TRACE_FUNCTION ("ma_cs_rxlev_req()");
3060
3061 switch (GET_STATE (STATE_CS))
3062 {
3063 case CS_INIT_L1:
3064 power_meas = cs_prepare_power_req();
3065 /* init radio band before measurement */
3066 ma_cs_init_l1_req(alr_data->cs_data.std);
3067 SET_STATE(STATE_CS, CS_INIT_ACTIVE);
3068 return; /* wait of MPHC_INIT_L1_CON */
3069 case CS_INIT_ACTIVE:
3070 return; /* wait of MPHC_INIT_L1_CON */
3071 case CS_INIT_DONE:
3072 /* go through and wait or start the first resp. next measurement */
3073 case CS_START_MEASURE:
3074 /* without or after configuration of radio band */
3075 if (IS_TIMER_ACTIVE(TIM_POWERMEAS))
3076 {
3077 /*
3078 * use time to spread power measurements also to write out
3079 * possible available DL offline traces
3080 */
3081 PSIGNAL (hCommDL, PH_TRACE_IND, NULL);
3082 return; /* do nothing and wait for timer delay */
3083 }
3084 break; /* OK start the first resp. next measurement */
3085 default:
3086 TRACE_EVENT_P1 ("wrong CS state (%u) in ma_cs_rxlev_req()", GET_STATE (STATE_CS));
3087 return;
3088 }
3089
3090 power_meas = cs_prepare_power_req();
3091 if (power_meas)
3092 {
3093 PALLOC(rxlev_req, MPHC_RXLEV_REQ);
3094 rxlev_req->shared_ptr = (ULONG) power_meas;
3095 SET_STATE(STATE_CS, CS_ACTIVE_MEASURE);
3096 PSENDX(L1, rxlev_req);
3097 /* start timer new */
3098 TIMERSTART(TIM_POWERMEAS, alr_data->cs_data.c_tim_meas);
3099
3100 ALR_EM_FIELDSTRENGTH_MEASUREMENT_REQUEST;
3101
3102 }
3103 }
3104
3105
3106 /*
3107 +--------------------------------------------------------------------+
3108 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3109 | STATE : code ROUTINE : ma_cs_init_l1_req |
3110 +--------------------------------------------------------------------+
3111
3112 PURPOSE : set the radio band configuration.
3113 */
3114
3115 GLOBAL void ma_cs_init_l1_req (UBYTE radio_band_config)
3116 {
3117 PALLOC (init_l1_req, MPHC_INIT_L1_REQ); /* T_MPHC_INIT_L1_REQ */
3118 init_l1_req->radio_band_config = radio_band_config;
3119 TRACE_EVENT_P1 ("radio_band_config=%u", init_l1_req->radio_band_config);
3120 PSENDX(L1, init_l1_req);
3121 cs_set_wideband_sync();
3122 }
3123
3124 /*
3125 +--------------------------------------------------------------------+
3126 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3127 | STATE : code ROUTINE : ma_cs_network_sync_req |
3128 +--------------------------------------------------------------------+
3129
3130 PURPOSE : Process the signal cs_network_sync_req from SDL process
3131 Cell_Selection.
3132 */
3133
3134 GLOBAL void ma_cs_network_sync_req (USHORT channel)
3135 {
3136 PALLOC (network_sync_req, MPHC_NETWORK_SYNC_REQ);
3137
3138 network_sync_req->radio_freq = channel;
3139 network_sync_req->fn_offset = 0;
3140 network_sync_req->time_alignment = 0;
3141 network_sync_req->timing_validity = TV_INVALID_TIMING_INFO;
3142 network_sync_req->search_mode = alr_data->cs_data.search_mode;
3143 alr_data->cs_data.sync_active = TRUE;
3144 PSENDX(L1, network_sync_req);
3145
3146 TIMERSTART(TIM_NW_SYNC_GUARD, TIM_NW_SYNC_GUARD_VALUE);
3147
3148 }
3149
3150
3151 /*
3152 +--------------------------------------------------------------------+
3153 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3154 | STATE : code ROUTINE : ma_nc_rxlev_periodic_req |
3155 +--------------------------------------------------------------------+
3156
3157 PURPOSE : Process the signal nc_rxlev_periodic_req from SDL process
3158 Idle_Neighbour_Cell.
3159
3160 */
3161
3162 GLOBAL void ma_nc_rxlev_periodic_req (T_MPHC_RXLEV_PERIODIC_REQ* update)
3163 {
3164 switch (GET_STATE (STATE_MA))
3165 {
3166 case MA_CELL_RESELECTION:
3167 case MA_IDLE:
3168 PSENDX (L1, update);
3169 break;
3170
3171 default:
3172 PFREE (update);
3173 break;
3174 }
3175 }
3176
3177
3178 /*
3179 +--------------------------------------------------------------------+
3180 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3181 | STATE : code ROUTINE : ma_nc_stop_ncell_bcch_req |
3182 +--------------------------------------------------------------------+
3183
3184 PURPOSE : Process the signal nc_stop_ncell_bcch_req from SDL process
3185 Idle_Neighbour_Cell.
3186
3187 */
3188
3189 GLOBAL void ma_nc_stop_ncell_bcch_req (USHORT arfcn)
3190 {
3191 PALLOC(stop_req, MPHC_STOP_NCELL_BCCH_REQ);
3192
3193 memset (stop_req, 0, sizeof(T_MPHC_STOP_NCELL_BCCH_REQ));
3194 stop_req->radio_freq_array_size = 1;
3195 stop_req->radio_freq_array[0] = ARFCN_TO_L1(arfcn);
3196
3197 PSENDX(L1, stop_req);
3198
3199 }
3200
3201 /*
3202 +--------------------------------------------------------------------+
3203 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3204 | STATE : code ROUTINE : ma_nc_stop_ncell_bcch_req |
3205 +--------------------------------------------------------------------+
3206
3207 PURPOSE : Process the signal nc_stop_ncell_bcch_req from SDL process
3208 Idle_Neighbour_Cell.
3209
3210 */
3211
3212 GLOBAL void ma_nc_stop_ncell_sync_req (USHORT arfcn)
3213 {
3214 PALLOC (mphc_stop_ncell_sync_req, MPHC_STOP_NCELL_SYNC_REQ);
3215
3216 mphc_stop_ncell_sync_req->radio_freq_array_size = 1;
3217 mphc_stop_ncell_sync_req->radio_freq_array[0] = ARFCN_TO_L1(arfcn);
3218
3219 PSENDX(L1, mphc_stop_ncell_sync_req);
3220 }
3221 /*
3222 +--------------------------------------------------------------------+
3223 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3224 | STATE : code ROUTINE : ma_nc_sync_req |
3225 +--------------------------------------------------------------------+
3226
3227 PURPOSE : Process the signal nc_sync_req from SDL process
3228 Idle_Neighbour_Cell.
3229
3230 */
3231
3232 GLOBAL void ma_nc_sync_req (T_MPHC_NCELL_SYNC_REQ *sync_req)
3233 {
3234 PSENDX(L1, sync_req);
3235 }
3236
3237 /*
3238 +--------------------------------------------------------------------+
3239 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3240 | STATE : code ROUTINE : ma_nc_list_sync_req |
3241 +--------------------------------------------------------------------+
3242
3243 PURPOSE : Process the signal nc_list_sync_req from SDL process
3244 Idle_Neighbour_Cell.
3245
3246 */
3247
3248 GLOBAL void ma_nc_list_sync_req (T_MPHC_NCELL_LIST_SYNC_REQ *list_sync_req)
3249 {
3250 PSENDX(L1, list_sync_req);
3251 }
3252
3253 /*
3254 +--------------------------------------------------------------------+
3255 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3256 | STATE : code ROUTINE : ma_nc_bcch_req |
3257 +--------------------------------------------------------------------+
3258
3259 PURPOSE : Process the signal nc_bcch_req from SDL process
3260 Idle_Neighbour_Cell.
3261
3262 */
3263
3264 GLOBAL void ma_nc_bcch_req (T_MPHC_NCELL_BCCH_REQ *bcch_req)
3265 {
3266
3267 ALR_EM_READ_NEIGHBOURCELL_BCCH;
3268
3269 PSENDX(L1, bcch_req);
3270 }
3271
3272 /*
3273 +--------------------------------------------------------------------+
3274 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3275 | STATE : code ROUTINE : ma_nc_update_ba_list |
3276 +--------------------------------------------------------------------+
3277
3278 PURPOSE : Process the signal nc_update_ba_list from SDL process
3279 Idle_Neighbour_Cell.
3280
3281 */
3282
3283 GLOBAL void ma_nc_update_ba_list (T_MPHC_UPDATE_BA_LIST *update_ba_list)
3284 {
3285 switch (GET_STATE (STATE_MA))
3286 {
3287 case MA_DEDICATED:
3288 PSENDX (L1, update_ba_list);
3289 break;
3290
3291 default:
3292 PFREE (update_ba_list);
3293 break;
3294 }
3295 }
3296
3297
3298 /*
3299 +--------------------------------------------------------------------+
3300 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3301 | STATE : code ROUTINE : ma_nc_report_res |
3302 +--------------------------------------------------------------------+
3303
3304 PURPOSE : Process the signal nc_report_res from SDL process
3305 Idle_Neighbour_Cell.
3306
3307 */
3308
3309 GLOBAL void ma_nc_report_res (T_MPH_MEASUREMENT_IND *mph_measurement_ind)
3310 {
3311 TRACE_ASSERT((GET_STATE(STATE_MA) NEQ MA_NULL) OR
3312 (GET_STATE(STATE_MA) NEQ MA_CELL_SELECTION));
3313
3314 switch (GET_STATE (STATE_MA))
3315 {
3316 case MA_IDLE:
3317 #ifdef GPRS
3318 case MA_PTM:
3319 #endif
3320 case MA_CON_EST:
3321 case MA_CELL_RESELECTION:
3322 case MA_DEDICATED:
3323 PSENDX (RR, mph_measurement_ind);
3324 break;
3325 default:
3326 PFREE (mph_measurement_ind);
3327 break;
3328 }
3329 }
3330
3331 /*
3332 +--------------------------------------------------------------------+
3333 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3334 | STATE : code ROUTINE : ma_dedi_stop_req |
3335 +--------------------------------------------------------------------+
3336
3337 PURPOSE : Process the signal ma_dedi_stop_req from SDL process
3338 Dedicated_Control.
3339
3340 */
3341
3342 GLOBAL void ma_dedi_stop_req (void)
3343 {
3344 PALLOC (stop_dedicated, MPHC_STOP_DEDICATED_REQ);
3345 #if defined(DL_TRACE_ENABLED)
3346 DL_OFFLINE_TRACE ("MPHC_STOP_DEDICATED_REQ");
3347 #endif /* DL_TRACE_ENABLED */
3348 PSENDX (L1, stop_dedicated);
3349 }
3350
3351 /*
3352 +--------------------------------------------------------------------+
3353 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3354 | STATE : code ROUTINE : ma_dedi_cnf |
3355 +--------------------------------------------------------------------+
3356
3357 PURPOSE : Process the signal ma_dedi_cnf from SDL process
3358 Dedicated_Control.
3359
3360 */
3361
3362 GLOBAL void ma_dedi_cnf (UBYTE cause)
3363 {
3364 PALLOC (dedicated_cnf, MPH_DEDICATED_CNF);
3365
3366 dedicated_cnf->dedi_res = cause;
3367 PSENDX (RR, dedicated_cnf);
3368 }
3369
3370 /*
3371 +--------------------------------------------------------------------+
3372 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3373 | STATE : code ROUTINE : ma_dedi_chan_ass_req |
3374 +--------------------------------------------------------------------+
3375
3376 PURPOSE : Process the signal ma_dedi_chan_ass_req from SDL process
3377 Dedi Control.
3378
3379 */
3380
3381 GLOBAL void ma_dedi_chan_ass_req (T_MPHC_CHANNEL_ASSIGN_REQ *mphc_channel_assign_req)
3382 {
3383 #if defined(DL_TRACE_ENABLED)
3384 DL_OFFLINE_TRACE ("MPHC_CHANNEL_ASSIGN_REQ");
3385 #else
3386 SYST_TRACE_P ((SYST, "dedi chan ass req %d",
3387 mphc_channel_assign_req->channel_desc_1.channel_type));
3388 #endif /* DL_TRACE_ENABLED */
3389 PSENDX (L1, mphc_channel_assign_req);
3390 }
3391
3392 /*
3393 +--------------------------------------------------------------------+
3394 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3395 | STATE : code ROUTINE : ma_dedi_async_ho_req |
3396 +--------------------------------------------------------------------+
3397
3398 PURPOSE : Process the signal ma_dedi_async_ho_req from SDL process
3399 Dedi Control.
3400
3401 */
3402
3403 GLOBAL void ma_dedi_async_ho_req (T_MPHC_ASYNC_HO_REQ *async_ho_req)
3404 {
3405 PSENDX (L1, async_ho_req);
3406 }
3407
3408 /*
3409 +--------------------------------------------------------------------+
3410 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3411 | STATE : code ROUTINE : ma_dedi_sync_ho_req |
3412 +--------------------------------------------------------------------+
3413
3414 PURPOSE : Process the signal ma_dedi_sync_ho_req from SDL process
3415 Dedi Control.
3416
3417 */
3418
3419 GLOBAL void ma_dedi_sync_ho_req (T_MPHC_SYNC_HO_REQ * sync_ho_req)
3420 {
3421 PSENDX (L1, sync_ho_req);
3422 }
3423
3424 /*
3425 +--------------------------------------------------------------------+
3426 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3427 | STATE : code ROUTINE : ma_dedi_pre_sync_ho_req |
3428 +--------------------------------------------------------------------+
3429
3430 PURPOSE : Process the signal ma_dedi_pre_sync_ho_req from
3431 SDL process Dedi Control.
3432
3433 */
3434
3435 GLOBAL void ma_dedi_pre_sync_ho_req (T_MPHC_PRE_SYNC_HO_REQ *pre_sync_ho_req)
3436 {
3437 PSENDX (L1, pre_sync_ho_req);
3438 }
3439
3440 /*
3441 +--------------------------------------------------------------------+
3442 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3443 | STATE : code ROUTINE : ma_dedi_fail_cnf |
3444 +--------------------------------------------------------------------+
3445
3446 PURPOSE : Process the signal ma_dedi_fail_cnf from SDL process
3447 Dedicated_Control.
3448
3449 */
3450
3451 GLOBAL void ma_dedi_fail_cnf (void)
3452 {
3453 PALLOC (mph_dedicated_fail_cnf, MPH_DEDICATED_FAIL_CNF);
3454 PSENDX (RR, mph_dedicated_fail_cnf);
3455 }
3456
3457 /*
3458 +--------------------------------------------------------------------+
3459 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3460 | STATE : code ROUTINE : ma_dedi_ho_fail_req |
3461 +--------------------------------------------------------------------+
3462
3463 PURPOSE : Process the signal ma_dedi_ho_fail_req from SDL process
3464 Dedicated_Control.
3465
3466 */
3467
3468 GLOBAL void ma_dedi_ho_fail_req (void)
3469 {
3470 PALLOC (handover_fail_req, MPHC_HANDOVER_FAIL_REQ);
3471 PSENDX (L1, handover_fail_req);
3472 }
3473
3474 /*
3475 +--------------------------------------------------------------------+
3476 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3477 | STATE : code ROUTINE : ma_dedi_imm_ass_req |
3478 +--------------------------------------------------------------------+
3479
3480 PURPOSE : Process the signal ma_dedi_imm_ass_req from SDL process
3481 Dedicated_Control.
3482
3483 */
3484
3485 GLOBAL void ma_dedi_imm_ass_req (T_MPHC_IMMED_ASSIGN_REQ *immed_assign_req)
3486 {
3487 #if defined(DL_TRACE_ENABLED)
3488 DL_OFFLINE_TRACE ("MPHC_IMMED_ASSIGN_REQ");
3489 #else
3490 SYST_TRACE_P ((SYST, "dedi imm ass req %d",
3491 immed_assign_req->channel_desc.channel_type));
3492 #endif /* DL_TRACE_ENABLED */
3493 PSENDX (L1, immed_assign_req);
3494 }
3495
3496 /*
3497 +--------------------------------------------------------------------+
3498 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3499 | STATE : code ROUTINE : ma_dedi_change_freq_req |
3500 +--------------------------------------------------------------------+
3501
3502 PURPOSE : Process the signal ma_dedi_change_freq_req from
3503 SDL process Dedicated_Control.
3504
3505 */
3506
3507 GLOBAL void ma_dedi_change_freq_req (T_MPHC_CHANGE_FREQUENCY *change_frequency)
3508 {
3509 PSENDX (L1, change_frequency);
3510 }
3511
3512 /*
3513 +--------------------------------------------------------------------+
3514 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3515 | STATE : code ROUTINE : ma_dedi_chan_mode_req |
3516 +--------------------------------------------------------------------+
3517
3518 PURPOSE : Process the signal ma_dedi_chan_mode_req from
3519 SDL process Dedicated_Control.
3520
3521 */
3522
3523 GLOBAL void ma_dedi_chan_mode_req (T_MPHC_CHANNEL_MODE_MODIFY_REQ *channel_mode_modify_req)
3524 {
3525 PSENDX (L1, channel_mode_modify_req);
3526 }
3527
3528
3529 /*
3530 +--------------------------------------------------------------------+
3531 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3532 | STATE : code ROUTINE : ma_dedi_ciph_req |
3533 +--------------------------------------------------------------------+
3534
3535 PURPOSE : Process the signal ma_dedi_ciph_req from
3536 SDL process Dedicated_Control.
3537
3538 */
3539
3540 GLOBAL void ma_dedi_ciph_req (T_MPHC_SET_CIPHERING_REQ *set_ciphering_req)
3541 {
3542 PSENDX (L1, set_ciphering_req);
3543 }
3544
3545 /*
3546 +--------------------------------------------------------------------+
3547 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3548 | STATE : code ROUTINE : ma_dedi_data_out |
3549 +--------------------------------------------------------------------+
3550
3551 PURPOSE : Acknowledged frame or short PD header (format type Bter)
3552 Forward the message to DL. Uses the original primitive format.
3553
3554 */
3555
3556 LOCAL void ma_dedi_data_out (T_PH_DATA_IND *data_ind)
3557 {
3558 PPASS (data_ind, ph_data_ind, PH_DATA_IND);
3559 PSENDX (DL, ph_data_ind);
3560 }
3561
3562
3563 /*
3564 +--------------------------------------------------------------------+
3565 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3566 | STATE : code ROUTINE : ma_send_dedi_unitdata |
3567 +--------------------------------------------------------------------+
3568
3569 PURPOSE : Sends an unacknowledged message on SACCH to RR.
3570
3571 */
3572
3573 LOCAL void ma_send_dedi_unitdata (T_MPHC_DATA_IND *data_ind)
3574 {
3575 USHORT len_in_bits = 19 * 8;
3576 PALLOC_SDU (data_out, MPH_UNITDATA_IND, len_in_bits);
3577
3578 data_out->sdu.l_buf = 18 * 8;
3579 data_out->sdu.o_buf = 8;
3580 data_out->sdu.buf[0] = 0;
3581 memcpy (&data_out->sdu.buf[1], &data_ind->l2_frame.content[5], 18);/*lint !e419 (Warning -- Apparent data overrun) */
3582 data_out->arfcn = ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK;
3583 data_out->fn = data_ind->fn;
3584
3585 PSENDX (RR, data_out);
3586 }
3587 /*
3588 +--------------------------------------------------------------------+
3589 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3590 | STATE : code ROUTINE : ma_dedi_open_tch_loop_req |
3591 +--------------------------------------------------------------------+
3592
3593 PURPOSE : Process the signal ma_dedi_open_tch_loop_req from
3594 SDL process Dedicated_Control.
3595
3596 */
3597
3598 GLOBAL void ma_dedi_open_tch_loop_req (void)
3599 {
3600 PALLOC (oml1_open_tch_loop_req, OML1_OPEN_TCH_LOOP_REQ);
3601 PSENDX (L1, oml1_open_tch_loop_req);
3602 }
3603
3604
3605 /*
3606 +--------------------------------------------------------------------+
3607 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3608 | STATE : code ROUTINE : ma_dedi_stop_dai_req |
3609 +--------------------------------------------------------------------+
3610
3611 PURPOSE : Process the signal ma_dedi_stop_dai_req from
3612 SDL process Dedicated_Control.
3613
3614 */
3615 GLOBAL void ma_dedi_stop_dai_req (void)
3616 {
3617 PALLOC (oml1_stop_dai_test_req, OML1_STOP_DAI_TEST_REQ);
3618 PSENDX (L1, oml1_stop_dai_test_req);
3619 }
3620
3621
3622 /*
3623 +--------------------------------------------------------------------+
3624 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3625 | STATE : code ROUTINE : ma_dedi_close_tch_loop_req |
3626 +--------------------------------------------------------------------+
3627
3628 PURPOSE : Process the signal ma_dedi_close_tch_loop_req from
3629 SDL process Dedicated_Control.
3630
3631 */
3632
3633 GLOBAL void ma_dedi_close_tch_loop_req (T_OML1_CLOSE_TCH_LOOP_REQ *oml1_close_tch_loop_req)
3634 {
3635 PSENDX (L1, oml1_close_tch_loop_req);
3636 }
3637
3638
3639 /*
3640 +--------------------------------------------------------------------+
3641 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
3642 | STATE : code ROUTINE : ma_dedi_start_dai_req |
3643 +--------------------------------------------------------------------+
3644
3645 PURPOSE : Process the signal ma_dedi_start_dai_req from
3646 SDL process Dedicated_Control.
3647
3648 */
3649
3650 GLOBAL void ma_dedi_start_dai_req (T_OML1_START_DAI_TEST_REQ *oml1_start_dai_test_req)
3651 {
3652 PSENDX (L1, oml1_start_dai_test_req);
3653 }
3654
3655 /*
3656 +--------------------------------------------------------------------+
3657 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3658 | STATE : code ROUTINE : ma_rach_stop_ra_req |
3659 +--------------------------------------------------------------------+
3660
3661 PURPOSE : Process the signal rach_stop_ra_req from SDL process
3662 RACH_Control.
3663
3664 */
3665
3666 GLOBAL void ma_rach_stop_ra_req (void)
3667 {
3668 PALLOC (stop_ra_req, MPHC_STOP_RA_REQ);
3669
3670 PSENDX (L1, stop_ra_req);
3671 }
3672
3673 /*
3674 +--------------------------------------------------------------------+
3675 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3676 | STATE : code ROUTINE : ma_pch_start_ccch_req |
3677 +--------------------------------------------------------------------+
3678
3679 PURPOSE : Process the signal pch_start_ccch_req from SDL process
3680 PCH_Control.
3681
3682 */
3683
3684 GLOBAL void ma_pch_start_ccch_req (T_MPHC_START_CCCH_REQ *pl_idle)
3685 {
3686 if (memcmp ( &(alr_data->pch_data.last_start_ccch_req),
3687 pl_idle,
3688 sizeof(T_MPHC_START_CCCH_REQ) ) NEQ 0)
3689 {
3690 memcpy ( &(alr_data->pch_data.last_start_ccch_req),
3691 pl_idle,
3692 sizeof(T_MPHC_START_CCCH_REQ));
3693 PSENDX (L1, pl_idle);
3694 }
3695 else
3696 {
3697 PFREE(pl_idle);
3698 }
3699 }
3700
3701 /*
3702 +--------------------------------------------------------------------+
3703 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3704 | STATE : code ROUTINE : ma_rach_random_cnf |
3705 +--------------------------------------------------------------------+
3706
3707 PURPOSE : Process the signal rach_random_cnf from SDL process
3708 RACH_Control.
3709
3710 */
3711
3712 GLOBAL void ma_rach_random_cnf (T_MPH_RANDOM_ACCESS_CNF * mph_random_access_cnf)
3713 {
3714 switch (GET_STATE (STATE_MA))
3715 {
3716 case MA_CON_EST:
3717 ALR_TRACE_MAIN_RA_CNF(mph_random_access_cnf->frame_no.t1,
3718 mph_random_access_cnf->frame_no.t2,
3719 mph_random_access_cnf->frame_no.t3);
3720
3721 #if !defined (NCONFIG)
3722 if(v_cfg_rach_failure)
3723 memset(mph_random_access_cnf,0, sizeof(T_MPH_RANDOM_ACCESS_CNF));
3724 #endif
3725
3726 PSENDX (RR, mph_random_access_cnf);
3727 break;
3728
3729 default:
3730 PFREE (mph_random_access_cnf);
3731 break;
3732 }
3733 }
3734
3735 /*
3736 +--------------------------------------------------------------------+
3737 | PROJECT : GSM-PS (6103) MODULE : ALR_PCH |
3738 | STATE : code ROUTINE : ma_pch_paging_ind |
3739 +--------------------------------------------------------------------+
3740
3741 PURPOSE : Sends a paging indication to RR.
3742
3743 */
3744
3745 GLOBAL void ma_pch_paging_ind (UBYTE id_type, UBYTE channel_needed)
3746 {
3747 PALLOC (mph_paging_ind, MPH_PAGING_IND);
3748
3749 ALR_EM_PAGING_DETECTED;
3750
3751 mph_paging_ind->identity_type = id_type;
3752 mph_paging_ind->channel_needed = channel_needed;
3753
3754 // vsi_o_ttrace(VSI_CALLER 0xFFFF, "PAG IND ch=%x", channel_needed);
3755 #if defined(DL_TRACE_ENABLED)
3756 {
3757 sprintf (dl_trace_buf, "PAG%u ch=%u", id_type,channel_needed);
3758 DL_OFFLINE_TRACE (dl_trace_buf);
3759 }
3760 #else /* DL_TRACE_ENABLED */
3761 SYST_TRACE_P ((SYST, "PAG%u ch=%u", id_type,channel_needed));
3762 #endif /* DL_TRACE_ENABLED */
3763
3764
3765 PSENDX (RR, mph_paging_ind);
3766 }
3767
3768 /*
3769 +--------------------------------------------------------------------+
3770 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3771 | STATE : code ROUTINE : ma_pch_stop |
3772 +--------------------------------------------------------------------+
3773
3774 PURPOSE : Stop CCCH reading.
3775 */
3776
3777 GLOBAL void ma_pch_stop(void)
3778 {
3779 PALLOC(stop_req, MPHC_STOP_CCCH_REQ);
3780 alr_data->pch_data.last_start_ccch_req.bs_pa_mfrms = NOT_PRESENT_8BIT;
3781 PSENDX(L1, stop_req);
3782 }
3783
3784
3785
3786 /*
3787 +--------------------------------------------------------------------+
3788 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3789 | STATE : code ROUTINE : ma_mmi_cbch_req |
3790 +--------------------------------------------------------------------+
3791
3792 PURPOSE : Process the primitive MMI_CBCH_REQ.
3793
3794 */
3795
3796 GLOBAL void ma_mmi_cbch_req (T_MMI_CBCH_REQ *cbch_req)
3797 {
3798 TRACE_EVENT ("MMI_CBCH_REQ");
3799 cb_mmi_cbch_req (cbch_req);
3800 PFREE (cbch_req);
3801 }
3802
3803 /*
3804 +--------------------------------------------------------------------+
3805 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3806 | STATE : code ROUTINE : ma_mmi_cbch_req |
3807 +--------------------------------------------------------------------+
3808
3809 PURPOSE : Process the primitive MMI_CBCH_REQ.
3810
3811 */
3812
3813 GLOBAL void ma_mmi_sat_cbch_dwnld_req (T_MMI_SAT_CBCH_DWNLD_REQ *cbch_req)
3814 {
3815 TRACE_EVENT ("MMI_SAT_CBCH_DWNLD_REQ");
3816 cb_mmi_sat_cbch_req (cbch_req);
3817 PFREE (cbch_req);
3818 }
3819
3820 /*
3821 +--------------------------------------------------------------------+
3822 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3823 | STATE : code ROUTINE : ma_cb_stop_cbch_req |
3824 +--------------------------------------------------------------------+
3825
3826 PURPOSE : Process the signal ma_cb_stop_cbch_req.
3827
3828 */
3829 GLOBAL void ma_cb_stop_cbch_req (void)
3830 {
3831 PALLOC(stop_cbch_req, MPHC_STOP_CBCH_REQ);
3832
3833 stop_cbch_req->normal_cbch = CBCH_STOP;
3834 stop_cbch_req->extended_cbch = CBCH_STOP;
3835 TRACE_EVENT ("MPHC_STOP_CBCH_REQ");
3836 PSENDX(L1, stop_cbch_req);
3837 }
3838
3839 /*
3840 +--------------------------------------------------------------------+
3841 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3842 | STATE : code ROUTINE : ma_cb_sched_req |
3843 +--------------------------------------------------------------------+
3844
3845 PURPOSE : Process the signal ma_cb_sched_req.
3846
3847 */
3848 GLOBAL void ma_cb_sched_req (T_MPHC_CBCH_SCHEDULE_REQ *sched_req)
3849 {
3850 /*
3851 TRACE_EVENT ("MPHC_CBCH_SCHEDULE_REQ");
3852 */
3853 PSENDX (L1, sched_req);
3854 }
3855
3856 /*
3857 +--------------------------------------------------------------------+
3858 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3859 | STATE : code ROUTINE : ma_cb_config_cbch |
3860 +--------------------------------------------------------------------+
3861
3862 PURPOSE : Process the signal ma_cb_config_cbch.
3863
3864 */
3865 GLOBAL void ma_cb_config_cbch (T_MPHC_CONFIG_CBCH_REQ *config_cbch)
3866 {
3867 TRACE_EVENT ("MPHC_CONFIG_CBCH_REQ");
3868 PSENDX(L1, config_cbch);
3869 }
3870
3871 /*
3872 +--------------------------------------------------------------------+
3873 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3874 | STATE : code ROUTINE : ma_cb_mmi_cbch_ind |
3875 +--------------------------------------------------------------------+
3876
3877 PURPOSE : Process the signal ma_cb_mmi_cbch_ind.
3878
3879 */
3880 GLOBAL void ma_cb_mmi_cbch_ind (T_MMI_CBCH_IND *mmi_cbch_ind)
3881 {
3882 TRACE_EVENT ("MMI_CBCH_IND");
3883 PSENDX (MMI, mmi_cbch_ind);
3884 }
3885
3886 /*
3887 +--------------------------------------------------------------------+
3888 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3889 | STATE : code ROUTINE : ma_cb_info_req |
3890 +--------------------------------------------------------------------+
3891
3892 PURPOSE : Process the signal ma_cb_info_req.
3893
3894 */
3895 GLOBAL void ma_cb_info_req (UBYTE bitmap)
3896 {
3897 PALLOC(info_req, MPHC_CBCH_INFO_REQ);
3898
3899 info_req->tb_bitmap = bitmap;
3900 TRACE_EVENT ("MPHC_CBCH_INFO_REQ");
3901 PSENDX (L1, info_req);
3902 }
3903 /*====================================================================
3904 *Functions used by more than one process
3905 *====================================================================
3906
3907 /*
3908 +--------------------------------------------------------------------+
3909 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3910 | STATE : code ROUTINE : ma_scell_nbcch_req |
3911 +--------------------------------------------------------------------+
3912
3913 PURPOSE : Process the signal ma_scell_nbcch_req .
3914
3915 */
3916
3917 GLOBAL void ma_scell_full_nbcch (void)
3918 {
3919 PALLOC(scell_nbcch_req, MPHC_SCELL_NBCCH_REQ);
3920
3921 ALR_TRACE_MAIN ("start full sc bcch");
3922 scell_nbcch_req->schedule_array_size = 1;
3923 scell_nbcch_req->schedule_array[0].modulus = 1;
3924 scell_nbcch_req->schedule_array[0].relative_position = 0;
3925 ma_scell_nbcch_req(scell_nbcch_req);
3926 }
3927
3928 GLOBAL void ma_scell_nbcch_req (T_MPHC_SCELL_NBCCH_REQ *nbcch_req)
3929 {
3930 ALR_TRACE_MAIN ("start sc bcch");
3931
3932 PSENDX (L1, nbcch_req);
3933 }
3934
3935 /*
3936 +--------------------------------------------------------------------+
3937 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3938 | STATE : code ROUTINE : ma_scell_ebcch_req |
3939 +--------------------------------------------------------------------+
3940
3941 PURPOSE : Process the signal cs_scell_nbcch_req from SDL process
3942 Cell_Selection.
3943 */
3944
3945 GLOBAL void ma_scell_ebcch_req (T_MPHC_SCELL_EBCCH_REQ *ebcch_req)
3946 {
3947 PSENDX (L1, ebcch_req);
3948 }
3949
3950
3951 /*
3952 +--------------------------------------------------------------------+
3953 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
3954 | STATE : code ROUTINE : ma_stop_active_procs |
3955 +--------------------------------------------------------------------+
3956
3957 PURPOSE : Stop all active procedures.
3958 */
3959 GLOBAL void ma_stop_active_procs (UBYTE flags)
3960 {
3961 if (flags & STOP_PCH_READING)
3962 {
3963 pch_stop();
3964 }
3965
3966 if (flags & STOP_MEASUREMENTS)
3967 {
3968 ma_stop_rxlev_periodic_req();
3969 }
3970
3971 switch (GET_STATE(STATE_MA))
3972 {
3973 case MA_CELL_SELECTION:
3974 /*
3975 * if we are doing measurements or synchronising or
3976 * reading the BCCH of a cell, stop the process
3977 */
3978 cs_stop();
3979 break;
3980 case MA_CELL_RESELECTION:
3981 ma_stop_scell_bcch_req ();
3982 break;
3983 case MA_CON_EST:
3984 /*
3985 * Stop Uplink Random Burst Sending
3986 */
3987 rach_stop();
3988 break;
3989 case MA_DEDICATED:
3990 dedi_stop();
3991 break;
3992 case MA_IDLE:
3993 /* if we are reading the FCH or SCH of a ncell
3994 or reading its BCCH, stop it */
3995 nc_suspend();
3996 /* if we are reading the BCCH of the serving cell,
3997 stop it */
3998 ma_stop_scell_bcch_req();
3999 /* if we are reading the CBCH, stop it */
4000 cb_stop();
4001 break;
4002 #ifdef GPRS
4003 case MA_PTM:
4004 /* if we are reading the FCH or SCH of a ncell
4005 or reading its BCCH, stop it */
4006 nc_suspend();
4007 /* if we are reading the BCCH of the serving cell,
4008 stop it */
4009 /*
4010 ma_stop_scell_bcch_req();
4011 */
4012 break;
4013 #endif /* GPRS */
4014 };
4015 }
4016
4017 /*
4018 +--------------------------------------------------------------------+
4019 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4020 | STATE : code ROUTINE : ma_send_unitdata |
4021 +--------------------------------------------------------------------+
4022
4023 PURPOSE : Cut pseudo length and send data directly to RR.
4024
4025 */
4026
4027 GLOBAL void ma_send_unitdata (T_MPHC_DATA_IND * data_ind)
4028 {
4029 #define SYS_INFO_LEN 24
4030
4031 USHORT len_in_bits = SYS_INFO_LEN * BITS_PER_BYTE;
4032
4033 PALLOC_SDU (data_out, MPH_UNITDATA_IND, len_in_bits);
4034
4035 /* No IE and Pseudo Length */
4036 data_out->sdu.l_buf = (SYS_INFO_LEN - 2) * BITS_PER_BYTE;
4037 /* Pseudo Length */
4038 data_out->sdu.o_buf = 1 * BITS_PER_BYTE;
4039 /* No IE */
4040 memcpy (data_out->sdu.buf, &data_ind->l2_frame, SYS_INFO_LEN - 1);/*lint !e419 (Warning -- Apparent data overrun) */
4041 data_out->arfcn = ARFCN_TO_G23(data_ind->radio_freq)&ARFCN_MASK;
4042 data_out->fn = data_ind->fn;
4043
4044 #if 0 && defined(DL_TRACE_ENABLED)
4045 {
4046 sprintf (dl_trace_buf, "DATA ind msg=%u", msg_t);
4047 DL_OFFLINE_TRACE (dl_trace_buf);
4048 }
4049 #endif /* DL_TRACE_ENABLED */
4050
4051 PSENDX (RR, data_out);
4052 }
4053
4054 /*
4055 +--------------------------------------------------------------------+
4056 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
4057 | STATE : code ROUTINE : ma_error_ind |
4058 +--------------------------------------------------------------------+
4059
4060 PURPOSE : send a MPH_ERROR_IND to RR.
4061
4062 */
4063
4064 GLOBAL void ma_error_ind (UBYTE cause, USHORT arfcn)
4065 {
4066 PALLOC (error_ind, MPH_ERROR_IND);
4067
4068 ALR_TRACE_MAIN ("err ind");
4069
4070 ALR_EM_ERROR_IND(cause, arfcn);
4071
4072 error_ind->cs = cause;
4073 error_ind->arfcn = arfcn;
4074
4075 PSENDX (RR, error_ind);
4076 /*
4077 * These errors could mean that the AFC value in L1 might be srewed
4078 * up somehow. So go back to wide band search mode for next CS to be
4079 * safe.
4080 */
4081 if( (cause EQ CS_DOWN_LINK_FAIL) OR (cause EQ CS_RADIO_LINK_FAIL))
4082 cs_set_wideband_sync();
4083 }
4084
4085 /*
4086 +--------------------------------------------------------------------+
4087 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
4088 | STATE : code ROUTINE : ma_sync_ind |
4089 +--------------------------------------------------------------------+
4090
4091 PURPOSE : Send a synchronisation primitive to RR.
4092
4093 */
4094
4095 LOCAL void ma_sync_ind (UBYTE cause,
4096 USHORT arfcn)
4097 {
4098 PALLOC (sync_ind, MPH_SYNC_IND);
4099
4100 TRACE_FUNCTION ("ma_sync_ind()");
4101
4102 sync_ind->cs = cause;
4103 sync_ind->arfcn = arfcn;
4104 PSENDX (RR, sync_ind);
4105 }
4106
4107
4108 /*
4109 +--------------------------------------------------------------------+
4110 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4111 | STATE : code ROUTINE : ma_stop_scell_bcch_req |
4112 +--------------------------------------------------------------------+
4113
4114 PURPOSE : Process the signal cs_stop_bcch_reading from SDL processes
4115 Cell_Selection or Serving_Cell.
4116
4117 */
4118
4119 GLOBAL void ma_stop_scell_bcch_req (void)
4120 {
4121 PALLOC (stop_bcch_req, MPHC_STOP_SCELL_BCCH_REQ);
4122
4123 ALR_TRACE_MAIN ("stop sc bcch");
4124
4125 PSENDX (L1, stop_bcch_req);
4126 }
4127
4128 /*
4129 +--------------------------------------------------------------------+
4130 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4131 | STATE : code ROUTINE : ma_stop_rxlev_periodic_req |
4132 +--------------------------------------------------------------------+
4133
4134 PURPOSE : Stops the periodic fieldstrength measurements during
4135 idle mode.
4136
4137 */
4138
4139
4140 LOCAL void ma_stop_rxlev_periodic_req (void)
4141 {
4142 PALLOC (stop_rxlev_req, MPHC_STOP_RXLEV_PERIODIC_REQ);
4143
4144 ALR_TRACE_MAIN ("stop rxlev perio.");
4145
4146 PSENDX (L1, stop_rxlev_req);
4147 }
4148
4149
4150
4151 /*
4152 +--------------------------------------------------------------------+
4153 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4154 | STATE : code ROUTINE : ma_bsic_cnf |
4155 +--------------------------------------------------------------------+
4156
4157 PURPOSE : Sends the synchronisation result to RR.
4158
4159 */
4160
4161 GLOBAL void ma_bsic_cnf (T_MPH_BSIC_CNF* mph_bsic_cnf)
4162 {
4163 PSENDX (RR, mph_bsic_cnf);
4164 }
4165
4166 /*
4167 +--------------------------------------------------------------------+
4168 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4169 | STATE : code ROUTINE : ma_new_scell_req |
4170 +--------------------------------------------------------------------+
4171
4172 PURPOSE : Sends a new scell request to layer 1.
4173
4174 */
4175
4176 GLOBAL void ma_new_scell_req(T_MPHC_NEW_SCELL_REQ *new_scell)
4177 {
4178 alr_data->bsic = new_scell->tsc;
4179 PSENDX(L1, new_scell);
4180 }
4181
4182 /*
4183 +--------------------------------------------------------------------+
4184 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
4185 | STATE : code ROUTINE : ma_mphc_init_l1_cnf |
4186 +--------------------------------------------------------------------+
4187
4188 PURPOSE : Process the primitive MPHC_INIT_L1_CON.
4189
4190 */
4191
4192 GLOBAL void ma_mphc_init_l1_cnf (T_MPHC_INIT_L1_CON *init_l1_cnf)
4193 {
4194 PFREE (init_l1_cnf);
4195 switch (GET_STATE (STATE_CS))
4196 {
4197 case CS_INIT_ACTIVE:
4198 SET_STATE (STATE_CS, CS_INIT_DONE);
4199 ma_cs_rxlev_req ();
4200 break;
4201 case CS_INIT_SYNC:
4202 SET_STATE (STATE_CS, CS_INIT_DONE);
4203 cs_bsic_req (NULL);
4204 }
4205 }
4206
4207 /*
4208 +--------------------------------------------------------------------+
4209 | PROJECT : GSM-PS (6302) MODULE : ALR_MAIN |
4210 | STATE : code ROUTINE : ma_mphc_stop_dedi_con |
4211 +--------------------------------------------------------------------+
4212
4213 PURPOSE : Process the primitive MPHC_STOP_DEDICATED_CON.
4214
4215 */
4216
4217 GLOBAL void ma_mphc_stop_dedi_con (T_MPHC_STOP_DEDICATED_CON *stop_cnf)
4218 {
4219 PFREE (stop_cnf);
4220
4221 #ifdef GPRS
4222 if(alr_data->dedi_data.act_mode EQ MODE_PDCH_ASSIGN)
4223 {
4224 /*
4225 * Notify RR about the actions performed due to PDCH Assignment.
4226 * Note that MPH_DEDICATED_CNF is misleading as L1 is in Idle Mode now.
4227 */
4228 ma_dedi_cnf (DEDI_RES_OK);
4229 trc_state_transition(0, MA_IDLE);
4230 SET_STATE(STATE_MA, MA_IDLE); /* allow PTM with next MPH_IDLE_REQ(PTM) */
4231 return;
4232 }
4233 #endif
4234 {
4235 PALLOC(mph_dedi_cnf, MPH_STOP_DEDICATED_CNF);
4236 PSENDX ( RR, mph_dedi_cnf );
4237 }
4238 }
4239
4240 /*
4241 +--------------------------------------------------------------------+
4242 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4243 | STATE : code ROUTINE : convert_arfcn_to_l1 |
4244 +--------------------------------------------------------------------+
4245
4246 PURPOSE : Convert_arfcn_to_l1 converts the arfcn given by the upper
4247 layer (ETSI GSM spec.) to the internal format of layer 1.
4248
4249 Frequency Band config. ETSI GSM spec. coding used in L1
4250 GSM 900 STD_900 1-124 1-124
4251 E-GSM STD_EGSM 1-124, 1-124,
4252 975-1023, 0 125-174
4253 PCS 1900 STD_1900 512-810 512-810
4254 DCS 1800 STD_1800 512-885 512-885
4255 GSM 900/DCS 1800 STD_DUAL 1-124, 1-124,
4256 512-885 125-498
4257 E-GSM/DCS 1800 STD_DUAL_EGSM 1-124, 1-124,
4258 975-1023,0 125-174,
4259 512-885 175-548
4260 GSM 850 STD_850 128-251 128-251
4261 GSM 850/PCS 1900 STD_DUAL_US 128-251, 1-124,
4262 512-810 125-424
4263 */
4264
4265 GLOBAL USHORT convert_arfcn_to_l1 (USHORT arfcn, UBYTE local_std)
4266 {
4267 if (local_std EQ 0)
4268 local_std = std;
4269 arfcn &= ARFCN_MASK;
4270 switch (local_std)
4271 {
4272 case STD_DUAL:
4273 if (arfcn >= LOW_CHANNEL_1800)
4274 arfcn -= (LOW_CHANNEL_1800-125);
4275 break;
4276
4277 case STD_EGSM:
4278 case STD_DUAL_EGSM:
4279 if (arfcn >= LOW_CHANNEL_EGSM)
4280 arfcn -= (LOW_CHANNEL_EGSM-125);
4281 else if (arfcn >= LOW_CHANNEL_1800)
4282 arfcn -= (LOW_CHANNEL_1800-175);
4283 else if (arfcn EQ CHANNEL_0)
4284 arfcn = 174;
4285 break;
4286
4287 case STD_DUAL_US:
4288 if (arfcn >= LOW_CHANNEL_1900)
4289 arfcn -= (LOW_CHANNEL_1900-125);
4290 else
4291 arfcn -= (LOW_CHANNEL_850-1);
4292 break;
4293
4294 default:
4295 break;
4296 }
4297 return arfcn;
4298 }
4299
4300 /*
4301 +--------------------------------------------------------------------+
4302 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4303 | STATE : code ROUTINE : convert_arfcn_to_g23 |
4304 +--------------------------------------------------------------------+
4305
4306 PURPOSE : Convert_arfcn_to_g23 converts the radio frequence given by
4307 layer 1 to the common format of the upper layer (ETSI GSM spec.).
4308
4309 Frequency Band config. ETSI GSM spec. coding used in L1
4310 GSM 900 STD_900 1-124 1-124
4311 E-GSM STD_EGSM 1-124, 1-124,
4312 975-1023, 0 125-174
4313 PCS 1900 STD_1900 512-810 512-810
4314 DCS 1800 STD_1800 512-885 512-885
4315 GSM 900/DCS 1800 STD_DUAL 1-124, 1-124,
4316 512-885 125-498
4317 E-GSM/DCS 1800 STD_DUAL_EGSM 1-124, 1-124,
4318 975-1023,0 125-174,
4319 512-885 175-548
4320 GSM 850 STD_850 128-251 128-251
4321 GSM 850/PCS 1900 STD_DUAL_US 128-251, 1-124,
4322 512-810 125-424
4323 */
4324
4325 GLOBAL USHORT convert_arfcn_to_g23 (USHORT arfcn, UBYTE local_std)
4326 {
4327 if (local_std EQ 0)
4328 local_std = std;
4329 arfcn &= ARFCN_MASK;
4330 switch (local_std)
4331 {
4332 case STD_DUAL:
4333 if (arfcn >=125)
4334 arfcn += (LOW_CHANNEL_1800-125);
4335 break;
4336
4337 case STD_EGSM:
4338 case STD_DUAL_EGSM:
4339 if (arfcn >= 175)
4340 arfcn += (LOW_CHANNEL_1800-175);
4341 else if (arfcn EQ 174)
4342 arfcn = CHANNEL_0;
4343 else if (arfcn >= 125)
4344 arfcn += (LOW_CHANNEL_EGSM-125);
4345 break;
4346
4347 case STD_DUAL_US:
4348 if (arfcn >= 125)
4349 arfcn += (LOW_CHANNEL_1900-125);
4350 else
4351 arfcn += (LOW_CHANNEL_850-1);
4352 /*lint -fallthrough*/
4353 case STD_850:
4354 case STD_1900:
4355 /* only for MPH_POWER_CNF and MPH_BSIC_CNF
4356 arfcn |= US_BIT;
4357 */
4358 break;
4359
4360 default:
4361 break;
4362 }
4363 return arfcn;
4364 }
4365
4366 /*
4367 +--------------------------------------------------------------------+
4368 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4369 | STATE : code ROUTINE : ma_clean_dedi_sys_buffer |
4370 +--------------------------------------------------------------------+
4371
4372 PURPOSE : Cleans System Information Message from SACCH.
4373
4374 */
4375
4376 GLOBAL void ma_clean_dedi_sys_buffer (void)
4377 {
4378 memset (alr_data->ma_data.sys_info_5, 0, 18);
4379 memset (alr_data->ma_data.sys_info_5bis, 0, 18);
4380 memset (alr_data->ma_data.sys_info_5ter, 0, 18);
4381 memset (alr_data->ma_data.sys_info_6, 0, 18);
4382 }
4383
4384
4385
4386 /*
4387 +--------------------------------------------------------------------+
4388 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4389 | STATE : code ROUTINE : ma_fill_sys_buffer |
4390 +--------------------------------------------------------------------+
4391
4392 PURPOSE : Stores a System Information Message.
4393
4394 */
4395
4396 LOCAL void ma_fill_sys_buffer (T_MPHC_DATA_IND* data_ind, UBYTE msg_t)
4397 {
4398 switch (msg_t)
4399 {
4400 case D_SYS_INFO_1:
4401 memcpy (alr_data->ma_data.sys_info_1,
4402 &data_ind->l2_frame.content[1], 22);
4403 break;
4404 case D_SYS_INFO_2:
4405 memcpy (alr_data->ma_data.sys_info_2,
4406 &data_ind->l2_frame.content[1], 22);
4407 break;
4408 case D_SYS_INFO_2BIS:
4409 memcpy (alr_data->ma_data.sys_info_2bis,
4410 &data_ind->l2_frame.content[1], 22);
4411 break;
4412 case D_SYS_INFO_2TER:
4413 memcpy (alr_data->ma_data.sys_info_2ter,
4414 &data_ind->l2_frame.content[1], 22);
4415 break;
4416 case D_SYS_INFO_3:
4417 memcpy (alr_data->ma_data.sys_info_3,
4418 &data_ind->l2_frame.content[1], 22);
4419 break;
4420 case D_SYS_INFO_4:
4421 memcpy (alr_data->ma_data.sys_info_4,
4422 &data_ind->l2_frame.content[1], 22);
4423 break;
4424 #ifdef GPRS
4425 case D_SYS_INFO_13:
4426 memcpy (alr_data->ma_data.sys_info_13,
4427 &data_ind->l2_frame.content[1], 22);
4428 break;
4429 #endif /* GPRS */
4430 default:
4431 break;
4432 }
4433 }
4434
4435 /*
4436 +--------------------------------------------------------------------+
4437 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4438 | STATE : code ROUTINE : ma_compare_sys_buffer |
4439 +--------------------------------------------------------------------+
4440
4441 PURPOSE : Compares a System Information Message.
4442
4443 */
4444 LOCAL BOOL ma_compare_sys_buffer (T_MPHC_DATA_IND *mphc_data_ind,
4445 UBYTE msg_t)
4446 {
4447 switch (msg_t)
4448 {
4449 case D_SYS_INFO_1:
4450 return (!memcmp (alr_data->ma_data.sys_info_1,
4451 &mphc_data_ind->l2_frame.content[1], 22));
4452 /*break;*/
4453 case D_SYS_INFO_2:
4454 return (!memcmp (alr_data->ma_data.sys_info_2,
4455 &mphc_data_ind->l2_frame.content[1], 22));
4456 /*break;*/
4457 case D_SYS_INFO_2BIS:
4458 return (!memcmp (alr_data->ma_data.sys_info_2bis,
4459 &mphc_data_ind->l2_frame.content[1], 22));
4460 /*break;*/
4461 case D_SYS_INFO_2TER:
4462 return (!memcmp (alr_data->ma_data.sys_info_2ter,
4463 &mphc_data_ind->l2_frame.content[1], 18));/* Ignore si2ter_rest_octets changes */
4464 /*break;*/
4465 case D_SYS_INFO_3:
4466 return (!memcmp (alr_data->ma_data.sys_info_3,
4467 &mphc_data_ind->l2_frame.content[1], 22));
4468 /*break;*/
4469 case D_SYS_INFO_4:
4470 return (!memcmp (alr_data->ma_data.sys_info_4,
4471 &mphc_data_ind->l2_frame.content[1], 22));
4472 /*break;*/
4473 #ifdef GPRS
4474 case D_SYS_INFO_13:
4475 return (!memcmp (alr_data->ma_data.sys_info_13,
4476 &mphc_data_ind->l2_frame.content[1], 22));
4477 /*break;*/
4478 #endif /* GPRS */
4479 default:
4480 break;
4481 }
4482 return 0;
4483 }
4484
4485
4486 GLOBAL void sc_start_periodic (void)
4487 {
4488 #ifdef GPRS
4489 if(gprs_check_read_si13_only(SI13_ON_NBCCH))
4490 #endif /* GPRS */
4491 {
4492 USHORT i;
4493 PALLOC(scell_bcch_req, MPHC_SCELL_NBCCH_REQ);
4494 /* we want to read all possible SYSTEM INFO's TC=0..7 */
4495 scell_bcch_req->schedule_array_size = 8;
4496 for (i = 0; i < 8; i++ )
4497 {
4498 scell_bcch_req->schedule_array[i].modulus = THIRTY_SECONDS_SCELL_BCCH;
4499 scell_bcch_req->schedule_array[i].relative_position = i;
4500 }
4501 ma_scell_nbcch_req(scell_bcch_req);
4502 }
4503
4504 }
4505
4506 /*
4507 +--------------------------------------------------------------------+
4508 | PROJECT : GSM-PS (6103) MODULE : alr_MAIN |
4509 | STATE : code ROUTINE : ma_is_ptm |
4510 +--------------------------------------------------------------------+
4511
4512 PURPOSE : Returns True if the current state is MA_PTM,
4513 otherwise returns FALSE.
4514
4515 */
4516
4517
4518 #ifdef GPRS
4519 GLOBAL BOOL ma_is_ptm(void)
4520 {
4521 if(GET_STATE(STATE_MA) EQ MA_PTM)
4522 return TRUE;
4523 else
4524 return FALSE;
4525 }
4526 #endif /* GPRS */
4527
4528 /*
4529 +--------------------------------------------------------------------+
4530 | PROJECT : GSM-PS (6103) MODULE : alr_MAIN |
4531 | STATE : code ROUTINE : ma_nc_rxlev_sc_req |
4532 +--------------------------------------------------------------------+
4533
4534 PURPOSE : A new RXLEV value of the serving cell has been measured.
4535 Inform GPL in case it is necessary.
4536
4537 */
4538 #ifdef GPRS
4539
4540 GLOBAL void ma_nc_rxlev_sc_req (T_TB_RXLEV_SC_REQ *rxlev_sc_req)
4541 {
4542 if(GET_STATE (STATE_MA) EQ MA_IDLE AND
4543 gprs_alr_is_supported( ) EQ TRUE )
4544 {
4545 PSENDX (GPL, rxlev_sc_req);
4546 }
4547 else
4548 {
4549 PFREE (rxlev_sc_req);
4550 }
4551 }
4552
4553 #endif /* #ifdef GPRS */
4554
4555 /*
4556 *--------------------------------------------------------------------
4557 * helper functions for main process
4558 * these should all be LOCAL
4559 *--------------------------------------------------------------------
4560 */
4561
4562 /*
4563 +--------------------------------------------------------------------+
4564 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4565 | STATE : code ROUTINE : ma_clean_sys_buffer |
4566 +--------------------------------------------------------------------+
4567
4568 PURPOSE : Cleans System Information Message from BCCH.
4569
4570 */
4571
4572 GLOBAL void ma_clean_sys_buffer (USHORT si_mask)
4573 {
4574 if ( si_mask & IND_SI_1 ) memset (alr_data->ma_data.sys_info_1, 0, 22);
4575 if ( si_mask & IND_SI_2 ) memset (alr_data->ma_data.sys_info_2, 0, 22);
4576 if ( si_mask & IND_SI_2BIS ) memset (alr_data->ma_data.sys_info_2bis, 0, 22);
4577 if ( si_mask & IND_SI_3 ) memset (alr_data->ma_data.sys_info_3, 0, 22);
4578 if ( si_mask & IND_SI_4 ) memset (alr_data->ma_data.sys_info_4, 0, 22);
4579 if ( si_mask & IND_SI_2TER ) memset (alr_data->ma_data.sys_info_2ter, 0, 22);
4580 #ifdef GPRS
4581 if ( si_mask & IND_SI_13 ) memset (alr_data->ma_data.sys_info_13, 0, 22);
4582 #endif
4583 if ( si_mask & IND_SI_5 ) memset (alr_data->ma_data.sys_info_5, 0, 18);
4584 if ( si_mask & IND_SI_5BIS ) memset (alr_data->ma_data.sys_info_5bis, 0, 18);
4585 if ( si_mask & IND_SI_5TER ) memset (alr_data->ma_data.sys_info_5ter, 0, 18);
4586 if ( si_mask & IND_SI_6 ) memset (alr_data->ma_data.sys_info_6, 0, 18);
4587 }
4588
4589
4590
4591 /*
4592 +--------------------------------------------------------------------+
4593 | PROJECT : GSM-PS (6103) MODULE : ALR_MAIN |
4594 | STATE : code ROUTINE : ma_fill_dedi_sys_buffer |
4595 +--------------------------------------------------------------------+
4596
4597 PURPOSE : Stores a System Information Message from SACCH.
4598
4599 */
4600 LOCAL void ma_fill_dedi_sys_buffer (T_MPHC_DATA_IND * mphc_data_ind,
4601 UBYTE msg_t)
4602 {
4603 switch (msg_t)
4604 {
4605 case D_SYS_INFO_5:
4606 memcpy (alr_data->ma_data.sys_info_5,
4607 &mphc_data_ind->l2_frame.content[5], 18);
4608 break;
4609 case D_SYS_INFO_5BIS:
4610 memcpy (alr_data->ma_data.sys_info_5bis,
4611 &mphc_data_ind->l2_frame.content[5], 18);
4612 break;
4613 case D_SYS_INFO_5TER:
4614 memcpy (alr_data->ma_data.sys_info_5ter,
4615 &mphc_data_ind->l2_frame.content[5], 18);
4616 break;
4617 case D_SYS_INFO_6:
4618 memcpy (alr_data->ma_data.sys_info_6,
4619 &mphc_data_ind->l2_frame.content[5], 18);
4620 break;
4621 }
4622 }
4623
4624 /*
4625 +--------------------------------------------------------------------+
4626 | PROJECT : GSM-PS (6103) MODULE : alr_MAIN |
4627 | STATE : code ROUTINE : ma_compare_dedi_sys_buffer |
4628 +--------------------------------------------------------------------+
4629
4630 PURPOSE : Compares a System Information Message on SACCH.
4631
4632 */
4633
4634 LOCAL BOOL ma_compare_dedi_sys_buffer (T_MPHC_DATA_IND * mphc_data_ind,
4635 UBYTE msg_t)
4636 {
4637 switch (msg_t)
4638 {
4639 case D_SYS_INFO_5:
4640 return (!memcmp (alr_data->ma_data.sys_info_5,
4641 &mphc_data_ind->l2_frame.content[5], 18));
4642 /*break;*/
4643 case D_SYS_INFO_5BIS:
4644 return (!memcmp (alr_data->ma_data.sys_info_5bis,
4645 &mphc_data_ind->l2_frame.content[5], 18));
4646 /*break;*/
4647 case D_SYS_INFO_5TER:
4648 return (!memcmp (alr_data->ma_data.sys_info_5ter,
4649 &mphc_data_ind->l2_frame.content[5], 18));
4650 /*break;*/
4651 case D_SYS_INFO_6:
4652 return (!memcmp (alr_data->ma_data.sys_info_6,
4653 &mphc_data_ind->l2_frame.content[5], 18));
4654 /*break;*/
4655 default:
4656 break;
4657 }
4658 return FALSE;
4659 }
4660
4661 /*
4662 +--------------------------------------------------------------------+
4663 | PROJECT : GSM-PS (6147) MODULE : RR_ATT |
4664 | STATE : code ROUTINE : tim_stop_sync_to_nw |
4665 +--------------------------------------------------------------------+
4666
4667 PURPOSE : Timeout of TIM_NW_SYNC_GUARD - Time to cancel Nw
4668 search as it is taking too long
4669
4670 */
4671 GLOBAL void tim_stop_sync_to_nw( void )
4672 {
4673 /* Change the CS State to CS_NW_SYNC_TIMEOUT only if NW Sync is active */
4674 if(alr_data->cs_data.sync_active)
4675 {
4676 SET_STATE(STATE_CS, CS_NW_SYNC_TIMEOUT);
4677 ma_cs_stop_network_sync_req();
4678 }
4679 }
4680
4681 #ifdef _TARGET_
4682 #ifndef FAX_AND_DATA
4683 /*
4684 * Dummy functions for RA (needed when building voice-only PS w/ F&D TI
4685 * layer 1 libs).
4686 */
4687 GLOBAL void dll_data_ul
4688 (
4689 USHORT *_ul_buffer_address,
4690 USHORT *_d_ra_conf,
4691 USHORT *_d_ra_act,
4692 USHORT *_d_ra_test,
4693 USHORT *_d_ra_statu,
4694 USHORT *_d_fax
4695 )
4696 {
4697 /* do nothing */
4698 }
4699
4700 GLOBAL void dll_data_dl
4701 (
4702 USHORT *_dl_buffer_address,
4703 USHORT *_d_ra_act,
4704 USHORT *_d_ra_statd
4705 )
4706 {
4707 /* do nothing */
4708 }
4709 #endif /* !_FAX_AND_DATA_ */
4710
4711 #ifndef GPRS
4712 /*
4713 * Dummy functions for GRR (needed when building non-GPRS PS w/ GPRS TI
4714 * layer 1 libs).
4715 */
4716 typedef void T_ul_poll_resp;
4717 typedef void T_ul_data;
4718 typedef void T_dl_struct;
4719 typedef UBYTE UWORD8;
4720 typedef ULONG UWORD32;
4721 #define WORD8 UBYTE
4722 #define UWORD16 USHORT
4723
4724 GLOBAL void maca_power_control ( UWORD8 assignment_id,
4725 BOOL crc_error,
4726 WORD8 bcch_level,
4727 UWORD16 *radio_freq,
4728 WORD8 *burst_level,
4729 UWORD8 *pch )
4730 {
4731 /* do nothing */
4732 }
4733
4734 GLOBAL void rlc_uplink ( UWORD8 assignment_id,
4735 UWORD8 tx_data_no,
4736 UWORD32 fn,
4737 UWORD8 timing_advance_value,
4738 T_ul_poll_resp * ul_poll_response,
4739 T_ul_data * ul_data,
4740 BOOL allocation_exhausted)
4741 {
4742 /* do nothing */
4743 }
4744
4745 GLOBAL void rlc_downlink ( UWORD8 assignment_id,
4746 UWORD32 fn,
4747 T_dl_struct *data_ptr,
4748 UWORD8 rlc_blocks_sent,
4749 UWORD8 last_poll_response)
4750 {
4751 /* do nothing */
4752 }
4753 #endif /* !GPRS */
4754 #endif /* _TARGET_ */
4755
4756 #endif /* ALR_MAIN_C */