[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/protocol/interface/lte/l4c_el1_struct.h b/mcu/protocol/interface/lte/l4c_el1_struct.h
new file mode 100644
index 0000000..d16f50f
--- /dev/null
+++ b/mcu/protocol/interface/lte/l4c_el1_struct.h
@@ -0,0 +1,395 @@
+/*****************************************************************************
+*  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) 2012
+*
+*  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:
+ * ---------
+ *   l4c_el1_struct.h
+ *
+ * Project:
+ * --------
+ *   MOLY
+ *
+ * Description:
+ * ------------
+ *   message and common structure definition between L4C and EL1 modules.
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 06 02 2021 titi.wu
+ * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D
+ * 	
+ * 	.
+ *
+ * 04 09 2021 titi.wu
+ * [MOLY00609450] [FM350][HP][Kaixuan.Zhang]LTE«D«H¥OTx©MRxªºAT©R¥O»Ý¨D
+ * .
+ *
+ * 07 03 2020 wade.chen
+ * [MOLY00534567] LTE B38 ©M B41ªº «ü¥OAT+ERFTX=6,0,1,41,2,26825,1,1,4,0,25,0,23,1,1 ?¤£¥X?¥\²v
+ * 	
+ * 	[EWSP0000125300][R3]add rx ant state for ERFTX test
+ *
+ * 05 26 2020 chun-yu.chien
+ * [MOLY00516314] [CAYMAN][SPR] OMADM node to control ./LTE/QAM/Downlink ./LTE/QAM/Uplink ./LTE/TDD/TM9: ./LTE/FDD/TM9: ./LTE/B25/4x4MIMO:./LTE/B41/4x4MIMO:
+ * 	
+ * 	AT+EGDM extension : GET/SET omadm 4x4 MIMO interface
+ * 	R3.MP
+ *
+ * 09 25 2019 wade.chen
+ * [MOLY00347940] [Gen97][MT6297] tstm_meta development
+ * 	
+ * 	[VMOLY]ERFTX error handle enhancement (code sync)
+ *
+ * 01 29 2019 wade.chen
+ * [MOLY00347940] [Gen97][MT6297] tstm_meta development
+ * 	
+ * 	[ERS00028822][EVB.SEPT.DEV][code sync] RF De-sense modification
+ *
+ * 06 06 2018 vend_mtb_mobiveil012
+ * [MOLY00331680] [CODE SYNC] Looking for TAS AT comamnd while target execte RF test by AT+ERFTX
+ * Added two antenna parameters to AT+ERFTX=6.
+ *
+ * 05 22 2018 aki.hietala
+ * [MOLY00260136] [MT6295] EL1C TX development
+ * -SAR update for Gen95, EL1C part
+ *
+ * 12 04 2017 bart.liang
+ * [MOLY00293238] [GEN93] EM Power Detector - error handling
+ *
+ * 12 01 2017 bart.liang
+ * [MOLY00293238] [GEN93] EM Power Detector - error handling
+ *
+ * 12 01 2017 bart.liang
+ * [MOLY00293238] [GEN93] EM Power Detector - error handling
+ * Rollback for V-list sync fail
+ *
+ * 07 10 2017 jung-ching.hsieh
+ * [MOLY00262750] [PH1 VZW] Regarding Antenna Testing interface modify
+ *
+ * 12 19 2016 gary.liu
+ * [MOLY00207413] EL1C 6293 development
+ * [EL1 CH] change lte band from uint8 to uint16
+ *
+ * 11 16 2016 popcafa.shih
+ * [MOLY00196065] [MT6293][folder structure] Move EL1/EL2 files from LTE domain to SWRD domain
+ * modify MOLY00173949 & MOLY00172964 for IS_EL1_ANDROID_M_LCE_REPORT_SUPPORT 0.
+ *
+ * 01 15 2016 ty.shen
+ * [MOLY00159734] TX power detector support on Jade
+ * L4C/EL1 Interface.
+ *
+ * 07 09 2014 yr.chiang
+ * [MOLY00071851] [MT6290E2][EL1TX] ROME DSDA support for AT+EB3INFO
+ * .
+ *
+ * 05 20 2014 yr.chiang
+ * [MOLY00066106] [MT6290E2][EL1] EL1 support for EM forceTx function
+ * .
+ *
+ ****************************************************************************/
+
+
+#ifndef  _L4C_EL1_STRUCT_H_
+#define  _L4C_EL1_STRUCT_H_
+
+#include "kal_general_types.h"
+#include "kal_public_defs.h"
+#include "el1_comm_inter_category_public.h"
+
+#if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__)))
+#include "l3_inc_enums.h"
+#include "l4c_common_enum.h"
+#endif
+
+//#include "ps_public_enum.h"
+
+#define LTE_MAX_TX_PWR_REQ_ANT_NUM 16 // LTE_MAX_TX_PWR_REQ_ANT_NUM >= LTE_SAR_ENABLE_MAX_ANT_TABLE_NUM
+/* MSG_ID_EL1_LTE_MAX_TX_PWR_RED_REQ */
+typedef struct
+{
+    LOCAL_PARA_HDR
+    // op 1: for all band, op 3,5: only for band, op 4: reset, n = 1
+    // op 9: for all band (2 antennas), op 10: one band (2 antennas), n = 2
+    // op 11: for all band (n antennas), op 12: one band (n antennas), 1 < n <= LTE_MAX_TX_PWR_REQ_ANT_NUM
+    kal_uint8   op;
+    kal_uint16  band;  // Band in integer format (1 - 255)
+    // note: para1, para2 and para3 to be removed
+    kal_uint8   para1; // 0~255, unit: 1/8 dB, (0~32 dB)
+    kal_uint8   para2; // reserved
+    kal_uint8   para3; // reserved
+    kal_uint8   n;     // 1~LTE_MAX_TX_PWR_REQ_ANT_NUM, number of valid parameters in param[]
+    kal_uint8   param[LTE_MAX_TX_PWR_REQ_ANT_NUM]; // 0~255, unit: 1/8 dB, (0~32 dB)
+} el1_lte_max_tx_pwr_red_req_struct;
+
+
+typedef enum
+{
+    EL1_EM_TST_CMD_FORCE_TX_PWR,
+    EL1_EM_TST_CMD_END,
+    EL1_EM_TST_CMD_TX_REPORT,
+} EL1_EM_TSTCmdType;
+
+typedef struct
+{
+    kal_uint8                   on;
+    kal_bool                    duplex_mode;
+    kal_uint8                   band;
+    kal_uint8                   ul_bandwidth;
+    kal_uint16                  ul_freq;
+    kal_uint8                   tdd_cfg;
+    kal_uint8                   tdd_sp_sf_cfg;
+    kal_uint8                   vrb_start;
+    kal_uint8                   vrb_len;
+    kal_uint8                   mcs;
+    kal_int16                   tx_power;
+    kal_bool                    tas_en;
+    kal_uint8                   tx_ant_state;
+    kal_uint8                   rx_ant_state; 
+} EL1_EM_TSTCmd_ForceTxPwr_T;
+
+typedef union
+{
+    EL1_EM_TSTCmd_ForceTxPwr_T  forceTxPwr;
+} EL1_EM_TSTCmdParam;
+
+
+/* MSG_ID_L4C_EL1_EM_TST_CONTROL_REQ */
+typedef struct
+{
+    LOCAL_PARA_HDR
+
+    kal_uint8                   src_id;
+    EL1_EM_TSTCmdType           type;
+    EL1_EM_TSTCmdParam          param;
+} l4c_el1_em_tst_control_req_struct;
+
+typedef enum
+{     
+    //L4CEL1_ERR_START           =   IND_AT_CMD_CAUSE_START, // 0x1900
+    L4C_EL1_ERR_NOT_IN_FLIGHT   =   0x1901,     
+    L4C_EL1_ERR_SIM_IN_SLOT     =   0x1902,
+    L4C_EL1_ERR_PARA_BAND       =   0x1903,
+    L4C_EL1_ERR_PARA_UL_BW      =   0x1904,
+    L4C_EL1_ERR_PARA_UL_FREQ    =   0x1905,
+    L4C_EL1_ERR_PARA_DUPLEX_MODE=   0x1906,
+    L4C_EL1_ERR_PARA_TDD_CFG    =   0x1907,
+    L4C_EL1_ERR_PARA_SP_SF_CFG  =   0x1908,
+    L4C_EL1_ERR_PARA_VRB        =   0x1909,
+    L4C_EL1_ERR_PARA_MCS        =   0x190A,
+    L4C_EL1_ERR_ROUTE_VALID     =   0x190B,
+    L4C_EL1_ERR_TEST_ONGOING    =   0x190C,
+    L4C_EL1_ERR_ANT_STATE       =   0x190D,
+    L4C_EL1_ERR_OTHERS          =   0x194F,
+    L4CEL1_ERR_INVALID          =   0x1950 //success=true, error_code is useless
+} l4cel1_error_enum       ; //error_code should be larger than 256
+
+/* MSG_ID_L4C_EL1_EM_TST_CONTROL_CNF */
+typedef struct
+{
+    LOCAL_PARA_HDR
+
+    kal_uint8                   src_id;
+    kal_bool                    success;
+    l4cel1_error_enum           error_code;
+} l4c_el1_em_tst_control_cnf_struct;
+
+
+/* MSG_ID_L4C_EL1_EM_TX_REPORT_IND */
+typedef struct
+{
+    LOCAL_PARA_HDR
+
+    kal_int32                   tx_power;   // dBm*8
+} l4c_el1_em_tx_report_ind_struct;
+
+
+/* MSG_ID_L4CEL1_B3_INFO_REQ */
+typedef struct
+{
+    LOCAL_PARA_HDR
+
+    kal_uint8                   type;  // 0: Off, 1: TCH, 2: BCCH
+    kal_uint8                   index; // frequency index
+                                       // 0:1850-1860 
+                                       // 1:1860-1870
+                                       // 2:1870-1875
+                                       // 3:1875-1880
+                                       // 4:1845-1850
+    kal_uint16                  arfcn; // GSM arfcn
+    kal_int16                   rssi;  // GSM rssi
+    kal_uint8                   src;   // Sourcd id
+} l4cel1_b3_info_req_struct;
+
+
+/* MSG_ID_L4CEL1_B3_INFO_CNF */
+typedef struct
+{
+    LOCAL_PARA_HDR
+
+    kal_uint8                   result;// 1: success, 0: error
+    kal_uint8                   src;   // Sourcd id
+} l4cel1_b3_info_cnf_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    kal_uint8  srcid;               // srcid is set by request
+    kal_uint32 lce_mode;            // Stop:0, Push mode:1, Pull mode:2
+    kal_uint32 lce_rpt_interval_ms; // LCE report interval
+} l4c_el1_lce_report_start_req_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    kal_uint8 srcid;
+} l4c_el1_lce_report_pulldata_req_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    kal_uint8  srcid;
+    kal_uint8  lce_status;          // stop:0, active:1
+    kal_uint32 lce_act_interval_ms; // actually reporting interval(ms)
+} l4c_el1_lce_report_cnf_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    kal_uint8  srcid;
+    kal_uint8  lce_suspend;    
+    kal_uint32 tput_curr;
+    kal_uint32 conf_lv1;
+} l4c_el1_lce_report_ind_struct;
+
+typedef enum
+{
+    ANTENNA_CONFIG_NORMAL_DUAL		=	0x1,	// normal dual receiver operation (default UE behavior)
+    ANTENNA_CONFIG_SINGLE_PRIMARY	=	0x2,	// Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver)
+    ANTENNA_CONFIG_SINGLE_SECONDARY	=	0x3	// Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver)
+} l4cel1_antenna_config_enum;
+
+typedef enum
+{
+    ANTENNA_STATUS_NORMAL_DUAL		=	0x1,	// normal dual receiver operation (default UE behavior)
+    ANTENNA_STATUS_SINGLE_PRIMARY	=	0x2,	// Single receiver operation ' enable primary receiver only (disable secondary/MIMO receiver)
+    ANTENNA_STATUS_SINGLE_SECONDARY	=	0x3	// Single receiver operation ' enable secondary/MIMO receiver only (disable primary receiver)
+} l4cel1_antenna_status_enum;
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+	kal_bool pri_receiver;
+	kal_bool sec_receiver;
+} l4cel1_antenna_information_req_struct;
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+	kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE
+	kal_bool is_pri_receiver_valid;
+	kal_uint16 pri_rssi;
+	kal_bool is_sec_receiver_valid;
+	kal_uint16 sec_rssi;
+	kal_bool is_relative_phase_valid;
+	kal_uint16 relative_phase;
+} l4cel1_antenna_information_cnf_struct;
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+	l4cel1_antenna_config_enum configuration;
+} l4cel1_antenna_config_req_struct;
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+	kal_bool result; //KAL_TRUE if success; otherwise KAL_FALSE
+} l4cel1_antenna_config_cnf_struct;
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+} l4cel1_antenna_config_status_req_struct;
+
+
+typedef struct
+{
+	LOCAL_PARA_HDR
+	kal_uint8 src_id;
+    kal_bool result; //antenna status result
+	l4cel1_antenna_status_enum ue_behavior;
+} l4cel1_antenna_config_status_cnf_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    kal_int32 rssi_edBm[LTE_UE_ANT_NUM];
+}l4cel1_ps_local_rx_rssi_verify_ind_struct;
+
+#if (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__)))
+typedef struct
+{
+    LOCAL_PARA_HDR
+    l4c_source_id_enum   src_id;       // piggyback value, indicate the source
+    omadm_cmd_type_enum  cmd;          // command mode
+    omadm_node_type_enum node_type;    // OMADM node
+    kal_uint32           node_value;   // the value for set mode
+} l4c_el1_omadm_update_req_struct;
+
+typedef struct
+{
+    LOCAL_PARA_HDR
+    l4c_source_id_enum   src_id;       // piggyback value, indicate the source
+    omadm_cmd_type_enum  cmd;          // command mode
+    kal_bool             result;       // TRUE=>pass, FALSE=>error
+    omadm_node_type_enum node_type;    // OMADM node
+    kal_uint32           node_value;   // the value for set mode
+} l4c_el1_omadm_update_cnf_struct;
+#endif /* (!defined(__MAUI_BASIC__)) && (!(defined(__NR_L1SIM__) || defined(__LTE_L1SIM__))) */
+
+#endif
+
+