blob: 7aca1b4ab0557a19c3cdc95e7035e875f9058b1e [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2007
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35
36/*******************************************************************************
37 * Filename:
38 * ---------
39 * mrs_as_struct.h
40 *
41 * Project:
42 * --------
43 * Multimode
44 *
45 * Description:
46 * ------------
47 *
48 *
49 * Author:
50 * -------
51 * -------
52 *
53 * ----------------------------------------------------------------------------
54 * removed!
55 *
56 * removed!
57 * removed!
58 *
59 * removed!
60 * removed!
61 *
62 * removed!
63 * removed!
64 *
65 * removed!
66 * removed!
67 *
68 * removed!
69 * removed!
70 * removed!
71 *
72 * removed!
73 * removed!
74 * removed!
75 *
76 * removed!
77 * removed!
78 *
79 * removed!
80 * removed!
81 *
82 * removed!
83 * removed!
84 * removed!
85 * removed!
86 *
87 * removed!
88 * removed!
89 * removed!
90 *
91 * removed!
92 * removed!
93 * removed!
94 * removed!
95 *
96 * removed!
97 * removed!
98 *
99 * removed!
100 * removed!
101 * removed!
102 * removed!
103 *
104 * removed!
105 * removed!
106 * removed!
107 *
108 * removed!
109 * removed!
110 * removed!
111 * removed!
112 *
113 * removed!
114 * removed!
115 * removed!
116 *
117 * removed!
118 * removed!
119 * removed!
120 *
121 * removed!
122 * removed!
123 * removed!
124 *
125 * removed!
126 * removed!
127 * removed!
128 *
129 * removed!
130 * removed!
131 * removed!
132 *
133 * removed!
134 * removed!
135 * removed!
136 * removed!
137 *
138 * removed!
139 * removed!
140 * removed!
141 *
142 * removed!
143 * removed!
144 * removed!
145 *
146 * removed!
147 * removed!
148 * removed!
149 *
150 * removed!
151 * removed!
152 * removed!
153 *
154 * removed!
155 * removed!
156 * removed!
157 *
158 * removed!
159 * removed!
160 * removed!
161 *
162 * removed!
163 * removed!
164 * removed!
165 *
166 * removed!
167 * removed!
168 * removed!
169 *
170 * removed!
171 * removed!
172 * removed!
173 *
174 * removed!
175 * removed!
176 * removed!
177 * removed!
178 * removed!
179 * removed!
180 * removed!
181 * removed!
182 *
183 * removed!
184 * removed!
185 * removed!
186 *
187 * removed!
188 * removed!
189 * removed!
190 * removed!
191 * removed!
192 * removed!
193 * removed!
194 * removed!
195 *
196 * removed!
197 * removed!
198 *
199 * removed!
200 * removed!
201 * removed!
202 *
203 * removed!
204 * removed!
205 * removed!
206 *
207 * removed!
208 * removed!
209 * removed!
210 *
211 * removed!
212 * removed!
213 * removed!
214 *
215 * removed!
216 * removed!
217 * removed!
218 *
219 * removed!
220 * removed!
221 * removed!
222 * removed!
223 ******************************************************************************/
224#ifndef _MRS_AS_STRUCT_H
225#define _MRS_AS_STRUCT_H
226
227#include "mrs_as_enums.h"
228#include "mrs_as_inter_core_struct.h"
229#include "kal_public_defs.h"
230#include "global_type.h"
231#include "l3_inc_enums.h"
232#include "mcd_l3_inc_struct.h"
233#include "ps_public_enum.h"
234
235#define AFR_FREQ_MAX_NUM 8
236#define MAX_NUM_MULTI_MCC 6
237
238#ifdef __NR_RAT__
239#define EUTRA_MULTI_BANDS_MAX_NUM (8)
240#define EUTRA_NS_PMAX_LIST_MAX_NUM (8)
241#endif /* __NR_RAT__ */
242
243#define MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM (256) // 36.331 maxFeatureSets-r15
244#define MRS_MAX_AFR_FREQ_NUM 64
245#define MRS_AFR_TO_4G_TIMER 2000 //msec
246#define MRS_AFR_TO_5G_TIMER 2000 //msec
247
248#define AS_PINGPONG_THRESHOLD_MAX 8 /* if IRAT Change fount exceeds threshold, PINGPONG confirmed */
249
250#define MRS_MAX_CC_NUM 8
251#define MAX_NUM_VALID_MCC_REGIONS 22
252#define MAX_NUM_VALID_MCC_REGION_PLMNS 55
253#define NVRAM_EF_AS_GSM_BAND_SETTING_SIZE 1
254#define NVRAM_EF_AS_FDD_UMTS_BAND_SETTING_SIZE 4
255#define NVRAM_EF_AS_LTE_BAND_SETTING_SIZE 32
256
257#define MRS_COMPILE_TIME_ASSERT(e) ((void)sizeof(char[1-2*!(e)]))
258
259/* MRS uses this primitive to inform AS about white list change */
260typedef struct {
261 LOCAL_PARA_HDR
262 csg_white_list_update_cause update_cause;
263 kal_bool acsgl_changed;
264 kal_bool ocsgl_changed;
265} mrs_as_csg_white_list_update_ind_struct;
266
267/* MRS uses this primitive to synch LLA status with AS */
268typedef struct {
269 LOCAL_PARA_HDR
270 //lower_layer_availability_enum l1_availibility_status;
271} mrs_lower_layer_availability_update_ind_struct;
272
273/* GAS synch LLA status with MRS */
274typedef struct {
275 LOCAL_PARA_HDR
276 lower_layer_availability_enum l1_availibility_status;
277} mrs_gas_lower_layer_availability_update_req_struct;
278
279/* UAS synch LLA status with MRS */
280typedef struct {
281 LOCAL_PARA_HDR
282 lower_layer_availability_enum l1_availibility_status;
283} mrs_uas_lower_layer_availability_update_req_struct;
284
285/* EAS synch LLA status with MRS */
286typedef struct {
287 LOCAL_PARA_HDR
288 lower_layer_availability_enum l1_availibility_status;
289} mrs_eas_lower_layer_availability_update_req_struct;
290
291/* Inform GAS band setting is changed */
292typedef struct {
293 LOCAL_PARA_HDR
294} mrs_gas_band_setting_update_ind_struct;
295
296/* Inform UAS band setting is changed */
297typedef struct {
298 LOCAL_PARA_HDR
299} mrs_uas_band_setting_update_ind_struct;
300
301/* Inform EAS band setting is changed */
302typedef struct {
303 LOCAL_PARA_HDR
304} mrs_eas_band_setting_update_ind_struct;
305
306/* Inform EAS band contral */
307typedef struct {
308 LOCAL_PARA_HDR
309 kal_uint16 band;
310 eas_band_control_enum ctrl_info;
311} mrs_eas_band_ctrl_ind_struct;
312
313
314typedef struct mrs_plmn_id
315{
316 kal_uint8 mcc1;
317 kal_uint8 mcc2;
318 kal_uint8 mcc3;
319 kal_uint8 mnc1;
320 kal_uint8 mnc2;
321 kal_uint8 mnc3;
322} mrs_plmn_id;
323
324typedef struct
325{
326 kal_uint8 plmn_id_len;
327 mrs_plmn_id plmn_id[MAX_NUM_MULTI_PLMN];
328} mrs_plmn_id_list;
329
330/* Used to store EHPLMN ID List in SIM card */
331typedef struct
332{
333 kal_uint8 plmn_id_len;
334 mrs_plmn_id plmn_id[MD1_MAX_NUM_HPLMN];
335} mrs_ehplmn_id_list;
336
337/* MRS notifies UAS of the transmission of INTER RAT HANDOVER INFO in GSM */
338typedef struct {
339 LOCAL_PARA_HDR
340} mrs_uas_umts_ho_info_rsp_struct;
341
342typedef struct {
343 LOCAL_PARA_HDR
344} mrs_l4c_capability_update_ind_struct;
345
346//NR freq nfo for AFR
347typedef struct
348{
349 kal_uint8 periodicity;
350 kal_uint8 offset;
351}mrs_ssb_mtc_periodicity_and_offset_struct;
352
353typedef struct
354{
355 mrs_ssb_mtc_periodicity_and_offset_struct periodicity_and_offset;
356 kal_uint8 duration;
357}mrs_ssb_mtc_struct;
358
359typedef struct
360{
361 NRARFCN freq;
362 mrs_nr_scs_enum ssb_scs;
363 kal_bool is_ssb_mtc_valid;
364 mrs_ssb_mtc_struct ssb_mtc;
365} mrs_afr_nr_freq_info_struct;
366
367typedef struct
368{
369 kal_uint8 freq_num;
370 mrs_afr_nr_freq_info_struct freq_info[MRS_MAX_AFR_FREQ_NUM];
371} mrs_afr_nr_freq_list_struct;
372
373typedef struct
374{
375 kal_bool ongoing_status;
376 MRS_RAT_MODE_TYPE afr_target_rat;
377 mrs_afr_strict_constrain_state strict_constrain_state;
378} mrs_afr_service_struct;
379
380typedef struct
381{
382 kal_bool ever_trigger;
383 kal_bool pre_cond_reqd;
384 MRS_RAT_MODE_TYPE afr_src_rat;
385} mrs_afr_pre_cond_proc_struct;
386
387typedef struct
388{
389 /* [b1: not used] [b2: reduce lau, enable] [b3: defer si13, enable] [b4: 2g afr, enable] [b5: 3g afr, enable] */
390 /* [b6: CSFB_2G_FDD_eCSFB, disable] [b7: CSFB_3G_FDD_eCSFB, disable] [b8: CSFB_2G_TDD_eCSFB, enable] [b9: CSFB_3G_TDD_eCSFB, disable] */
391 /* [b10 ~ b16: reserved] */
392 kal_uint16 csfb_enhancement_item_status;
393 /* [b1: not used] [b2: reduce lau, disable] [b3: defer si13, enable] [b4: 2g afr, disable] [b5: 3g afr, disable] */
394 /* [b6: CSFB_2G_FDD_eCSFB, disable] [b7: CSFB_3G_FDD_eCSFB, disable] [b8: CSFB_2G_TDD_eCSFB, disable] [b9: CSFB_3G_TDD_eCSFB, disable] */
395 /* [b10 ~ b16: reserved] */
396 kal_uint16 csfb_enhancement_item_status_in_test_mode;
397 kal_bool is_csfb_ongoing;
398 kal_uint8 num;
399 EARFCN afr_list[AFR_FREQ_MAX_NUM];
400} mrs_afr_main_struct;
401
402typedef struct
403{
404 /* [b1: 2g4 afr, enable] [b2: 3g4 afr, enable, enable] [b3: 2g5 fdd afr, enable] [b4: 2g5 tdd afr, enable] [b5: 3g5 fdd afr, enable] */
405 /* [b6: 3g5 tdd afr, disable] [b7: 4g5 fdd afr, disable] */
406 /* [b8 ~ b16: reserved] */
407 kal_uint16 afr_enhancement_item_status;
408 /* [b1: 2g4 afr, enable] [b2: 3g4 afr, enable, enable] [b3: 2g5 fdd afr, enable] [b4: 2g5 tdd afr, enable] [b5: 3g5 fdd afr, enable] */
409 /* [b6: 3g5 tdd afr, disable] [b7: 4g5 fdd afr, disable] */
410 /* [b8 ~ b16: reserved] */
411 kal_uint16 afr_enhancement_item_status_in_test_mode;
412
413 mrs_afr_service_struct service_tbl[AFR_SRVC_MAX_NUM];
414 mrs_afr_pre_cond_proc_struct pre_cond_proc_tbl[AFR_PROC_MAX_NUM];
415
416#ifdef __NR_RAT__
417 mrs_afr_nr_freq_list_struct afr_nr_priority_freq_list;
418#endif /* __NR_RAT__ */
419 mrs_afr_nr_freq_list_struct afr_nr_freq_list;
420 mrs_afr_nr_freq_info_struct nr_serving_freq_info;
421 kal_uint32 afr_to_4g_timer; //msec
422 kal_uint32 afr_to_5g_timer; //msec
423} mrs_afr_nr_main_struct;
424
425typedef struct {
426 mrs_plmn_id plmn_id;
427 kal_uint8 la_code[2];
428} mrs_lai_struct;
429
430typedef struct
431{
432 kal_uint16 arfcn;
433 kal_uint8 bsic;
434}mrs_gas_cell_struct;
435
436typedef struct
437{
438 mrs_gas_cell_struct gas_cell;
439 mrs_lai_struct lai;
440 mrs_gas_ecsfb_call_status_enum ecsfb_call_status;
441}mrs_gas_cell_inf_struct;
442
443typedef struct
444{
445 kal_uint16 uarfcn;
446 kal_uint16 psc;
447}mrs_uas_cell_struct;
448
449typedef struct
450{
451 mrs_uas_cell_struct uas_cell;
452 mrs_lai_struct lai;
453}mrs_uas_cell_inf_struct;
454
455typedef struct
456{
457 EARFCN earfcn;
458 kal_uint16 pci;
459}mrs_eas_cell_struct;
460
461typedef struct {
462 kal_bool valid;
463 MRS_RAT_MODE_TYPE rat;
464 mrs_plmn_id plmn_id;
465 kal_uint16 lac_or_tac;
466 kal_uint32 cell_id;
467 kal_uint32 arfcn_or_uarfcn_or_earfcn;
468 kal_uint16 bsic_or_psc_or_pci;
469 kal_int16 report_offset_for_serv_in_black_list; /* serving is a black cell, unit:dbm */
470 kal_int16 report_offset_for_nc_in_black_list; /* neighbor is a black cell, unit:dbm */
471} mrs_as_black_cell_struct;
472
473/* inform xAS black cell list added/cleared. */
474typedef struct {
475 LOCAL_PARA_HDR
476} mrs_uas_add_black_cell_ind_struct;
477
478typedef struct {
479 LOCAL_PARA_HDR
480} mrs_gas_add_black_cell_ind_struct;
481
482typedef struct {
483 LOCAL_PARA_HDR
484} mrs_uas_clear_black_cell_ind_struct;
485
486typedef struct {
487 LOCAL_PARA_HDR
488} mrs_gas_clear_black_cell_ind_struct;
489
490typedef struct mrs_mcc_id
491{
492 kal_uint8 mcc1;
493 kal_uint8 mcc2;
494 kal_uint8 mcc3;
495} mrs_mcc_id;
496
497/* AS use this struct to get MCC from MRS */
498typedef struct mrs_as_mcc_struct
499{
500 kal_uint8 mrs_as_mcc_count;
501 mrs_mcc_id multi_mcc_id[MAX_NUM_MULTI_MCC];
502} mrs_as_mcc_struct;
503
504/* MRS use this struct to set and save MCC from NAS */
505typedef struct
506{
507 kal_uint8 multi_plmn_count;
508 mrs_plmn_id multi_plmn_id[MAX_NUM_MULTI_PLMN];
509} mrs_nas_mcc_struct;
510
511typedef struct
512{
513 /* Fast Mode Switch, record the latest serving cell's essential SI
514 for fast camp on for FDD/TDD mode switch. */
515 mrs_gas_fast_mode_switch_status_enum fast_mode_switch_status;
516 kal_uint8 bsic;
517 kal_uint16 arfcn;
518 plmn_id_struct plmn_id;
519 kal_uint8 si_raw_data_valid_bitmap;
520 kal_uint8 si1_raw_data[GAS_SI_RAW_DATA_LEN];
521 kal_uint8 si2_raw_data[GAS_SI_RAW_DATA_LEN];
522 kal_uint8 si2bis_raw_data[GAS_SI_RAW_DATA_LEN];
523 kal_uint8 si3_raw_data[GAS_SI_RAW_DATA_LEN];
524 kal_uint8 si4_raw_data[GAS_SI_RAW_DATA_LEN];
525#ifdef __PS_SERVICE__
526 kal_uint8 si13_raw_data[GAS_SI_RAW_DATA_LEN];
527#endif /* __PS_SERVICE__ */
528} mrs_gas_shared_info_struct;
529
530/* MRS use this struct to set and get PLMN status from NAS
531 * is_roaming: current PLMN is roaming or not
532 */
533typedef struct
534{
535 kal_bool is_roaming;
536} mrs_nas_plmn_info_struct;
537
538#ifdef __GAS_STORED_SI_FEAT__
539typedef struct
540{
541 kal_bool valid;
542 /* RRM_BA_ROW_DATA_SIZE */
543 kal_uint8 ba_raw_data[16];
544 kal_uint8 count;
545 kal_uint8 rest[RRM_MAX_SI2TER_INSTANCES][RRM_SI2TER_REST_LEN];
546}rrm_si2ter_struct;
547
548typedef struct
549{
550 kal_bool valid;
551 kal_uint8 count;
552 kal_uint8 rest[RRM_MAX_SI2QUARTER_INSTANCES][RRM_SI2QUARTER_REST_LEN];
553}rrm_si2quarter_struct;
554
555typedef struct
556{
557 kal_bool valid;
558 kal_bool essential_si_valid;
559 kal_uint32 system_tick;
560 kal_uint16 storedSI_arfcn;
561 kal_uint8 storedSI_bsic;
562 kal_uint8 si_raw_data_bitmap;
563 kal_uint8 si1_data[21];
564 kal_uint8 si2_data[21];
565 kal_uint8 si2bis_data[21];
566 kal_uint8 si3_data[21];
567 kal_uint8 si4_data[21];
568 kal_uint8 si13_data[21];
569 rrm_si2ter_struct si2ter;
570 rrm_si2quarter_struct si2quarter;
571} rrm_gsm_storedSI_struct;
572
573#endif
574
575#ifdef __NR_RAT__
576typedef struct
577{
578 kal_bool additional_pmax_valid;
579 kal_int8 additional_pmax;
580 kal_bool additional_spectrum_emission_valid;
581 kal_uint16 additional_spectrum_emission;
582} eutra_ns_pmax_value_struct;
583
584typedef struct
585{
586 kal_uint8 eutra_ns_pmax_list_len;
587 eutra_ns_pmax_value_struct eutra_ns_pmax_list[EUTRA_NS_PMAX_LIST_MAX_NUM];
588} eutra_ns_pmax_list_struct;
589
590typedef struct
591{
592 kal_uint16 freq_band_indicator_eutra;
593 eutra_ns_pmax_list_struct ns_pmax_list;
594} eutra_multibandinfo_struct;
595
596typedef struct
597{
598 kal_uint8 eutra_multibandinfo_list_len;
599 eutra_multibandinfo_struct eutra_multibandinfo_list[EUTRA_MULTI_BANDS_MAX_NUM];
600} eutra_multibandinfo_list_struct;
601#endif /* __NR_RAT__ */
602
603typedef struct {
604 kal_uint8 *oct;
605 kal_uint16 oct_len;
606} mrs_nras_octet_string_struct;
607
608/**
609 * Structure for EUTRAN feature set IDs. IDs are in the order they shall be
610 * reported to the network. ID values are IDs of feature sets read from L1.
611 * fs_dl_num Number of IDs in fs_dl_id list
612 * fs_dl_id List of EUTRAN DL feature set IDs
613 * fs_ul_num Number of IDs in fs_ul_id list
614 * fs_ul_id List of EUTRAN UL feature set IDs
615 */
616typedef struct
617{
618 kal_uint16 fs_dl_num;
619 kal_uint16 fs_dl_id[MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM];
620 kal_uint16 fs_ul_num;
621 kal_uint16 fs_ul_id[MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM];
622} mrs_nras_eutran_feature_set_ids_struct;
623
624/* record systime of RAT_CHANGE_CNF(succes),
625 During timewindow, if the rat change reaches specific times, PINGPONG confirmed.
626 the MAX record for RAT change is AS_PINGPONG_THRESHOLD_MAX, but user can customize their PINGPONG scenario with count less than AS_PINGPONG_THRESHOLD_MAX
627*/
628typedef struct
629{
630 kal_uint32 rat_change_time[AS_PINGPONG_THRESHOLD_MAX];
631} mrs_irat_change_info_struct;
632
633typedef struct
634{
635 rat_enum rat; // Current active rat
636 kal_uint8 cc_idx; // Idle mode: always 0. Connected mode: NW configured CC idx.
637 kal_uint32 freq_1khz; // Corresponding Pcell/Scell frequency in 1khz.
638 kal_uint32 bw_1khz; // Corresponding Pcell/Scell BW in 1khz
639 kal_uint16 band; // Universal band
640 kal_uint8 mimo_layer; // 0xFF if no valid info
641} mrs_common_cc_info_struct;
642
643typedef struct
644{
645 protocol_id_enum ps_id;
646 kal_uint8 dl_cc_num; // Idle mode: always 1. Connected mode: NW configured DL cc num.
647 mrs_common_cc_info_struct dl_cc_info[MRS_MAX_CC_NUM];
648 kal_uint8 ul_cc_num; // Idle mode: always 1 or 0 if UL info is not available. Connected mode: NW configured UL cc num.
649 mrs_common_cc_info_struct ul_cc_info[MRS_MAX_CC_NUM];
650} mrs_cell_cc_info_struct;
651
652typedef struct
653{
654 kal_uint8 gsm_band;
655 kal_uint8 fdd_umts_band[NVRAM_EF_AS_FDD_UMTS_BAND_SETTING_SIZE];
656 kal_uint8 lte_band[NVRAM_EF_AS_LTE_BAND_SETTING_SIZE];
657} mrs_mcc_band_setting_per_region_struct;
658
659typedef struct
660{
661 kal_uint8 mcc_region_number;
662 kal_uint8 no_of_plmns;
663 mrs_plmn_id mcc_region_plmns[MAX_NUM_VALID_MCC_REGION_PLMNS];
664 mrs_mcc_band_setting_per_region_struct band_setting;
665} mrs_mcc_plmn_list_within_region_record_struct;
666
667
668typedef struct
669{
670 kal_uint8 no_of_mcc_regions;
671 mrs_mcc_plmn_list_within_region_record_struct setting[MAX_NUM_VALID_MCC_REGIONS];
672} mrs_mcc_region_band_setting_record_struct;
673
674#endif /* _MRS_AS_STRUCT_H */