[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/protocol/interface/general/mrs_common_capability.h b/mcu/protocol/interface/general/mrs_common_capability.h
new file mode 100644
index 0000000..9a480f5
--- /dev/null
+++ b/mcu/protocol/interface/general/mrs_common_capability.h
@@ -0,0 +1,259 @@
+/******************************************************************************
+*  Copyright Statement:
+*  --------------------
+*  This software is protected by Copyright and the information contained
+*  herein is confidential. The software may not be copied and the information
+*  contained herein may not be used or disclosed except with the written
+*  permission of MediaTek Inc. (C) 2007
+*
+*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
+*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
+*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
+*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
+*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
+*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
+*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
+*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
+*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
+*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
+*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
+*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
+*
+*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
+*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
+*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
+*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
+*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. 
+*
+*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
+*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
+*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
+*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
+*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
+*
+*******************************************************************************/
+
+/******************************************************************************
+ * Filename:
+ * --------------------------------------------------------
+ *   mrs_common_capability.h
+ *
+ * Project:
+ * --------------------------------------------------------
+ *   Multimode
+ *
+ * Description:
+ * --------------------------------------------------------
+ *   Declaration of funcitons of mrs_common_capability.c.
+ *
+ * Author:
+ * --------------------------------------------------------
+ * -------
+ *
+ * --------------------------------------------------------
+ * $Log$
+ *
+ * 01 11 2022 tom.wu
+ * [MOLY00742518] MIPC API support for Enable/Disable SA for a given 5G band
+ * 	
+ * 	.
+ *
+ * 10 30 2020 vend_mtb_aricent017
+ * [MOLY00581307] [LOVE]Question about l4c_nw_set_preferred_band_req_nosave()
+ * 	
+ * 	.
+ *
+ * 10 01 2020 tero.miettinen
+ * [MOLY00560032] ????SA???
+ * MRS - PLMN based 5G band disabling.
+ *
+ * 09 28 2020 esko.oikarinen
+ * [MOLY00557246] [P200803-00845] [MTK][5G][A326B] AT+EPBSEH 셋팅ì?´í›„ ue capa info ì—? nr41,79 올ë?¼ê°€ëŠ” 현ìƒ?
+ *
+ * 01 22 2020 bo-yao.tsai
+ * [MOLY00475582] �i��?��?�j�i���n??��?�j �i19165�j���n??��Z��?��?���q?�v��??�A?��?�E? - TAU capability change for workaround
+ *
+ * 09 18 2019 vinayak.bandagi
+ * [MOLY00441244] [CODE SYNC] modem mini dump??????????-USIR Changes
+ *
+ * 01 31 2019 esko.oikarinen
+ * [MOLY00308821] [6297][MRS] NR implementation
+ * 	Band support configuration with AT command
+ *
+ * 09 07 2018 esko.oikarinen
+ * [MOLY00346011] [Gen97][NRRC] Merge to VMOLY TRUNK
+ * 	
+ * 	CL 6335055 merge to VMOLY
+ *
+ * 05 29 2018 jiawei.he
+ * [MOLY00329258] [GAS part]FT SRVCC improvement
+ * 	
+ * 	.
+ *
+ * 04 18 2018 lw.chen
+ * [MOLY00320662] [Gen93][P40][UMOLYE] Gionee blacklist feature - MRS
+ *
+ * 04 18 2018 morton.lin
+ * [MOLY00320662] [Gen93][P40][UMOLYE] Gionee blacklist feature - MRS
+ * [MRS] Gionee Blacklist feature phase-in
+ *
+ * 03 02 2018 qingyu.lai
+ * [MOLY00310177] [����][CMCC VoLTE]���ݽ����껪_�컪Է_3.1SRVCC fail SW workaround solution
+ * .
+ *
+ * 11 29 2017 sapna.ks
+ * [MOLY00292082] [Gen93][TMO] 2G disable with ecc enable
+ * .
+ *
+ * 07 06 2017 morton.lin
+ * [MOLY00261305] [Gen93] B71 development
+ * MRS and NVRAM phase in
+ *
+ * 03 14 2017 menghau.wu
+ * [MOLY00217129] [MT6293] code sync from UMOLY (Phase4)
+ * UMOLY CR : [MOLY00224474] [6291][MP3][Post MP] CU HST Patch - MRS and CUSTOM
+ * UMOLY CL : 3547100
+ *
+ * 02 08 2017 menghau.wu
+ * [MOLY00217129] [MT6293] code sync from UMOLY (Phase4)
+ * UMOLY CR : [ALPS02900073][MT6292][ELBRUS][Phone][GCF][BLOCKING][TS8980][TDD B41,TC 8.7.13] No 4G measurement report from WCDMA to TD-LTE
+ * UMOLY CL : 3354520/3354606
+ *
+ * 12 27 2016 david.niu
+ * LR12->UMOLYA sync for CR[MOLY00210217].
+ *
+ * 10 24 2016 vend_mtb_mobiveil003
+ * [MOLY00209293] Band 66 support
+ * Band 66 support
+ *
+ * 10 12 2016 menghau.wu
+ * [MOLY00207053] [MT6293] code sync form UMOLY
+ * UMOLY CR : [MOLY00153524] [6291] Vivo BlackList feature
+ * UMOLY CL : 2577150
+ *
+ * 03 10 2016 morton.lin
+ * [MOLY00165947] [6291 HSR] Protocol Enhancement (Header/Interface)
+ * CMCC requirement: HSFR CTRL (SBP, NVRAM and MRS) (Protocol Header / Interface)
+ *
+ * 02 17 2016 sabrina.hsu
+ * [MOLY00156230] [6292] ERRC code sync LR11 to UMOLY
+ * AT+EPBSE
+ *
+ * 12 02 2015 wonder.lee
+ * [MOLY00151252] World Mode ID & Support Band collision check
+ * 	
+ * 	.
+ *
+ * 11 05 2014 wonder.lee
+ * [MOLY00083318] [USIME/MCDLL/UMA] sync code from MT6291_DEV
+ * 	.
+ *
+ * 01 21 2014 wcpuser_integrator
+ * [MOLY00054475] SGLTE option rename
+ * .
+ *
+ * 12 31 2013 wonder.lee
+ * [MOLY00051335] USIMEcall SCSI function with sim index which UMTS is not supported
+ *
+ * 11 13 2013 peng.pan
+ * [MOLY00046027] [MT6290E1][MMDS_DC] MMDC feature patch back to MOLY trunk
+ * B3/B39 common capability.
+ *
+ * 02 05 2013 yenchih.yang
+ * [MOLY00009186] [SIBE/USIME/DBME] Multi-Mode CBr merge to MOLY
+ * .
+ *
+ *****************************************************************************/
+
+#ifndef _MRS_COMMON_CAPABILITY_H
+#define _MRS_COMMON_CAPABILITY_H
+
+#include "mrs_as_enums.h" // for MRS_SIM_INDE
+
+#include "mrs_as_struct.h" //for mrs_as_black_cell_struct
+
+#define MRS_LTE_BAND_BITMASK_SIZE   8
+#define MRS_NR_BAND_BITMASK_SIZE 128
+
+/*  Type Definitions */
+typedef struct {
+    kal_uint8  gsm_band;
+    kal_uint32 umts_band;
+    kal_uint8  lte_band[MRS_LTE_BAND_BITMASK_SIZE];
+} mrs_as_band_setting;
+
+/* B66 support */
+typedef struct {
+    kal_uint8  gsm_band;
+    kal_uint32 umts_band;
+    kal_uint8  lte_band[SIZE_LTE_BAND_MASK_TABLE_EXTENDED];
+    kal_uint8  nr_band[MRS_NR_BAND_BITMASK_SIZE];       // NR SA band only
+    kal_uint8  nr_endc_band[MRS_NR_BAND_BITMASK_SIZE];  // NR ENDC band only
+} mrs_as_band_setting_extended;
+
+/* Shall be aligned to NVRAM_MAX_MRS_AS_BLACK_CELL_NUM */
+#define MAX_BLACK_CELL_NUM      50
+
+typedef struct {
+    kal_uint8                   num;
+    mrs_as_black_cell_struct    as_black_cell_list[MAX_BLACK_CELL_NUM];
+} mrs_as_black_cell_list_struct;
+
+/* PUBLIC FUNCTION PROTOTYPES ***********************************************/
+extern void mrs_get_asband_settings(MRS_SIM_INDEX sim_index, kal_uint8 *nocheck_invalidrat, kal_uint8 *support_rat);
+extern void mrs_em_get_as_band_setting(MRS_SIM_INDEX sim_index, mrs_as_band_setting *band_setting);
+extern void mrs_em_get_as_band_setting_extended(MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting);
+extern void mrs_get_as_band_setting(MRS_SIM_INDEX sim_index, mrs_as_band_setting *band_setting);
+extern void mrs_get_as_band_setting_extended(MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting);
+#if defined(__TC10__) || defined(__TC01__)
+extern void mrs_em_set_as_band_setting(MRS_SIM_INDEX sim_index, mrs_as_band_setting *band_setting, kal_bool is_nvram_save_needed);
+extern void mrs_em_set_as_band_setting_extended( MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting, kal_bool is_nvram_save_needed);
+#else
+extern void mrs_em_set_as_band_setting(MRS_SIM_INDEX sim_index, mrs_as_band_setting *band_setting);
+extern void mrs_em_set_as_band_setting_extended( MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting);
+#endif
+extern void mrs_set_as_band_setting(MRS_SIM_INDEX sim_index, mrs_as_band_setting *band_setting);
+extern void mrs_set_as_band_setting_extended(MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting);
+extern void mrs_set_as_band_setting_nosave(MRS_SIM_INDEX sim_index, mrs_as_band_setting_extended *band_setting);
+
+extern void mrs_hsr_set_mode(MRS_SIM_INDEX sim_index, kal_bool hsr_mode);
+extern kal_bool mrs_hsr_get_mode(MRS_SIM_INDEX sim_index);
+void FDD_mrs_cleanup(kal_uint8 sim_index);
+
+
+extern void mrs_scsi_retrieveGsmBandBitmask(MRS_SIM_INDEX sim_index, kal_uint8 *pGBandBitmask);
+extern void mrs_scsi_retrieveUmtsBandBitmask(MRS_SIM_INDEX sim_index, kal_uint32 *pUBandBitmask);
+extern void mrs_scsi_retrieveLteBandBitmask(MRS_SIM_INDEX sim_index, void *pLBandBitmask);
+extern void mrs_scsi_retrieveLteBandBitmask_extended(MRS_SIM_INDEX sim_index, void *pLBandBitmask);
+#ifdef __NR_RAT__
+void mrs_scsi_retrieveNRBandBitmask(MRS_SIM_INDEX sim_index, void *pNRBandBitmask);
+void mrs_scsi_retrieveNR_ENDCBandBitmask(MRS_SIM_INDEX sim_index,
+    mrs_gemini_status_enum gemini_status, void *pNR_ENDCBandBitmask);
+#endif /* __NR_RAT__ */
+
+extern kal_bool mrs_add_black_cell_list(MRS_SIM_INDEX sim_index, mrs_as_black_cell_list_struct *black_cell_list);
+extern void mrs_get_black_cell_list(MRS_SIM_INDEX sim_index, mrs_as_black_cell_list_struct *black_cell_list);
+extern kal_bool mrs_check_black_cell_list(MRS_SIM_INDEX sim_index, MRS_RAT_MODE_TYPE rat, mrs_plmn_id plmn_id, kal_uint32 cell_identity, kal_uint16 lac_or_tac);
+// SBP_BLACK_CELL_LIST for CONNECTED mode
+extern kal_int16 mrs_check_black_cell_list_earfcn_pci(MRS_SIM_INDEX sim_index, MRS_RAT_MODE_TYPE rat, mrs_plmn_id plmn_id, kal_uint16 lac_or_tac, kal_uint32 earfcn, kal_uint16 pci, kal_bool is_serv_cell);
+extern void mrs_clear_black_cell_list(MRS_SIM_INDEX sim_index);
+extern void mrs_update_disable_rat_mode(MRS_SIM_INDEX sim_index, rat_enum disable_rat_mode);
+
+void mrs_common_read_nvram_cnf_handler(kal_uint16 nvram_file_id, kal_uint8 *data, kal_uint16 len);
+
+#if defined(__ANT_RXPWR_OFFSET_SUPPORT__)
+extern kal_int16 L1D_RF_Antenna_RX_Power_Offset(kal_uint16 rf_band, kal_uint16 arfcn, kal_int16 RSSI, kal_uint32 pcell_id);
+extern kal_int16 EAS_GAS_RF_Antenna_RX_Power_Offset(kal_uint16 rf_band, kal_uint16 arfcn, kal_int16 RSSI, kal_uint32 pcell_id);
+#endif
+
+void mrs_update_as_capability_event(MRS_SIM_INDEX sim_index, mrs_as_capa_event_enum event);
+
+kal_bool mrs_get_as_capability_change_feature_state(MRS_SIM_INDEX sim_index, mrs_as_capa_change_feature_enum feature);
+
+kal_bool mrs_get_as_radio_capability_change(MRS_SIM_INDEX sim_index);
+
+kal_bool mrs_as_is_mcc_match(mrs_plmn_id plmn1, mrs_plmn_id plmn2);
+
+kal_bool mrs_as_is_plmn_match(mrs_plmn_id plmn1, mrs_plmn_id plmn2);
+
+#endif /* _MRS_COMMON_CAPABILITY_H */