X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=src%2Fcm%2Fcommon_def.h;h=1220b2e42d0e7739d66cc882e115c4b2d1720f01;hb=03343a6a545fb0f5bd36fb309a5dee153831c54f;hp=af3cccad20e4c5cfd5a55caaa2f6dec89c4034b0;hpb=a31737d4988c5e02d4998c16973b1048fa2be9a4;p=o-du%2Fl2.git diff --git a/src/cm/common_def.h b/src/cm/common_def.h index af3cccad2..1220b2e42 100644 --- a/src/cm/common_def.h +++ b/src/cm/common_def.h @@ -56,8 +56,10 @@ #define RADIO_FRAME_DURATION 10 /* Time duration of a radio frame in ms */ /* MAX values */ #define MAX_NUM_CELL 1 -#define MAX_NUM_UE 1 -#define MAX_NUM_LC 11 +#define MAX_NUM_MU 4 +#define MAX_NUM_UE 3 +#define MAX_NUM_UE_PER_TTI 1 +#define MAX_NUM_LC MAX_DRB_LCID + 1 /*Spec 38.331: Sec 6.4: maxLC-ID Keyword*/ #define MAX_NUM_SRB 3 /* Max. no of Srbs */ #define MAX_NUM_DRB 29 /* spec 38.331, maxDRB */ @@ -88,14 +90,22 @@ #define PUCCH_FORMAT_3 3 #define PUCCH_FORMAT_4 4 +#define DEFAULT_MCS 4 + #define BANDWIDTH_20MHZ 20 #define BANDWIDTH_100MHZ 100 /* PRB allocation as per 38.101, Section 5.3.2 */ #define TOTAL_PRB_20MHZ_MU0 106 #define TOTAL_PRB_100MHZ_MU1 273 +#ifdef NR_TDD +#define MAX_NUM_RB TOTAL_PRB_100MHZ_MU1 /* value for numerology 1, 100 MHz */ +#else +#define MAX_NUM_RB TOTAL_PRB_20MHZ_MU0 /* value for numerology 0, 20 MHz */ +#endif -#define ODU_THROUGHPUT_PRINT_TIME_INTERVAL 5 /* in milliseconds */ +#define ODU_UE_THROUGHPUT_PRINT_TIME_INTERVAL 5 /* in milliseconds */ +#define ODU_SNSSAI_THROUGHPUT_PRINT_TIME_INTERVAL 60000 /* in milliseconds */ /* Defining macros for common utility functions */ #define ODU_GET_MSG_BUF SGetMsg @@ -123,11 +133,15 @@ #define ODU_SET_THREAD_AFFINITY SSetAffinity #define ODU_CREATE_TASK SCreateSTsk +#define MAX_SYMB_PER_SLOT 14 + +/* Slice */ +#define SD_SIZE 3 + #ifdef NR_TDD /* Maximum slots for max periodicity and highest numerology is 320. * However, aligning to fapi_interface.h, setting this macro to 160 */ #define MAX_TDD_PERIODICITY_SLOTS 160 -#define MAX_SYMB_PER_SLOT 14 #endif #define GET_UE_IDX( _crnti,_ueIdx) \ @@ -176,6 +190,17 @@ _bitPos = __builtin_ctz(_in); \ } +/* MACRO for checking CRNTI range*/ +#define CHECK_CRNTI(_crnti, _isCrntiValid) \ +{ \ + _isCrntiValid = ((_crnti >= ODU_START_CRNTI && _crnti <= ODU_END_CRNTI ) ? 1 : 0); \ +} + +#define CHECK_LCID(_lcId, _isLcidValid) \ +{\ + _isLcidValid = ((_lcId >= SRB0_LCID && _lcId <= MAX_DRB_LCID) ? 1 : 0);\ +} + typedef enum { UE_CFG_INACTIVE, @@ -229,12 +254,21 @@ typedef enum CELL_DOWN }OduCellStatus; -typedef struct slotIndInfo + +typedef enum +{ + DIR_NONE, + DIR_UL, + DIR_DL, + DIR_BOTH +}Direction; + +typedef struct slotTimingInfo { uint16_t cellId; uint16_t sfn; uint16_t slot; -}SlotIndInfo; +}SlotTimingInfo; typedef struct PlmnIdentity { @@ -242,6 +276,12 @@ typedef struct PlmnIdentity uint8_t mnc[3]; }Plmn; +typedef struct snssai +{ + uint8_t sst; + uint8_t sd[SD_SIZE]; +}Snssai; + typedef struct oduCellId { uint16_t cellId; @@ -260,9 +300,17 @@ OduCellStatus gCellStatus; uint64_t gSlotCount; uint64_t gDlDataRcvdCnt; /* Number of DL data received at EGTP */ -void freqDomRscAllocType0(uint16_t startPrb, uint16_t prbSize, uint8_t *freqDomain); +void fillCoresetFeqDomAllocMap(uint16_t startPrb, uint16_t prbSize, uint8_t *freqDomain); void oduCpyFixBufToMsg(uint8_t *fixBuf, Buffer *mBuf, uint16_t len); uint8_t buildPlmnId(Plmn plmn, uint8_t *buf); +uint16_t fetchScsValue(uint8_t scsEnumValue); + +uint8_t SGetSBufNewForDebug(char *file, char *func, char *line, Region region, Pool pool, Data **ptr, Size size); +uint8_t SPutSBufNewForDebug(char *file, char *func, char *line, Region region, Pool pool, Data *ptr, Size size); +uint8_t SGetStaticBufNewForDebug(char *file, char *func, char *line, \ +Region region, Pool pool, Data **ptr, Size size, uint8_t memType); +uint8_t SPutStaticBufNewForDebug(char *file, char *func, char *line, \ +Region region, Pool pool, Data *ptr, Size size, uint8_t memType); #endif