X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=src%2Fdu_app%2Fdu_cfg.h;h=77af097781887849cfe42c0d92a6695f3725ce17;hb=deeae2741b8520edcd37ecb20a40f1de821ceadf;hp=91ecd45d73acf9a8e15536c587d0686be4607589;hpb=ef711b0830aedde36f4a1beceed146d08e77ce58;p=o-du%2Fl2.git diff --git a/src/du_app/du_cfg.h b/src/du_app/du_cfg.h index 91ecd45d7..77af09778 100644 --- a/src/du_app/du_cfg.h +++ b/src/du_app/du_cfg.h @@ -22,7 +22,7 @@ #include "stdbool.h" #include "du_app_mac_inf.h" #include "du_log.h" -#include "BIT_STRING.h" +#include "odu_common_codec.h" /* MACROS */ #define DU_INST 0 @@ -39,7 +39,7 @@ #define NR_CELL_ID 1 #define DU_NAME "ORAN_OAM_DU" #define CELL_TYPE SMALL -#define DUPLEX_MODE DUP_MODE_TDD +#define DUPLEX_MODE DUP_MODE_FDD #define DU_TAC 1 #define PLMN_MCC0 3 #define PLMN_MCC1 1 @@ -47,38 +47,85 @@ #define PLMN_MNC0 4 #define PLMN_MNC1 8 #define PLMN_MNC2 0 +#define PLMN_SIZE 3 #define NR_ARFCN 2079427 #define SUL_ARFCN 100 #define NR_FREQ_BAND 257 +#define NR_FREQ_BAND_IND 78 #define SUL_BAND 2 #define TIME_CFG 0 #define CARRIER_IDX 1 #define NUM_TX_ANT 2 #define NUM_RX_ANT 2 #define FREQ_SHIFT_7P5KHZ FALSE -#define SSB_PBCH_PWR 0 +#define SSB_PBCH_PWR -5 #define BCH_PAYLOAD MAC_GEN_FULL_PBCH_PAYLD -#define SUBCARRIER_SPACING 3 -#define PRB_OFFSET 0 -#define BETA_PSS BETA_PSS_0DB -#define SSB_PERIODICITTY SSB_PRDCTY_MS_20 -#define SSB_SUBCARRIER_OFFSET 0 +#define SUBCARRIER_SPACING 0 +#define SCS_CARRIER_BANDWIDTH 273 /* Subcarrier spacing- carrier bandwidth */ +#define OFFSET_TO_POINT_A 24 /* PRB Offset to Point A */ +#define BETA_PSS BETA_PSS_0DB +#define SSB_PERIODICITY 5 +#define SSB_SUBCARRIER_OFFSET 0 #define SSB_MULT_CARRIER_BAND FALSE #define MULT_CELL_CARRIER FALSE +#define FREQ_LOC_BW 1099 /* DL frequency location and bandwidth */ +#define UL_P_MAX 23 +#define BANDWIDTH 20 +/* MACRO defines for PRACH Configuration */ +#define PRACH_CONFIG_IDX 105 +#define PRACH_FREQ_START 0 #define PRACH_SEQ_LEN SHORT_SEQUENCE -#define PRACH_SUBCARRIER_SPACING 3 -#define PRACH_RESTRICTED_SET_CFG UNRESTRICTED +#define PRACH_SUBCARRIER_SPACING 1 +#define PRACH_RESTRICTED_SET_CFG 0 #define NUM_PRACH_FDM 1 -#define ROOT_SEQ_IDX 0 +#define ROOT_SEQ_IDX 139 #define NUM_ROOT_SEQ 1 -#define ZERO_CORRELATION_ZONE_CFG 2 -#define NUM_UNUSED_ROOT_SEQ 1 +#define ZERO_CORRELATION_ZONE_CFG 6 +#define NUM_UNUSED_ROOT_SEQ 0 #define UNUSED_ROOT_SEQ 1 -#define SSB_PER_RACH 3 +#define SSB_PER_RACH 1 #define PRACH_MULT_CARRIER_BAND FALSE +#define PRACH_PREAMBLE_RCVD_TGT_PWR -74 +#define NUM_RA_PREAMBLE 63 +#define RSRP_THRESHOLD_SSB 31 #define TDD_PERIODICITY TX_PRDCTY_MS_2P5 #define RSS_MEASUREMENT_UNIT DONT_REPORT_RSSI +#define RA_CONT_RES_TIMER 64 +#define RA_RSP_WINDOW 180 +#define PRACH_RESTRICTED_SET 0 /* Unrestricted */ + + +/* MACRCO Ddefine for PDCCH Configuration */ +#define PDCCH_CTRL_RSRC_SET_ZERO 13 /* Control resouce set zero */ +#define PDCCH_SEARCH_SPACE_ZERO 0 /* Search space zero */ +#define PDCCH_SEARCH_SPACE_ID 1 /* Common search space id */ +#define PDCCH_CTRL_RSRC_SET_ID 0 /* Control resource set id */ +#define PDCCH_SEARCH_SPACE_ID_SIB1 0 /* Search space id for sib1 */ +#define PDCCH_SEARCH_SPACE_ID_PAGING 1 /* Search space id for paging */ +#define PDCCH_SEARCH_SPACE_ID_RA 1 /* Search spaced id for random access */ +#define PDCCH_SERACH_SPACE_DCI_FORMAT 0 +#define SIB1_VALUE_TAG 10 + +/* MACRCO Ddefine for PDSCH Configuration */ +#define PDSCH_K0 0 +#define PDSCH_START_SYMB_AND_LEN 53 + +/* MACRO Define for PUSCH Configuration */ +#define PUSCH_K0 3 +#define PUSCH_START_SYMB_AND_LEN 55 +#define PUSCH_MSG3_DELTA_PREAMBLE 0 +#define PUSCH_P0_NOMINAL_WITH_GRANT -70 + +/* Macro define for PUCCH Configuration */ +#define PUCCH_RSRC_COMMON 0 +#define PUCCH_P0_NOMINAL -74 + +/* MACRO defines for TDD DL-UL Configuration */ +#define NUM_DL_SLOTS 3 +#define NUM_DL_SYMBOLS 12 +#define NUM_UL_SLOTS 1 +#define NUM_UL_SYMBOLS 0 #define DU_PROC 0 #define DU_INST 0 @@ -393,15 +440,9 @@ typedef struct f1ResetType }type; }F1ResetType; -typedef struct f1PLMN -{ - uint8_t mcc[3]; - uint8_t mnc[3]; -}PlmnId; - typedef struct nrEcgi { - PlmnId plmn; + Plmn plmn; uint16_t cellId; }NrEcgi; @@ -505,14 +546,14 @@ typedef struct f1TaiSliceSuppLst typedef struct f1SrvdPlmn { - PlmnId plmn; + Plmn plmn; F1TaiSliceSuppLst taiSliceSuppLst; }F1SrvdPlmn; typedef struct f1BrdcstPlmnInfo { - PlmnId plmn[MAX_PLMN]; /* PLMN id list */ - PlmnId extPlmn[MAX_PLMN]; /* Extended PLMN id list */ + Plmn plmn[MAX_PLMN]; /* PLMN id list */ + Plmn extPlmn[MAX_PLMN]; /* Extended PLMN id list */ uint16_t tac; /* 5GS-TAC */ uint32_t nrCellId; /* NR Cell id */ uint8_t ranac; /* RAN Area code */ @@ -521,18 +562,18 @@ typedef struct f1BrdcstPlmnInfo typedef struct f1CellInfo { NrEcgi nrCgi; /* Cell global Identity */ - uint32_t nrPci; /* Physical Cell Identity */ - PlmnId plmn[MAX_PLMN]; /* Available PLMN list */ - PlmnId extPlmn[MAX_PLMN]; /* Extended available PLMN list */ + uint32_t nrPci; /* Physical Cell Identity */ + Plmn plmn[MAX_PLMN]; /* Available PLMN list */ + Plmn extPlmn[MAX_PLMN]; /* Extended available PLMN list */ }F1CellInfo; typedef struct f1DuCellInfo { F1CellInfo cellInfo; /* cell info */ - uint16_t tac; /* tracking area code */ - uint16_t epsTac; /* Configured EPS TAC */ + uint16_t tac; /* tracking area code */ + uint16_t epsTac; /* Configured EPS TAC */ NrModeInfo f1Mode; /* NR mode info : FDD/TDD */ - uint8_t measTimeCfg; /* Measurement timing configuration */ + uint8_t measTimeCfg; /* Measurement timing configuration */ F1CellDir cellDir; /* Cell Direction */ F1CellType cellType; /* Cell Type */ F1BrdcstPlmnInfo brdcstPlmnInfo[MAXBPLMNNRMINUS1]; /* Broadcast PLMN Identity Info List */ @@ -541,7 +582,9 @@ typedef struct f1DuCellInfo typedef struct f1DuSysInfo { uint8_t *mibMsg; /* MIB message */ + uint16_t mibLen; uint8_t *sib1Msg; /* SIB1 message */ + uint16_t sib1Len; }F1DuSysInfo; typedef struct f1CuSysInfo @@ -666,7 +709,7 @@ typedef struct f1UacType /* Unified Access Class Assistance Information */ typedef struct f1UacAssistInfo { - PlmnId plmn[MAXNUMOFUACPLMN]; /* UAC PLMN list */ + Plmn plmn[MAXNUMOFUACPLMN]; /* UAC PLMN list */ F1UacType uacType[MAXNUMOFUACPERPLMN]; /* UAC Type list */ }F1UacAssistInfo; @@ -865,14 +908,14 @@ typedef struct f1EgtpParams typedef struct schedulerCfg { - uint8_t numTxAntPorts; /*!< Number of Tx antenna ports */ - uint8_t ulSchdType; /*!< Indicates which UL scheduler to use, range - * is 0..(number of schedulers - 1) */ - uint8_t dlSchdType; /*!< Indicates which DL scheduler to use, range - * is 0..(number of schedulers - 1) */ - uint8_t numCells; /*!< Max number of cells */ - uint8_t maxUlUePerTti; /*!< Max number of UE in UL per TTI */ - uint8_t maxDlUePerTti; /*!< Max number of UE in DL per TTI */ + uint8_t numTxAntPorts; /*!< Number of Tx antenna ports */ + uint8_t ulSchdType; /*!< Indicates which UL scheduler to use, range + * is 0..(number of schedulers - 1) */ + uint8_t dlSchdType; /*!< Indicates which DL scheduler to use, range + * is 0..(number of schedulers - 1) */ + uint8_t numCells; /*!< Max number of cells */ + uint8_t maxUlUePerTti; /*!< Max number of UE in UL per TTI */ + uint8_t maxDlUePerTti; /*!< Max number of UE in DL per TTI */ }SchedulerCfg; typedef struct mibParams @@ -887,29 +930,175 @@ typedef struct mibParams long intraFreqReselection; }MibParams; +typedef struct siSchedInfo +{ + long winLen; /* SI Window Length */ + long broadcastSta; /* Broadcast status */ + long preiodicity; /* si periodicity */ + long sibType; + long sibValTag; /* Value tag */ +}SiSchedInfo; + +typedef struct pdcchCfgCommon +{ + uint8_t present; + long ctrlRsrcSetZero; /* Control resource set zero */ + long searchSpcZero; /* Search space zero */ + long searchSpcId; /* Search space id */ + long ctrlRsrcSetId; /* Control resource set id */ + uint8_t monitorSlotPrdAndOffPresent; + long monitorSlotPrdAndOff; /* Monitoring slot periodicity and offset */ + uint8_t monitorSymbolsInSlot[2]; /* Monitoring symbols within slot */ + long numCandAggLvl1; /* Number of candiates at aggregation level 1 */ + long numCandAggLvl2; /* Number of candiates at aggregation level 2 */ + long numCandAggLvl4; /* Number of candiates at aggregation level 4 */ + long numCandAggLvl8; /* Number of candiates at aggregation level 8 */ + long numCandAggLvl16; /* Number of candiates at aggregation level 16 */ + uint8_t searchSpcType; /* Search Space type */ + uint8_t commSrchSpcDciFrmt; /* DCI format of common search space type */ + long searchSpcSib1; /* Id of serch space for SIB1 */ + long pagingSearchSpc; /* Id of search space for paging */ + long raSearchSpc; /* Id of search space for Random Access proc */ +}PdcchCfgCommon; + +typedef struct pdschCfgCommon +{ + uint8_t present; + long k0; + long mapType; /* Mapping Type */ + long startSymbAndLen; /* Start Symbol and Length */ +}PdschCfgCommon; + +typedef struct bcchCfg +{ + long modPrdCoeff; /* Modification period co-efficient */ +}BcchCfg; + +typedef struct pcchCfg +{ + long dfltPagingCycle; /* Default paging cycle */ + long nAndPagingFrmOffPresent; + long nAndPagingFrmOff; /* n and Paging Frame offset */ + long numPagingOcc; /* Number of paging occassions in paging frame */ +}PcchCfg; + +typedef struct scsSpecCarrier +{ + long scsOffset; /* Offset to point A considering subcarrier spacing */ + long scs; /* subcarrier spacing */ + long scsBw; /* Carrier bandwidth considering subcarrier spacing */ + +}ScsSpecCarrier; + +typedef struct dlCfgCommon +{ + long freqBandInd; /* Downlink frequency band indicator */ + long offsetToPointA; /* DL ofset to point A */ + long locAndBw; /* Frequency location and bandwidth */ + ScsSpecCarrier dlScsCarrier; /* SCS Specific carrier */ + PdcchCfgCommon pdcchCfg; + PdschCfgCommon pdschCfg; + BcchCfg bcchCfg; + PcchCfg pcchCfg; +}DlCfgCommon; + +typedef struct rachCfgCommon +{ + uint8_t present; + long prachCfgIdx; /* PRACH configuration index */ + long msg1Fdm; /* Num of PRACH transmission occassions */ + long msg1FreqStart; /* Offset of lowest msg1 transmission occassion */ + long zeroCorrZoneCfg; /* Zero correlation zone configuration */ + long preambleRcvdTgtPwr; /* Traget power level */ + long preambleTransMax; /* Max num of preamble transmission */ + long pwrRampingStep; /* Power ramping steps for PRACH */ + long raRspWindow; /* RA response window */ + long numRaPreamble; /* Total num of preamble used in random access */ + uint8_t ssbPerRachOccPresent; + long numSsbPerRachOcc; /* Numer of SSBs per RACH Occassion */ + long contResTimer; /* Contention resolution timer */ + long rsrpThreshSsb; + uint8_t rootSeqIdxPresent; + long rootSeqIdx; /* PRACH root sequence index */ + long msg1Scs; /* Msg1 subcarrier spacing */ + long restrictedSetCfg; /* Restricted set configuration */ +}RachCfgCommon; + +typedef struct puschCfgCommon +{ + uint8_t present; + long k2; + long mapType; + long startSymbAndLen; + long msg3DeltaPreamble; + long p0NominalWithGrant; +}PuschCfgCommon; + +typedef struct pucchCfgCommon +{ + uint8_t present; + long rsrcComm; + long grpHop; + long p0Nominal; +}PucchCfgCommon; + +typedef struct ulCfgCommon +{ + long pMax; /* Max UL transmission power that UE applies */ + long locAndBw; /* Frequency location and bandwidth */ + ScsSpecCarrier ulScsCarrier; /* SCS Specific carrier */ + RachCfgCommon rachCfg; + PuschCfgCommon puschCfg; + PucchCfgCommon pucchCfg; + long timeAlignTimerComm; +}UlCfgCommon; + +typedef struct tddUlDlCfgCommon +{ + long refScs; /* Reference subcarrier spacing */ + long txPrd; /* Transmission periodicity */ + long numDlSlots; + long numDlSymbols; + long numUlSlots; + long numUlSymbols; +}TddUlDlCfgCommon; + +typedef struct srvCellCfgCommSib +{ + DlCfgCommon dlCfg; + UlCfgCommon ulCfg; + uint8_t ssbPosInBurst; + long ssbPrdServingCell; + TddUlDlCfgCommon tddCfg; + long ssPbchBlockPwr; +}SrvCellCfgCommSib; + typedef struct sib1Params { - PlmnId plmn; + Plmn plmn; uint8_t tac; long ranac; uint8_t cellIdentity; long cellResvdForOpUse; + long connEstFailCnt; + long connEstFailOffValidity; + SiSchedInfo siSchedInfo; + SrvCellCfgCommSib srvCellCfgCommSib; }Sib1Params; typedef struct duCfgParams { - SctpParams sctpParams; /* SCTP Params */ - F1EgtpParams egtpParams; /* EGTP Params */ + SctpParams sctpParams; /* SCTP Params */ + F1EgtpParams egtpParams; /* EGTP Params */ uint32_t maxUe; uint32_t duId; uint8_t duName[CU_DU_NAME_LEN_MAX]; SchedulerCfg schedCfg; - F1DuSrvdCellInfo srvdCellLst[DU_MAX_CELLS]; /* Serving cell list *///TODO: this must be removed eventually - F1RrcVersion rrcVersion; /* RRC version */ - - MacCellCfg macCellCfg; /* MAC cell configuration */ - MibParams mibParams; /* MIB Params */ - Sib1Params sib1Params; /* SIB1 Params */ + F1DuSrvdCellInfo srvdCellLst[DU_MAX_CELLS]; /* Serving cell list *///TODO: this must be removed eventually + F1RrcVersion rrcVersion; /* RRC version */ + MacCellCfg macCellCfg; /* MAC cell configuration */ + MibParams mibParams; /* MIB Params */ + Sib1Params sib1Params; /* SIB1 Params */ }DuCfgParams; /*function declarations */