JIRA ID: ODUHIGH-314 : Time domain allocation for SSB in TDD mode
[o-du/l2.git] / src / cm / common_def.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 #ifndef __COMMON_DEF_H__
19 #define __COMMON_DEF_H__
20
21 #include <stdio.h>
22 #include <ctype.h>
23 #include <stdlib.h>
24 #include <string.h>
25 #include <stdbool.h>
26 #include <stdint.h>
27
28 #include "cm_mem.h"
29 #include "cm_math.h"
30 #include "envopt.h"
31 #include "envdep.h"
32 #include "envind.h"
33 #include "gen.h" 
34 #include "ssi.h" 
35 #include "cm5.h"
36 #include "cm_tkns.h"
37 #include "cm_mblk.h"
38 #include "cm_llist.h"
39 #include "cm_hash.h"
40 #include "cm_lte.h"
41 #include "cm_err.h"
42 #include "cm_tpt.h"
43 #include "cm.h"
44 #include "gen.x"           /* general */
45 #include "ssi.x"           /* system services */
46 #include "cm_math.x"
47 #include "cm_tpt.x"
48 #include "cm_tkns.x" 
49 #include "cm_mblk.x"
50 #include "cm_llist.x"
51 #include "cm5.x" 
52 #include "cm_hash.x"
53 #include "cm_lte.x"
54 #include "cm_lib.x"
55 #include "du_log.h"
56
57 #define RADIO_FRAME_DURATION 10 /* Time duration of a radio frame in ms */
58 /* MAX values */
59 #define MAX_NUM_CELL 1
60 #define MAX_NUM_UE   1
61 #define MAX_NUM_LC   11
62 #define MAX_NUM_SRB  3    /* Max. no of Srbs */
63 #define MAX_NUM_DRB  29   /* spec 38.331, maxDRB */
64
65 /* 5G ORAN phy delay */
66 #define PHY_DELTA 2
67
68  /* SELECTORS */ 
69 #define ODU_SELECTOR_LC 0
70 #define ODU_SELECTOR_TC 1
71 #define ODU_SELECTOR_LWLC 2
72
73 #define ODU_START_CRNTI   100
74 #define ODU_END_CRNTI     500
75
76 /* LCID */
77 #define SRB0_LCID  0
78 #define SRB1_LCID  1
79 #define SRB2_LCID  2
80 #define SRB3_LCID  3
81 #define MIN_DRB_LCID 4
82 #define MAX_DRB_LCID 32
83
84 #define FREQ_DOM_RSRC_SIZE  6      /* i.e. 6 bytes because Size of frequency domain resource is 45 bits */
85 #define PUCCH_FORMAT_0 0
86 #define PUCCH_FORMAT_1 1
87 #define PUCCH_FORMAT_2 2
88 #define PUCCH_FORMAT_3 3 
89 #define PUCCH_FORMAT_4 4
90
91 #define BANDWIDTH_20MHZ 20
92 #define BANDWIDTH_100MHZ 100
93
94 /* PRB allocation as per 38.101, Section 5.3.2 */
95 #define TOTAL_PRB_20MHZ_MU0 106
96 #define TOTAL_PRB_100MHZ_MU1 273
97
98 /* Defining macros for common utility functions */
99 #define ODU_GET_MSG_BUF SGetMsg
100 #define ODU_PUT_MSG_BUF SPutMsg
101 #define ODU_ADD_PRE_MSG_MULT SAddPreMsgMult
102 #define ODU_ADD_PRE_MSG_MULT_IN_ORDER SAddPreMsgMultInOrder
103 #define ODU_ADD_POST_MSG_MULT SAddPstMsgMult
104 #define ODU_START_TASK SStartTask
105 #define ODU_STOP_TASK SStopTask
106 #define ODU_ATTACH_TTSK SAttachTTsk
107 #define ODU_POST_TASK SPstTsk
108 #define ODU_COPY_MSG_TO_FIX_BUF SCpyMsgFix
109 #define ODU_COPY_FIX_BUF_TO_MSG SCpyFixMsg
110 #define ODU_REG_TTSK SRegTTsk
111 #define ODU_SET_PROC_ID SSetProcId
112 #define ODU_GET_MSG_LEN SFndLenMsg
113 #define ODU_EXIT_TASK SExitTsk
114 #define ODU_PRINT_MSG SPrntMsg
115 #define ODU_REM_PRE_MSG SRemPreMsg
116 #define ODU_REM_PRE_MSG_MULT SRemPreMsgMult
117 #define ODU_REG_TMR_MT SRegTmrMt
118 #define ODU_SEGMENT_MSG SSegMsg
119 #define ODU_CAT_MSG SCatMsg
120 #define ODU_GET_PROCID SFndProcId
121 #define ODU_SET_THREAD_AFFINITY SSetAffinity
122 #define ODU_CREATE_TASK SCreateSTsk
123
124 #ifdef NR_TDD
125 /* Maximum slots for max periodicity and highest numerology is 320.
126  * However, aligning to fapi_interface.h, setting this macro to 160 */
127 #define MAX_TDD_PERIODICITY_SLOTS 160 
128 #define MAX_SYMB_PER_SLOT 14 
129 #endif
130
131 #define GET_UE_IDX( _crnti,_ueIdx)         \
132 {                                          \
133    _ueIdx = _crnti - ODU_START_CRNTI + 1;  \
134 }
135
136 #define GET_CRNTI( _crnti,_ueIdx)          \
137 {                                          \
138    _crnti = _ueIdx + ODU_START_CRNTI - 1;  \
139 }
140
141 /* Calculates cellIdx from cellId */
142 #define GET_CELL_IDX(_cellId, _cellIdx)   \
143 {                                         \
144    _cellIdx = _cellId - 1;                \
145 }
146
147 #define SET_BITS_MSB(_startBit, _numBits, _byte) \
148 {                                                \
149    _byte = (~((0xFF) >> _numBits));              \
150        _byte >>= _startBit;                          \
151 }
152
153 #define SET_BITS_LSB(_startBit, _numBits, _byte) \
154 {                                                \
155    _byte = (~((0xFF) << _numBits));              \
156        _byte <<= _startBit;                          \
157 }
158
159 /* this MACRO set 1 bit at the bit position */
160 #define SET_ONE_BIT(_bitPos, _out)            \
161 {                                             \
162    _out = ((1<<_bitPos) | _out);              \
163 }
164
165 /* this MACRO un-set 1 bit at the bit position */
166 #define UNSET_ONE_BIT(_bitPos, _out)            \
167 {                                               \
168    _out = (~(1<<_bitPos) & _out);               \
169 }
170
171 /* this MACRO finds the index of the rightmost set bit */
172 #define GET_RIGHT_MOST_SET_BIT( _in,_bitPos)        \
173 {                                                \
174    _bitPos = __builtin_ctz(_in);                 \
175 }
176
177 typedef enum
178 {
179    UE_CFG_INACTIVE,
180    UE_CREATE_COMPLETE,
181    UE_RECFG_COMPLETE
182 }UeCfgState;
183
184 typedef enum
185 {
186    CONFIG_UNKNOWN,
187    CONFIG_ADD,
188    CONFIG_MOD,
189    CONFIG_DEL
190 }ConfigType;
191
192 #ifdef NR_TDD
193 typedef enum
194 {
195    DL_SLOT,
196    UL_SLOT,
197    FLEXI_SLOT
198 }SlotConfig;
199
200 typedef enum
201 {
202    TX_PRDCTY_MS_0P5,
203    TX_PRDCTY_MS_0P625,
204    TX_PRDCTY_MS_1,
205    TX_PRDCTY_MS_1P25,
206    TX_PRDCTY_MS_2,
207    TX_PRDCTY_MS_2P5,
208    TX_PRDCTY_MS_5,
209    TX_PRDCTY_MS_10
210 }DlUlTxPeriodicity;
211 #endif
212
213 typedef enum
214 {
215    SCS_15KHZ,
216    SCS_30KHZ,
217    SCS_60KHZ,
218    SCS_120KHZ,
219    SCS_240KHZ
220 }SCS;
221
222 typedef struct slotIndInfo
223 {
224    uint16_t cellId;
225    uint16_t sfn;
226    uint16_t slot;
227 }SlotIndInfo;
228
229 typedef struct PlmnIdentity
230 {
231    uint8_t mcc[3];
232    uint8_t mnc[3];
233 }Plmn;
234
235 typedef struct oduCellId
236 {
237    uint16_t cellId;
238 }OduCellId;
239
240 #ifdef NR_TDD
241 typedef struct tddCfg
242 {
243    bool               pres;
244    DlUlTxPeriodicity  tddPeriod;      /* DL UL Transmission periodicity */
245    SlotConfig         slotCfg[MAX_TDD_PERIODICITY_SLOTS][MAX_SYMB_PER_SLOT]; 
246 }TDDCfg;
247 #endif
248
249
250 uint64_t gSlotCount;
251 uint64_t gDlDataRcvdCnt;   /* Number of DL data received at EGTP */
252
253 void freqDomRscAllocType0(uint16_t startPrb, uint16_t prbSize, uint8_t *freqDomain);
254 void oduCpyFixBufToMsg(uint8_t *fixBuf, Buffer *mBuf, uint16_t len);
255 uint8_t buildPlmnId(Plmn plmn, uint8_t *buf);
256
257 #endif
258
259 /**********************************************************************
260   End of file
261 ***********************************************************************/