[Feature]Upload Modem source code
Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/protocol/interface/ddm/d2cm_struct.h b/mcu/protocol/interface/ddm/d2cm_struct.h
new file mode 100644
index 0000000..cfae5c2
--- /dev/null
+++ b/mcu/protocol/interface/ddm/d2cm_struct.h
@@ -0,0 +1,1049 @@
+/*****************************************************************************
+* 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).
+*
+*****************************************************************************/
+
+#ifndef __D2CM_STRUCT_H__
+#define __D2CM_STRUCT_H__
+
+#include "kal_general_types.h"
+#include "kal_public_defs.h"
+#include "ps_public_enum.h"
+#include "pdn_public_defs.h"
+#include "custom_d2_config.h"
+#include "d2pm_ddm_struct.h" // NEED_TO_BE_NOTICED, to review it
+#include "d2pm_d2rm_struct.h" // NEED_TO_BE_NOTICED, to review it
+#include "ursp_public_defs.h"
+#include "d2rm_public_defs.h"
+#include "n3epc_public_defs.h"
+#include "iwlan_public_defs.h"
+
+// Type definition
+typedef struct d2cm_hdr d2cm_hdr_t;
+typedef struct d2cm_hdr* d2cm_hdr_ptr_t;
+typedef d2pm_ddm_ims_prv_data_t d2cm_act_data_call_ims_info_struct;
+
+// Macros
+#define D2CM_REQ_LOCAL_PARA_HDR \
+ LOCAL_PARA_HDR \
+ kal_uint32 src_id;
+
+#define D2CM_CNF_LOCAL_PARA_HDR \
+ LOCAL_PARA_HDR \
+ kal_uint32 src_id;
+
+#define D2CM_IND_LOCAL_PARA_HDR \
+ LOCAL_PARA_HDR \
+ kal_uint32 src_id;
+
+#define D2CM_RSP_LOCAL_PARA_HDR \
+ LOCAL_PARA_HDR \
+ kal_uint32 src_id;
+
+// Functions
+// N/A
+
+// Implementation
+struct d2cm_hdr
+{
+ LOCAL_PARA_HDR
+ kal_uint32 src_id;
+};
+
+/*******************************************************************************
+* Internal *
+*******************************************************************************/
+
+typedef struct {
+ // Header path: //VMOLY/BRANCHES_NR15/NR15.R3.MP/mcu/interface/protocol/general/ps_public_enum.h
+ ps_cause_enum deact_cause, mod_cause;
+}ddm_deact_res_info_struct;
+
+typedef struct {
+ iwlan_ran_e ran;
+
+ union {
+ ddm_deact_res_info_struct ddm_res_info;
+// n3x_deact_res_info_struct data4_res_info;
+ }res;
+}ran_deact_res_info;
+
+typedef union {
+ ran_deact_res_info ran_deact_res[RPL_PRIO_CNT + 1];
+}deact_res_info_struct;
+
+
+/*******************************************************************************
+* User to D2CM REQ *
+*******************************************************************************/
+
+// MSG_ID_D2CM_GET_PDN_PROFILE_REQ
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ // => unique key of APN
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ // => unique key of CID
+ kal_bool cid_present;
+ kal_int32 cid;
+ // => non-key values
+ kal_uint32 flag;
+
+ /* operater part */
+ kal_uint32 mcc_mnc;
+ union
+ {
+ struct
+ {
+ kal_uint32 apncl;
+ }vzw;
+ }op;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_get_pdn_profile_req_struct;
+
+
+// MSG_ID_D2CM_ACT_DATA_CALL_REQ
+typedef struct
+{
+ kal_bool cid_present;
+ kal_int32 cid;
+ kal_bool cgdcont_req_present;
+ at_cgdcont_req_struct cgdcont_req;
+ kal_uint32 tm_flag;
+ kal_bool if_id_present;
+ kal_int32 if_id;
+ kal_bool egpco_req_present;
+ at_egpco_req_struct egpco_req;
+}d2at_d2cm_act_data_call_req_prv_struct;
+
+typedef struct
+{
+ kal_int32 cid;
+ kal_int32 p_cid;
+ kal_int32 fb_cid;
+}d2am_d2cm_act_data_call_req_prv_struct;
+
+typedef struct
+{
+ kal_bool pcscf_restore;
+}imsm_d2cm_act_data_call_req_prv_struct;
+
+typedef struct
+{
+ kal_bool is_defined;
+ kal_char pdp_type[PDP_TYPE_STRING_LEN];
+ kal_char roam_prot[ROAMING_IP_TYPE_STRING_LEN];
+ kal_char username[APN_STRING_LEN];
+ kal_char passwd[APN_STRING_LEN];
+ kal_int8 auth_type;
+ ran_filter_struct ran_filter; // MUST give a value regardless of is_defined, by MTK14037
+ kal_bool qos_param_present;
+ kal_int32 qos_reliability;
+ kal_int32 qos_precedence_class;
+ kal_int32 qos_delay_class;
+ kal_int32 qos_peak_throughput_class;
+ kal_int32 qos_mean_throughput_class;
+}bip_d2cm_act_data_call_req_prv_struct;
+
+typedef struct
+{
+ kal_int32 if_id;
+ kal_uint32 bearer_bitmask;
+ kal_bool egpco_req_present;
+ at_egpco_req_struct egpco_req;
+}l5updn_d2cm_act_data_call_req_prv_struct;
+
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_char apn_type[APN_TYPE_STRING_LEN];
+ kal_uint32 suff_cond;
+ kal_uint32 flag;
+ d2cm_ipv4v6_fb_pref_enum ipv4v6_fb_pref;
+ ran_filter_struct ran_filter;
+
+ /* ursp part */
+ struct
+ {
+ kal_bool is_match_all;
+ kal_uint8 dnn_len;
+ kal_char dnn[URSP_TDC_LEN_DNN]; // APN in TS 23.003
+ kal_uint8 os_id[URSP_TDC_LEN_OS_ID]; // UUID in RFC 4122
+ kal_uint8 app_id_len;
+ kal_uint8 app_id[URSP_TDC_LEN_OS_APP_ID];
+ kal_uint8 ipv4_addr[URSP_TDC_LEN_IPV4_REMOTE_ADDR];
+ kal_uint8 ipv4_mask[URSP_TDC_LEN_IPV4_REMOTE_MASK];
+ kal_uint8 ipv6_addr[URSP_TDC_LEN_IPV6_REMOTE_ADDR];
+ kal_uint8 ipv6_prefix_len;
+ kal_uint8 prot_id_next_hdr;
+ kal_uint16 single_remote_port;
+ kal_uint16 min_remote_port;
+ kal_uint16 max_remote_port;
+ kal_uint8 dst_fqdn_len;
+ kal_uint8 dst_fqdn[URSP_TDC_LEN_DST_FQDN];
+ }traffic_desc;
+
+ struct
+ {
+ kal_uint8 ssc_mode;
+ kal_uint8 s_nssai_len;
+ kal_uint8 s_nssai[URSP_RSDC_LEN_S_NSSAI];
+ kal_uint8 dnn_len;
+ kal_uint8 dnn[URSP_TDC_LEN_DNN]; // APN in TS 23.003
+ kal_uint8 pdu_session_type;
+ kal_uint8 pref_access_type;
+ }ue_local_conf;
+ kal_uint32 ursp_eval_flag;
+
+ /* custom part */
+ /* Since AP fully controls APN settings in Gen93, this part can create a new APN setting, but cannot overwrite an existing one. */
+ kal_bool has_custom;
+ kal_char pdp_type[PDP_TYPE_STRING_LEN];
+ kal_char roam_prot[ROAMING_IP_TYPE_STRING_LEN];
+ kal_char username[APN_STRING_LEN];
+ kal_char passwd[APN_STRING_LEN];
+ kal_int8 auth_type;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_act_data_call_req_prv_struct d2at;
+ d2am_d2cm_act_data_call_req_prv_struct d2am;
+ imsm_d2cm_act_data_call_req_prv_struct imsm;
+ bip_d2cm_act_data_call_req_prv_struct bip;
+ l5updn_d2cm_act_data_call_req_prv_struct l5updn;
+ }prv;
+}d2cm_act_data_call_req_struct;
+
+// MSG_ID_D2CM_DEACT_DATA_CALL_REQ
+typedef struct
+{
+ kal_uint32 tm_flag;
+}d2at_d2cm_deact_data_call_req_prv_struct;
+
+typedef d2am_ddm_deact_data_call_req_prv_struct d2am_d2cm_deact_data_call_req_prv_struct;
+
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid;
+ atcmd_deact_cause_enum reason;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_deact_data_call_req_prv_struct d2at;
+ d2am_d2cm_deact_data_call_req_prv_struct d2am;
+ }prv;
+}d2cm_deact_data_call_req_struct;
+
+
+// MSG_ID_D2CM_ABORT_DATA_CALL_REQ
+typedef struct
+{
+ kal_uint8 unused;
+}imsm_d2cm_abort_data_call_req_prv_struct;
+
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_bool cid_present;
+ kal_int32 cid;
+ atcmd_deact_cause_enum reason;
+
+ /* private part */
+ union
+ {
+ imsm_d2cm_abort_data_call_req_prv_struct imsm;
+ }prv;
+}d2cm_abort_data_call_req_struct;
+
+
+#if 0
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+#endif
+
+
+// MSG_ID_D2CM_RESET_RETRY_TMR_REQ
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_uint32 reason;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_reset_retry_tmr_req_struct;
+
+
+/*******************************************************************************
+* D2CM to User CNF *
+*******************************************************************************/
+
+// MSG_ID_D2CM_GET_PDN_PROFILE_CNF
+typedef struct
+{
+ D2CM_REQ_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_get_pdn_profile_cnf_struct;
+
+
+// MSG_ID_D2CM_ACT_DATA_CALL_CNF
+typedef struct
+{
+ d2cm_act_data_call_ims_info_struct ims_info; // IMS information for p_cid
+ d2cm_act_data_call_ims_info_struct fb_ims_info; // IMS information for fb_cid
+}imsm_d2cm_act_data_call_cnf_prv_struct;
+
+typedef struct
+{
+ D2CM_CNF_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid, p_cid, fb_cid; // cid == fb_cid for fallback default bearer; cid == p_cid for default bearer; cid != p_cid for dedicated bearer
+ kal_uint8 p_ded_cid[D2CM_CID_BITMAP_SIZE], fb_ded_cid[D2CM_CID_BITMAP_SIZE]; // a bitmap
+ d2cm_act_data_call_ip_info_struct ip_info; // IP address for p_cid
+ d2cm_act_data_call_net_info_struct net_info; // Internet information for p_cid
+ d2cm_act_data_call_if_info_struct if_info; // interface information for p_cid
+ d2cm_act_data_call_ran_info_struct ran_info; // RAN info of non-3GPP for p_cid
+ d2cm_act_data_call_ip_info_struct fb_ip_info; // IP address for fb_cid
+ d2cm_act_data_call_net_info_struct fb_net_info; // Internet information for fb_cid
+ d2cm_act_data_call_if_info_struct fb_if_info; // interface information for fb_cid
+ d2cm_act_data_call_ran_info_struct fb_ran_info; // RAN info of non-3GPP for fb_cid
+ d2cm_act_data_call_retry_info_struct retry_info; // retry timer for APN
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ imsm_d2cm_act_data_call_cnf_prv_struct imsm;
+ }prv;
+}d2cm_act_data_call_cnf_struct;
+/* IMSM_INTERMEDIATE_CNF share the same structure*/
+typedef d2cm_act_data_call_cnf_struct d2cm_netif_send_imsm_intermediate_cnf_struct;
+
+// MSG_ID_D2CM_DEACT_DATA_CALL_CNF
+typedef struct
+{
+ D2CM_CNF_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_deact_data_call_cnf_struct;
+
+
+// MSG_ID_D2CM_ABORT_DATA_CALL_CNF
+typedef struct
+{
+ D2CM_CNF_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_bool cid_present;
+ kal_int32 cid;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_abort_data_call_cnf_struct;
+
+
+#if 0
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+/* under construction !*/
+#endif
+
+
+// MSG_ID_D2CM_RESET_RETRY_TMR_CNF
+typedef struct
+{
+ D2CM_CNF_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_reset_retry_tmr_cnf_struct;
+
+
+/*******************************************************************************
+* D2CM to User IND *
+*******************************************************************************/
+
+// MSG_ID_D2CM_GET_PDN_PROFILE_IND
+// ---- TO_BE_REMOVED ----
+typedef struct
+{
+ ran_info_struct ran_info;
+}bip_d2cm_get_pdn_profile_ind_prv_struct;
+// ++++ TO_BE_REMOVED ++++
+
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* static part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_char apn_type[APN_TYPE_LIST_STRING_LEN];
+ kal_char pdp_type[PDP_TYPE_STRING_LEN];
+ kal_char roam_prot[ROAMING_IP_TYPE_STRING_LEN];
+ kal_char username[APN_STRING_LEN];
+ kal_char passwd[APN_STRING_LEN];
+ kal_int8 auth_type;
+ kal_uint32 bearer_bitmask;
+
+ /* dynamic part */
+ d2cm_pdn_state_enum state;
+ kal_uint32 flag;
+ kal_int32 p_cid, fb_cid;
+ kal_uint8 p_ded_cid[D2CM_CID_BITMAP_SIZE], fb_ded_cid[D2CM_CID_BITMAP_SIZE]; // a bitmap
+ kal_char real_apn[APN_STRING_LEN];
+ kal_int32 engaged_apn_idx;
+ kal_char engaged_apn_type[APN_TYPE_STRING_LEN];
+ kal_char engaged_pdp_type[PDP_TYPE_STRING_LEN];
+ kal_uint32 num_of_p_cid_usr;
+ module_type p_cid_usr_list[D2CM_MAX_NUM_OF_USR];
+ kal_uint32 num_of_fb_cid_usr;
+ module_type fb_cid_usr_list[D2CM_MAX_NUM_OF_USR];
+
+ /* operater part */
+ struct
+ {
+ struct
+ {
+ kal_uint32 wapn;
+ kal_uint32 apncl;
+ kal_uint32 apned;
+ kal_uint32 max_conn;
+ kal_uint32 max_conn_t;
+ kal_uint32 wait_time;
+ }vzw;
+
+ struct
+ {
+ kal_uint32 inact_time;
+ }sprint;
+ }op;
+
+ /* private part */
+ struct
+ {
+ bip_d2cm_get_pdn_profile_ind_prv_struct bip; // ==== TO_BE_REMOVED ====
+ }prv;
+}d2cm_get_pdn_profile_ind_struct;
+
+
+// MSG_ID_D2CM_PDN_PROFILE_CHG_IND
+typedef d2cm_get_pdn_profile_ind_struct d2cm_pdn_profile_chg_ind_struct;
+
+
+// MSG_ID_D2CM_ACT_DATA_CALL_IND
+typedef struct
+{
+ cgev_event_enum cgev_event;
+ union
+ {
+ struct
+ {
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }nw_pdn_act;
+
+ struct
+ {
+ kal_bool reason_present;
+ atcmd_reason_enum reason;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }me_pdn_act;
+
+ struct
+ {
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }nw_act;
+
+ struct
+ {
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }me_act;
+ }cgev_info;
+}d2at_d2cm_act_data_call_ind_prv_struct;
+
+typedef struct
+{
+ d2cm_act_data_call_ims_info_struct ims_info; // IMS information for p_cid
+}imsm_d2cm_act_data_call_ind_prv_struct;
+
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid, p_cid, fb_cid; // cid == fb_cid for fallback default bearer; cid == p_cid for default bearer; cid != p_cid for dedicated bearer
+ kal_uint8 p_ded_cid[D2CM_CID_BITMAP_SIZE], fb_ded_cid[D2CM_CID_BITMAP_SIZE]; // a bitmap
+ d2cm_act_data_call_ip_info_struct ip_info; // for IP address
+ d2cm_act_data_call_net_info_struct net_info; // for Internet information
+ d2cm_act_data_call_if_info_struct if_info; // for interface information
+ d2cm_act_data_call_ran_info_struct ran_info; // RAN info of non-3GPP
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_act_data_call_ind_prv_struct d2at;
+ imsm_d2cm_act_data_call_ind_prv_struct imsm;
+ }prv;
+}d2cm_act_data_call_ind_struct;
+
+
+// MSG_ID_D2CM_DEACT_DATA_CALL_IND
+typedef struct
+{
+ cgev_event_enum cgev_event;
+ union
+ {
+ struct
+ {
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }nw_pdn_deact;
+
+ struct
+ {
+ int unused;
+ }me_pdn_deact;
+
+ struct
+ {
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }nw_deact;
+
+ struct
+ {
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ }me_deact;
+
+ struct
+ {
+ kal_bool PDP_type_present;
+ kal_uint8 PDP_type[PDP_TYPE_STRING_LEN];
+ kal_bool PDP_addr_present;
+ at_addr_struct PDP_addr;
+ }nw_react;
+ }cgev_info;
+}d2at_d2cm_deact_data_call_ind_prv_struct;
+
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid;
+ kal_int32 res;
+
+ deact_res_info_struct res_info;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_deact_data_call_ind_prv_struct d2at;
+ }prv;
+}d2cm_deact_data_call_ind_struct;
+
+
+// MSG_ID_D2CM_ABORT_DATA_CALL_IND
+typedef d2at_d2cm_deact_data_call_ind_prv_struct d2at_d2cm_abort_data_call_ind_prv_struct;
+
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ kal_bool cid_present;
+ kal_int32 cid;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_abort_data_call_ind_prv_struct d2at;
+ }prv;
+}d2cm_abort_data_call_ind_struct;
+
+
+// MSG_ID_D2CM_MOD_DATA_CALL_IND
+typedef struct
+{
+ cgev_event_enum cgev_event;
+ union
+ {
+ struct
+ {
+ kal_bool change_reason_present;
+ kal_uint32 change_reason;
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }nw_mod;
+
+ struct
+ {
+ kal_bool change_reason_present;
+ kal_uint32 change_reason;
+ kal_bool event_type_present;
+ atcmd_event_type_enum event_type;
+ kal_bool WLAN_Offload_present;
+ atcmd_WLAN_Offload_enum WLAN_Offload;
+ }me_mod;
+ }cgev_info;
+}d2at_d2cm_mod_data_call_ind_prv_struct;
+
+typedef struct
+{
+ d2cm_act_data_call_ims_info_struct ims_info; // IMS information for cid
+}imsm_d2cm_mod_data_call_ind_prv_struct;
+
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid, p_cid;
+ d2cm_act_data_call_ip_info_struct ip_info; // for IP address
+ d2cm_act_data_call_net_info_struct net_info; // for Internet information
+ d2cm_act_data_call_if_info_struct if_info; // for interface information
+ d2cm_act_data_call_ran_info_struct ran_info; // RAN info of non-3GPP
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ d2at_d2cm_mod_data_call_ind_prv_struct d2at;
+ imsm_d2cm_mod_data_call_ind_prv_struct imsm;
+ }prv;
+}d2cm_mod_data_call_ind_struct;
+
+
+// MSG_ID_D2CM_BYPASS_IND
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ // => unique key of APN
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ // => unique key of CID
+ kal_bool cid_present;
+ kal_int32 cid;
+ d2cm_bypass_event_enum event;
+ local_para_struct *local_para_ptr; /* local_para pointer */
+ peer_buff_struct *peer_buff_ptr; /* peer_buff pointer */
+
+ /* private part */
+ // N/A
+}d2cm_bypass_ind_struct;
+
+
+// MSG_ID_D2CM_HO_IND
+typedef d2pm_d2rm_pdn_ho_notify_ind_struct d2cm_ho_ind_struct;
+typedef d2pm_d2rm_pdn_ho_notify_ind_struct d2cm_ho_data_call_ind_struct;
+
+// MSG_ID_D2CM_DATA_CALL_INFO_IND
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 ps_id;
+ kal_char prefix[APN_STRING_LEN];
+ kal_char info[APN_STRING_LEN >> 1];
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_data_call_info_ind_struct;
+
+// MSG_ID_D2CM_RESET_RETRY_TMR_IND
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ d2cm_reset_retry_tmr_retry_info_struct retry_info;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_reset_retry_tmr_ind_struct;
+
+// MSG_ID_D2CM_VOLTE_CFG_CHANGE_IND
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ d2cm_reset_retry_tmr_retry_info_struct retry_info;
+
+}d2cm_volte_cfg_change_ind_struct;
+
+// MSG_ID_D2CM_EVENT_IND
+typedef struct
+{
+ D2CM_IND_LOCAL_PARA_HDR
+
+ /* common part */
+ d2cm_event_enum event;
+ struct
+ {
+ // unique key of APN
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ // unique key of CID
+ kal_bool cid_present;
+ kal_int32 cid;
+ }info;
+}d2cm_event_ind_struct;
+
+
+/*******************************************************************************
+* User to D2CM RSP *
+*******************************************************************************/
+
+// MSG_ID_D2CM_ACT_DATA_CALL_RSP
+typedef struct
+{
+ D2CM_RSP_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_act_data_call_rsp_struct;
+
+
+// MSG_ID_D2CM_DEACT_DATA_CALL_RSP
+typedef struct
+{
+ D2CM_RSP_LOCAL_PARA_HDR
+
+ /* common part */
+ kal_int32 cid;
+ kal_int32 res;
+
+ /* private part */
+ union
+ {
+ kal_uint8 unused;
+ }prv;
+}d2cm_deact_data_call_rsp_struct;
+
+
+// MSG_ID_D2CM_BYPASS_RSP
+typedef struct
+{
+ D2CM_RSP_LOCAL_PARA_HDR
+
+ /* common part */
+ // => unique key of APN
+ kal_bool apn_present;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ // => unique key of CID
+ kal_bool cid_present;
+ kal_int32 cid;
+ d2cm_bypass_event_enum event;
+ local_para_struct *local_para_ptr; /* local_para pointer */
+ peer_buff_struct *peer_buff_ptr; /* peer_buff pointer */
+
+ /* private part */
+ // N/A
+}d2cm_bypass_rsp_struct;
+
+
+/*******************************************************************************
+* D2CM NetIF by Verit Chen: Debug Dump *
+*******************************************************************************/
+
+typedef enum {
+ D2CM_NETIF_RA_ERROR = -1,
+ D2CM_NETIF_RA_DEFAULT = 0,
+ D2CM_NETIF_RA_SUCCESS = 1,
+ D2CM_NETIF_RA_INITIAL_FAIL = 2,
+ D2CM_NETIF_RA_REFRESH_FAIL = 3,
+ D2CM_NETIF_RA_OOXX = 0x7FFFFFFF
+} d2cm_netif_ra_state_enum;
+
+typedef enum {
+ D2CM_NETIF_IF_STATE_DOWN = 0,
+ D2CM_NETIF_IF_STATE_UP = 1,
+
+ D2CM_NETIF_IF_STATE_DOWNING = 10,
+ D2CM_NETIF_IF_STATE_UPING = 11,
+ D2CM_NETIF_IF_STATE_OOXX = 0x7FFFFFFF
+} d2cm_netif_interface_state_enum;
+
+typedef struct {
+ kal_uint32 is_set;
+ kal_uint8 addr[4];
+} d2cm_netif_interface_ipv4_info_t;
+
+typedef struct {
+ kal_uint32 is_set;
+ kal_uint8 addr[16];
+ kal_int32 prefix;
+} d2cm_netif_interface_ipv6_info_t;
+
+typedef struct {
+ d2cm_netif_interface_state_enum state;
+ kal_uint16 is_use;
+ kal_uint8 is_set_v4_addr;
+ kal_uint8 is_set_v6_addr;
+} d2cm_netif_interface_status;
+
+typedef struct {
+ d2cm_netif_interface_status md_if_status;
+ d2cm_netif_interface_status ap_if_status;
+
+ kal_int32 ap_addr_type;
+ d2cm_netif_ra_state_enum ra_state;
+
+ kal_bool mtu_present;
+ kal_uint32 mtu;
+
+ d2cm_netif_interface_ipv4_info_t md_pco_v4;
+ d2cm_netif_interface_ipv6_info_t md_pco_v6;
+ d2cm_netif_interface_ipv6_info_t global_v6;
+} d2cm_netif_interface_info_t;
+
+typedef struct {
+ kal_uint8 is_used;
+ kal_uint8 ps_id;
+ kal_uint16 transaction_id;
+ kal_uint32 interface_id;
+ d2cm_netif_interface_info_t info;
+} d2cm_netif_interface_dump_item_t;
+
+#define D2CM_NETIF_MAX_INTERFACE_ID (20)
+#define D2CM_NETIF_MAX_DUMP_INTERFACE_ID (D2CM_NETIF_MAX_INTERFACE_ID) //(8)
+
+// MSG_ID_D2CM_NETIF_CONTEXT_DUMP_IND
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_int32 interface_id;
+ kal_int32 num;
+ kal_char str[32];
+ d2cm_netif_interface_dump_item_t item[D2CM_NETIF_MAX_DUMP_INTERFACE_ID];
+}d2cm_netif_context_dump_ind_struct;
+
+typedef struct {
+ D2CM_IND_LOCAL_PARA_HDR
+
+ module_type mod_id; //send to which mod
+
+ kal_int32 cid;
+ kal_char apn[APN_STRING_LEN];
+ kal_int32 apn_idx;
+ ddm_apn_type_enum apn_type;
+
+ ip_info_struct ip_info;
+ net_info_struct net_info;
+ if_info_struct if_info;
+ kal_int32 res;
+} l5updn_dup_act_data_call_ind_struct;
+
+typedef struct {
+ D2CM_IND_LOCAL_PARA_HDR
+
+ module_type mod_id; //send to which mod
+
+ kal_int32 cid;
+ kal_int32 res;
+} l5updn_dup_deact_data_call_ind_struct;
+#endif