[Feature]Upload Modem source code
Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/protocol/interface/l4misc/l4bpdn_tcm_struct.h b/mcu/protocol/interface/l4misc/l4bpdn_tcm_struct.h
new file mode 100644
index 0000000..4389ba3
--- /dev/null
+++ b/mcu/protocol/interface/l4misc/l4bpdn_tcm_struct.h
@@ -0,0 +1,410 @@
+/*****************************************************************************
+* 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:
+ * ---------
+ * l4bpdn_tcm_struct.h
+ *
+ * Project:
+ * --------
+ *
+ *
+ * Description:
+ * ------------
+ *
+ *
+ * Author:
+ * -------
+ *
+ *
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 09 22 2021 stun.wu
+ * [MOLY00728968] [ZM62] AT+EGPCO to get MSISDN
+ *
+ * 09 17 2021 judy.zhu
+ * [MOLY00704256] [VzW] 5G Ultra Wideband icon display
+ *
+ * Patch back from NR15.R3.MP branch
+ * .
+ *
+ * 09 08 2021 judy.zhu
+ * [MOLY00704256] [VzW] 5G Ultra Wideband icon display
+ *
+ * [VzW]5G Ultra Wideband icon display feature patch back
+ *
+ * .
+ *
+ * 04 19 2019 yu-hsin.lin
+ * [MOLY00399993] [Gen97][VMOLY] interworking withN26 features
+ * [MPD][Code] merge from 7781298, l4 ps with n26
+ *
+ * 03 26 2019 yu-hsin.lin
+ * [MOLY00393456] [Gen97][VMOLY] 45G InterRAT & interSystem feature
+ * [VMOLY][MPD][Interface] L4_PS Gen97 irat withou n26
+ *
+ * 12 14 2018 poying.chuang
+ * [MOLY00372635] [VMOLY] L4/TCM/TFTLIB/VGSM phase2 check-in
+ *
+ * - [L4] Phase 2 - Interfaces .
+ *
+ * 08 17 2018 poying.chuang
+ * [MOLY00346763] [6297] Gen97 L4 PS Check-In
+ *
+ * - interfaces .
+ *
+ * 05 21 2018 praveen.komatiguntla
+ * [MOLY00327084] [EIGER][MT3967]PS Data Off feature: PDP Modify procedure to update the PS Data Off Statusto NW side.
+ * PS Data off feature - L4/TCM changes.
+ *
+ * 12 11 2017 poying.chuang
+ * [MOLY00294886] [MT6763][Bianco][O1][MP2][TMO][simulator][in-house][Anritsu][Protocol_IMS & VoLTE][50905][L_IMS_VoLTE_6752_1]
+ * .
+ *
+ * 04 05 2017 poying.chuang
+ * [MOLY00209737] [MT6293] LWTG and C2K L4 integration check in
+ * [M3] Merge CL up to 3677934 - interface .
+ *
+ * 02 20 2017 poying.chuang
+ * [MOLY00209737] [MT6293] LWTG and C2K L4 integration check in
+ *
+ * - [M2] l4bpdn/tcm - interface (up to CL 3474533) .
+ *
+ ****************************************************************************/
+
+
+#ifndef _L4BPDN_TCM_STRUCT_H
+#define _L4BPDN_TCM_STRUCT_H
+
+#include "kal_general_types.h"
+#include "kal_public_defs.h"
+
+#include "tftlib_common_enum.h"
+#include "tftlib_common_struct.h"
+
+#include "ps_public_enum_public.h"
+#include "l3_inc_enums_public.h"
+#include "ps_public_struct.h"
+
+
+#if __GROUP_L4BPDN_TCM_INTERFACE_DEFINE_AND_SUB_STRUCT__ || 1
+
+#define L4BPDN_TCM_PCSCF_4_TO_8_SIZE 5
+#define L4BPDN_TCM_BEARER_NUM 15
+
+#define L4BPDN_TCM_PDU_ADDR_LIFETIME_SIZE 2
+
+typedef struct {
+ pdp_addr_type_enum type;
+ pdp_addr_len_enum len;
+ kal_uint8 val[IPV4V6_ADDR_LEN];
+} l4bpdn_tcm_ip_addr_struct;
+
+typedef struct {
+ kal_uint8 mcc1;
+ kal_uint8 mcc2;
+ kal_uint8 mcc3;
+ kal_uint8 mnc1;
+ kal_uint8 mnc2;
+ kal_uint8 mnc3;
+} l4bpdn_tcm_plmn_id_struct;
+
+typedef struct {
+ kal_uint8 context_id; /* CID */
+
+ /**
+ * In 5G, indicate PDU session id
+ * Otherwise, simply fill-in 0 (or the mapped PDU session id?) */
+ kal_uint8 pdu_session_id;
+
+ /**
+ * In 5G, indicate QoS flow id (qfi)
+ * Otherwise, indicate nsapi(23G) or ebi(4G) */
+ kal_uint8 bearer_id;
+
+ ps_cause_enum cause;
+} l4bpdn_tcm_deact_id_struct;
+
+typedef struct {
+ kal_uint8 apn_length;
+ kal_uint8 apn[MAX_APN_LEN];
+ kal_bool src_addr_sb_net_mask_present;
+ kal_uint8 src_addr_sb_net_mask[IPV4_ADDR_LEN * 2];
+ kal_bool ipv6_src_addr_sb_net_mask_present;
+ kal_uint8 ipv6_src_addr_sb_net_mask[IPV6_ADDR_LEN * 2];
+ kal_bool gw_addr_present;
+ kal_uint8 gw_addr[IPV4_ADDR_LEN];
+ kal_bool ipv6_gw_addr_present;
+ kal_uint8 ipv6_gw_addr[IPV6_ADDR_LEN];
+ kal_bool dns_present;
+ kal_uint8 dns[IPV4_ADDR_LEN];
+ kal_bool dns2_present;
+ kal_uint8 dns2[IPV4_ADDR_LEN];
+ kal_bool dns3_present;
+ kal_uint8 dns3[IPV4_ADDR_LEN];
+ kal_bool ipv6_dns_present;
+ kal_uint8 ipv6_dns[IPV6_ADDR_LEN];
+ kal_bool ipv6_dns2_present;
+ kal_uint8 ipv6_dns2[IPV6_ADDR_LEN];
+ kal_bool ipv6_dns3_present;
+ kal_uint8 ipv6_dns3[IPV6_ADDR_LEN];
+ kal_bool p_cscf_prim_addr_present;
+ kal_uint8 p_cscf_prim_addr[IPV4_ADDR_LEN];
+ kal_bool p_cscf_sec_addr_present;
+ kal_uint8 p_cscf_sec_addr[IPV4_ADDR_LEN];
+ kal_bool p_cscf_third_addr_present;
+ kal_uint8 p_cscf_third_addr[IPV4_ADDR_LEN];
+ kal_bool ipv6_p_cscf_prim_addr_present;
+ kal_uint8 ipv6_p_cscf_prim_addr[IPV6_ADDR_LEN];
+ kal_bool ipv6_p_cscf_sec_addr_present;
+ kal_uint8 ipv6_p_cscf_sec_addr[IPV6_ADDR_LEN];
+ kal_bool ipv6_p_cscf_third_addr_present;
+ kal_uint8 ipv6_p_cscf_third_addr[IPV6_ADDR_LEN];
+ kal_bool im_cn_signalling_flag_present;
+ kal_uint8 im_cn_signalling_flag;
+ kal_bool lipa_indication_present; // indicates that the PDP context provides connectivity using a LIPA PDN connection
+ kal_uint8 lipa_indication;
+ kal_bool v4_mtu_present; // shows the IPv4 MTU size in octets
+ kal_uint16 v4_mtu;
+ kal_bool wlan_offload_present; // indicates whether traffic can be offloaded using the specified PDN connection via a WLAN or not
+ kal_uint8 wlan_offload;
+ kal_bool local_addr_ind_present; // indicates whether or not the MS and the network support local IP address in TFTs
+ kal_uint8 local_addr_ind;
+ kal_bool p_cscf_fourth_to_eighth_addr_present[L4BPDN_TCM_PCSCF_4_TO_8_SIZE]; //add for CT support 8 p-cscf address requirement
+ kal_uint8 p_cscf_fourth_to_eighth_addr[L4BPDN_TCM_PCSCF_4_TO_8_SIZE][IPV4_ADDR_LEN]; //add for CT support 8 p-cscf address requirement
+ kal_bool ipv6_p_cscf_fourth_to_eighth_addr_present[L4BPDN_TCM_PCSCF_4_TO_8_SIZE]; //add for CT support 8 p-cscf address requirement
+ kal_uint8 ipv6_p_cscf_fourth_to_eighth_addr[L4BPDN_TCM_PCSCF_4_TO_8_SIZE][IPV6_ADDR_LEN]; //add for CT support 8 p-cscf address requirement
+ kal_bool ps_data_off_support_present;
+ kal_uint8 ps_data_off_support;
+ kal_bool ssc_mode_present;
+ l4c_tcm_ssc_mode_enum ssc_mode;
+ kal_bool s_nssai_present;
+ l4c_tcm_s_nssai_struct s_nssai;
+ kal_bool access_type_present;
+ l4c_tcm_access_type_enum access_type;
+ kal_uint32 rq_timer_value_in_sec;
+ l4c_tcm_always_on_pdu_enum always_on_pdu_by_nw;
+} l4bpdn_tcm_pdp_rdp_info_struct;
+
+typedef struct {
+ /* v4 dns -> Contained in l4bpdn_tcm_prim_pdp_rdp_info_struct */
+ /* v6 dns -> Contained in l4bpdn_tcm_prim_pdp_rdp_info_struct */
+ /* v4 mtu -> Contained in l4bpdn_tcm_prim_pdp_rdp_info_struct */
+
+ kal_bool msisdn_present;
+ kal_uint8 msisdn[MAX_MSISDN_LEN];
+ kal_uint8 msisdn_len;
+
+ /* pdu address lifetime */
+ kal_bool pdu_addr_lifetime_present;
+ kal_uint8 pdu_addr_lifetime[L4BPDN_TCM_PDU_ADDR_LIFETIME_SIZE];
+
+ /****************************************
+ * Operator Specific PCOs in VZW: Start *
+ ****************************************/
+ /* 0xFF00 */
+ kal_bool pdn_application_access_control_present;
+ l4bpdn_tcm_plmn_id_struct pdn_application_access_control_plmnid;
+ kal_uint8 pdn_application_access_control_action;
+
+ /* 0xFF01 */
+ kal_bool epdg_v6_plmnid_present;
+ l4bpdn_tcm_plmn_id_struct epdg_v6_plmnid;
+ kal_bool epdg_v6_addr_present;
+ kal_uint8 epdg_v6_addr[IPV6_ADDR_LEN];
+ kal_bool epdg_v6_addr2_present;
+ kal_uint8 epdg_v6_addr2[IPV6_ADDR_LEN];
+
+ /* 0xFF02 */
+ kal_bool epdg_v4_plmnid_present;
+ l4bpdn_tcm_plmn_id_struct epdg_v4_plmnid;
+ kal_bool epdg_v4_addr_present;
+ kal_uint8 epdg_v4_addr[IPV4_ADDR_LEN];
+ kal_bool epdg_v4_addr2_present;
+ kal_uint8 epdg_v4_addr2[IPV4_ADDR_LEN];
+
+ /* 0xFF03 */
+ kal_bool vzw_5guw_present;
+ kal_uint8 vzw_5guw;
+ /****************************************
+ * Operator Specific PCOs in VZW: End *
+ ****************************************/
+} l4bpdn_tcm_pco_rdp_info_struct;
+
+#endif // __GROUP_L4BPDN_TCM_INTERFACE_DEFINE_AND_SUB_STRUCT__
+
+typedef struct {
+ LOCAL_PARA_HDR
+
+ kal_uint8 context_id;
+
+ /**
+ * Indicate how to interpret the below ids: pdu_session_id, bearer_id, linked_bearer_id */
+ kal_bool is_5g_id;
+
+ /**
+ * In 5G, indicate PDU session id
+ * Otherwise, simply fill-in 0 (or the mapped PDU session id?) */
+ kal_uint8 pdu_session_id;
+
+ /**
+ * In 5G, indicate QoS flow id (qfi)
+ * Otherwise, indicate nsapi(23G) or ebi(4G) */
+ kal_uint8 bearer_id;
+
+ /**
+ * If the PDP is secondary, indicate UPCM which primary PDP context the bearer is linked with.
+ * If the PDP is primary, indicate the linked_nspai = nsapi.
+ * If in 5G, indicate the qfi which contains default qos rule */
+ kal_uint8 linked_bearer_id;
+
+ /**
+ * TFTLIB output: pkt_filter_act_list_struct
+ * - Needs to convert to pkt_filters_act_list_node_struct for UPCM use
+ * - In 5G, the conversion is done by VGSM
+ * - In 234G, the conversions are done by UGTCM and ETCM, respectively */
+ pkt_filters_act_list_node_struct *pf_action_list_node;
+
+ /* Address acquired by PDP context activation. */
+ l4bpdn_tcm_ip_addr_struct ip_addr;
+
+ kal_bool pdp_rdp_present;
+ l4bpdn_tcm_pdp_rdp_info_struct pdp_rdp;
+} l4bpdn_tcm_bearer_act_ind_struct;
+
+typedef struct {
+ LOCAL_PARA_HDR
+
+ kal_uint8 bearer_num; /* indicate number of nsapi/EBI entries carried in deact_nsapi_list.*/
+ l4bpdn_tcm_deact_id_struct deact_id_list[L4BPDN_TCM_BEARER_NUM]; /* CID/NSAPI/EBI list of the deactivated PDP contexts*/
+} l4bpdn_tcm_bearer_deact_ind_struct;
+
+typedef struct {
+ kal_uint8 context_id;
+
+ /**
+ * Indicate how to interpret the below ids: pdu_session_id, bearer_id, linked_bearer_id */
+ kal_bool is_5g_id;
+
+ /**
+ * In 5G, indicate PDU session id
+ * Otherwise, simply fill-in 0 (or the mapped PDU session id?) */
+ kal_uint8 pdu_session_id;
+
+ /**
+ * In 5G, indicate QoS flow id (qfi)
+ * Otherwise, indicate nsapi(23G) or ebi(4G) */
+ kal_uint8 bearer_id;
+
+ /**
+ * If the PDP is secondary, indicate UPCM which primary PDP context the bearer is linked with.
+ * If the PDP is primary, indicate the linked_nspai = nsapi.
+ * If in 5G, indicate the qfi which contains default qos rule */
+ kal_uint8 linked_bearer_id;
+
+ /**
+ * TFTLIB output: pkt_filter_act_list_struct
+ * - Needs to convert to pkt_filters_act_list_node_struct for UPCM use
+ * - In 5G, the conversion is done by VGSM
+ * - In 234G, the conversions are done by UGTCM and ETCM, respectively */
+ pkt_filters_act_list_node_struct *pf_action_list_node;
+
+ /* Address acquired by PDP context activation. */
+ l4bpdn_tcm_ip_addr_struct ip_addr;
+
+ kal_bool pdp_rdp_present;
+ l4bpdn_tcm_pdp_rdp_info_struct pdp_rdp;
+} l4bpdn_tcm_act_id_struct;
+
+
+typedef struct {
+ LOCAL_PARA_HDR
+
+ /* Indicate UPCM the packet filter modification is triggered by which PDP context/EPS bearer context */
+ kal_uint8 context_id;
+
+ /**
+ * Indicate how to interpret the below ids: pdu_session_id, bearer_id, linked_bearer_id */
+ kal_bool is_5g_id;
+
+ /**
+ * In 5G, indicate PDU session id
+ * Otherwise, simply fill-in 0 (or the mapped PDU session id?) */
+ kal_uint8 pdu_session_id;
+
+ /**
+ * In 5G, indicate QoS flow id (qfi)
+ * Otherwise, indicate nsapi(23G) or ebi(4G) */
+ kal_uint8 bearer_id;
+
+ /**
+ * TFTLIB output: pkt_filter_act_list_struct
+ * - Needs to convert to pkt_filters_act_list_node_struct for UPCM use
+ * - In 5G, the conversion is done by VGSM
+ * - In 234G, the conversions are done by UGTCM and ETCM, respectively */
+ pkt_filters_act_list_node_struct *pf_action_list_node;
+} l4bpdn_tcm_pf_update_ind_struct;
+
+/* Use this ILM to update PCO RDP info
+ * when it is changed by activate/modify/deactivate procedures */
+typedef struct {
+ LOCAL_PARA_HDR
+
+ kal_uint8 context_id;
+
+ l4bpdn_tcm_pco_rdp_info_struct pco_rdp;
+
+ kal_bool pdp_rdp_present;
+ l4bpdn_tcm_pdp_rdp_info_struct pdp_rdp;
+
+} l4bpdn_tcm_pco_rdp_update_ind_struct;
+
+typedef struct {
+ LOCAL_PARA_HDR
+
+ kal_uint8 deact_bearer_num; /* indicate number of nsapi/EBI entries carried in deact_bearer_list.*/
+ l4bpdn_tcm_deact_id_struct deact_bearer_list[L4BPDN_TCM_BEARER_NUM]; /* CID/NSAPI/EBI list of the deactivated PDP contexts*/
+
+ kal_bool is_4g5_irat;
+
+ kal_uint8 act_bearer_num; /* indicate number of nsapi/EBI entries carried in act_bearer_list.*/
+ l4bpdn_tcm_act_id_struct act_bearer_list[L4BPDN_TCM_BEARER_NUM]; /* CID/NSAPI/EBI list of the activated PDP contexts*/
+
+} l4bpdn_tcm_45g_irat_bearer_update_ind_struct;
+
+#endif /* _L4BPDN_TCM_STRUCT_H */