[Feature]Upload Modem source code
Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/interface/protocol/nas_multimode/upcm/ipcore_upcm_struct.h b/mcu/interface/protocol/nas_multimode/upcm/ipcore_upcm_struct.h
new file mode 100644
index 0000000..bb01882
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/ipcore_upcm_struct.h
@@ -0,0 +1,242 @@
+/*****************************************************************************
+* 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:
+ * ---------
+ * ipcore_upcm_struct.h
+ *
+ * Project:
+ * --------
+ * MOLY
+ *
+ * Description:
+ * ------------
+ *
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 07 04 2019 tc.chang
+ * [MOLY00418272] [Gen97] Sync Gen95 UMOLYE patch.
+ *
+ * 12 28 2016 cammie.yang
+ * [MOLY00221324] [6293][EL2][UPCM] C2K feature integrations
+ * [TRUNK][UPCM] modifications for C2K feature integrations
+ *
+ * 12 27 2016 cammie.yang
+ * [MOLY00221324] [6293][EL2][UPCM] C2K feature integrations
+ * [UMOLYA][UPCM] Interface change for C2K integration
+ *
+ * 09 26 2016 cammie.yang
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [TRUNK] UPCM/RATDM/EPDCP feature integrations from PS.DEV
+ *
+ * 02 05 2015 stan.chen
+ * [MOLY00094939] MASE UMOLY check in
+ * MASE/4GESL code checkin.
+ *
+ * 10 21 2013 moja.hsu
+ * [MOLY00041018] [MT6290E1][WWFT][HK](2013HKFT_VP)Add Inject ILM for EMAC to TA timeout for testing
+ * Reply to MOD_TCM_N for many TCM instance case
+ *
+ * 06 04 2013 moja.hsu
+ * [MOLY00024881] Network Interface Bind Confirm
+ * add PDN Bind related structure and enum.
+ *
+ * 03 29 2013 moja.hsu
+ * [MOLY00007625] Maintain code
+ * add dns info for bearer act and pdn bind.
+ *
+ * 01 14 2013 moja.hsu
+ * [MOLY00007625] Maintain code
+ * add upcm_rcv_ul_by_ebi and add EBI for DL Deliver for IMS requirement.
+ ****************************************************************************/
+/*
+ * =====================================================================================
+ *
+ * Filename: ipcore_upcm_struct.h
+ *
+ * Description: IPCORE and UPCM ILM structures
+ *
+ * Created: 2012/3/21 �W�� 11:30:09
+ * Author: mtk01641 (moja)
+ * =====================================================================================
+ */
+#ifndef IPCORE_UPCM_STRUCT_INC
+#define IPCORE_UPCM_STRUCT_INC
+
+#include "kal_public_api.h"
+#include "ps_public_enum.h"
+#include "ps_public_struct.h"
+#include "ddm_common_struct.h"
+#include "ue_testmode_struct.h"
+#include "upcm_enum.h"
+
+/* Valid bit length of IPv6 interface identifier from UPCM */
+#define IPV6_VALID_IID_BITS (64)
+
+/*
+ * IPCORE just copy back the info to UPCM
+ */
+typedef struct
+{
+ kal_uint32 reply_dest_mod_id;
+ kal_uint8 context_id;
+}upcm_ipcore_back_info_t;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint32 network_interface_id;
+ kal_uint8 pdn_id;
+ apn_type_info_struct apn_type_info;
+
+ /*
+ * Currently we don't know how to handle PPP_ADDR_TYPE
+ * So UPCM will assert when meet this type
+ */
+ ip_addr_struct ip_addr;
+
+ /* DNS info. */
+ dns_struct dns;
+
+ /*
+ * IPCORE just copy back the info to UPCM
+ */
+ upcm_ipcore_back_info_t back_info;
+}ipcore_upcm_pdn_bind_ind_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ /* Same to ipcore_upcm_pdn_bind_ind_struct */
+ kal_uint32 network_interface_id;
+ kal_uint8 pdn_id;
+ apn_type_info_struct apn_type_info;
+
+ ip_addr_struct ip_addr;
+ dns_struct dns;
+
+ /* return value */
+ ps_cause_enum result; /* Success: HIF_IPC_OK, Error cause : HIF_IPC_PDN_BIND_RSP_XXX */
+
+ /*
+ * IPCORE just copy back the info to UPCM
+ */
+ upcm_ipcore_back_info_t back_info;
+}ipcore_upcm_pdn_bind_rsp_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint8 pdn_id;
+}ipcore_upcm_pdn_unbind_ind_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint32 network_interface_id;
+ kal_uint8 new_pdn_id;
+ kal_uint8 old_pdn_id;
+
+ ip_addr_struct ip_addr;
+ dns_struct dns;
+}ipcore_upcm_pdn_rebind_ind_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint32 network_interface_id;
+ kal_uint8 new_pdn_id;
+ kal_uint8 old_pdn_id;
+
+ ip_addr_struct ip_addr;
+ dns_struct dns;
+
+ /* return value */
+ ps_cause_enum result; /* Success: HIF_IPC_OK, Error cause : HIF_IPC_PDN_BIND_RSP_XXX */
+}ipcore_upcm_pdn_rebind_rsp_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint8 pdn_id;
+ upcm_pdn_info_e pdn_info;
+}ipcore_upcm_pdn_info_ind_struct;
+
+/*
+ * UPCM will fill DL info only on head GPD's SW control Info.
+ * user use QBM_DES_GET_SW_CTRL_FIELD(_p) to get this structure
+ */
+typedef struct
+{
+ kal_uint8 ebi;
+}upcm_dlvr_dl_info_t;
+
+/*
+ * IPCORE notifties UPCM the network interface id under ESL simulation.
+ */
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ /* Selected network interface id. */
+ kal_uint32 network_interface_id;
+
+}ipcore_upcm_esl_pdn_bind_req_struct;
+
+typedef testloop_cfg_struct ipcore_upcm_testloop_ind_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint32 is_success; // test loop operation success/failure
+}ipcore_upcm_testloop_rsp_struct;
+
+#endif /* ----- #ifndef IPCORE_UPCM_STRUCT_INC ----- */
+
diff --git a/mcu/interface/protocol/nas_multimode/upcm/lhifcore_upcm_interface.h b/mcu/interface/protocol/nas_multimode/upcm/lhifcore_upcm_interface.h
new file mode 100644
index 0000000..f49fdff
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/lhifcore_upcm_interface.h
@@ -0,0 +1,106 @@
+/*****************************************************************************
+* 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:
+ * ---------
+ * lhifcore_upcm_interface.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ * Used to process LHIF HW log table
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 02 11 2020 tc.chang
+ * [MOLY00498768] [MT6873][Margaux][Q0][MP3][SQC][VDF][FT][UK][London][NSA][MDST][SWIFT]Assert fail: Line 1024 Code 0x0 0x0 0x0.
+ * DL PSN
+ *
+ * 09 18 2018 tc.chang
+ * [MOLY00345990] [VMOLY] Code sync.
+ *
+ * 09 14 2018 tc.chang
+ * [MOLY00345990] [VMOLY] Code sync
+ * Rollback first. Fix build error locally
+ *
+ * 08 15 2017 steve.kao
+ * [MOLY00269909] [MT6293] IP Tag development
+ *
+ * [UMOLYA][TRUNK][UPCM] IP packet tagging interface changes.
+ *
+ * 08 15 2017 steve.kao
+ * [MOLY00269909] [MT6293] IP Tag development
+ *
+ * [UMOLYA][TRUNK][UPCM] IP packet tagging interface changes.
+ *
+ ****************************************************************************/
+#ifndef LHIFCORE_UPCM_INTERFACE_INC
+#define LHIFCORE_UPCM_INTERFACE_INC
+
+#include "kal_public_api.h"
+
+/* Only enable UPCM to handle LHIF HW log when 52 bytes data is dumped */
+#if defined (__MTK_TARGET__)
+#define UPCM_HANDLE_HW_LOG (1)
+#else
+#define UPCM_HANDLE_HW_LOG (0)
+#endif
+
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+
+ kal_uint32 start_idx;
+ kal_uint32 end_idx;
+
+ kal_uint8 *start_addr;
+ kal_uint8 *end_addr;
+
+} lhifcore_upcm_hw_log_ntf_struct;
+
+void upcm_send_hw_log_ntf(kal_uint32 start_idx, kal_uint32 end_idx, kal_uint8 *start_addr, kal_uint8 *end_addr);
+
+#endif /* ----- #ifndef LHIFCORE_UPCM_INTERFACE_INC ----- */
+
diff --git a/mcu/interface/protocol/nas_multimode/upcm/upcm.h b/mcu/interface/protocol/nas_multimode/upcm/upcm.h
new file mode 100644
index 0000000..fd7f078
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/upcm.h
@@ -0,0 +1,719 @@
+/*****************************************************************************
+* 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:
+ * ---------
+ * upcm.h
+ *
+ * Project:
+ * --------
+ * MOLY
+ *
+ * Description:
+ * ------------
+ *
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 11 04 2021 stun.wu
+ * [MOLY00678218] [Gen97][4N SQC-Lite][W2124][W2128][Internal FT][Post_MP7][Guangzhou][MT6877][Montrose][Feature_Enhance_Test]CU+CMCC_SA+SA_Temp_Data_Switch_On, SIM1 MT call failed(1/10)
+ *
+ * .
+ *
+ * 11 16 2020 stun.wu
+ * [MOLY00591799] [MT6880][Colgin][New feature] Add New ICDs CM_IP_DL_STATs/CM_IP_UL_STATs
+ *
+ * .
+ *
+ * 08 13 2020 ken.li
+ * [MOLY00543497] [MT6873][Margaux][R0][MP5][in-house FTA][LTE][7.1.1.2]enable volte fail
+ *
+ * UPCM TESTMODE drops non-loopback data for obtaining IP address case (SWRD)
+ *
+ * 05 07 2020 andy-wc.chang
+ * [MOLY00506312] [Titan][IPC][IMS] IPC_IMS_INVITE_FLUSH (0x1C) - EL2 dev
+ * [VMOLY][TITAN] ipc flush command porting - setting3
+ *
+ * 04 15 2020 chin-wei.hsu
+ * [MOLY00509991] [Gen97] monitor DL paging for NR RAT
+ * [RD] monitor DL paging for NR RAT.
+ *
+ * 03 10 2020 chin-wei.hsu
+ * [MOLY00503427] [MT6885][Petrus][TMO-US][WWFT][Seattle][5G4G][NSN][MDST][SWIFT][Assert] file:mcu/middleware/hif/ipcore/src/ipc_filter.c line:3815
+ * [RD domain] makefile+header.
+ *
+ * 02 26 2020 willy-wj.chen
+ * [MOLY00501981] [Gen97][UPCM] TMO-US F4L data performance patch sync from Gen93
+ *
+ * Fix build error for certain projects.
+ *
+ * 02 26 2020 willy-wj.chen
+ * [MOLY00501981] [Gen97][UPCM] TMO-US F4L data performance patch sync from Gen93
+ * [UPCM] put small UDP packet into pri-SIT upon channel lock.
+ *
+ * 12 06 2019 tc.chang
+ * [MOLY00463231] [GEN97][GWSD+] patchback from 1001dev.
+ *
+ * 12 05 2019 tc.chang
+ * [MOLY00446861] [Gen97][Code Sync] [B190414-819]¤ýªÌ?Ä£´å??µ{¥d?¡AÊI?©µ?450 (?±`¥X?¡A©Î?¤é¦h¦¸Î`?) According to data type to release HPS for paging.
+ *
+ * 10 30 2019 tc.chang
+ * [MOLY00426963] [Gen97][NWSIM][5G][SA][GCF TEST] TC 8.1.1.2.3 : UE fails to send RRC Setup Request at test step 7..
+ *
+ * 09 23 2019 tc.chang
+ * [MOLY00427068] [Gen97][UPCM][RATDM][ENPDCP] Dynamic SIT.
+ *
+ * 09 06 2019 chin-wei.hsu
+ * [MOLY00437199] [MT6297][ICD][EM] fix wrong values of PDCP throughput and IP throughput
+ *
+ * [ICD] fix wrong value.
+ *
+ * 05 15 2019 tc.chang
+ * [MOLY00406246] [Gaming][KoG][L2] Gen97 Gaming enhancement.
+ *
+ * 05 09 2019 tc.chang
+ * [MOLY00404770] [Gen97] Sync Gen95 UMOLYE patch.
+ * RBRQ, USIR, fake A2
+ *
+ * 04 19 2019 tc.chang
+ * [MOLY00399993] [Gen97][VMOLY] interworking withN26 features.
+ *
+ * 04 16 2019 tc.chang
+ * [MOLY00395158] [Gen97] Sync Gen95 UMOLYE bug fix
+ * [UPCM] ICD and some bug fix.
+ *
+ * 01 28 2019 tc.chang
+ * [MOLY00381488] [Gen97] [MCF] MCF porting to VMOLY.
+ *
+ * 10 16 2018 tc.chang
+ * [MOLY00356444] [VMOLY] Bug fix and add UT cases
+ * Coverity fix.
+ *
+ * 10 08 2018 tc.chang
+ * [MOLY00356444] [VMOLY] Bug fix and add UT cases.
+ *
+ * 09 18 2018 tc.chang
+ * [MOLY00345990] [VMOLY] Code sync.
+ *
+ * 09 14 2018 tc.chang
+ * [MOLY00345990] [VMOLY] Code sync
+ * Rollback first. Fix build error locally
+ *
+ * 09 07 2018 tc.chang
+ * [MOLY00351053] [VMOLY] Compile option clean up
+ * .
+ *
+ * 08 01 2018 chin-wei.hsu
+ * [MOLY00343584] [MT6295][UPCM] log reduction
+ * [UPCM] log reduction.
+ *
+ * 08 01 2018 steve.kao
+ * [MOLY00343532] [6295] EL2 log reduction: EPDCP parts
+ * EPDCP LOG REDUCTION.
+ *
+ * 07 12 2018 chin-wei.hsu
+ * [MOLY00337991] [Gemini][L+L][Gen95] A2 trigger network release
+ * [UPCM][fake A2] provide data prediction.
+ *
+ * 06 14 2018 timothy.yao
+ * [MOLY00333176] [ICD] stage1+stage2 ICD UMOLYE CBr patch back to LR13.R0
+ * [ICD][UPCM]
+ *
+ * 06 11 2018 timothy.yao
+ * [MOLY00319373] [MT6295] recommended bit rate feature
+ * recommended bit rate feature: upcm design (merged from 5764964)
+ *
+ * 05 15 2018 chin-wei.hsu
+ * [MOLY00326156] [EIGER][MT3967][RDIT][Phone][NVIOT][FDD][MVTVD][4G][MIMO-OLSM-TM3][7.2.3.7.12]UE ping failed after re-selection from WCDMA
+ * [UPCM] get PDN by EBI.
+ *
+ * 03 08 2018 chin-wei.hsu
+ * [MOLY00310680] [UMOLYE][Gen95] Add debug assert to compare HW result and SW result
+ * [UMOLYE] check HW HPC result.
+ *
+ * 03 02 2018 chin-wei.hsu
+ * [MOLY00310911] [EIGER][MT3967][RDIT][EVB][LTG][MD_Pre-Sanity][SIM1:CMCC][SIM2:NONE][7.2]SIM1 MT VoLTE call EE
+ *
+ * [UMOLYE] remove debug assert due to coding defect
+ *
+ * 03 02 2018 chin-wei.hsu
+ * [MOLY00310829] 1237333¡G[IN-FT_DC066] [R2_EVT1] [L+L] [Free_Test] [Kochi] DUT takes approx. 30 sec time to register on IMS after Emergency call failed with JIO operator.
+ * [UMOLYE] queue IPv6 RS from IMS EBI.
+ *
+ * 03 01 2018 chin-wei.hsu
+ * [MOLY00310680] [UMOLYE][Gen95] Add debug assert to compare HW result and SW result
+ * [UMOLYE] add debug assert to check IPF.
+ *
+ * 02 21 2018 chin-wei.hsu
+ * [MOLY00309099] [PVT must resolve] ·L«H??¥]ºC?? for Gen95
+ * [UMOLYE][UPCM-307] internal feature.
+ *
+ * 01 09 2018 chin-wei.hsu
+ * [MOLY00299863] [PVT must resolve] ·L«H??¥]ºC?? - keep alive
+ *
+ * [TRUNK][UPCM][RATDM] UPCM_FEATURE_301.
+ *
+ * 01 09 2018 chin-wei.hsu
+ * [MOLY00299863] [PVT must resolve] ·L«H??¥]ºC?? - keep alive
+ * [TRUNK][UPCM][RATDM] UPCM_FEATURE_301.
+ *
+ * 08 29 2017 chin-wei.hsu
+ * [MOLY00274358] [6293] Adapt UPCM Throughput EM to 6293 DL architecture.
+ * [TRUNK] DL throughput for EM.
+ *
+ * 08 23 2017 chin-wei.hsu
+ * [MOLY00273240] [Gen93] New API to set forced SW path to all bearers at once
+ * [TRUNK] forced sw path on/off all
+ *
+ * 08 09 2017 chin-wei.hsu
+ * [MOLY00269663] [Gen 93][LR11.MP5 to UMOLYA code sync] UPCM provides IMS statistics for NWSEL
+ * [TRUNK] UPCM add ims ebi tx/rx statistic query API.
+ *
+ * 07 06 2017 timothy.yao
+ * [MOLY00261868] [6293]UL SIT new handling
+ * new SIT handling (to TRUNK)
+ * - UPCM / RATDM.
+ *
+ * 04 07 2017 timothy.yao
+ * [MOLY00240413] [BIANCO][MT6763][RDIT][PHONE][Overnight][HQ][MTBF][Lab][Ericsson][ASSERT] file:mcu/common/driver/dpcopro/src/dpcopro_mmu_drv.c line:1200
+ * bugfix: IRAT HO data handling. (TRUNK only)
+ *
+ * - if RAT protocol not handled, target RAT can perform UL.
+ * --> UPCM trigger RATDM. (new)
+ *
+ * - if RAT protocol handled, source RAT shall perform rollback.
+ * --> then UPCM can trigger RATDM. (exist)
+ *
+ * 03 23 2017 chin-wei.hsu
+ * [MOLY00237294] [MT6293][UPCM] Forced SW path
+ * [trunk] Forced SW path for EBI/PDN.
+ *
+ * 03 22 2017 steve.kao
+ * [MOLY00230062] [UMOLYA] M-PS related interface changes for UPCM, RATDM, and EPDCP
+ *
+ * [UMOLYA][TRUNK][UPCM][RATDM][M-PS] Add "protocol_idx" for upcm_get_pending_ul_data_status().
+ *
+ * 03 22 2017 steve.kao
+ * [MOLY00230062] [UMOLYA] M-PS related interface changes for UPCM, RATDM, and EPDCP
+ *
+ * [UMOLYA][UMOLYA][UPCM][M-PS] Add "protocol_idx" into the interface of upcm_query_epsb_txrx_statistics().
+ *
+ * 02 16 2017 steve.kao
+ * [MOLY00230062] [UMOLYA] M-PS related interface changes for UPCM, RATDM, and EPDCP
+ *
+ * [M-PS][UPCM]
+ * 1. add protocol_idx into callback interfaces,
+ * 2. one set of UPCM UL SIT per SIM.
+ *
+ * 10 07 2016 cammie.yang
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [TRUNK][UPCM] fix incorrect input type of upcm_reg_cbk_dlvr_dl_sdu
+ *
+ * 09 26 2016 cammie.yang
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [TRUNK] UPCM/RATDM/EPDCP feature integrations from PS.DEV
+ *
+ * 01 23 2014 clark.peng
+ * [MOLY00047398] [MT6582LTE][WWFT][UK][Vodafone][EE] CSFB performance anlysis [only for UKFT]
+ * Implementation of upcm_get_pending_ul_data_status() based on timestamp difference (3sec)
+ *
+ * 07 17 2013 moja.hsu
+ * [MOLY00030111] Add UPCM Tx/Rx statistics query API
+ * .
+ *
+ * 05 16 2013 moja.hsu
+ * [MOLY00007625] Maintain code
+ * Back out changelist 156018
+ * patch for QMU_BM/UPCM/RATADP/TFT_PF trace
+ *
+ * 05 15 2013 moja.hsu
+ * [MOLY00007625] Maintain code
+ * add tft_pf/qmu_bm/upcm/ratadp trace
+ *
+ * 01 14 2013 moja.hsu
+ * [MOLY00007625] Maintain code
+ * add upcm_rcv_ul_by_ebi and add EBI for DL Deliver for IMS requirement.
+ ****************************************************************************/
+/*
+ * =====================================================================================
+ *
+ * Filename: upcm.h
+ *
+ * Description: UPCM (User plane connection manager exported header file)
+ *
+ * Created: 2012/3/19 �W�� 11:20:22
+ *
+ * Author: mtk01641 (moja)
+ * =====================================================================================
+ */
+#ifndef UPCM_INC
+#define UPCM_INC
+
+#include "kal_public_api.h"
+#include "qmu_bm.h"
+#include "upcm_enum.h"
+#include "upcm_did.h"
+#include "lhif_if.h"
+#include "upcm_emac_struct.h"
+
+/********************************************
+ * FEATURE CONTROL *
+ ********************************************/
+#define UPCM_FEATURE_301 1
+#if UPCM_FEATURE_301
+#define NO_INTERNET_ILM_FOR_EMAC 1
+#endif
+
+#define UPCM_PAGING_EARLY_RELEASE 1
+#if UPCM_PAGING_EARLY_RELEASE
+#define UPCM_PAGING_EARLY_RELEASE_VGMM 1
+#endif
+
+#ifdef __IPC_ADAPTER__
+#define UPCM_INVITE_FLUSH_CMD 1
+#else
+#define UPCM_INVITE_FLUSH_CMD 0
+#endif
+
+#define UPCM_DEBUG_MODE 0
+#define UPCM_NORMAL_MODE !UPCM_DEBUG_MODE
+
+#define UPCM_FEATURE_RBRQ 1
+
+#define UPCM_FEATURE_ICD 1
+
+#define UPCM_FEATURE_LOG_REDUCTION 1
+
+#define UPCM_FEATURE_VIP 1 // very important packet should be put in pri-SIT
+#define UPCM_FEATURE_VIP_NOTIFY_EL2 1 // notify EL2 that VIP is received by UPCM
+
+#ifdef __CHANNEL_LOCK__
+#define UPCM_FEATURE_F4L_DATA_COVERAGE 1 // enhancement for F4L Data Coverage
+#else
+#define UPCM_FEATURE_F4L_DATA_COVERAGE 0 // no channel lock
+#endif
+/********************************************
+ * MACROS *
+ ********************************************/
+#define UPCM_GET_FIVEG_MAPPED_BEARER_ID_BY_PSI_QFI(_psi, _qfi) \
+ (MIN_5G_BEARER_ID + (((_psi) - 1) * QFI_NUM_PER_PSI) + (_qfi))
+
+#define UPCM_GET_FIVEG_MAPPED_BEARER_ID(_is_5g, _psi, _bearer) \
+ ((_is_5g) ? UPCM_GET_FIVEG_MAPPED_BEARER_ID_BY_PSI_QFI(_psi, _bearer) : (_bearer))
+
+#define UPCM_GET_FIVEG_MAPPED_PDN_ID(_is_5g, _psi, _bearer) \
+ ((_is_5g) ? (MIN_5G_PDN_ID + (_psi) - 1) : (_bearer))
+
+#define UPCM_IS_FIVEG_BEARER_ID(_id) \
+ (((MIN_5G_BEARER_ID <= (_id)) && ((_id) < MAX_EPSB_NUM)) ? KAL_TRUE : KAL_FALSE)
+
+#define UPCM_IS_FIVEG_PDN_ID(_id) \
+ (((MIN_5G_PDN_ID <= (_id)) && ((_id) <= MAX_5G_PDN_ID)) ? KAL_TRUE : KAL_FALSE)
+
+#define GET_SIT_TABLE_INFO_PRI(_info) (((_info)>>31) & 0x1)
+#define GET_SIT_TABLE_INFO_IDX(_info) ((_info) & 0x7FFFFFFF)
+
+#define GET_FREE_ENTRY_INFO_START(_info) (((_info)>>16) & 0xFFFF)
+#define GET_FREE_ENTRY_INFO_END(_info) ((_info) & 0xFFFF)
+
+/**
+ * @brief UPCM_HAS_[DL/UL]_[INTERNET/IMS]_Data_IN_MS
+ * Check whether there's data in given milliseconds.
+ * For UL, duration can be >= 0.
+ * For DL, duration should be > 0.
+ *
+ * @param protocol_idx, duration_ms
+ *
+ * @return bool
+ * For UL
+ * if duration_ms == 0
+ * KAL_TURE: there are data in Internet/IMS SIT, i.e. some packets are not sent to NW or Acked yet.
+ * KAL_FALSE: there's no data in Internet/IMS SIT.
+ * if duration_ms > 0
+ * KAL_TURE: there are data in given milliseconds.
+ * KAL_FALSE: there's no data in given milliseconds.
+ * For DL
+ * if duration_ms == 0 (invalid parameter)
+ * KAL_TURE: -
+ * KAL_FALSE: always false.
+ * if duration_ms > 0
+ * KAL_TURE: there are data in given milliseconds.
+ * KAL_FALSE: there's no data in given milliseconds.
+ */
+#define UPCM_HAS_DL_INTERNET_DATA_IN_MS(_protocol_idx, _dl_duration_ms) \
+ (upcm_latest_time_of_DL_internet_data(_protocol_idx) < (_dl_duration_ms))
+
+#define UPCM_HAS_DL_IMS_DATA_IN_MS(_protocol_idx, _dl_duration_ms) \
+ (upcm_latest_time_of_DL_ims_data(_protocol_idx) < (_dl_duration_ms))
+
+#define UPCM_HAS_UL_INTERNET_DATA_IN_MS(_protocol_idx, _ul_duration_ms) \
+ ((_ul_duration_ms == 0)? \
+ upcm_is_ul_internet_data_ongoing(_protocol_idx) : \
+ upcm_latest_time_of_UL_internet_data(_protocol_idx) < (_ul_duration_ms))
+
+#define UPCM_HAS_UL_IMS_DATA_IN_MS(_protocol_idx, _ul_duration_ms) \
+ ((_ul_duration_ms == 0)? \
+ upcm_is_ul_ims_data_ongoing(_protocol_idx) : \
+ upcm_latest_time_of_UL_ims_data(_protocol_idx) < (_ul_duration_ms))
+
+#define UPCM_HAS_DL_UL_INTERNET_DATA_IN_MS(_protocol_idx, _dl_duration_ms, _ul_duration_ms) \
+ (UPCM_HAS_DL_INTERNET_DATA_IN_MS(_protocol_idx, _dl_duration_ms) || \
+ UPCM_HAS_UL_INTERNET_DATA_IN_MS(_protocol_idx, _ul_duration_ms))
+
+#define UPCM_HAS_DL_UL_IMS_DATA_IN_MS(_protocol_idx, _dl_duration_ms, _ul_duration_ms) \
+ (UPCM_HAS_DL_IMS_DATA_IN_MS(_protocol_idx, _dl_duration_ms) || \
+ UPCM_HAS_UL_IMS_DATA_IN_MS(_protocol_idx, _ul_duration_ms))
+
+#define UPCM_HAS_DL_UL_DATA_IN_MS(_protocol_idx, _dl_duration_ms, _ul_duration_ms) \
+ (UPCM_HAS_DL_UL_INTERNET_DATA_IN_MS(_protocol_idx, _dl_duration_ms, _ul_duration_ms) || \
+ UPCM_HAS_DL_UL_IMS_DATA_IN_MS(_protocol_idx, _dl_duration_ms, _ul_duration_ms))
+
+/********************************************
+ * TYPE DEFINITIONS & ENUMS *
+ ********************************************/
+#if UPCM_FEATURE_301
+typedef enum
+{
+ UPCM_KEEP_CONNECTED_DISABLE = 0x0,
+ UPCM_KEEP_CONNECTED_EL2_ONLY = 0x1,
+ UPCM_KEEP_CONNECTED_RATDM_ONLY = 0x2,
+ UPCM_KEEP_CONNECTED_UPCM_ONLY = 0x4,
+ UPCM_KEEP_CONNECTED_UPCM_RATDM = (UPCM_KEEP_CONNECTED_UPCM_ONLY | UPCM_KEEP_CONNECTED_RATDM_ONLY),
+ UPCM_KEEP_CONNECTED_EL2_RATDM = (UPCM_KEEP_CONNECTED_EL2_ONLY | UPCM_KEEP_CONNECTED_RATDM_ONLY)
+} upcm_keep_connected_mode_e;
+#endif
+
+/*
+ * lte tick source notify callback prototype.
+ * is_lte_tick: KAL_TRUE - has LTE tick.
+ * KAL_FLAE - may no LTE tick.
+ */
+typedef void (*upcm_nofify_lte_tick_f)(kal_bool is_lte_tick);
+typedef void (*upcm_dlvr_dl_sdu_93_f)(kal_uint32 pdn_id, upcm_did* p_head, upcm_did* p_tail, kal_uint8 protocol_idx);
+
+typedef struct
+{
+ /* tx/rx bytes */
+ kal_uint64 tx_bytes;
+ kal_uint32 tx_nums;
+ kal_uint32 tx_max;
+ kal_uint64 rx_bytes;
+ kal_uint32 rx_nums;
+ kal_uint32 rx_max;
+} single_epsb_txrx_info_struct;
+
+typedef struct
+{
+ single_epsb_txrx_info_struct txrx_info[MAX_234G_EPSB_NUM];
+#ifdef __FIVEG_NAS__
+ single_epsb_txrx_info_struct nr_txrx_info[NUM_5G_PDU_SESSION];
+#endif
+} upcm_query_epsb_statistics_struct;
+
+typedef struct
+{
+ LOCAL_PARA_HDR
+ /*
+ * D2 notify UPCM that all IP addr(s) of this netif_id has obtained
+ * the range of netif_id is 0x00~0xff
+ */
+ kal_int32 netif_id;
+}d2cm_upcm_get_ip_addr_ind_struct;
+
+/********************************************
+ * FUNCTION DECLARATIONS *
+ ********************************************/
+/**
+ * @brief upcm_init Init UPCM module.
+ *
+ * @return TRUE
+ */
+kal_bool upcm_init(void);
+
+/**
+ * @brief upcm_reset
+ * Reset UPCM module.
+ *
+ * @return TRUE
+ *
+ * @return
+ */
+kal_bool upcm_reset(void);
+
+/**
+ * @brief upcm_on_ilm
+ * Receive ILM message
+ *
+ * @param ilm
+ */
+void upcm_on_ilm(ilm_struct *p_ilm);
+
+
+/**
+ * @brief upcm_rcv_ul_sdu
+ * Receive UL SDUs. UL SDU are GPD list.
+ *
+ * @param ip_type the UL SDU IP type. may help UPCM go quick path if the IP type is known.
+ * @param pdn_id PDN Connection ID
+ * @param p_head SDU list head. (GPD based)
+ * @param p_tail SDU list tail. (GPD based)
+ *
+ * for 93:
+ * - GPD-based, for LTE-CSR (ex: GPD).
+ * - PIT-based, for VRB.
+ */
+void upcm_rcv_ul_sdu_93_gpd(ip_type_e ip_type, kal_uint32 pdn_id, qbm_gpd* p_head, qbm_gpd* p_tail, kal_uint8 protocol_idx);
+void upcm_rcv_ul_sdu_93(kal_uint16 pit_start, kal_uint16 pit_end, LHIF_QUEUE_TYPE queue_type);
+
+/**
+ * @brief upcm_forced_sw_path_xxx
+ * Ensure set/clear should be paired
+ * is_forced_sw_path will +1 or -1 count but is_forced_sw_path can not directly change path
+ * UPCM will use count to determine SW-path or not
+ * if count=0, direct path
+ * if count!=0, inderect(sw) path
+ * @param ebi/pdn:
+ * @param is_forced_sw_path: TRUE(set forced SW path)/FALSE(clear forced SW path)
+ * @param protocol_id:
+ */
+void upcm_forced_sw_path_by_ebi(kal_uint32 ebi, kal_bool is_forced_sw_path, kal_uint8 protocol_idx);
+void upcm_forced_sw_path_by_pdn(kal_uint32 pdn, kal_bool is_forced_sw_path, kal_uint8 protocol_idx);
+//void upcm_forced_sw_path_all(kal_bool is_forced_sw_path); //retire
+void upcm_forced_sw_path_all_by_protocol(kal_bool is_forced_sw_path, kal_uint8 protocol_idx);
+
+
+/**
+ * @brief upcm_rcv_ul_sdu_by_ebi
+ * Receive UL SDUs on specified EBI. The Function will bypass TFT Process.
+ * But for inter-rat case, the data will enter suspend queue, so TFT Process will be applied.
+ * It can't be called on test loopback mode.
+ *
+ * @param ebi
+ * @param p_head
+ * @param p_tail
+ */
+void upcm_rcv_ul_sdu_by_ebi_93_gpd(kal_uint32 ebi, qbm_gpd* p_head, qbm_gpd* p_tail, kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_reg_cbk_notify_lte_tick
+ * Register callback function.
+ * For get if there is a LTE tick source.
+ *
+ * @param pf_notify callback function.
+ */
+void upcm_reg_cbk_notify_lte_tick(upcm_nofify_lte_tick_f pf_notify);
+
+/**
+ * @brief upcm_reg_cbk_dlvr_dl_sdu
+ * Register callback for deliver DL SDUs.
+ *
+ * @param pf_dlvr_sdu
+ */
+void upcm_reg_cbk_dlvr_dl_sdu(upcm_dlvr_dl_sdu_93_f pf_dlvr_sdu);
+
+#if defined(__SENSITIVE_DATA_MOSAIC__)
+/**
+ * @brief upcm_module_clean
+ * clean sensitive context
+ *
+ * @param
+ */
+void upcm_module_clean(void);
+#endif
+
+/**
+ * @brief upcm_query_epsb_txrx_statistics
+ * Query UPCM tx/rx statistics.
+ * If the connection is deactivated, it will give the last value of previous activate.
+ *
+ * @param query_result
+ */
+void upcm_query_epsb_txrx_statistics(upcm_query_epsb_statistics_struct *query_result, kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_query_epsb_ims_ebi_tx_rx_statistics
+ * Query tx/rx statistics of the IMS ebi.
+ * If the connection is deactivated, it will give the last value of previous activate.
+ *
+ * @param query_result
+ */
+#ifdef __GEMINI__
+kal_uint64 upcm_query_epsb_ims_ebi_tx_rx_statistics(kal_uint8 sim_idx);
+#else
+kal_uint64 upcm_query_epsb_ims_ebi_tx_rx_statistics(void);
+#endif
+
+/**
+ * @brief upcm_get_pending_ul_data_status
+ * Predict pending UL data of each NSAPI/EBI by checking if there is UL data
+ * within past UPCM_UL_DATA_INTERVAL_TO_TRIGGER_SR.
+ *
+ * @return 16-bit bitmap for each NSAPI/EBI.
+ * If it predicts this NSAPI/EBI has UL data, the corresponding bit is set to 1.
+ * Otherwise, the corresponding bit is set to 0.
+ * For example, if there is pending UL data for NSAPI/EBI 5~15,
+ * then the return value will be 0xFFE0.
+ */
+kal_uint16 upcm_get_pending_ul_data_status(kal_uint8 protocol_idx);
+
+#ifdef __FIVEG_NAS__
+kal_uint16 upcm_get_pending_ul_data_status_5g(kal_uint8 protocol_idx);
+kal_uint16 upcm_get_bind_status_5g(kal_uint8 protocol_idx);
+#endif
+
+kal_bool upcm_is_ims_ebi(kal_uint32 ebi, kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_predict_internet_data_on_going
+ * predict potential internet data is ongoing
+ * If query main-ps and internet PDN has data in previous time, return TRUE.
+ * If query non-main-ps, return FALSE.
+ *
+ * @param protocol_idx
+ *
+ * @return bool
+ * KAL_TURE: the possibility of ongoing interent data is high
+ * KAL_FALSE: the possiblilty of ongoing internet data is low
+ */
+// Obsoleted. Remove it when other module (ERRC) is not needed anymore.
+kal_bool upcm_predict_internet_data_is_ongoing(kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_predict_ims_data_is_ongoing
+ * predict potential ims data is ongoing
+ *
+ * @param protocol_idx
+ *
+ * @return bool
+ * KAL_TURE: the possibility of ongoing ims data is high
+ * KAL_FALSE: the possiblilty of ongoing ims data is low
+ */
+// Obsoleted. Remove it when other module (ERRC) is not needed anymore.
+kal_bool upcm_predict_ims_data_is_ongoing(kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_latest_time_of_[UL/DL]_[internet/ims]_data
+ * provide the latest UL/DL data arrival time of Internet/IMS data
+ * These APIs are needed by control plane modules, e.g. RRC, MSPM, EMM, and SBP.
+ * RRC: to decide whether to trigger fake A2 to release RRC Connection.
+ * EMM: to enhance V-Con in the scenario of Paging+TAU (V-Con feature)
+ * MSPM: to decide leave V-Con to Con or Idle (V-Con feature)
+ * SBP: to help decide whether turn off screen (data dormant feature)
+ *
+ * @param protocol_idx
+ *
+ * @return kal_uint32
+ * the latest UL/DL data arrival time of Internet/IMS data in millisecond
+ */
+kal_uint32 upcm_latest_time_of_internet_data(kal_uint8 protocol_idx);
+kal_uint32 upcm_latest_time_of_UL_internet_data(kal_uint8 protocol_idx);
+kal_uint32 upcm_latest_time_of_DL_internet_data(kal_uint8 protocol_idx);
+kal_uint32 upcm_latest_time_of_UL_ims_data(kal_uint8 protocol_idx);
+kal_uint32 upcm_latest_time_of_DL_ims_data(kal_uint8 protocol_idx);
+
+/**
+ * @brief upcm_is_ul_[internet/ims]_data_ongoing
+ * UL data is ongoing or not
+ * Checks whether SDU Information Table (SIT) is empty or not.
+ * UL packet in SIT would be cleared when sent to NW successfully.
+ *
+ * @param protocol_idx
+ *
+ * @return bool
+ * KAL_TURE: SIT is not empty, i.e. some packets are being sent.
+ * KAL_FALSE: SIT is empty, i.e. no packets are being sent.
+ */
+kal_bool upcm_is_ul_internet_data_ongoing(kal_uint8 protocol_idx);
+kal_bool upcm_is_ul_ims_data_ongoing(kal_uint8 protocol_idx);
+
+#if UPCM_FEATURE_RBRQ
+void upcm_rbrq_set_rb_ebi_mapping(kal_uint8 rb_idx, kal_uint8 ebi, kal_uint32 sim_idx);
+void upcm_rbrq_support_rel_ind(upcm_emac_rbrq_support_rel_ind_struct *p_local);
+#endif
+kal_uint8 upcm_get_pdn_id_by_ebi(kal_uint32 ebi, kal_uint8 protocol_idx);
+
+void upcm_free_sit_entry_wi_free_buf(kal_uint32 sit_table_info, kal_uint32 free_entry_info,
+ kal_uint32 task_id, kal_uint8 protocol_idx);
+
+void upcm_free_sit_entry_wo_free_buf(kal_uint32 sit_table_info, kal_uint32 free_entry_info,
+ kal_uint32 task_id, kal_uint8 protocol_idx);
+
+void upcm_add_rx_statistics(kal_uint32 ebi, kal_uint32 bytes, kal_uint32 nums, kal_uint32 max, kal_uint8 protocol_idx);
+
+qbm_gpd* upcm_copy_pkt_to_gpd(kal_uint16 len, kal_uint32 addr);
+
+void upcm_send_ims_sdu_drop_ind_to_imc(kal_uint32 drop_type, kal_uint8 protocol_idx);
+
+#if UPCM_FEATURE_301
+kal_bool upcm_keep_connected_data_working(kal_uint32 *p_psi_ebi, kal_bool is_5g,
+ kal_uint8 protocol_idx);
+#endif
+
+#if NO_INTERNET_ILM_FOR_EMAC
+void upcm_send_internet_disconnect_notify();
+#endif
+
+kal_uint16 upcm_gen_packet_tag(kal_uint8 *p_data, kal_uint32 data_len);
+kal_uint16 upcm_get_sit_idx(kal_bool is_5g, kal_uint32 psi, kal_uint32 bearer,
+ kal_uint8 protocol_idx);
+
+#if defined(__MTK_INTERNAL__) || defined(__GTEST_ENABLE__)
+void upcm_set_sit_idx(kal_bool is_5g, kal_uint32 psi, kal_uint32 bearer,
+ kal_uint8 protocol_idx, kal_uint16 sit_idx);
+#endif
+
+/**
+ * @brief upcm_is_active_protocol
+ *
+ * @param protocol_idx
+ * @return bool
+ * TRUE: at lease one bearer is activated
+ * FALSE: otherwise
+ */
+kal_bool upcm_is_active_protocol(kal_uint8 protocol_idx);
+
+void upcm_get_psi_qfi_by_bearer_id(kal_uint32 bearer_id, kal_uint8 *psi,
+ kal_uint8 *qfi);
+
+kal_bool upcm_is_test_loop(kal_uint8 protocol_idx);
+
+#endif /* ----- #ifndef UPCM_INC ----- */
diff --git a/mcu/interface/protocol/nas_multimode/upcm/upcm_did.h b/mcu/interface/protocol/nas_multimode/upcm/upcm_did.h
new file mode 100644
index 0000000..3cd295c
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/upcm_did.h
@@ -0,0 +1,701 @@
+/*****************************************************************************
+* 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:
+ * ---------
+ * upcm_did.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ *
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$
+ *
+ * 09 03 2021 stun.wu
+ * [MOLY00724659] [Colgin][New Feature]MD Virtual Network Interface
+ *
+ * .
+ *
+ * 04 22 2020 yi-lin.lee
+ * [MOLY00516228] [MT6873][Margaux][IODT][CMRI][FT][SA][N41][5G FT][China][Guangzhou][ZTE][6.2 VONR-??-??]Assert fail: ipc_filter.c 3420 - IPCORE
+ *
+ * [VoNR] casting to unsigned to avoid build error
+ *
+ * 04 22 2020 chin-wei.hsu
+ * [MOLY00515791] [MP3 Excluded][MT6885][Petrus][TMO-US][MP3][WWFT][Seattle][5G4G][NSN][MDST][SWIFT][Assert] file:mcu/driver/dpcopro/src/l2_3g_drv.c line:444
+ * add more DID debug information.
+ *
+ * 12 02 2019 tc.chang
+ * [MOLY00462885] [Gen97][UPCM] Support UPCM_DID_SI_BUF_TYPE_WSVC.
+ *
+ * 08 09 2019 tc.chang
+ * [MOLY00417411] [TOP Issue][MT6297][PCT IODT][SA FullStack][StarPoint][PCT 7.1.1.3.3] lgch 5 trigger SR while lgch 6 is waiting for SR delay timer.
+ *
+ * 07 04 2019 tc.chang
+ * [MOLY00418272] [Gen97] Sync Gen95 UMOLYE patch.
+ *
+ * 06 10 2019 tc.chang
+ * [MOLY00412029] [UPCM] Support Wifi proxy DID buffer type.
+ *
+ * 03 27 2019 tc.chang
+ * [MOLY00390750] [MT6297][Apollo][MP0.25][LTE][MLAPI][CMW500][FDDB3, TC 0.4.1.1.A-2][1][core0,vpe1,tc2(vpe1)] Assert fail: dpcopro_hisr.c 722 - (LISR)mml2_excep_lisr
+ * Fix build warning.
+ *
+ * 03 26 2019 tc.chang
+ * [MOLY00390750] [MT6297][Apollo][MP0.25][LTE][MLAPI][CMW500][FDDB3, TC 0.4.1.1.A-2][1][core0,vpe1,tc2(vpe1)] Assert fail: dpcopro_hisr.c 722 - (LISR)mml2_excep_lisr.
+ *
+ * 01 10 2019 mingtsung.sun
+ * [MOLY00374594] [Gen97][5G reorder] L2SW / IPCORE / IPFCORE / LHIF driver integration patch
+ * 5G reorder - SWRD
+ *
+ * 09 06 2018 tc.chang
+ * [MOLY00345990] [VMOLY] Code sync.
+ *
+ * 08 28 2018 mingtsung.sun
+ * [MOLY00327926] [GEN97][ENPDCP] base development check-in
+ * correct offset bit length
+ *
+ * 08 28 2018 mingtsung.sun
+ * [MOLY00327926] [GEN97][ENPDCP] base development check-in
+ *
+ * merge upcm header change from GEN97 DEV
+ *
+ * 04 10 2018 i-feng.chen
+ * [MOLY00318846] [Eiger][E1][MTBF_Monkey][3.15 hours] Externel (EE),0,0,99,/data/vendor/core/,1,modem,Trigger time:[2018-04-02 18:57:29.927529]md1:(MCU_core0.vpe0.tc0(VPE0))[Fatal error(MPU_NOT_ALLOW)] err_code1:0x0000001D err_code2:0x91137C4B err_code3:
+ * [UMOLYE] RTP Confidence API Modification
+ *
+ * 10 25 2017 cammie.yang
+ * [MOLY00285041] ¡i?¥~³¡?¥Î¡jVoLTE ¨ü???
+ * [R3] RTP Confidence Development
+ * - [ROHC] add/set rtp confidence in DL output (interface with EPDCPDL)
+ * - [UPCM] add confidence indication bit in UPCM SI field and modify/provide corresponding MACROs
+ * - [EPDCPDL] fill confidence into SI field
+ *
+ * 06 09 2017 steve.kao
+ * [MOLY00256235] [BIANCO][MT6763][RDIT][PHONE][GCF][TS8980][CA 3A_7A 8.7.1.1_A.1]Assert fail: upcm.c 3554 - IPCORE
+ * [UMOLYA][TRUNK][EPDCP] Fix DID linkage during scaling.
+ *
+ * 05 19 2017 steve.kao
+ * [MOLY00250411] [BIANCO][MT6763][RDIT][PHONE][GCF][ME7873L][CA 39A_41A 8.7.2.1_A.1 ]Assert fail: erlcdl_reasm.c 692 - EL2H
+ * [UMOLYA][TRUNK]
+ * [UPCM] DID format change and new macro for filling SI.
+ * [EPDCP] Use type 2 DID format for loopback test mode buffer release.
+ *
+ * 05 18 2017 steve.kao
+ * [MOLY00250411] [BIANCO][MT6763][RDIT][PHONE][GCF][ME7873L][CA 39A_41A 8.7.2.1_A.1 ]Assert fail: erlcdl_reasm.c 692 - EL2H
+ * [UMOLYA][TRUNK] Use DID macros; add new macro for SIT entry pointer access.
+ *
+ * 02 23 2017 tj.chang
+ * [MOLY00227639] [Bianco Bring-up] RNDIS support DID/DRB
+ * [UMOLYA] ring-buffer based support.
+ *
+ * 02 22 2017 steve.kao
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [UPCM][DID] Fix typo for SW Ctrl Field macro.
+ *
+ * 01 24 2017 steve.kao
+ * [MOLY00226568] [MT6293][NWSIM][3G][R6][All cases][BLOCK] Modis & UESIM will power on fail
+ *
+ * [UMOLYA_TRUNK][UPCM][DID] Reset DID header field-by-field instead resetting a whole word.
+ *
+ * 01 24 2017 steve.kao
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [UMOLYA][TRUNK] Clear F bit for an UPCM DID SIT entry after buffer release by upcm_did_si_free_data_buf().
+ *
+ * 01 23 2017 steve.kao
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [UMOLYA_TRUNK][UPCM][DID] Add SW control field.
+ *
+ * 10 07 2016 steve.kao
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [UMOLYA_PS.DEV][UPCM][DID] Add buf_type for PRB_SHARE.
+ *
+ * 09 26 2016 cammie.yang
+ * [MOLY00195563] [6293][EL2][UPCM][RATDM][EPDCP] Initial feature integrations
+ * [TRUNK] UPCM/RATDM/EPDCP feature integrations from PS.DEV
+ *
+ * 07 27 2016 jeremy.chen
+ * [MOLY00190683] [UMOLYA][6293] EL2 merge back to UMOLYA TRUNK & PS DEV
+ * [EL2][OA domain] sync latest UPCM
+ *
+ ****************************************************************************/
+/*
+ * =====================================================================================
+ *
+ * Filename: upcm_did.h
+ *
+ * Description:
+ * We want data path API are synced from UPCM to AS module (LTM is 4G AS module)
+ *
+ * Created: 2016/3/29
+ * Author: mtk05362 (Steve)
+ * =====================================================================================
+ */
+#ifndef UPCM_DID_INC
+#define UPCM_DID_INC
+
+#include "kal_public_api.h"
+#include "ipc_enums.h"
+
+/*---------------------------------------------------------------------------
+ * structure, constants, macro definitions
+ *---------------------------------------------------------------------------*/
+
+#define UPCM_DID_DBG (1 || defined(__UPCMDIDEUTEST__))
+
+#define UPCM_DID_MAX_SIT_ENT_NUM 62 //defined to make size upcm_did a power of 2
+#define UPCM_DID_NUM 128
+#define UPCM_DID_MAX_AVAIL_NUM (UPCM_DID_NUM - 1)
+
+/////// UPCM DID Embedded Commands
+#define UPCM_DID_CMD_NONE (0x0)
+#define UPCM_DID_CMD_FLUSH (0x1)
+#define UPCM_DID_CMD_ENABLE_RO (0x2)
+#define UPCM_DID_CMD_DISABLE_RO (0x3)
+
+/////// UPCM DID SI HIF Types
+#define UPCM_DID_SI_HIF_TYPE_NULL (0x0)
+#define UPCM_DID_SI_HIF_TYPE_USB (0x1)
+#define UPCM_DID_SI_HIF_TYPE_MCIF (0x2)
+#define UPCM_DID_SI_HIF_TYPE_VNIF (0x3)
+#define UPCM_DID_SI_HIF_TYPE_IGR (0x7)
+
+/////// UPCM DID SI Buffer Types
+#define UPCM_DID_SI_BUF_TYPE_VRB (0x0)
+#define UPCM_DID_SI_BUF_TYPE_ROHC_PRB (0x1)
+#define UPCM_DID_SI_BUF_TYPE_SHARED_PRB (0x2)
+
+//new SI type for USB over DPMAIF
+#define UPCM_DID_SI_BUF_TYPE_BAT (0x3)
+#define UPCM_DID_SI_BUF_TYPE_FRAGBAT (0x4)
+#define UPCM_DID_SI_BUF_TYPE_INVALID (0xF)
+
+// For WIFI Proxy
+#define UPCM_DID_SI_BUF_TYPE_WIFI_PROXY (0x5)
+
+// For WSVC
+#define UPCM_DID_SI_BUF_TYPE_WSVC (0x6)
+
+#define UPCM_DID_MAGIC_CODE (0x4944)
+
+
+//NOTE: The following macros are strongly dependent on the format of upcm_did_si
+#define UPCM_DID_SI_FIELD_EOL (0x1)
+#define UPCM_DID_SI_FIELD_F (0x2)
+#define UPCM_DID_SI_FIELD_T (0x4)
+#define UPCM_DID_SI_FIELD_CI (0x8)
+#define UPCM_DID_SI_FIELD_BUF_TYPE_MSK (0xF)
+#define UPCM_DID_SI_FIELD_BUF_TYPE_OFST (4)
+#define UPCM_DID_SI_FIELD_OFFSET_MSK (0xFFU)
+#define UPCM_DID_SI_FIELD_OFFSET_OFST (8)
+#define UPCM_DID_SI_FIELD_LEN_MSK (0x3FFF)
+
+// Offset exceeds 32 bit. Access it according to data structure directly.
+//#define UPCM_DID_SI_FIELD_LEN_OFST (64)
+
+#define UPCM_DID_SI_FIELD_HIF_TYPE_MSK (0x7)
+#define UPCM_DID_SI_FIELD_HIF_TYPE_OFST (29)
+
+typedef struct upcm_did_t upcm_did;
+
+typedef struct upcm_did_si_t {
+ /* W1 */
+ kal_uint32 eol:1;
+ kal_uint32 f:1;
+ kal_uint32 t:1;
+ kal_uint32 ci:1; // confidence indication; for 2-segment RoHC packets, ci at header part is for TS, and ci at payload part is for SN
+ kal_uint32 buf_type:4;
+ kal_uint32 offset:8;
+ kal_uint32 rsv1:13;
+ kal_uint32 hif_type:3;
+ /* W1 */
+
+ /* W2 */
+ void *p_data;
+ /* W2 */
+
+ /* W3 */
+ kal_uint32 len:14;
+ kal_uint32 rsv2:9;
+ kal_uint32 qfi:8;
+ kal_uint32 nrqi:1;
+ /* W3 */
+}upcm_did_si;
+
+typedef struct upcm_did_hdr_t {
+ /* W1 */
+ kal_uint16 pdu_session_id:4;
+ kal_uint16 sw_ctrl_field:12;
+ kal_uint16 mcode_used;
+ /* W1 */
+
+ /* W2 */
+ kal_uint32 pkt_num:8;
+ kal_uint32 seg_num:8;
+ kal_uint32 flow:6;
+ kal_uint32 cmd:3;
+ kal_uint32 rsv2:7;
+ /* W2 */
+
+ /* W3 */
+ upcm_did *p_next;
+ /* W3 */
+
+ /* W4 */
+ kal_uint32 count_l:24;
+ kal_uint32 idx:8;
+ /* W4 */
+}upcm_did_hdr;
+
+// Data Indication Descriptor
+struct upcm_did_t {
+ upcm_did_hdr hdr;
+ upcm_did_si sit[UPCM_DID_MAX_SIT_ENT_NUM];
+};
+
+typedef struct upcm_did_pool_db_t {
+ upcm_did *p_free;
+ kal_atomic_uint32 atm_rem_buff;
+
+ kal_enhmutexid enhmutexid;
+} upcm_did_pool_db;
+
+// Since DID is large, check pointer for list status
+typedef struct {
+ upcm_did *p_head;
+ upcm_did *p_tail;
+} upcm_did_list;
+
+#if UPCM_DID_DBG
+#define UPCM_DID_ASSERT(x) ASSERT(x)
+#else // #if UPCM_DID_DBG
+#define UPCM_DID_ASSERT(x)
+#endif // #if !UPCM_DID_DBG
+
+#define UPCM_DID_SI_GET_PTR(_p) (_p)
+
+#define UPCM_DID_SI_SET_EOL(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->eol = 1)
+#define UPCM_DID_SI_CLR_EOL(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->eol = 0)
+#define UPCM_DID_SI_SET_F(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->f = 1)
+#define UPCM_DID_SI_CLR_F(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->f = 0)
+#define UPCM_DID_SI_SET_T(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->t = 1)
+#define UPCM_DID_SI_CLR_T(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->t = 0)
+#define UPCM_DID_SI_SET_CI(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->ci = 1)
+#define UPCM_DID_SI_CLR_CI(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->ci = 0)
+#define UPCM_DID_SI_GET_EOL(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->eol)
+#define UPCM_DID_SI_GET_F(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->f)
+#define UPCM_DID_SI_GET_T(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->t)
+#define UPCM_DID_SI_GET_CI(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->ci)
+
+#define UPCM_DID_SI_SET_BUF_TYPE(_p, _type) \
+ ((UPCM_DID_SI_GET_PTR(_p))->buf_type = (_type))
+
+#define UPCM_DID_SI_SET_OFFSET(_p, _offset) \
+ do { \
+ UPCM_DID_SI_CLR_T(_p); \
+ (UPCM_DID_SI_GET_PTR(_p))->offset = (_offset); \
+ } while(0)
+#define UPCM_DID_SI_SET_LEN(_p, _len) \
+ do { \
+ UPCM_DID_SI_CLR_T(_p); \
+ (UPCM_DID_SI_GET_PTR(_p))->len = (_len); \
+ } while(0)
+
+// The field len and offset are swapped for T=1
+#define UPCM_DID_SI_SET_OFFSET_WITH_T(_p, _offset) \
+ do { \
+ UPCM_DID_SI_SET_T(_p); \
+ (UPCM_DID_SI_GET_PTR(_p))->len = (_offset); \
+ } while(0)
+#define UPCM_DID_SI_SET_LEN_WITH_T(_p, _len) \
+ do { \
+ UPCM_DID_SI_SET_T(_p); \
+ (UPCM_DID_SI_GET_PTR(_p))->offset = (_len); \
+ } while(0)
+
+#define UPCM_DID_SI_SET_HIF_TYPE(_p, _type) \
+ ((UPCM_DID_SI_GET_PTR(_p))->hif_type = (_type))
+#define UPCM_DID_SI_SET_DATAPTR(_p, _ptr) \
+ ((UPCM_DID_SI_GET_PTR(_p))->p_data = (_ptr))
+
+#define UPCM_DID_SI_GET_BUF_TYPE(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->buf_type)
+
+// The field len and offset are swapped for T=1
+#define UPCM_DID_SI_GET_OFFSET(_p) \
+ (UPCM_DID_SI_GET_T(_p)? \
+ (UPCM_DID_SI_GET_PTR(_p))->len : \
+ (UPCM_DID_SI_GET_PTR(_p))->offset)
+#define UPCM_DID_SI_GET_LEN(_p) \
+ (UPCM_DID_SI_GET_T(_p)? \
+ (UPCM_DID_SI_GET_PTR(_p))->offset : \
+ (UPCM_DID_SI_GET_PTR(_p))->len)
+#define UPCM_DID_SI_GET_HIF_TYPE(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->hif_type)
+#define UPCM_DID_SI_GET_DATAPTR(_p) \
+ ((UPCM_DID_SI_GET_PTR(_p))->p_data)
+
+
+// Assumes T=0; sets the field EOL, F, buf_type, offset, len, ci, hif_type
+#define UPCM_DID_SI_SET_MISC_INFO( \
+ _p_si, _is_eol, _is_f, _buf_type, _offset, _len, _is_ci, _hif_type) \
+do { \
+ UPCM_DID_ASSERT( \
+ !((_buf_type) & (~UPCM_DID_SI_FIELD_BUF_TYPE_MSK)) && \
+ !((_offset) & (~UPCM_DID_SI_FIELD_OFFSET_MSK)) && \
+ !((kal_uint16)(_len) & (~UPCM_DID_SI_FIELD_LEN_MSK)) && \
+ !((_hif_type) & (~UPCM_DID_SI_FIELD_HIF_TYPE_MSK)) \
+ ); \
+ *((kal_uint32*)(_p_si)) = \
+ ((_is_eol)?UPCM_DID_SI_FIELD_EOL:0x0) | \
+ ((_is_f)?UPCM_DID_SI_FIELD_F:0x0) | \
+ (((_buf_type) & UPCM_DID_SI_FIELD_BUF_TYPE_MSK) << UPCM_DID_SI_FIELD_BUF_TYPE_OFST) | \
+ (((_offset) & UPCM_DID_SI_FIELD_OFFSET_MSK) << UPCM_DID_SI_FIELD_OFFSET_OFST) | \
+ ((_is_ci)?UPCM_DID_SI_FIELD_CI:0x0) | \
+ (((_hif_type) & UPCM_DID_SI_FIELD_HIF_TYPE_MSK) << UPCM_DID_SI_FIELD_HIF_TYPE_OFST); \
+ (_p_si)->len = _len; \
+} while (0)
+// Assumes T=1; sets the field EOL, F, buf_type, offset, len, hif_type
+// The field len and offset are swapped for T=1
+#define UPCM_DID_SI_SET_MISC_INFO_WITH_T( \
+ _p_si, _is_eol, _is_f, _buf_type, _offset, _len, _is_ci, _hif_type) \
+do { \
+ UPCM_DID_ASSERT( \
+ !((_buf_type) & (~UPCM_DID_SI_FIELD_BUF_TYPE_MSK)) && \
+ !((_len) & (~UPCM_DID_SI_FIELD_OFFSET_MSK)) && \
+ !((_offset) & (~UPCM_DID_SI_FIELD_LEN_MSK)) && \
+ !((_hif_type) & (~UPCM_DID_SI_FIELD_HIF_TYPE_MSK)) \
+ ); \
+ *((kal_uint32*)(_p_si)) = \
+ ((_is_eol)?UPCM_DID_SI_FIELD_EOL:0x0) | \
+ ((_is_f)?UPCM_DID_SI_FIELD_F:0x0) | \
+ (UPCM_DID_SI_FIELD_T) | \
+ (((_buf_type) & UPCM_DID_SI_FIELD_BUF_TYPE_MSK) << UPCM_DID_SI_FIELD_BUF_TYPE_OFST) | \
+ (((_len) & UPCM_DID_SI_FIELD_OFFSET_MSK) << UPCM_DID_SI_FIELD_OFFSET_OFST) | \
+ ((_is_ci)?UPCM_DID_SI_FIELD_CI:0x0) | \
+ (((_hif_type) & UPCM_DID_SI_FIELD_HIF_TYPE_MSK) << UPCM_DID_SI_FIELD_HIF_TYPE_OFST); \
+ (_p_si)->len = _offset; \
+} while (0)
+
+#define UPCM_DID_GET_PTR(_p) (_p)
+
+#define UPCM_DID_SET_USED(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used |= 0x1)
+#define UPCM_DID_CLR_USED(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used &= ~0x1)
+#define UPCM_DID_GET_USED(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used & 0x1)
+
+#define UPCM_DID_SET_MCODE(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used &= ~0xFFFE );\
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used |= UPCM_DID_MAGIC_CODE)
+#define UPCM_DID_GET_MCODE(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->mcode_used & 0xFFFE )
+
+#define UPCM_DID_SET_SW_CTRL_FIELD(_p, _val) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->sw_ctrl_field = (_val));
+#define UPCM_DID_GET_SW_CTRL_FIELD(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->sw_ctrl_field)
+
+#define UPCM_DID_SET_PKT_NUM(_p, _num) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->pkt_num = (_num))
+#define UPCM_DID_SET_SEG_NUM(_p, _num) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->seg_num = (_num))
+#define UPCM_DID_SET_NEXT(_p, _nxt) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->p_next = (_nxt))
+#define UPCM_DID_SET_COUNT_L(_p, _cntl) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->count_l = (_cntl))
+#define UPCM_DID_SET_FLOW(_p, _flow) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->flow = (_flow))
+#define UPCM_DID_SET_CMD(_p, _cmd) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->cmd = (_cmd))
+#define UPCM_DID_SET_IDX(_p, _idx) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->idx = (_idx))
+
+#define UPCM_DID_GET_PKT_NUM(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->pkt_num)
+#define UPCM_DID_GET_SEG_NUM(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->seg_num)
+#define UPCM_DID_GET_NEXT(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->p_next)
+#define UPCM_DID_GET_COUNT_L(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->count_l)
+#define UPCM_DID_GET_FLOW(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->flow)
+#define UPCM_DID_GET_CMD(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->cmd)
+#define UPCM_DID_GET_IDX(_p) \
+ ((UPCM_DID_GET_HDR_PTR(_p))->idx)
+
+#define UPCM_DID_GET_HDR_PTR(_p) \
+ (&(UPCM_DID_GET_PTR(_p))->hdr)
+#define UPCM_DID_GET_SIT_PTR(_p) \
+ (&(UPCM_DID_GET_PTR(_p))->sit[0])
+#define UPCM_DID_GET_SIT_ENTRY_PTR(_p, _entry_idx) \
+ (&(UPCM_DID_GET_PTR(_p))->sit[_entry_idx])
+
+#define UPCM_DID_RESET_HDR(_p) \
+do { \
+ UPCM_DID_CLR_USED(_p); \
+ UPCM_DID_SET_MCODE(_p); \
+ UPCM_DID_SET_PKT_NUM(_p, 0); \
+ UPCM_DID_SET_SEG_NUM(_p, 0); \
+ UPCM_DID_SET_CMD(_p, UPCM_DID_CMD_NONE); \
+}while(0)
+
+
+#define upcm_did_list_clr(_p) \
+ (_p)->p_head = NULL
+
+#define upcm_did_list_is_empty(_p) \
+ ((_p)->p_head == NULL)
+
+#define upcm_did_list_get_head(_p) \
+ (_p)->p_head
+
+#define upcm_did_list_get_tail(_p) \
+ (_p)->p_tail
+
+#define upcm_did_list_add(_p, _did) \
+{ \
+ if(upcm_did_list_is_empty(_p)) \
+ { \
+ (_p)->p_head = (_did); \
+ (_p)->p_tail = (_did); \
+ } \
+ else \
+ { \
+ UPCM_DID_SET_NEXT((_p)->p_tail, (_did)); \
+ (_p)->p_tail = (_did); \
+ } \
+}
+
+#define upcm_did_list_add_list(_p, _did_h, _did_t) \
+{ \
+ if(upcm_did_list_is_empty(_p)) \
+ { \
+ (_p)->p_head = (_did_h); \
+ (_p)->p_tail = (_did_t); \
+ } \
+ else \
+ { \
+ UPCM_DID_SET_NEXT((_p)->p_tail, (_did_h)); \
+ (_p)->p_tail = (_did_t); \
+ } \
+}
+
+// Release DIDs but not releasing data buffers
+#define upcm_did_list_drop(_p) \
+{ \
+ if (!upcm_did_list_is_empty(_p)) { \
+ upcm_did_dest_q( \
+ upcm_did_list_get_head(_p), \
+ upcm_did_list_get_tail(_p) \
+ ); \
+ upcm_did_list_clr(_p); \
+ } \
+}
+
+// Release DIDs and also release data buffers
+#define upcm_did_list_drop_free_buf(_p) \
+{ \
+ if (!upcm_did_list_is_empty(_p)) { \
+ upcm_did_dest_q_free_buf( \
+ upcm_did_list_get_head(_p), \
+ upcm_did_list_get_tail(_p) \
+ ); \
+ upcm_did_list_clr(_p); \
+ } \
+}
+
+/*---------------------------------------------------------------------------
+ * Exported context
+ *---------------------------------------------------------------------------*/
+
+extern kal_uint32 upcm_did_entry_history_user[UPCM_DID_NUM];
+extern kal_uint8 upcm_did_entry_history_operation[UPCM_DID_NUM];
+
+
+/*---------------------------------------------------------------------------
+ * Exported Function Prototypes
+ *---------------------------------------------------------------------------*/
+
+kal_bool upcm_did_init();
+kal_bool upcm_did_reset();
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_alloc_one
+ * Description: Allocates single DID initially carrying no packet.
+ * Return: The address of the DID allocated.
+ * ============================================================================
+ */
+upcm_did* upcm_did_alloc_one();
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_free_one
+ * Description: Releases single DID.
+ * Note:
+ * The buffers of the packets indicated in the SIT would not
+ * be freed with by API.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_free_one(upcm_did *p_did);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_free_one_free_buf
+ * Description: Releases single DID.
+ * Note:
+ * The buffers of the packet segments indicated by the SIT
+ * entries with the F bit set would be freed by this API.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_free_one_free_buf(upcm_did *p_did);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_alloc_q
+ * Description: Allocates a list of DIDs as requested.
+ * num: Number of DIDs requested to be allocated.
+ * pp_head: Returns the head of the list of DIDs allocated.
+ * pp_tail: Returns the tail of the list of DIDs allocated.
+ * Return: The actual number of DIDs allocated
+ * ============================================================================
+ */
+kal_uint32 upcm_did_alloc_q(kal_uint32 num, upcm_did **pp_head, upcm_did **pp_tail);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_dest_q
+ * Description: Releases a list of DIDs.
+ * Note:
+ * The buffers of the packets indicated in the SIT would not
+ * be freed with by API.
+ * p_head: Input the head of the list of DIDs to be released.
+ * p_tail: Input the tail of the list of DIDs to be released.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_dest_q(upcm_did *p_head, upcm_did *p_tail);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_dest_q_free_buf
+ * Description: Releases a list of DIDs.
+ * Note:
+ * The buffers of the packet segments indicated by the SIT
+ * entries with the F bit set would be freed by this API.
+ * p_head: Input the head of the list of DIDs to be released.
+ * p_tail: Input the tail of the list of DIDs to be released.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_dest_q_free_buf(upcm_did *p_head, upcm_did *p_tail);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_dest_q_but_tail_free_buf
+ * Description: Releases a list of DIDs, but save the tail.
+ * Note:
+ * Nothing would be released if list only contains one DID.
+ * p_head: Input the head of the list of DIDs to be released.
+ * p_tail: Input the tail of the list of DIDs to be released.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_dest_q_but_tail_free_buf(upcm_did *p_head, upcm_did *p_tail);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_get_buff_remain_num
+ * Description: Get the number of DIDs reamining for allocation.
+ * Return: The number of DIDs reamining for allocation.
+ * ============================================================================
+ */
+kal_uint32 upcm_did_get_buff_remain_num();
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_si_free_data_buf
+ * Description: Free the data buffer indicated by the SIT entry if the F bit
+ * is set.
+ * The F bit of the SIT entry would be cleared by this API.
+ * p_si: Address of the SIT entry.
+ * Return: void
+ * ============================================================================
+ */
+void upcm_did_si_free_data_buf(upcm_did_si *p_si);
+
+/*
+ * === FUNCTION =============================================================
+ * Name: upcm_did_si_get_confidence
+ * Description: Get confidence from the SIT entry.
+ * upcm_did: Address of DID.
+ * desc_idx: The index of si entry for the specific data.
+ * desc_type: IPCore filter_info source descriptor type. IPC_FI_DESC_TYPE_NONE implies that it is in HW path and RoHC is off, it always return 0 for confident.
+ * Return: rtp_confidence
+ * (0: confident; 1: SN not confident; 2: TS not confident)
+ * ============================================================================
+ */
+kal_uint32 upcm_did_si_get_confidence(upcm_did *p_did, kal_uint32 desc_idx, ipc_fi_desc_type_e desc_type);
+#endif /* ----- #ifndef UPCM_DID_INC ----- */
+
diff --git a/mcu/interface/protocol/nas_multimode/upcm/upcm_trc.h b/mcu/interface/protocol/nas_multimode/upcm/upcm_trc.h
new file mode 100644
index 0000000..48ebb0b
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/upcm_trc.h
@@ -0,0 +1,75 @@
+/*****************************************************************************
+* 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) 2005
+*
+* 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:
+ * ---------
+ * upcm_trc.h
+ *
+ * Project:
+ * --------
+ * MOLY
+ *
+ * Description:
+ * ------------
+ * This file defines the trace functions used by UPCM.
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *==============================================================================
+ * HISTORY
+ * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *------------------------------------------------------------------------------
+ * removed!
+ * removed!
+ * removed!
+ *
+ *------------------------------------------------------------------------------
+ * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *==============================================================================
+ *******************************************************************************/
+#ifndef _UPCM_TRC_H
+#define _UPCM_TRC_H
+#include "stack_config.h"
+#include "kal_trace.h"
+#if !defined(GEN_FOR_PC)
+#if defined(__TST_MODULE__) || defined(__CUSTOM_RELEASE__)
+#endif /* TST Trace Defintion */
+#endif
+#if !defined(GEN_FOR_PC)
+#include"upcm_trc_mod_upcm_utmd.h"
+#endif
+#endif
diff --git a/mcu/interface/protocol/nas_multimode/upcm/upcm_trc_mod_upcm_utmd.json b/mcu/interface/protocol/nas_multimode/upcm/upcm_trc_mod_upcm_utmd.json
new file mode 100644
index 0000000..cbf9529
--- /dev/null
+++ b/mcu/interface/protocol/nas_multimode/upcm/upcm_trc_mod_upcm_utmd.json
@@ -0,0 +1,176 @@
+{
+ "legacyParameters": {},
+ "module": "MOD_UPCM",
+ "traceClassDefs": [
+ {
+ "TRACE_INFO": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline",
+ "TRACE_INFO"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_WARNING": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline",
+ "TRACE_WARNING"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_ERROR": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline",
+ "TRACE_ERROR"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_FUNC": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline",
+ "TRACE_FUNC"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_STATE": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline",
+ "TRACE_STATE"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_1": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_2": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_3": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_4": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_5": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_6": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_7": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_8": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_9": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ },
+ {
+ "TRACE_GROUP_10": {
+ "debugLevel": "Ultra-Low",
+ "tag": [
+ "Baseline"
+ ],
+ "traceType": "Public"
+ }
+ }
+ ],
+ "traceDefs": [
+ {
+ "UPCM_UL_RAW_DATA": {
+ "format": "[UPCM] UL RAW",
+ "traceClass": "TRACE_INFO"
+ }
+ },
+ {
+ "UPCM_DL_RAW_DATA": {
+ "format": "[UPCM] DL RAW",
+ "traceClass": "TRACE_INFO"
+ }
+ },
+ {
+ "UPCM_IMS_UL_RAW_DATA": {
+ "format": "[UPCM] IMS UL RAW",
+ "traceClass": "TRACE_INFO"
+ }
+ },
+ {
+ "UPCM_IMS_DL_RAW_DATA": {
+ "format": "[UPCM] IMS DL RAW",
+ "traceClass": "TRACE_INFO"
+ }
+ }
+ ],
+ "traceFamily": "PS",
+ "userModule": "UPCM",
+ "startGen": "Legacy",
+ "endGen": "-"
+}