/******************************************************************************* ################################################################################ # Copyright (c) [2017-2019] [Radisys] # # # # Licensed under the Apache License, Version 2.0 (the "License"); # # you may not use this file except in compliance with the License. # # You may obtain a copy of the License at # # # # http://www.apache.org/licenses/LICENSE-2.0 # # # # Unless required by applicable law or agreed to in writing, software # # distributed under the License is distributed on an "AS IS" BASIS, # # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # # See the License for the specific language governing permissions and # # limitations under the License. # ################################################################################ *******************************************************************************/ /* This file contains all utility functions */ #if 0 #include #include #include #include #include #endif #include "du_mgr.h" #define DU_INST 0 #define DU_ID 1 #define DU_IP_V4_ADDR "168.168.31.12" #define CU_IP_V4_ADDR "168.168.31.57" #define DU_IP_V6_ADDR "0000:0000:0000:0000:0000:0000:0000:0001" #define DU_PORT 38472 #define CU_PORT 38472 #define NR_PCI 1 #define NR_CELL_ID 1 #define DU_NAME "Oran_OAM_DU" #define CELL_DIR UL_DL #define CELL_TYPE SMALL #define DUPLEX_MODE DUP_MODE_TDD #define DU_TAC 1 #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 NR_ARFCN 2079427 #define SUL_ARFCN 100 #define NR_FREQ_BAND 257 #define SUL_BAND 2 #define TIME_CFG 10 #define NR_RANAC 150 #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 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 SSB_MULT_CARRIER_BAND FALSE #define MULT_CELL_CARRIER FALSE #define PRACH_SEQ_LEN SHORT_SEQUENCE #define PRACH_SUBCARRIER_SPACING 3 #define PRACH_RESTRICTED_SET_CFG UNRESTRICTED #define NUM_PRACH_FDM 1 #define ROOT_SEQ_IDX 0 #define NUM_ROOT_SEQ 1 #define ZERO_CORRELATION_ZONE_CFG 2 #define NUM_UNUSED_ROOT_SEQ 1 #define UNUSED_ROOT_SEQ 1 #define SSB_PER_RACH 3 #define PRACH_MULT_CARRIER_BAND FALSE #define TDD_PERIODICITY TX_PRDCTY_MS_2P5 #define RSS_MEASUREMENT_UNIT DONT_REPORT_RSSI extern DuCfgParams ducfgparam; /* Filling Slot configuration as : * Slot Sym 0 Sym 1 Sym 2 Sym 3 Sym 4 Sym 5 Sym 6 Sym 7 Sym 8 Sym 9 Sym10 Sym11 Sym12 Sym13 * 0 DL DL DL DL DL DL DL DL DL DL DL DL DL DL * 1 DL DL DL DL DL DL DL DL DL DL DL DL DL DL * 2 DL DL DL DL DL DL DL DL DL DL DL DL DL DL * 3 DL DL DL DL DL DL DL DL DL DL GD GD GD UL * 4 UL UL UL UL UL UL UL UL UL UL UL UL UL UL */ /******************************************************************* * * @brief Fills the Slot configuration * * @details * * Function : fillSlotConfig * * Functionality:Fill the Slot configuration values * * @params[in] void * @return ROK - success * RFAILED - failure * * ****************************************************************/ void fillSlotConfig() { U8 slot; U8 symbol; for(slot = 0; slot <= 3; slot++) { for(symbol = 0; symbol < MAX_SYMB_PER_SLOT; symbol++) ducfgparam.clCellCfg.tddCfg.slotCfg[slot][symbol] = DL_SLOT; } ducfgparam.clCellCfg.tddCfg.slotCfg[3][10] = GUARD_SLOT; ducfgparam.clCellCfg.tddCfg.slotCfg[3][11] = GUARD_SLOT; ducfgparam.clCellCfg.tddCfg.slotCfg[3][12] = GUARD_SLOT; ducfgparam.clCellCfg.tddCfg.slotCfg[3][13] = UL_SLOT; for(symbol = 0; symbol < MAX_SYMB_PER_SLOT; symbol++) ducfgparam.clCellCfg.tddCfg.slotCfg[4][symbol] = UL_SLOT; } /******************************************************************* * * @brief Reads the CL Configuration. * * @details * * Function : readClCfg * * Functionality: * - Fills up the cell configuration for CL. * - Calls fillSlotConfig() * * @params[in] void * @return ROK - success * RFAILED - failure * * ****************************************************************/ /* This function is used to fill up the cell configuration for CL */ void readClCfg() { ducfgparam.clCellCfg.carrierId = CARRIER_IDX; /* Cell configuration */ ducfgparam.clCellCfg.cellId = NR_CELL_ID; ducfgparam.clCellCfg.phyCellId = NR_PCI; ducfgparam.clCellCfg.dupType = DUPLEX_MODE; /* DL carrier configuration */ ducfgparam.clCellCfg.dlCarrCfg.pres = TRUE; ducfgparam.clCellCfg.dlCarrCfg.bw = SUL_ARFCN; ducfgparam.clCellCfg.dlCarrCfg.freq = NR_ARFCN; ducfgparam.clCellCfg.dlCarrCfg.k0[0] = 1; ducfgparam.clCellCfg.dlCarrCfg.k0[1] = 1; ducfgparam.clCellCfg.dlCarrCfg.k0[2] = 1; ducfgparam.clCellCfg.dlCarrCfg.k0[3] = 1; ducfgparam.clCellCfg.dlCarrCfg.k0[4] = 1; ducfgparam.clCellCfg.dlCarrCfg.gridSize[0] = 1; ducfgparam.clCellCfg.dlCarrCfg.gridSize[1] = 1; ducfgparam.clCellCfg.dlCarrCfg.gridSize[2] = 1; ducfgparam.clCellCfg.dlCarrCfg.gridSize[3] = 1; ducfgparam.clCellCfg.dlCarrCfg.gridSize[4] = 1; ducfgparam.clCellCfg.dlCarrCfg.numAnt = NUM_TX_ANT; /* UL Carrier configuration */ ducfgparam.clCellCfg.ulCarrCfg.pres = TRUE; ducfgparam.clCellCfg.ulCarrCfg.bw = SUL_ARFCN; ducfgparam.clCellCfg.ulCarrCfg.freq = NR_ARFCN; ducfgparam.clCellCfg.ulCarrCfg.k0[0] = 1; ducfgparam.clCellCfg.ulCarrCfg.k0[1] = 1; ducfgparam.clCellCfg.ulCarrCfg.k0[2] = 1; ducfgparam.clCellCfg.ulCarrCfg.k0[3] = 1; ducfgparam.clCellCfg.ulCarrCfg.k0[4] = 1; ducfgparam.clCellCfg.ulCarrCfg.gridSize[0] = 1; ducfgparam.clCellCfg.ulCarrCfg.gridSize[1] = 1; ducfgparam.clCellCfg.ulCarrCfg.gridSize[2] = 1; ducfgparam.clCellCfg.ulCarrCfg.gridSize[3] = 1; ducfgparam.clCellCfg.ulCarrCfg.gridSize[4] = 1; ducfgparam.clCellCfg.ulCarrCfg.numAnt = NUM_RX_ANT; ducfgparam.clCellCfg.freqShft = FREQ_SHIFT_7P5KHZ; /* SSB configuration */ ducfgparam.clCellCfg.ssbCfg.ssbPbchPwr = SSB_PBCH_PWR; ducfgparam.clCellCfg.ssbCfg.bchPayload = BCH_PAYLOAD; ducfgparam.clCellCfg.ssbCfg.scsCmn = SUBCARRIER_SPACING; ducfgparam.clCellCfg.ssbCfg.ssbPrbOffset = PRB_OFFSET; ducfgparam.clCellCfg.ssbCfg.betaPss = BETA_PSS; ducfgparam.clCellCfg.ssbCfg.ssbPeriod = SSB_PERIODICITTY; ducfgparam.clCellCfg.ssbCfg.ssbSubcOffset = SSB_SUBCARRIER_OFFSET; ducfgparam.clCellCfg.ssbCfg.mibPdu = 104; ducfgparam.clCellCfg.ssbCfg.nSSBMask[0] = 2162721; ducfgparam.clCellCfg.ssbCfg.nSSBMask[1] = 0; ducfgparam.clCellCfg.ssbCfg.multCarrBand = SSB_MULT_CARRIER_BAND; ducfgparam.clCellCfg.ssbCfg.multCellCarr = MULT_CELL_CARRIER; /* PRACH configuration */ ducfgparam.clCellCfg.prachCfg.pres = TRUE; ducfgparam.clCellCfg.prachCfg.prachSeqLen = PRACH_SEQ_LEN; ducfgparam.clCellCfg.prachCfg.prachSubcSpacing = PRACH_SUBCARRIER_SPACING; ducfgparam.clCellCfg.prachCfg.prachRstSetCfg = PRACH_RESTRICTED_SET_CFG; ducfgparam.clCellCfg.prachCfg.prachFdm = NUM_PRACH_FDM; ducfgparam.clCellCfg.prachCfg.fdm[0].rootSeqIdx = ROOT_SEQ_IDX; ducfgparam.clCellCfg.prachCfg.fdm[0].numRootSeq = NUM_ROOT_SEQ; ducfgparam.clCellCfg.prachCfg.fdm[0].k1 = 1; ducfgparam.clCellCfg.prachCfg.fdm[0].zeroCorrZoneCfg = ZERO_CORRELATION_ZONE_CFG; ducfgparam.clCellCfg.prachCfg.fdm[0].numUnusedRootSeq = NUM_UNUSED_ROOT_SEQ; *(ducfgparam.clCellCfg.prachCfg.fdm[0].unsuedRootSeq) = UNUSED_ROOT_SEQ; ducfgparam.clCellCfg.prachCfg.ssbPerRach = SSB_PER_RACH; ducfgparam.clCellCfg.prachCfg.prachMultCarrBand = PRACH_MULT_CARRIER_BAND; /* TDD configuration */ ducfgparam.clCellCfg.tddCfg.pres = TRUE; ducfgparam.clCellCfg.tddCfg.tddPeriod = TDD_PERIODICITY; fillSlotConfig(); /* RSSI Measurement configuration */ ducfgparam.clCellCfg.rssiUnit = RSS_MEASUREMENT_UNIT; /* This should be calculated based on (number of mandatory parameters) + (number of otional parameters being filled) */ ducfgparam.clCellCfg.numTlv = 39; } /******************************************************************* * * @brief Configures the DU Parameters * * @details * * Function : readCfg * * Functionality: * - Initializes the DuCfg members. * - Calls readClCfg() * * @params[in] system task ID * @return ROK - success * RFAILED - failure * * ****************************************************************/ void readCfg() { U8 i,j,k; /* F1 DU IP Address and Port*/ ducfgparam.sctpParams.duIpAddr.ipV4Pres = TRUE; strcpy(ducfgparam.sctpParams.duIpAddr.ipV4Addr, (char*)DU_IP_V4_ADDR); ducfgparam.sctpParams.duIpAddr.ipV6Pres = FALSE; strcpy(ducfgparam.sctpParams.duIpAddr.ipV6Addr, (char*)DU_IP_V6_ADDR); ducfgparam.sctpParams.duPort = DU_PORT; /* F1 CU IP Address and Port*/ ducfgparam.sctpParams.cuIpAddr.ipV4Pres = TRUE; strcpy(ducfgparam.sctpParams.cuIpAddr.ipV4Addr, (char*)CU_IP_V4_ADDR); ducfgparam.sctpParams.cuIpAddr.ipV6Pres = FALSE; strcpy(ducfgparam.sctpParams.cuIpAddr.ipV6Addr, DU_IP_V6_ADDR); ducfgparam.sctpParams.cuPort = CU_PORT; /* DU Info */ ducfgparam.duId = DU_ID; strcpy(ducfgparam.duName,DU_NAME); for(i=0;i