1 /*******************************************************************************
2 ################################################################################
3 # Copyright (c) [2017-2019] [Radisys] #
5 # Licensed under the Apache License, Version 2.0 (the "License"); #
6 # you may not use this file except in compliance with the License. #
7 # You may obtain a copy of the License at #
9 # http://www.apache.org/licenses/LICENSE-2.0 #
11 # Unless required by applicable law or agreed to in writing, software #
12 # distributed under the License is distributed on an "AS IS" BASIS, #
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
14 # See the License for the specific language governing permissions and #
15 # limitations under the License. #
16 ################################################################################
17 *******************************************************************************/
19 /* This file contains message handling functionality for DU APP */
22 #include "du_f1ap_msg_hdl.h"
23 #include "du_e2ap_msg_hdl.h"
26 #include "du_app_mac_inf.h"
27 #include "du_ue_mgr.h"
31 extern S16 cmUnpkLkwCfgCfm(LkwCfgCfm func,Pst *pst, Buffer *mBuf);
32 extern S16 cmUnpkLkwCntrlCfm(LkwCntrlCfm func,Pst *pst, Buffer *mBuf);
33 extern S16 cmUnpkLrgCfgCfm(LrgCfgCfm func,Pst *pst, Buffer *mBuf);
35 /**************************************************************************
36 * @brief Task Initiation callback function.
40 * Function : duActvInit
43 * This function is supplied as one of parameters during DU APP's
44 * task registration. SSI will invoke this function once, after
45 * it creates and attaches this TAPA Task to a system task.
47 * @param[in] Ent entity, the entity ID of this task.
48 * @param[in] Inst inst, the instance ID of this task.
49 * @param[in] Region region, the region ID registered for memory
51 * @param[in] Reason reason.
52 * @return ROK - success
54 ***************************************************************************/
55 S16 duActvInit(Ent entity, Inst inst, Region region, Reason reason)
57 duCb.init.procId = SFndProcId();
58 duCb.init.ent = entity;
59 duCb.init.inst = inst;
60 duCb.init.region = region;
61 duCb.init.reason = reason;
62 duCb.init.cfgDone = FALSE;
63 duCb.init.pool = DU_POOL;
64 duCb.init.acnt = FALSE;
65 duCb.init.trc = FALSE;
66 duCb.init.usta = TRUE;
67 duCb.mem.region = DFLT_REGION;
68 duCb.mem.pool = DU_POOL;
70 duCb.f1Status = FALSE;
71 duCb.e2Status = FALSE;
73 if(ROK != cmHashListInit(&(duCb.cellLst),
77 (U16) CM_HASH_KEYTYPE_CONID,
81 DU_LOG("\nDU_APP : cellLst Initialization Failed");
84 if(ROK != cmHashListInit(&(duCb.actvCellLst),
88 (U16) CM_HASH_KEYTYPE_CONID,
92 DU_LOG("\nDU_APP : ActvCellLst Initialization Failed");
101 /**************************************************************************
102 * @brief Task Activation callback function.
106 * Function : duActvTsk
109 * Primitives invoked by DU APP's users/providers through
110 * a loosely coupled interface arrive here by means of
111 * SSI's message handling. This API is registered with
112 * SSI during the Task Registration of DU APP.
114 * @param[in] Pst *pst, Post structure of the primitive.
115 * @param[in] Buffer *mBuf, Packed primitive parameters in the
117 * @return ROK - success
120 ***************************************************************************/
121 S16 duActvTsk(Pst *pst, Buffer *mBuf)
133 DU_LOG("\n****** Received initial configs at DU APP ******\n");
140 DU_LOG("\nDU_APP : Invalid event received at duActvTsk from ENTDUAPP");
152 case LKW_EVT_CFG_CFM:
154 ret = cmUnpkLkwCfgCfm(duHdlRlcCfgComplete, pst, mBuf);
157 case LKW_EVT_CNTRL_CFM:
159 ret = cmUnpkLkwCntrlCfm(duHdlRlcCntrlCfgComplete, pst, mBuf);
162 case LKW_EVT_STA_IND:
166 case KWU_EVT_DAT_IND:
168 ret = cmUnpkKwuDatInd(duHdlRlcUlData, pst, mBuf);
173 DU_LOG("\nDU_APP : Invalid event %d received at duActvTsk from ENTKW", \
193 ret = cmUnpkLrgCfgCfm(duHdlMacCfgComplete, pst, mBuf);
200 case EVTMACSCHGENCFGCFM:
202 ret = cmUnpkLrgSchCfgCfm(duHdlSchCfgComplete, pst, mBuf);
205 case EVENT_MAC_CELL_CONFIG_CFM:
207 ret = unpackMacCellCfgCfm(duHandleMacCellCfgCfm, pst, mBuf);
212 DU_LOG("\nDU_APP : Invalid event received at duActvTsk from ENTRG");
231 ret = cmUnpkSctpNtfy(duSctpNtfyHdl, pst, mBuf);
242 DU_LOG("\nDU_APP : Invalid event received at duActvTsk from ENTSCTP");
256 cmUnpkEgtpCfgCfm(duHdlEgtpCfgComplete, mBuf);
261 cmUnpkEgtpSrvOpenCfm(duHdlEgtpSrvOpenComplete, mBuf);
266 cmUnpkEgtpTnlMgmtCfm(duHdlEgtpTnlMgmtCfm, mBuf);
271 DU_LOG("\nDU_APP : Invalid event[%d] received at duActvTsk from ENTEGTP", pst->event);
280 DU_LOG("\nDU_APP : DU APP can not process message from Entity %d", pst->srcEnt);
290 /**********************************************************************
292 **********************************************************************/