X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=src%2Fdu_app%2Fdu_sctp.c;h=374ab506b826e36260b89d34e327e02671d17624;hb=49856df248fd976b4a9882ca4e650fc0bc3e4ee3;hp=e9fdcb8b16c38bd1af2e0ceff543a1808f9ffd3d;hpb=0bb62f25ad9d8f9ff8724572f96e51a898937f0c;p=o-du%2Fl2.git diff --git a/src/du_app/du_sctp.c b/src/du_app/du_sctp.c index e9fdcb8b1..374ab506b 100644 --- a/src/du_app/du_sctp.c +++ b/src/du_app/du_sctp.c @@ -18,6 +18,7 @@ /* This file contains all SCTP related functionality */ #include "common_def.h" +#include "du_tmr.h" #include "lrg.h" #include "legtp.h" #include "lrg.x" @@ -25,12 +26,23 @@ #include "cm_inet.h" #include "cm_inet.x" #include "du_app_mac_inf.h" +#include "du_e2ap_mgr.h" #include "du_cfg.h" #include "du_sctp.h" #include "lsctp.h" #include "du_app_rlc_inf.h" #include "du_mgr.h" #include "du_utils.h" +/* Global variable declaration */ +uint8_t socket_type; /* Socket type */ +bool nonblocking; /* Blocking/Non-blocking socket */ +bool connUp; /* Is connection up */ +bool pollingState; +CmInetNetAddrLst localAddrLst; +CmInetNetAddrLst remoteAddrLst; +/* Global variable declaration */ +DuSctpDestCb f1Params; /* SCTP configurations at DU */ +DuSctpDestCb ricParams; /* SCTP configurations at DU */ /************************************************************************** * @brief Task Initiation callback function. @@ -569,7 +581,7 @@ void sendToDuApp(Buffer *mBuf, Event event) * RFAILED - failure * * ****************************************************************/ -uint8_t sctpNtfyHdlr(CmInetSctpNotification *ntfy, uint8_t *itfState) +uint8_t sctpNtfyHdlr(CmInetSctpNotification *ntfy, uint8_t *itfState, uint8_t interface) { Pst pst; @@ -615,10 +627,21 @@ uint8_t sctpNtfyHdlr(CmInetSctpNotification *ntfy, uint8_t *itfState) DU_LOG("\nINFO --> SCTP : Send Failed notification received\n"); break; case CM_INET_SCTP_SHUTDOWN_EVENT : /* peer socket gracefully closed */ - DU_LOG("\nINFO --> SCTP : Shutdown Event notification received\n"); - *itfState = DU_SCTP_DOWN; - exit(0); - break; + { + DU_LOG("\nINFO --> SCTP : Shutdown Event notification received\n"); + *itfState = DU_SCTP_DOWN; + switch(interface) + { + case F1_INTERFACE: + break; + case E2_INTERFACE: + removeE2NodeInformation(); + break; + default: + exit(0); + } + break; + } case CM_INET_SCTP_ADAPTATION_INDICATION : DU_LOG("\nINFO --> SCTP : Adaptation Indication received\n"); break; @@ -690,6 +713,7 @@ uint8_t processPolling(sctpSockPollParams *pollParams, CmInetFd *sockFd, uint32 { DU_LOG("\nERROR --> SCTP: Failed to receive sctp msg for sockFd[%d]\n", sockFd->fd); recvMsgSet = RFAILED; + } else { @@ -705,13 +729,13 @@ uint8_t processPolling(sctpSockPollParams *pollParams, CmInetFd *sockFd, uint32 { f1Params.assocId = pollParams->ntfy.u.assocChange.assocId; DU_LOG("\nDEBUG --> SCTP : AssocId assigned to F1Params from PollParams [%d]\n", f1Params.assocId); - ret = sctpNtfyHdlr(&pollParams->ntfy, &f1Params.itfState); + ret = sctpNtfyHdlr(&pollParams->ntfy, &f1Params.itfState, F1_INTERFACE); } else if(pollParams->port == ricParams.destPort) { ricParams.assocId = pollParams->ntfy.u.assocChange.assocId; DU_LOG("\nDEBUG --> SCTP : AssocId assigned to ricParams from PollParams [%d]\n", ricParams.assocId); - ret = sctpNtfyHdlr(&pollParams->ntfy, &ricParams.itfState); + ret = sctpNtfyHdlr(&pollParams->ntfy, &ricParams.itfState, E2_INTERFACE); } else { @@ -843,7 +867,7 @@ uint8_t sctpSend(Buffer *mBuf, uint8_t itfType) if(itfType == F1_INTERFACE) { - DU_LOG("\nDEBUG --> SCTP : sending the message to CU"); + DU_LOG("\nDEBUG --> SCTP : sending the message to CU"); #ifdef CALL_FLOW_DEBUG_LOG DU_LOG("\nCall Flow: ENTSCTP -> CU : EVENT_F1AP_MSG_TO_CU\n"); #endif @@ -852,7 +876,7 @@ uint8_t sctpSend(Buffer *mBuf, uint8_t itfType) if(itfType == E2_INTERFACE) { - DU_LOG("\nDEBUG --> SCTP : sending the message to ric"); + DU_LOG("\nDEBUG --> SCTP : sending the message to ric"); #ifdef CALL_FLOW_DEBUG_LOG DU_LOG("\nCall Flow: ENTSCTP -> RIC : EVENT_E2AP_MSG_TO_RIC\n"); #endif