a287413e4ceaae64fa2bd711716e97a1328ac36a
[o-du/l2.git] / src / 5gnrsch / sch_utils.h
1 /*******************************************************************************
2 ################################################################################
3 #   Copyright (c) [2017-2019] [Radisys]                                        #
4 #                                                                              #
5 #   Licensed under the Apache License, Version 2.0 (the "License");            #
6 #   you may not use this file except in compliance with the License.           #
7 #   You may obtain a copy of the License at                                    #
8 #                                                                              #
9 #       http://www.apache.org/licenses/LICENSE-2.0                             #
10 #                                                                              #
11 #   Unless required by applicable law or agreed to in writing, software        #
12 #   distributed under the License is distributed on an "AS IS" BASIS,          #
13 #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   #
14 #   See the License for the specific language governing permissions and        #
15 #   limitations under the License.                                             #
16 ################################################################################
17 *******************************************************************************/
18
19 #include <stdint.h>
20 #include <math.h>
21
22 /* Memory info */
23 #define SCH_MEM_REGION     4
24 #define SCH_POOL           1
25
26 /* macros */
27 #define MAX_CORESET_INDEX      16
28 #define MAX_SEARCH_SPACE_INDEX 16
29 #define MAX_RACH_NUM_RB_IDX    16
30 #define MAX_PUCCH_RES_SET_IDX  16
31 #define MAX_PRACH_CONFIG_IDX   256
32 #define MAX_MU_PUSCH           4
33 #define TOTAL_TBSIZE_VALUES    93
34
35 #define SET_BITS_MSB(_startBit, _numBits, _byte) \
36 {                                                \
37    _byte = (~((0xFF) >> _numBits));              \
38    _byte >>= _startBit;                          \
39 }
40
41 #define SET_BITS_LSB(_startBit, _numBits, _byte) \
42 {                                                \
43    _byte = (~((0xFF) << _numBits));              \
44    _byte <<= _startBit;                          \
45 }
46
47 /* allocate and zero out a static buffer */
48 #ifdef ODU_MEMORY_DEBUG_LOG
49 #define SCH_MEM_LOG(_macro, _file, _line, _func, _size, _datPtr)\
50 {\
51    printf("\n%s=== %s +%d, %s, %d, %p\n",           \
52          _macro, _file, _line, _func, _size, _datPtr); \
53 }
54 #else
55 #define SCH_MEM_LOG(_macro, _file, _line, _func, _size, _dataPtr) {}
56 #endif
57
58 #define SCH_ALLOC(_datPtr, _size)                               \
59 {                                                               \
60    uint8_t _ret;                                                    \
61    _ret = SGetSBuf(SCH_MEM_REGION, SCH_POOL,                    \
62           (Data **)&_datPtr, _size);                             \
63    if(_ret == ROK)                                              \
64    {  \
65       SCH_MEM_LOG("SCH_ALLOC", __FILE__, __LINE__, __FUNCTION__, _size, _datPtr);\
66       memset(_datPtr, 0, _size);                         \
67    }                                                            \
68    else                                                         \
69    {                                                            \
70       _datPtr = NULLP;                                          \
71    }                                                            \
72 }
73
74 /* free a static buffer */
75 #define SCH_FREE(_datPtr, _size)                                \
76 {                                                               \
77    if(_datPtr)                                                  \
78    {\
79       SCH_MEM_LOG("SCH_FREE", __FILE__, __LINE__, __FUNCTION__, _size, _datPtr);\
80       SPutSBuf(SCH_MEM_REGION, SCH_POOL,                        \
81             (Data *)_datPtr,(Size) _size);                            \
82       _datPtr = NULLP;                                          \
83    }                                                            \
84 }
85                           
86 /* Fill post structure for msg from SCH to MAC */
87 #define FILL_PST_SCH_TO_MAC(_pst, _inst)                     \
88 {                                                            \
89    _pst.srcProcId = ODU_GET_PROCID();                       \
90    _pst.dstProcId = ODU_GET_PROCID();                       \
91    _pst.srcEnt    = ENTMAC;                                  \
92    _pst.dstEnt    = ENTMAC;                                  \
93    _pst.srcInst   = 1;                                       \
94    _pst.dstInst   = 0;                                       \
95    _pst.selector  = ODU_SELECTOR_TC;                         \
96 }
97
98 int8_t coresetIdxTable[MAX_CORESET_INDEX][4];
99 int8_t searchSpaceIdxTable[MAX_SEARCH_SPACE_INDEX][4];
100
101 /* functions declarations */
102 void freqDomRscAllocType0(uint16_t startPrb, uint16_t prbSize, uint8_t *freqDomain);
103 uint16_t schCalcTbSize(uint32_t payLoadSize);
104 uint16_t schCalcNumPrb(uint16_t tbSize, uint16_t mcs, uint8_t numSymbols);
105 uint16_t schCalcTbSizeFromNPrb(uint16_t numPrb, uint16_t mcs, uint8_t numSymbols);
106 #ifdef NR_TDD
107 SlotConfig schGetSlotSymbFrmt(uint16_t slot, uint32_t bitMap);
108 #endif
109
110 /**********************************************************************
111   End of file
112  **********************************************************************/