blob: 767ddadec1a214fdd83fb8c14d8355657feb0681 [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!
rjw2b1408e2022-12-19 11:19:29 +080070 *
71 * removed!
72 * removed!
rjw6c1fd8f2022-11-30 14:33:01 +080073 * removed!
74 *
75 * removed!
76 * removed!
77 * removed!
78 *
79 * removed!
80 * removed!
81 *
82 * removed!
83 * removed!
84 *
85 * removed!
86 * removed!
87 * removed!
88 * removed!
89 *
90 * removed!
91 * removed!
92 * removed!
93 *
94 * removed!
95 * removed!
96 * removed!
97 * removed!
98 *
99 * removed!
100 * removed!
101 *
102 * removed!
103 * removed!
104 * removed!
105 * removed!
106 *
107 * removed!
108 * removed!
109 * removed!
110 *
111 * removed!
112 * removed!
113 * removed!
114 * removed!
115 *
116 * removed!
117 * removed!
118 * removed!
119 *
120 * removed!
121 * removed!
122 * removed!
123 *
124 * removed!
125 * removed!
126 * removed!
127 *
128 * removed!
129 * removed!
130 * removed!
131 *
132 * removed!
133 * removed!
134 * removed!
135 *
136 * removed!
137 * removed!
138 * removed!
139 * removed!
140 *
141 * removed!
142 * removed!
143 * removed!
144 *
145 * removed!
146 * removed!
147 * removed!
148 *
149 * removed!
150 * removed!
151 * removed!
152 *
153 * removed!
154 * removed!
155 * removed!
156 *
157 * removed!
158 * removed!
159 * removed!
160 *
161 * removed!
162 * removed!
163 * removed!
164 *
165 * removed!
166 * removed!
167 * removed!
168 *
169 * removed!
170 * removed!
171 * removed!
172 *
173 * removed!
174 * removed!
175 * removed!
176 *
177 * removed!
178 * removed!
179 * removed!
180 * removed!
181 * removed!
182 * removed!
183 * removed!
184 * removed!
185 *
186 * removed!
187 * removed!
188 * removed!
189 *
190 * removed!
191 * removed!
192 * removed!
193 * removed!
194 * removed!
195 * removed!
196 * removed!
197 * removed!
198 *
199 * removed!
200 * removed!
201 *
202 * removed!
203 * removed!
204 * removed!
205 *
206 * removed!
207 * removed!
208 * removed!
209 *
210 * removed!
211 * removed!
212 * removed!
213 *
214 * removed!
215 * removed!
216 * removed!
217 *
218 * removed!
219 * removed!
220 * removed!
221 *
222 * removed!
223 * removed!
224 * removed!
225 * removed!
226 ******************************************************************************/
227#ifndef _MRS_AS_STRUCT_H
228#define _MRS_AS_STRUCT_H
229
230#include "mrs_as_enums.h"
231#include "mrs_as_inter_core_struct.h"
232#include "kal_public_defs.h"
233#include "global_type.h"
234#include "l3_inc_enums.h"
235#include "mcd_l3_inc_struct.h"
236#include "ps_public_enum.h"
237
238#define AFR_FREQ_MAX_NUM 8
239#define MAX_NUM_MULTI_MCC 6
240
241#ifdef __NR_RAT__
242#define EUTRA_MULTI_BANDS_MAX_NUM (8)
243#define EUTRA_NS_PMAX_LIST_MAX_NUM (8)
244#endif /* __NR_RAT__ */
245
246#define MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM (256) // 36.331 maxFeatureSets-r15
247#define MRS_MAX_AFR_FREQ_NUM 64
248#define MRS_AFR_TO_4G_TIMER 2000 //msec
249#define MRS_AFR_TO_5G_TIMER 2000 //msec
250
251#define AS_PINGPONG_THRESHOLD_MAX 8 /* if IRAT Change fount exceeds threshold, PINGPONG confirmed */
252
253#define MRS_MAX_CC_NUM 8
254#define MAX_NUM_VALID_MCC_REGIONS 22
255#define MAX_NUM_VALID_MCC_REGION_PLMNS 55
256#define NVRAM_EF_AS_GSM_BAND_SETTING_SIZE 1
257#define NVRAM_EF_AS_FDD_UMTS_BAND_SETTING_SIZE 4
258#define NVRAM_EF_AS_LTE_BAND_SETTING_SIZE 32
259
260#define MRS_COMPILE_TIME_ASSERT(e) ((void)sizeof(char[1-2*!(e)]))
261
262/* MRS uses this primitive to inform AS about white list change */
263typedef struct {
264 LOCAL_PARA_HDR
265 csg_white_list_update_cause update_cause;
266 kal_bool acsgl_changed;
267 kal_bool ocsgl_changed;
268} mrs_as_csg_white_list_update_ind_struct;
269
270/* MRS uses this primitive to synch LLA status with AS */
271typedef struct {
272 LOCAL_PARA_HDR
273 //lower_layer_availability_enum l1_availibility_status;
274} mrs_lower_layer_availability_update_ind_struct;
275
276/* GAS synch LLA status with MRS */
277typedef struct {
278 LOCAL_PARA_HDR
279 lower_layer_availability_enum l1_availibility_status;
280} mrs_gas_lower_layer_availability_update_req_struct;
281
282/* UAS synch LLA status with MRS */
283typedef struct {
284 LOCAL_PARA_HDR
285 lower_layer_availability_enum l1_availibility_status;
286} mrs_uas_lower_layer_availability_update_req_struct;
287
288/* EAS synch LLA status with MRS */
289typedef struct {
290 LOCAL_PARA_HDR
291 lower_layer_availability_enum l1_availibility_status;
292} mrs_eas_lower_layer_availability_update_req_struct;
293
294/* Inform GAS band setting is changed */
295typedef struct {
296 LOCAL_PARA_HDR
297} mrs_gas_band_setting_update_ind_struct;
298
299/* Inform UAS band setting is changed */
300typedef struct {
301 LOCAL_PARA_HDR
302} mrs_uas_band_setting_update_ind_struct;
303
304/* Inform EAS band setting is changed */
305typedef struct {
306 LOCAL_PARA_HDR
307} mrs_eas_band_setting_update_ind_struct;
308
309/* Inform EAS band contral */
310typedef struct {
311 LOCAL_PARA_HDR
312 kal_uint16 band;
313 eas_band_control_enum ctrl_info;
314} mrs_eas_band_ctrl_ind_struct;
315
316
317typedef struct mrs_plmn_id
318{
319 kal_uint8 mcc1;
320 kal_uint8 mcc2;
321 kal_uint8 mcc3;
322 kal_uint8 mnc1;
323 kal_uint8 mnc2;
324 kal_uint8 mnc3;
325} mrs_plmn_id;
326
327typedef struct
328{
329 kal_uint8 plmn_id_len;
330 mrs_plmn_id plmn_id[MAX_NUM_MULTI_PLMN];
331} mrs_plmn_id_list;
332
333/* Used to store EHPLMN ID List in SIM card */
334typedef struct
335{
336 kal_uint8 plmn_id_len;
337 mrs_plmn_id plmn_id[MD1_MAX_NUM_HPLMN];
338} mrs_ehplmn_id_list;
339
340/* MRS notifies UAS of the transmission of INTER RAT HANDOVER INFO in GSM */
341typedef struct {
342 LOCAL_PARA_HDR
343} mrs_uas_umts_ho_info_rsp_struct;
344
345typedef struct {
346 LOCAL_PARA_HDR
347} mrs_l4c_capability_update_ind_struct;
348
349//NR freq nfo for AFR
350typedef struct
351{
352 kal_uint8 periodicity;
353 kal_uint8 offset;
354}mrs_ssb_mtc_periodicity_and_offset_struct;
355
356typedef struct
357{
358 mrs_ssb_mtc_periodicity_and_offset_struct periodicity_and_offset;
359 kal_uint8 duration;
360}mrs_ssb_mtc_struct;
361
362typedef struct
363{
364 NRARFCN freq;
365 mrs_nr_scs_enum ssb_scs;
366 kal_bool is_ssb_mtc_valid;
367 mrs_ssb_mtc_struct ssb_mtc;
368} mrs_afr_nr_freq_info_struct;
369
370typedef struct
371{
372 kal_uint8 freq_num;
373 mrs_afr_nr_freq_info_struct freq_info[MRS_MAX_AFR_FREQ_NUM];
374} mrs_afr_nr_freq_list_struct;
375
376typedef struct
377{
378 kal_bool ongoing_status;
379 MRS_RAT_MODE_TYPE afr_target_rat;
380 mrs_afr_strict_constrain_state strict_constrain_state;
381} mrs_afr_service_struct;
382
383typedef struct
384{
385 kal_bool ever_trigger;
386 kal_bool pre_cond_reqd;
387 MRS_RAT_MODE_TYPE afr_src_rat;
388} mrs_afr_pre_cond_proc_struct;
389
390typedef struct
391{
392 /* [b1: not used] [b2: reduce lau, enable] [b3: defer si13, enable] [b4: 2g afr, enable] [b5: 3g afr, enable] */
393 /* [b6: CSFB_2G_FDD_eCSFB, disable] [b7: CSFB_3G_FDD_eCSFB, disable] [b8: CSFB_2G_TDD_eCSFB, enable] [b9: CSFB_3G_TDD_eCSFB, disable] */
394 /* [b10 ~ b16: reserved] */
395 kal_uint16 csfb_enhancement_item_status;
396 /* [b1: not used] [b2: reduce lau, disable] [b3: defer si13, enable] [b4: 2g afr, disable] [b5: 3g afr, disable] */
397 /* [b6: CSFB_2G_FDD_eCSFB, disable] [b7: CSFB_3G_FDD_eCSFB, disable] [b8: CSFB_2G_TDD_eCSFB, disable] [b9: CSFB_3G_TDD_eCSFB, disable] */
398 /* [b10 ~ b16: reserved] */
399 kal_uint16 csfb_enhancement_item_status_in_test_mode;
400 kal_bool is_csfb_ongoing;
401 kal_uint8 num;
402 EARFCN afr_list[AFR_FREQ_MAX_NUM];
403} mrs_afr_main_struct;
404
405typedef struct
406{
407 /* [b1: 2g4 afr, enable] [b2: 3g4 afr, enable, enable] [b3: 2g5 fdd afr, enable] [b4: 2g5 tdd afr, enable] [b5: 3g5 fdd afr, enable] */
408 /* [b6: 3g5 tdd afr, disable] [b7: 4g5 fdd afr, disable] */
409 /* [b8 ~ b16: reserved] */
410 kal_uint16 afr_enhancement_item_status;
411 /* [b1: 2g4 afr, enable] [b2: 3g4 afr, enable, enable] [b3: 2g5 fdd afr, enable] [b4: 2g5 tdd afr, enable] [b5: 3g5 fdd afr, enable] */
412 /* [b6: 3g5 tdd afr, disable] [b7: 4g5 fdd afr, disable] */
413 /* [b8 ~ b16: reserved] */
414 kal_uint16 afr_enhancement_item_status_in_test_mode;
415
416 mrs_afr_service_struct service_tbl[AFR_SRVC_MAX_NUM];
417 mrs_afr_pre_cond_proc_struct pre_cond_proc_tbl[AFR_PROC_MAX_NUM];
418
419#ifdef __NR_RAT__
420 mrs_afr_nr_freq_list_struct afr_nr_priority_freq_list;
421#endif /* __NR_RAT__ */
422 mrs_afr_nr_freq_list_struct afr_nr_freq_list;
423 mrs_afr_nr_freq_info_struct nr_serving_freq_info;
424 kal_uint32 afr_to_4g_timer; //msec
425 kal_uint32 afr_to_5g_timer; //msec
426} mrs_afr_nr_main_struct;
427
428typedef struct {
429 mrs_plmn_id plmn_id;
430 kal_uint8 la_code[2];
431} mrs_lai_struct;
432
433typedef struct
434{
435 kal_uint16 arfcn;
436 kal_uint8 bsic;
437}mrs_gas_cell_struct;
438
439typedef struct
440{
441 mrs_gas_cell_struct gas_cell;
442 mrs_lai_struct lai;
443 mrs_gas_ecsfb_call_status_enum ecsfb_call_status;
444}mrs_gas_cell_inf_struct;
445
446typedef struct
447{
448 kal_uint16 uarfcn;
449 kal_uint16 psc;
450}mrs_uas_cell_struct;
451
452typedef struct
453{
454 mrs_uas_cell_struct uas_cell;
455 mrs_lai_struct lai;
456}mrs_uas_cell_inf_struct;
457
458typedef struct
459{
460 EARFCN earfcn;
461 kal_uint16 pci;
462}mrs_eas_cell_struct;
463
464typedef struct {
465 kal_bool valid;
466 MRS_RAT_MODE_TYPE rat;
467 mrs_plmn_id plmn_id;
468 kal_uint16 lac_or_tac;
469 kal_uint32 cell_id;
470 kal_uint32 arfcn_or_uarfcn_or_earfcn;
471 kal_uint16 bsic_or_psc_or_pci;
472 kal_int16 report_offset_for_serv_in_black_list; /* serving is a black cell, unit:dbm */
473 kal_int16 report_offset_for_nc_in_black_list; /* neighbor is a black cell, unit:dbm */
474} mrs_as_black_cell_struct;
475
476/* inform xAS black cell list added/cleared. */
477typedef struct {
478 LOCAL_PARA_HDR
479} mrs_uas_add_black_cell_ind_struct;
480
481typedef struct {
482 LOCAL_PARA_HDR
483} mrs_gas_add_black_cell_ind_struct;
484
485typedef struct {
486 LOCAL_PARA_HDR
487} mrs_uas_clear_black_cell_ind_struct;
488
489typedef struct {
490 LOCAL_PARA_HDR
491} mrs_gas_clear_black_cell_ind_struct;
492
493typedef struct mrs_mcc_id
494{
495 kal_uint8 mcc1;
496 kal_uint8 mcc2;
497 kal_uint8 mcc3;
498} mrs_mcc_id;
499
500/* AS use this struct to get MCC from MRS */
501typedef struct mrs_as_mcc_struct
502{
503 kal_uint8 mrs_as_mcc_count;
504 mrs_mcc_id multi_mcc_id[MAX_NUM_MULTI_MCC];
505} mrs_as_mcc_struct;
506
507/* MRS use this struct to set and save MCC from NAS */
508typedef struct
509{
510 kal_uint8 multi_plmn_count;
511 mrs_plmn_id multi_plmn_id[MAX_NUM_MULTI_PLMN];
512} mrs_nas_mcc_struct;
513
514typedef struct
515{
516 /* Fast Mode Switch, record the latest serving cell's essential SI
517 for fast camp on for FDD/TDD mode switch. */
518 mrs_gas_fast_mode_switch_status_enum fast_mode_switch_status;
519 kal_uint8 bsic;
520 kal_uint16 arfcn;
521 plmn_id_struct plmn_id;
522 kal_uint8 si_raw_data_valid_bitmap;
523 kal_uint8 si1_raw_data[GAS_SI_RAW_DATA_LEN];
524 kal_uint8 si2_raw_data[GAS_SI_RAW_DATA_LEN];
525 kal_uint8 si2bis_raw_data[GAS_SI_RAW_DATA_LEN];
526 kal_uint8 si3_raw_data[GAS_SI_RAW_DATA_LEN];
527 kal_uint8 si4_raw_data[GAS_SI_RAW_DATA_LEN];
528#ifdef __PS_SERVICE__
529 kal_uint8 si13_raw_data[GAS_SI_RAW_DATA_LEN];
530#endif /* __PS_SERVICE__ */
531} mrs_gas_shared_info_struct;
532
533/* MRS use this struct to set and get PLMN status from NAS
534 * is_roaming: current PLMN is roaming or not
535 */
536typedef struct
537{
538 kal_bool is_roaming;
539} mrs_nas_plmn_info_struct;
540
541#ifdef __GAS_STORED_SI_FEAT__
542typedef struct
543{
544 kal_bool valid;
545 /* RRM_BA_ROW_DATA_SIZE */
546 kal_uint8 ba_raw_data[16];
547 kal_uint8 count;
548 kal_uint8 rest[RRM_MAX_SI2TER_INSTANCES][RRM_SI2TER_REST_LEN];
549}rrm_si2ter_struct;
550
551typedef struct
552{
553 kal_bool valid;
554 kal_uint8 count;
555 kal_uint8 rest[RRM_MAX_SI2QUARTER_INSTANCES][RRM_SI2QUARTER_REST_LEN];
556}rrm_si2quarter_struct;
557
558typedef struct
559{
560 kal_bool valid;
561 kal_bool essential_si_valid;
562 kal_uint32 system_tick;
563 kal_uint16 storedSI_arfcn;
564 kal_uint8 storedSI_bsic;
565 kal_uint8 si_raw_data_bitmap;
566 kal_uint8 si1_data[21];
567 kal_uint8 si2_data[21];
568 kal_uint8 si2bis_data[21];
569 kal_uint8 si3_data[21];
570 kal_uint8 si4_data[21];
571 kal_uint8 si13_data[21];
572 rrm_si2ter_struct si2ter;
573 rrm_si2quarter_struct si2quarter;
574} rrm_gsm_storedSI_struct;
575
576#endif
577
578#ifdef __NR_RAT__
579typedef struct
580{
581 kal_bool additional_pmax_valid;
582 kal_int8 additional_pmax;
583 kal_bool additional_spectrum_emission_valid;
584 kal_uint16 additional_spectrum_emission;
585} eutra_ns_pmax_value_struct;
586
587typedef struct
588{
589 kal_uint8 eutra_ns_pmax_list_len;
590 eutra_ns_pmax_value_struct eutra_ns_pmax_list[EUTRA_NS_PMAX_LIST_MAX_NUM];
591} eutra_ns_pmax_list_struct;
592
593typedef struct
594{
595 kal_uint16 freq_band_indicator_eutra;
596 eutra_ns_pmax_list_struct ns_pmax_list;
597} eutra_multibandinfo_struct;
598
599typedef struct
600{
601 kal_uint8 eutra_multibandinfo_list_len;
602 eutra_multibandinfo_struct eutra_multibandinfo_list[EUTRA_MULTI_BANDS_MAX_NUM];
603} eutra_multibandinfo_list_struct;
604#endif /* __NR_RAT__ */
605
606typedef struct {
607 kal_uint8 *oct;
608 kal_uint16 oct_len;
609} mrs_nras_octet_string_struct;
610
611/**
612 * Structure for EUTRAN feature set IDs. IDs are in the order they shall be
613 * reported to the network. ID values are IDs of feature sets read from L1.
614 * fs_dl_num Number of IDs in fs_dl_id list
615 * fs_dl_id List of EUTRAN DL feature set IDs
616 * fs_ul_num Number of IDs in fs_ul_id list
617 * fs_ul_id List of EUTRAN UL feature set IDs
618 */
619typedef struct
620{
621 kal_uint16 fs_dl_num;
622 kal_uint16 fs_dl_id[MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM];
623 kal_uint16 fs_ul_num;
624 kal_uint16 fs_ul_id[MRS_NRAS_EUTRAN_FEATURE_SETS_MAX_NUM];
625} mrs_nras_eutran_feature_set_ids_struct;
626
627/* record systime of RAT_CHANGE_CNF(succes),
628 During timewindow, if the rat change reaches specific times, PINGPONG confirmed.
629 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
630*/
631typedef struct
632{
633 kal_uint32 rat_change_time[AS_PINGPONG_THRESHOLD_MAX];
634} mrs_irat_change_info_struct;
635
636typedef struct
637{
638 rat_enum rat; // Current active rat
639 kal_uint8 cc_idx; // Idle mode: always 0. Connected mode: NW configured CC idx.
640 kal_uint32 freq_1khz; // Corresponding Pcell/Scell frequency in 1khz.
641 kal_uint32 bw_1khz; // Corresponding Pcell/Scell BW in 1khz
642 kal_uint16 band; // Universal band
643 kal_uint8 mimo_layer; // 0xFF if no valid info
644} mrs_common_cc_info_struct;
645
646typedef struct
647{
648 protocol_id_enum ps_id;
649 kal_uint8 dl_cc_num; // Idle mode: always 1. Connected mode: NW configured DL cc num.
650 mrs_common_cc_info_struct dl_cc_info[MRS_MAX_CC_NUM];
651 kal_uint8 ul_cc_num; // Idle mode: always 1 or 0 if UL info is not available. Connected mode: NW configured UL cc num.
652 mrs_common_cc_info_struct ul_cc_info[MRS_MAX_CC_NUM];
653} mrs_cell_cc_info_struct;
654
655typedef struct
656{
657 kal_uint8 gsm_band;
658 kal_uint8 fdd_umts_band[NVRAM_EF_AS_FDD_UMTS_BAND_SETTING_SIZE];
659 kal_uint8 lte_band[NVRAM_EF_AS_LTE_BAND_SETTING_SIZE];
660} mrs_mcc_band_setting_per_region_struct;
661
662typedef struct
663{
664 kal_uint8 mcc_region_number;
665 kal_uint8 no_of_plmns;
666 mrs_plmn_id mcc_region_plmns[MAX_NUM_VALID_MCC_REGION_PLMNS];
667 mrs_mcc_band_setting_per_region_struct band_setting;
668} mrs_mcc_plmn_list_within_region_record_struct;
669
670
671typedef struct
672{
673 kal_uint8 no_of_mcc_regions;
674 mrs_mcc_plmn_list_within_region_record_struct setting[MAX_NUM_VALID_MCC_REGIONS];
675} mrs_mcc_region_band_setting_record_struct;
676
rjw2b1408e2022-12-19 11:19:29 +0800677#ifdef __CHANNEL_LOCK__
678/* MSG_ID_MRS_ERRC_CH_LOCK_NTF */
679typedef struct {
680 LOCAL_PARA_HDR
681
682 MRS_CH_LOCK_STATE lock_state;
683 kal_uint8 lock_mode;
684} mrs_errc_ch_lock_ntf_struct;
685
686/* MSG_ID_MRS_NRRC_CH_LOCK_NTF */
687typedef struct {
688 LOCAL_PARA_HDR
689
690 MRS_CH_LOCK_STATE lock_state;
691 kal_uint8 lock_mode;
692} mrs_nrrc_ch_lock_ntf_struct;
693#endif /* __CHANNEL_LOCK__ */
694
695typedef struct mrs_csg_imsi_info
696{
697 kal_uint8 imsi_length;
698 kal_uint8 imsi[MRS_CSG_IMSI_MAX_LEN];
699} mrs_csg_imsi_info;
700
rjw6c1fd8f2022-11-30 14:33:01 +0800701#endif /* _MRS_AS_STRUCT_H */