X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=src%2Fric_stub%2Fric_stub.h;h=0bf9680f086868783cd72b4d781f8155f7952ed8;hb=refs%2Fchanges%2F82%2F11782%2F4;hp=566f070186905a93e23729d978a001541b8e0994;hpb=694adde1a08c393a8443fd5bbd4f036f5cf85403;p=o-du%2Fl2.git diff --git a/src/ric_stub/ric_stub.h b/src/ric_stub/ric_stub.h index 566f07018..0bf9680f0 100644 --- a/src/ric_stub/ric_stub.h +++ b/src/ric_stub/ric_stub.h @@ -19,11 +19,35 @@ #ifndef __RIC_MGR_MAIN_H__ #define __RIC_MGR_MAIN_H__ -#define MAX_IPV6_LEN 16 +#define RIC_ID 1 +#define RIC_NAME "ORAN_OAM_RIC" + +#define DU_IP_V6_ADDR "0000:0000:0000:0000:0000:0000:0000:0001" +#define RIC_IP_V6_ADDR "0000:0000:0000:0000:0000:0000:0000:0011" + +#ifndef O1_ENABLE +#define LOCAL_IP_RIC "192.168.130.80" + +#define E2_SCTP_PORT 36421 +#define NUM_E2_ASSOC 1 +#define REMOTE_IP_DU (char*[]){"192.168.130.81", "192.168.130.83"} +#endif + +#define RRC_VER 0 +#define EXT_RRC_VER 5 +#define PLMN_MCC0 3 +#define PLMN_MCC1 1 +#define PLMN_MCC2 1 +#define PLMN_MNC0 4 +#define PLMN_MNC1 8 +#define PLMN_MNC2 0 + #define RIC_DU_NAME_LEN_MAX 30 /* Max length of RIC/DU name string */ #define RIC_APP_MEM_REG 1 #define RIC_POOL 1 +#define MAX_RAN_FUNCTION 256 /* O-RAN.WG3.E2AP-R003-v03.00 : Section 9.1.2.2 : maxofRANfunctionID */ +#define MAX_NUM_TRANSACTION 256 /* As per, O-RAN WG3 E2AP v3.0, section 9.2.33 */ /* allocate and zero out a static buffer */ #define RIC_ALLOC(_datPtr, _size) \ @@ -42,30 +66,79 @@ SPutSBuf(RIC_APP_MEM_REG, RIC_POOL, \ (Data *)_datPtr, _size); -typedef struct ipAddr +#define SEARCH_DU_DB(_duIdx, _duId, _duDb){\ + _duDb = NULLP; \ + for(_duIdx=0; _duIdx < ricCb.numDu; _duIdx++)\ + {\ + if(ricCb.duInfo[_duIdx].duId == _duId)\ + {\ + _duDb = (&ricCb.duInfo[_duIdx]);\ + break; \ + }\ + }\ +} + +/* O-RAN.WG3.E2AP-R003-v03.00 : Section 9.2.26 */ +typedef enum +{ + NG, + XN, + E1, + F1, + W1, + S1, + X2 +}InterfaceType; + + +typedef struct { - bool ipV4Pres; - uint32_t ipV4Addr; - bool ipV6Pres; - uint8_t ipV6Addr[MAX_IPV6_LEN]; -}SctpIpAddr; + uint16_t id; + uint16_t revisionCounter; +}RanFunction; -typedef struct RicSctpParams +typedef struct { - SctpIpAddr duIpAddr; - uint16_t duPort; - SctpIpAddr ricIpAddr; - uint16_t ricPort; -}RicSctpParams; + InterfaceType interfaceType; + uint64_t componentId; +}E2NodeComponent; + +typedef struct duDb +{ + uint32_t duId; + uint8_t ricTransIdCounter; + uint16_t numOfRanFunction; + RanFunction ranFunction[MAX_RAN_FUNCTION]; + E2NodeComponent e2NodeComponent; + Bool ricSubscribedToDu; +}DuDb; typedef struct ricCfgParams { - uint32_t ricId; + uint32_t ricId; char ricName[RIC_DU_NAME_LEN_MAX]; RicSctpParams sctpParams; Plmn plmn; }RicCfgParams; -RicCfgParams ricCfgParams; //global variable to hold all configs + +typedef struct cuGlobalCb +{ + RicCfgParams ricCfgParams; + uint8_t numDu; + DuDb duInfo[MAX_DU_SUPPORTED]; +}RicGlobalCb; + +RicGlobalCb ricCb; + +typedef struct +{ + uint8_t numOfRanFunToBeAdded; + RanFunction ranFunToBeAdded[MAX_RAN_FUNCTION]; + uint8_t numOfRanFunToBeModified; + RanFunction ranFunToBeModified[MAX_RAN_FUNCTION]; + uint8_t numOfRanFunTodeleted; + RanFunction ranFunToBeDeleted[MAX_RAN_FUNCTION]; +}RicTmpRanFunList; void readRicCfg(); void cuAppInmsgHdlr(Buffer *mBuf);