[Issue-ID: ODUHIGH-388] PUSCH scheduling using K2
[o-du/l2.git] / src / du_app / du_cfg.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 #ifndef __DU_CONFIG_H_
20 #define __DU_CONFIG_H__
21
22 /* MACROS */
23 #define DU_INST 0
24 #define DU_ID 1
25
26 #ifndef O1_ENABLE
27
28 #define DU_IP_V4_ADDR "192.168.130.81"
29 #define CU_IP_V4_ADDR "192.168.130.82"
30 #define RIC_IP_V4_ADDR "192.168.130.80"
31 #define DU_PORT 38472
32 #define CU_PORT 38472
33 #define RIC_PORT 36421
34 #endif
35
36 #define DU_EGTP_PORT  39001
37 #define CU_EGTP_PORT  39002
38 #define NR_PCI 1
39 #define NR_CELL_ID 1
40
41 #define DU_NAME "ORAN_OAM_DU"
42 #define CELL_TYPE SMALL
43
44 //TODO: while testing for TDD, Mu1 and 100 MHz, this flag must be enabled
45 #ifdef NR_TDD
46 #define DUPLEX_MODE DUP_MODE_TDD
47 #define NR_NUMEROLOGY 1
48 #define NR_DL_ARFCN 623400
49 #define NR_UL_ARFCN 623400
50 #define NR_FREQ_BAND 78
51 #define NR_SCS SCS_30KHZ
52 #define NR_BANDWIDTH BANDWIDTH_100MHZ
53 #else
54 #define DUPLEX_MODE DUP_MODE_FDD
55 #define NR_NUMEROLOGY 0
56 #define NR_DL_ARFCN 428000
57 #define NR_UL_ARFCN 390000
58 #define NR_FREQ_BAND 1
59 #define NR_SCS SCS_15KHZ
60 #define NR_BANDWIDTH BANDWIDTH_20MHZ
61 #endif
62
63 #define DU_TAC 1
64 #define PLMN_MCC0 3
65 #define PLMN_MCC1 1
66 #define PLMN_MCC2 1
67 #define PLMN_MNC0 4
68 #define PLMN_MNC1 8
69 #define PLMN_MNC2 0
70 #define PLMN_SIZE 3
71
72 /* Spec 38.104 Table 5.4.2.3-1:Applicable NR-ARFCN per operating band in FR1 */
73 #define SUL_ARFCN 100
74 #define SUL_BAND 2
75
76 #define TIME_CFG 0
77 #define CARRIER_IDX 1
78 #define NUM_TX_ANT 2
79 #define NUM_RX_ANT 2
80 #define FREQ_SHIFT_7P5KHZ FALSE
81 #define SSB_PBCH_PWR 0
82 #define BCH_PAYLOAD PHY_GEN_TIMING_PBCH_BIT
83 #define NORMAL_CYCLIC_PREFIX 0
84 #define OFFSET_TO_POINT_A 24                     /* PRB Offset to Point A */
85 #define BETA_PSS BETA_PSS_0DB  
86 #define SSB_PERIODICITY_5MS   5
87 #define SSB_PERIODICITY_10MS  10
88 #define SSB_PERIODICITY_20MS  20
89 #define SSB_PERIODICITY_40MS  40
90 #define SSB_PERIODICITY_80MS  80
91 #define SSB_PERIODICITY_160MS 160
92 #define SSB_SUBCARRIER_OFFSET 0               
93 #define SSB_MULT_CARRIER_BAND FALSE
94 #define MULT_CELL_CARRIER FALSE
95 #define FREQ_LOC_BW  28875             /* DL frequency location and bandwidth. Spec 38.508 Table 4.3.1.0B-1*/
96 #define UL_P_MAX  23
97 #define DMRS_TYPE_A_POS 2
98 #define NUM_SYMBOLS_PER_SLOT 14       /* Number of symbols within a slot */
99 #define CORESET0_END_PRB   48
100 #define CORESET1_NUM_PRB   24
101
102 /* MACRO defines for PRACH Configuration */
103 #define PRACH_CONFIG_IDX   88
104 #define PRACH_MAX_PRB  24  /* As per (spec 38.211-Table 6.3.3.2-1), max allocated PRBs can go upto 24 */
105 #define PRACH_FREQ_START  (MAX_NUM_RB - PRACH_MAX_PRB) /* In order to allocate PRACH from end of the resource grid */
106 #define PRACH_SEQ_LEN SHORT_SEQUENCE
107 #define PRACH_SUBCARRIER_SPACING NR_SCS
108 #define PRACH_RESTRICTED_SET_CFG 0
109 #define NUM_PRACH_FDM 1
110 #define ROOT_SEQ_IDX 0
111 #define NUM_ROOT_SEQ 1
112 #define ZERO_CORRELATION_ZONE_CFG 4
113 #define NUM_UNUSED_ROOT_SEQ 0
114 #define UNUSED_ROOT_SEQ 1
115 #define SSB_PER_RACH 1
116 #define PRACH_MULT_CARRIER_BAND FALSE
117 #define PRACH_PREAMBLE_RCVD_TGT_PWR  -74   
118 #define NUM_RA_PREAMBLE  63
119 #define RSRP_THRESHOLD_SSB   31
120
121 #ifdef NR_TDD
122 #define TDD_PERIODICITY TX_PRDCTY_MS_5 
123 #endif
124
125 #define RSS_MEASUREMENT_UNIT DONT_REPORT_RSSI
126 #define RA_CONT_RES_TIMER 64
127 #define RA_RSP_WINDOW 10
128 #define PRACH_RESTRICTED_SET 0 /* Unrestricted */
129 #define ROOT_SEQ_LEN 139
130
131 /* MACRCO Ddefine for PDCCH Configuration */
132 #define PDCCH_SEARCH_SPACE_ID      1    /* Common search space id */
133 #define PDCCH_CTRL_RSRC_SET_ID     0    /* Control resource set id */
134 #define PDCCH_SEARCH_SPACE_ID_SIB1 1    /* Search space id for sib1 */
135 #define PDCCH_SEARCH_SPACE_ID_PAGING 1  /* Search space id for paging */
136 #define PDCCH_SEARCH_SPACE_ID_RA   1    /* Search spaced id for random access */
137 #define PDCCH_SERACH_SPACE_DCI_FORMAT 0
138 #define PDCCH_CTRL_RSRC_SET_ONE_ID  1
139 #define PDCCH_CTRL_RSRC_SET_ONE_DURATION 2  /* Duration for control resource set id i */
140 #define PDCCH_CTRL_RSRC_SET_ONE_PRECOD_GRANULARITY 1   /* Precoded granularity */
141 #define PDCCH_SRCH_SPC_TWO_ID 2
142 #define PDCCH_SRCH_SPC_TWO_AGG_LVL1_CANDIDATE 7   /* Num of candidate at aggregation level 1 */
143 #define PDCCH_SRCH_SPC_TWO_AGG_LVL2_CANDIDATE 7   /* Num of candidate at aggregation level 2 */
144 #define PDCCH_SRCH_SPC_TWO_AGG_LVL4_CANDIDATE 4   /* Num of candidate at aggregation level 4 */
145 #define PDCCH_SRCH_SPC_TWO_AGG_LVL8_CANDIDATE 2   /* Num of candidate at aggregation level 8 */
146 #define PDCCH_SRCH_SPC_TWO_AGG_LVL16_CANDIDATE 1  /* Num of candidate at aggregation level 16 */
147 #define PDCCH_SRCH_SPC_TWO_UE_SPEC_DCI_FORMAT  0  /* format 0-0 and 1-0 */
148 #define PDCCH_SYMBOL_WITHIN_SLOT 128     /* Symbol within Slot Value */
149
150
151 #define SIB1_VALUE_TAG 10
152
153 /* MACRO Ddefine for PDSCH Configuration */
154 #define PDSCH_K0_CFG1  0
155 #define PDSCH_K0_CFG2  1
156 #define PDSCH_START_SYMBOL  3
157 #define PDSCH_LENGTH_SYMBOL 11
158 #define PDSCH_RES_ALLOC_TYPE       1          /* Resource allocation type */
159 #define PDSCH_MAX_CODEWORD_SCH_BY_DCI 0       /* Max num of codewords scheduled by DCI */
160 #define PDSCH_RBG_SIZE   0                    /* 0: config1 */
161 #define PDSCH_NUM_HARQ_PROC 5
162
163 /* MACRO Define for PUSCH Configuration */
164 #define MAX_UL_ALLOC 16
165 #define PUSCH_K2_CFG1  4
166 #define PUSCH_K2_CFG2  5
167 #define PUSCH_START_SYMBOL  3
168 #define PUSCH_LENGTH_SYMBOL 11
169
170 #define PUSCH_MSG3_DELTA_PREAMBLE 0
171 #define PUSCH_P0_NOMINAL_WITH_GRANT -70
172 #define PUSCH_TRANSFORM_PRECODER    1      /* 1: Disabled */
173 #define PUSCH_MAX_MIMO_LAYERS       1
174 #define PUSCH_PROCESS_TYPE2_ENABLED false
175
176 /* Macro define for PUCCH Configuration */
177 #define PUCCH_RSRC_COMMON  0
178 #define PUCCH_GROUP_HOPPING 0 /* Neither sequence hopping nor group hopping */
179 #define PUCCH_P0_NOMINAL   -74
180
181 /* MACRO defines for TDD DL-UL Configuration */
182 #define NUM_DL_SLOTS 7
183 #define NUM_DL_SYMBOLS 12 
184 #define NUM_UL_SLOTS 2
185 #define NUM_UL_SYMBOLS 1
186 #define GUARD_SLOT_IDX 7
187
188 /* MACRO defines for SRC config */
189 #define SRS_RSRC_ID  1
190 #define SRS_RSET_ID  1
191 #define SRS_COMB_OFFSET_N2   0
192 #define SRS_CYCLIC_SHIFT_N2  0
193 #define SRS_FREQ_DOM_POS     0
194 #define SRS_FREQ_DOM_SHIFT   0
195 #define C_SRS 0
196 #define B_SRS 0
197 #define B_HOP 0
198 #define SRS_SEQ_ID 0
199 #define APERIODIC_SRS_RESRC_TRIGGER 1 
200
201 #define DU_PROC  0
202 #define DU_INST 0
203 #define DU_POOL  1
204 #define MAX_DU_PORT 2
205 #define F1_INTERFACE 0
206 #define E2_INTERFACE 1
207
208 #define SCTP_INST 0
209 #define EGTP_INST 0
210
211 /* Events */
212 #define EVTCFG 0
213
214 /* Macro definitions for F1 procedures */
215 #define CU_DU_NAME_LEN_MAX 30      /* Max length of CU/DU name string */
216 #define MAX_F1_CONNECTIONS 65536    /* Max num of F1 connections */
217 #define MAX_PLMN           1        /* Max num of broadcast PLMN ids */
218 #define MAXNRARFCN         3279165  /* Maximum values of NRAFCN */
219 #define MAX_NRCELL_BANDS   2       /* Maximum number of frequency bands */
220 #define MAX_NUM_OF_SLICE_ITEMS 1024     /* Maximum number of signalled slice support items */
221 #define MAX_BPLMN_NRCELL_MINUS_1   1       /* Maximum number of PLMN Ids broadcast in an NR cell minus 1 */
222 #define MAXNUMOFSIBTYPES   32       /* Maximum number of SIB types */
223 #define MAX_TNL_ASSOC      32       /* Max num of TNL Assoc between CU and DU */
224 #define MAXCELLINENB       256      /* Max num of cells served by eNB */
225 #define MAX_NUM_OF_UE_ID       65536    /* Max num of UEs served by DU */
226 #define MAXNUMOFUACPLMN    12       /* Maximum number of PLMN ids*/
227 #define MAXNUMOFUACPERPLMN 64       /* Maximum number of signalled categories per PLMN */
228 #define NR_RANAC           150      /* RANAC */
229 #define DEFAULT_CELLS      1        /* Max num of broadcast PLMN ids */
230 #define IE_EXTENSION_LIST_COUNT 1
231
232 /* Macro definitions for MIB/SIB1 */
233 #define SYS_FRAME_NUM 0
234 #define SPARE 0
235 #define SSB_SC_OFFSET 0
236 #define DU_RANAC 1
237 #define CELL_IDENTITY 32
238
239 /* Macro definitions for DUtoCuRrcContainer */
240 #define CELL_GRP_ID 1
241 #define SCH_REQ_ID  0
242 #define SR_PROHIBIT_TMR 5
243 #define SR_TRANS_MAX 2
244 #define PERIODIC_BSR_TMR 2
245 #define RETX_BSR_TMR     5
246 #define SR_DELAY_TMR     6
247 #define TAG_ID 0
248 #define TIME_ALIGNMENT_TMR 7
249 #define PHR_PERIODIC_TMR 7
250 #define PHR_PROHIBHIT_TMR 0
251 #define PHR_PWR_FACTOR_CHANGE 3
252 #define PHR_MODE_OTHER_CG 0
253 #define SN_FIELD_LEN 0
254 #define T_POLL_RETRANSMIT 8       /* Enum for 45ms */ 
255 #define T_POLL_RETRANSMIT_VAL 45  /* Value in ms */
256 #define POLL_PDU 0                /* Enum for 4 pdus */
257 #define POLL_PDU_VAL 4            /* Value of poll pdu */
258 #define POLL_BYTE 43              /* Enum for infinite poll bytes */
259 #define POLL_BYTE_VAL -1          /* Value for infinite poll byte */
260 #define MAX_RETX_THRESHOLD 5      /* Enum for 8 retransmissions */
261 #define MAX_RETX_THRESHOLD_VAL 8  /* Value for 8 retransmissions */
262 #define T_REASSEMBLY 8 /* enum for RE_ASM_40MS  */
263 #define T_REASSEMBLY_VAL 40 /* default re assembly timer */
264 #define T_STATUS_PROHIBHIT 7 /* enum for PROH_35MS */
265 #define T_STATUS_PROHIBHIT_VAL 35 /* default status prohibit timer */
266 #define MAC_LC_PRIORITY 1
267 #define PRIORTISIED_BIT_RATE 15
268 #define BUCKET_SIZE_DURATION 5
269 #define LC_GRP 0
270 #define P_NR_FR1 0
271 #define PDSCH_HARQ_ACK_CODEBOOK 1
272 #define SERV_CELL_IDX 0
273 #define RLM_SYNC_OUT_SYNC_THRESHOLD 0
274 #define ACTIVE_DL_BWP_ID 0
275 #define ACTIVE_UL_BWP_ID 0
276 #define SCRAMBLING_ID  NR_PCI
277 #define DMRS_ADDITIONAL_POS  0          /* DMRS Additional poistion */
278 #define RES_ALLOC_TYPE       1          /* Resource allocation type */
279
280 /* MACRO definitions for modulcation order */
281 #define MOD_ORDER_QPSK  2
282 #define MOD_ORDER_QAM16 4
283 #define MOD_ORDER_QAM64 6
284 #define MOD_ORDER_QAM256 8
285 #define PDSCH_MCS_INDEX 20  /* For 64QAM, valid mcs index: 17-28 in 38.214  - Table 5.1.3.1-1*/
286 #define PUSCH_MCS_INDEX 10  /* For 16QAM, valid mcs index: 10-16 in 38.214  - Table 5.1.3.1-1*/
287
288 /*VALID Tunnel ID*/
289 #define MIN_TEID 1   /*[Spec 29.281,Sec 5.1]: All Zero TEIDs are never assigned for setting up GTP-U Tunnel*/
290 #define MAX_TEID 10 /*[Spec 29.281]: Max limit is not mentioned but as per GTP-U Header Format, TEID occupies 4 octets */
291
292 /* Slice Ratio */
293 #define MAX_RATIO        30
294 #define MIN_RATIO        20
295 #define DEDICATED_RATIO  10
296 #define DEDICATED_SLICE_INDEX   1 
297 #define NUM_OF_SUPPORTED_SLICE  2
298
299 typedef enum
300 {
301    GNBDU,
302    GNBCU 
303 }F1Entity;
304
305 typedef enum
306 {
307    SERV_CELL_TO_MODIFY,
308    SERV_CELL_TO_DELETE
309 }ServCellAction;
310
311 typedef enum
312 {
313    UNSPECIFIED,
314    RL_FAILURE_RLC,
315    INVALID_CU_UE_F1AP_ID,
316    INVALID_DU_UE_F1AP_ID,
317    INTERACTION_WITH_OTHER_PROC,
318    INVALID_QCI_VALUE,
319    RADIO_RELATED_REASON,
320    INSUFFICIENT_RADIO_RESOURCE,
321    PROCEDURE_CANCELLED,
322    NORMAL_RELEASE,
323    UNAVAILABLE_CELL,
324    RL_FAILURE_OTHERS,
325    UE_ACCESS_REJECTED,
326    SLICE_RESOURCE_UNAVAILABLE,
327    AMF_ABNORMAL_RELEASE,
328    INVALID_PLMN
329 }RadioNwCause;
330
331 typedef enum
332 {
333    TRANS_CAUSE_UNSPECIFIED,
334    TRANSPORT_RESOURCE_UNAVAIL
335 }TransLayerCause;
336
337 typedef enum
338 {
339    TRANSFER_SYNTAX_ERR,
340    ABSTRACT_SYNTAX_ERR_REJECT,
341    ABSTRACT_SYNTAX_ERR_NOTIFY,
342    INCOMPATIBLE_MESSAGE,
343    SEMANTIC_ERROR,
344    ABSTRACT_SYNTAX_ERR_MSG_CONSTRUCT,
345    PROTOCOL_CAUSE_UNSPECIFIED
346 }ProtocolCause;
347
348 typedef enum
349 {
350    CONTROL_PROC_OVERLOAD,
351    INSUFF_USER_PLANE_RESOURCE,
352    HARDWARE_FAILURE,
353    O_AND_M_INTERVENTION,
354    MISC_CAUSE_UNSPECIFIED
355 }MiscCause;
356
357 typedef enum
358 {
359    ALL
360 }F1ResetAll;
361
362 typedef enum 
363 {
364    IN_SERVICE,
365    OUT_OF_SERVICE
366 }SrvState;
367
368 typedef enum
369 {
370    INITIATING_MSG,
371    SUCCESSFUL_OUTCOME,
372    UNSUCCESSFUL_OUTCOME
373 }F1TriggMsgVal;
374
375 typedef enum
376 {
377    CRIT_REJECT,
378    CRIT_IGNORE,
379    CRIT_NOTIFY
380 }F1ProcCritVal;
381
382 typedef enum
383 {
384    NOT_UNDERSTOOD,
385    MISSING_IE
386 }F1ErrorType;
387
388 typedef enum
389 {
390    SCS_15,
391    SCS_30,
392    SCS_60,
393    SCS_120
394 }F1NrScs;
395
396 typedef enum
397 {
398    NRB_11,
399    NRB_18,
400    NRB_24,
401    NRB_25,
402    NRB_31,
403    NRB_32,
404    NRB_38,
405    NRB_51,
406    NRB_52,
407    NRB_65,
408    NRB_66,
409    NRB_78,
410    NRB_79,
411    NRB_93,
412    NRB_106,
413    NRB_107,
414    NRB_121,
415    NRB_132,
416    NRB_133,
417    NRB_135,
418    NRB_160,
419    NRB_162,
420    NRB_189,
421    NRB_216,
422    NRB_217,
423    NRB_245,
424    NRB_264,
425    NRB_270,
426    NRB_273
427 }F1Nrb;
428
429 typedef enum
430 {
431    VERY_SMALL,
432    SMALL,
433    MEDIUM,
434    LARGE
435 }F1CellType;
436
437 typedef enum
438 {
439    DL,
440    UL,
441    DL_UL
442 }F1CellDir;
443
444 typedef enum
445 {
446    UE_USAGE,
447    NON_UE_USAGE,
448    BOTH
449 }F1AssocUsage;
450
451 typedef enum
452 {
453    BARRED,
454    NOT_BARRED
455 }CellBarred;
456
457 typedef enum
458 {
459    OFFER,
460    EXECUTION
461 }F1ReqType;
462
463 typedef enum
464 {
465    IGNORE_YES,
466    IGNORE_NO
467 }F1IgnoreReq;
468
469 typedef enum
470 {
471    OVERLOADED,
472    NOT_OVERLOADED
473 }F1GnbDuOvrloadInfo;
474
475 typedef enum
476 {
477    REJECT_RRC_CONN_NON_EMERG_MODT,
478    REJECT_RRC_CONN_SIGNALLING,
479    PERMIT_EMERG_SESSION_AND_MOBILE_TERM_SERVICE,
480    PERMIT_HIGH_PRIOR_SESSION_AND_MOBILE_TERM_SERVICE
481 }F1UacStandardAction;
482
483 typedef enum
484 {
485    PDSCH_MAPPING_TYPE_A,
486    PDSCH_MAPPING_TYPE_B,
487 }pdschMappingType;
488
489 typedef enum
490 {
491    PUSCH_MAPPING_TYPE_A,
492    PUSCH_MAPPING_TYPE_B,
493 }puschMappingType;
494
495 typedef struct f1RrcVersion
496 {
497    char    rrcVer[30];     /* Latest RRC Version */
498    uint32_t   extRrcVer;  /* Latest RRC version extended */
499 }F1RrcVersion;
500
501 typedef struct f1FailCause
502 {
503    union
504    {
505       RadioNwCause      radioNwCause;     /* Radio Network Layer Cause */
506       TransLayerCause   transLayerCause;  /* Transport Layer Cause */
507       ProtocolCause     protCause;        /* Protocol Cause */
508       MiscCause         miscCause;        /* Miscellaneous Cause */
509    }cause;
510 }F1FailCause;
511
512 typedef struct f1ProcCode
513 {
514    bool   pres;
515    uint8_t     value;
516 }F1ProcCode;
517
518 typedef struct f1TriggMsg
519 {
520    bool   pres;
521    F1TriggMsgVal   value;
522 }F1TriggMsg;
523
524 typedef struct f1ProcCrit
525 {
526    bool   pres;
527    F1ProcCritVal   value;
528 }F1ProcCrit;
529
530 typedef struct f1CritDignosIE
531 {
532    F1ProcCritVal   ieCritVal;
533    uint16_t             ieId;
534    F1ErrorType       type;
535 }F1CritDignosIE;
536
537 typedef struct f1CritDiagnostic
538 {
539    bool         pres;
540    F1ProcCode   procCode;      /* Procedure Code */
541    F1TriggMsg   triggeringMsg; /* Triggering Message */
542    F1ProcCrit   procCrit;      /* Criticality of Triggering msg/proc */
543    uint32_t          transId;
544    F1CritDignosIE diagnosIE;
545 }F1CritDiagnostic;
546
547 typedef struct f1FailureIE
548 {
549    uint32_t                transId;        /* Uniquely identify transaction */
550    F1FailCause        cause;          /* Failure cause */
551    uint8_t                 timeToWait;     /* Seconds to be waited before retry */
552    F1CritDiagnostic   critDiagnostic; /* Critical diagnostics */
553 }F1FailureIE;
554
555 typedef struct f1LogicalConnUeAssoc
556 {
557    uint32_t   gnbCuUeF1apId;
558    uint32_t   gnbDuUeF1apId;
559 }F1LogicalConnUeAssoc;
560
561 typedef struct f1ResetType
562 {
563    union
564    {
565       F1ResetAll             resetAll; /* Reset All */
566       F1LogicalConnUeAssoc   ueAssocLogicalConn[MAX_F1_CONNECTIONS]; /* In case of Partial Reset : UE associated logical F1 conn list*/
567    }type;
568 }F1ResetType;
569
570 typedef struct nrEcgi
571 {
572    Plmn  plmn;
573    uint16_t     cellId;
574 }NrEcgi;
575
576 typedef struct f1SibType
577 {
578    uint8_t   sibType;
579    uint8_t   sibMsg;
580    uint8_t   value;
581 }F1SibType;
582
583 typedef struct f1TxBw
584 {
585    F1NrScs   nrScs; /* NR subcarrier spacing */
586    F1Nrb     nrb;   /* Transmission bandwidth expressed in units of RBs */
587 }F1TxBw;
588
589 typedef struct f1SulInfo
590 {
591    uint32_t      sulArfcn; /* SUL ARFCN */
592    F1TxBw   sulTxBw;  /* SUL transmission bandwidth */ 
593 }F1SulInfo;
594
595 typedef struct f1FreqBand
596 {
597    uint16_t   nrFreqBand;
598    uint16_t   sulBand[MAX_NRCELL_BANDS];
599 }F1FreqBand;
600
601 typedef struct f1NrFreqInfo
602 {
603    uint32_t        nrArfcn;
604    F1SulInfo  sulInfo;
605    F1FreqBand freqBand[MAX_NRCELL_BANDS];
606 }F1NrFreqInfo;
607
608 typedef struct f1NrFddInfo
609 {
610    F1NrFreqInfo   ulNrFreqInfo;  /* UL NR Frequency Info */
611    F1NrFreqInfo   dlNrFreqInfo;  /* DL NR Frequency Info */
612    F1TxBw         ulTxBw;        /* UL Transmission bandwidth */
613    F1TxBw         dlTxBw;        /* DL Transmission bandwidth */
614 }F1NrFddInfo;
615
616 typedef struct f1NrTddInfo
617 {
618    F1NrFreqInfo   nrFreqInfo;   /* NR Frequency Info */
619    F1TxBw       nrTxBw;       /* NR Transmission Bandwidth */
620 }F1NrTddInfo;
621
622 typedef struct f1NrModeInfo
623 {
624    union
625    {
626       F1NrFddInfo  fdd;
627       F1NrTddInfo  tdd;
628    }mode;
629 }NrModeInfo;
630
631 typedef struct f1EutraFddInfo
632 {
633    uint16_t   ulOffset;   /* UL offset to Point A */
634    uint16_t   dlOffset;   /* DL offset to Point A */
635 }F1EutraFDDInfo;
636
637 typedef struct f1EutraTddInfo
638 {
639    uint16_t   tddOffset;  /* Offset to Point A */
640 }F1EutraTDDInfo;
641
642 typedef struct f1EutraModeInfo
643 {
644    union
645    {
646       F1EutraFDDInfo  fdd;
647       F1EutraTDDInfo  tdd;
648    }mode;
649 }F1EutraModeInfo;
650
651 typedef struct epIpAddr
652 {
653    char transportAddr[20]; /* Transport Layer Address */
654 }EpIpAddr;
655
656 typedef struct epIpAddrPort
657 {
658    EpIpAddr epIpAddr;
659    char   port[2];
660 }EpIpAddrPort;
661
662 typedef struct f1TaiSliceSuppLst
663 {
664    uint8_t    numSupportedSlices;
665    Snssai    **snssai;   
666 }F1TaiSliceSuppLst;
667
668 typedef struct f1SrvdPlmn
669 {
670    Plmn   plmn;
671    Plmn   extPlmn;    /* Extended available PLMN list */
672    F1TaiSliceSuppLst taiSliceSuppLst;
673 }F1SrvdPlmn;
674
675 typedef struct f1BrdcstPlmnInfo
676 {
677    Plmn   plmn[MAX_PLMN];     /* PLMN id list */
678    Plmn   extPlmn[MAX_PLMN];   /* Extended PLMN id list */
679    uint16_t      tac;                     /* 5GS-TAC */
680    uint32_t      nrCellId;                /* NR Cell id */
681    uint8_t       ranac;                   /* RAN Area code */
682 }F1BrdcstPlmnInfo;
683
684 typedef struct f1CellInfo
685 {
686    NrEcgi   nrCgi;                   /* Cell global Identity */
687    uint32_t nrPci;                   /* Physical Cell Identity */
688    F1SrvdPlmn srvdPlmn[MAX_PLMN];
689 }F1CellInfo;
690
691 typedef struct f1DuCellInfo
692 {
693    F1CellInfo         cellInfo;     /* cell info */
694    uint16_t           tac;          /* tracking area code */
695    uint16_t           epsTac;       /* Configured EPS TAC */
696    NrModeInfo         f1Mode;       /* NR mode info : FDD/TDD */
697    uint8_t            measTimeCfg;  /* Measurement timing configuration */
698    F1CellDir          cellDir;      /* Cell Direction */
699    F1CellType         cellType;     /* Cell Type */
700    F1BrdcstPlmnInfo   brdcstPlmnInfo[MAX_BPLMN_NRCELL_MINUS_1]; /* Broadcast PLMN Identity Info List */
701 }F1DuCellInfo;
702
703 typedef struct f1DuSysInfo
704 {
705    uint8_t   *mibMsg;   /* MIB message */
706    uint16_t  mibLen;
707    uint8_t   *sib1Msg;  /* SIB1 message */
708    uint16_t  sib1Len;
709 }F1DuSysInfo;
710
711 typedef struct f1CuSysInfo
712 {
713    F1SibType   sibTypeToUpd[MAXNUMOFSIBTYPES];   /* SIB types to be updated */
714 }F1CuSysInfo;
715
716 typedef struct f1DuSrvdCellInfo
717 {
718    F1DuCellInfo   duCellInfo;   /* gNB-DU served cell info */
719    F1DuSysInfo    duSysInfo;    /* gNB-DU System Information */
720 }F1DuSrvdCellInfo;
721
722 typedef struct f1DuSrvdCellToDel
723 {
724    NrEcgi             oldNrCgi;     /* Old NR CGI */
725    F1DuSrvdCellInfo   srvdCellInfo; /* Info of served cell to be deleted */ 
726 }F1DuSrvdCellToDel;
727
728 typedef struct f1CuActCellInfo
729 {
730    F1CellInfo    cuCellInfo;   /* gNB-CU available cell info */
731    F1CuSysInfo   cuSysInfo;    /* gNB-CU System Information */
732 }F1CuActCellInfo;
733
734 typedef struct f1ActCellFail
735 {
736    NrEcgi        nrCgi;
737    F1FailCause   cause;
738 }F1ActCellFail;
739
740 typedef struct srvStatus
741 {
742    SrvState    state;
743    bool        switchOffOngoing;
744 }SrvStatus;
745
746 typedef struct f1CellStatus
747 {
748    NrEcgi      nrEcgi;
749    SrvStatus   status;   /* Service status */
750 }F1CellStatus;
751
752 typedef struct f1DedSIDelUE
753 {
754    uint32_t      gnbCuUeF1apId;
755    NrEcgi   nrEcgi;
756 }F1DedSIDelUE;
757
758 typedef struct tnlAssocInfo
759 {
760    bool           pres;
761    EpIpAddr       epIpAddr;      /* Endpoint-IP Address */
762    EpIpAddrPort   epIpAddrport;  /* Endpoint-IP Address and Port */
763 }F1TnlAssocAddr;
764
765 typedef struct f1TnlAssocUsage
766 {
767    bool           pres;
768    F1AssocUsage   usage;
769 }F1TnlAssocUsage;
770
771 typedef struct f1TnlAssoc
772 {
773    F1TnlAssocAddr   assocInfo;    /* TNL Assoc Transport Layer Info */
774    F1TnlAssocUsage  assocUsage;   /* TNL Assoc usage */
775 }F1TnlAssoc;
776
777 typedef struct f1TnlAssocToRmv
778 {
779    F1TnlAssocAddr   assocInfoCu;   /* TNL Assoc Transport Layer Info of CU */
780    F1TnlAssocAddr   assocInfoDu;   /* TNL Assoc Transport Layer Info of DU */
781 }F1TnlAssocToRmv;
782
783 typedef struct f1TnlAssocSetupFail
784 {
785    F1TnlAssocAddr   assocInfo;
786    F1FailCause      cause;
787 }F1TnlAssocSetupFail;
788
789
790 typedef struct f1CellBarred
791 {
792    NrEcgi       nrcgi;
793    CellBarred   cellBarred;
794 }F1CellBarred;
795
796 typedef struct f1EutraCell
797 {
798    uint32_t                eutraCellId; /* EUTRA cell id */
799    F1EutraModeInfo    mode;        /* EUTRA mode info : FDD/TDD */
800    uint8_t                 rsrcInd;     /* Protected EUTRA resource Indication */
801 }F1EutraCell;
802
803 typedef struct f1ProtectEUTRARsrc
804 {
805    uint32_t           specShareGrpId;               /* Spectrum sharing group id */
806    F1EutraCell   eutraCellList[MAXCELLINENB];  /* EUTRA cells list */
807 }F1ProtectEUTRARsrc;
808
809 typedef struct f1UacOperatorDefined
810 {
811    uint8_t   accessCategory;
812    uint8_t   accessId; 
813 }F1UacOperatorDefined;
814
815 typedef struct f1UacCategoryType
816 {
817    union
818    {
819       F1UacStandardAction    action;      /* UAC standardized action */
820       F1UacOperatorDefined   operatorDef; /* UAC operator defined */
821    }type;
822 }F1UacCategoryType;
823
824 typedef struct f1UacType
825 {
826    uint8_t                  uacReducInd;     /* Value 0 means no access rate reduction. Value 100 means full access rate reduction */
827    F1UacCategoryType   uacCategoryType; /* UAC Category type */
828 }F1UacType;
829
830 /* Unified Access Class Assistance Information */
831 typedef struct f1UacAssistInfo
832 {
833    Plmn      plmn[MAXNUMOFUACPLMN];        /* UAC PLMN list */
834    F1UacType   uacType[MAXNUMOFUACPERPLMN];  /* UAC Type list */
835 }F1UacAssistInfo;
836
837 /* F1 setup related structures */
838 #if 0
839 typedef struct f1SetupReq
840 {
841    uint32_t                transId;                       /* Uniquely identify transaction */
842    uint32_t                duId;                          /* DU ID */ 
843    char               duName[CU_DU_NAME_LEN_MAX];    /* DU name */
844    F1DuSrvdCellInfo   srvdCellLst[MAX_NUM_CELL];   /* Serving cell list */
845    F1RrcVersion       rrcVersion;                    /* RRC version */
846 }F1SetupReq;
847
848 typedef struct f1setupRsp
849 {
850    uint32_t               transId;                      /* Uniquely identify transaction */
851    char              cuName[CU_DU_NAME_LEN_MAX];   /* CU Name */
852    F1CuActCellInfo   actCellInfo;                  /* cells to be activated */
853    F1RrcVersion      rrcVersion;                   /* RRC version */
854 }F1SetupRsp;
855
856 typedef struct f1SetupFail
857 {
858    F1FailureIE   setupFail;
859 }F1SetupFail;
860
861 /* At reception of the RESET message the gNB-DU shall release all allocated resources on F1 
862  * and radio resources related to the UE association(s) indicated explicitly or implicitly in 
863  * the RESET message and remove the indicated UE contexts including F1AP ID. */
864 typedef struct f1Reset
865 {
866    uint32_t              transId;   /* Uniquely identify transaction */
867    F1FailCause      cause;     /* Failure cause */
868    F1ResetType      resetType; /* type of reset */
869 }F1Reset;
870
871 /* After the gNB-CU has released all assigned F1 resources and the UE F1AP IDs for all indicated
872  * UE associations which can be used for new UE-associated logical F1-connections over the F1 interface,
873  *  the gNB-CU shall respond with the RESET ACKNOWLEDGE message. */
874 typedef struct f1ResetAck
875 {
876    uint32_t                    transId;         /* Uniquely identify transaction */
877    F1LogicalConnUeAssoc   ueAssocLogicalConn[MAX_F1_CONNECTIONS]; /* UE associated logical F1-connection list */
878    F1CritDiagnostic       critDiagnostic;  /* Critical diagnostics */
879 }F1ResetAck;
880
881 typedef struct f1ErrorInd
882 {
883    uint32_t                transId;         /* Uniquely identify transaction */
884    F1Entity           errorOrigin;     /* Specifies if error is originated at DU or CU */
885    F1FailCause        cause;           /* Failure cause */
886    /* If failure is due to Ue related message. */
887    uint32_t                gnbCuUeF1apId;   /* gNB-CU UE F1AP Id */
888    uint32_t                gnbDuUeF1apId;   /* gNB-DU UE F1AP Id */
889    F1CritDiagnostic   critDiagnostic;  /* Critical diagnostics */
890 }F1ErrorInd;
891
892 typedef struct f1GnbDuCfgUpd
893 {
894    uint32_t                 transId;                             /* Uniquely identify transaction */
895    F1DuSrvdCellInfo    srvdCellLstAdd[MAX_NUM_CELL];      /* Served cell list to be added */
896    F1DuSrvdCellToDel   srvdCellLstMod[MAX_NUM_CELL];      /* Served cell list to be modified */
897    NrEcgi              srvdCellLstDel[MAX_NUM_CELL];      /* Served cell list to be deleted */
898    F1CellStatus        cellStatus[MAX_NUM_CELL];          /* Cell status */
899    F1DedSIDelUE        ueLst[MAX_NUM_UE];                     /* Ue list that requires dedicated SI delivery */
900    uint32_t            gnbDuId;
901    F1TnlAssocToRmv     gnbDuTnlAssocRmv[MAX_TNL_ASSOC];  /* TNL Assoc list to remove */ 
902 }F1GnbDuCfgUpd;
903
904 typedef struct f1GnbDuCfgUpdAck
905 {
906    uint32_t           transId;                      /* Uniquely identify transaction */
907    F1CuActCellInfo    cellLstAct[MAX_NUM_CELL];    /* List of cells to be activated */   
908    F1CritDiagnostic   critDiagnostic;               /* Critical diagnostics */
909    NrEcgi             cellLstDeact[MAX_NUM_CELL]; /* List of cells to be deactivated */
910 }F1GnbDuCfgUpdAck;
911
912 typedef struct f1GnbDuCfgUpdFail
913 {
914    F1FailureIE   gnbDuCfgUpdFail;
915 }F1GnbDuCfgUpdFail;
916
917 /* Sent by the gNB-CU to transfer updated information associated to an F1-C interface instance */
918 typedef struct f1GnbCuCfgUpd
919 {
920    uint32_t            transId;                            /* Uniquely identifies transaction */
921    F1CuActCellInfo     cellLstAct[MAX_NUM_CELL];         /* List of cells to be activated */
922    NrEcgi              cellLstDeact[MAX_NUM_CELL];       /* List of cells to be deactivated */
923    F1TnlAssoc          assocLstAdd[MAX_TNL_ASSOC];     /* List of TNL assocs to be added */
924    F1TnlAssoc          assocLstUpd[MAX_TNL_ASSOC];     /* List of TNL assocs to be updated */
925    F1TnlAssocToRmv     assocLstRmv[MAX_TNL_ASSOC];     /* List of TNL assocs to be removed */
926    F1CellBarred        cellToBarList[MAX_NUM_CELL];      /* List of Cells to be barred */
927    F1ProtectEUTRARsrc  protectEutraRsrcList[MAXCELLINENB]; /* List of Protected EUTRA resources */
928 }F1GnbCuCfgUpd;
929
930 /* Sent by a gNB-DU to a gNB-CU to acknowledge update of information
931  * associated to an F1-C interface instance */
932 typedef struct f1GnbCuCfgUpdAck
933 {
934    uint32_t              transId;                              /* Uniquely identify transaction */
935    F1ActCellFail         actCellFailList[MAX_NUM_CELL];      /* Cells failed to be activated list */
936    F1CritDiagnostic      critDiagnostic;                       /* Critical diagnostics */
937    F1TnlAssocAddr        assocSetupList[MAX_TNL_ASSOC];     /* TNL Assoc Setup list */
938    F1TnlAssocSetupFail   assocSetupFailList[MAX_TNL_ASSOC]; /* TNL Assoc Setup fail list */
939    F1DedSIDelUE          dedSiDelUelist[MAX_NUM_OF_UE_ID];          /* Dedicated SI delivery needed UE list */
940 }F1GnbCuCfgUpdAck;
941
942 typedef struct f1GnbCuCfgUpdFail
943 {
944    F1FailureIE   gnbCuCfgUpdFail;
945 }F1GnbCuCfgUpdFail;
946
947 /* This procedure enables coordination of radio resource allocation between a gNB-CU and
948  * a gNB-DU. Coordination request is sent by CU to DU */
949 typedef struct f1GnbDuRsrcCoordReq
950 {
951    uint32_t      transId;              /* Uniquely identifies transaction */
952    F1ReqType     reqType;              /* Request type */
953    uint8_t       cellResCoordReqCont;  /* Container for X2AP E-UTRA - NR cell resource coordination request */
954    F1IgnoreReq   ignoreReq;            /* Ignore coordination request */
955 }F1GnbDuRsrcCoordReq;
956
957 /* This message is sent by a gNB-DU to a gNB-CU, to express the desired resource allocation
958  * for data traffic, as a response to the GNB-DU RESOURCE COORDINATION REQUEST. */
959 typedef struct f1GnbDuRsrcCoordRsp
960 {
961    uint32_t   transId;               /* Uniquely identifies transaction */
962    uint8_t    cellResCoordRspCont;   /* Container for X2AP E-UTRA - NR cell resource coordination response */
963 }F1GnbDuRsrcCoordRsp;
964
965 /* This message is sent by the gNB-DU to indicate to the gNB-CU its status of overload */
966 typedef struct f1GnbDuStatusInd
967 {
968    uint32_t                  transId;      /* Uniquely identifies transaction */
969    F1GnbDuOvrloadInfo   ovrloadInfo;  /* gNB-DU overloaded information */
970 }F1GnbDuStatusInd;
971
972 /* This message is sent by either the gNB-DU or the gNB-CU to intiate the removal
973  * of the interface instance and the related resources */
974 typedef struct f1RmvReq
975 {
976    uint32_t   transId; /* Uniquely identifies transaction */
977 }F1RmvReq;
978
979 /* This message acknowledges the initiation of removal of the interface
980  * instance and the related resources */
981 typedef struct f1RmvRsp
982 {
983    uint32_t           transId;     /* Uniquely identifies transaction */
984    F1CritDiagnostic   critDiagnos; /* Crititcality diagnostics */
985 }F1RmvRsp;
986
987 /* This message indicates that removing the interface instance and the related
988  * resources cannot be accepted */
989 typedef struct f1RmvFail
990 {
991    uint32_t           transId;         /* Uniquely identifies transaction */
992    F1FailCause        cause;          /* Failure cause */
993    F1CritDiagnostic   critDiagnostic; /* Criticality diagnostics */
994 }F1RmvFail;
995
996 /* This message is sent by the gNB-CU to indicate to the gNB-DU a need to reduce
997  * the rate at which UEs access the network. */
998 typedef struct f1NwkAccessRateRed
999 {
1000    uint32_t          transId;        /* Uniquely identifies transaction */
1001    F1UacAssistInfo   uacAssistInfo;  /* UAC Assistance Information */
1002 }F1NwkAccessRateRed;
1003 #endif
1004
1005 typedef struct f1Ipaddr
1006 {
1007    bool ipV4Pres;
1008    uint32_t  ipV4Addr; 
1009 }F1IpAddr;
1010
1011 typedef struct sctpParams
1012 {
1013    F1IpAddr  duIpAddr;
1014    uint16_t       duPort[MAX_DU_PORT];
1015    F1IpAddr  cuIpAddr;
1016    uint16_t       cuPort;
1017    F1IpAddr  ricIpAddr;
1018    uint16_t       ricPort;
1019 }SctpParams;
1020
1021 typedef struct f1EgtpParams
1022 {
1023    F1IpAddr  localIp;      /* Ip address of local node */
1024    uint16_t  localPort;    /* Sender Port at local node */
1025    F1IpAddr  destIp;       /* Ip address of peer node */
1026    uint16_t  destPort;     /* Sender port at peer node */
1027    uint32_t  minTunnelId;
1028    uint32_t  maxTunnelId;
1029 }F1EgtpParams;
1030
1031 typedef struct schedulerCfg
1032 {
1033    uint8_t   numTxAntPorts;    /*!< Number of Tx antenna ports */
1034    uint8_t   ulSchdType;     /*!< Indicates which UL scheduler to use, range
1035                               * is 0..(number of schedulers - 1) */
1036    uint8_t   dlSchdType;     /*!< Indicates which DL scheduler to use, range
1037                               * is 0..(number of schedulers - 1) */
1038    uint8_t   numCells;       /*!< Max number of cells */
1039    uint8_t   maxUlUePerTti;  /*!< Max number of UE in UL per TTI */
1040    uint8_t   maxDlUePerTti;  /*!< Max number of UE in DL per TTI */
1041 }SchedulerCfg;
1042
1043 typedef struct mibParams
1044 {
1045    uint8_t sysFrmNum;
1046    long    subCarrierSpacingCommon;
1047    long    ssb_SubcarrierOffset;
1048    long    dmrs_TypeA_Position;
1049    long    controlResourceSetZero;
1050    long    searchSpaceZero;
1051    long    cellBarred;
1052    long    intraFreqReselection;
1053 }MibParams;
1054
1055 typedef struct siSchedInfo
1056 {
1057    long     winLen;         /* SI Window Length */
1058    long     broadcastSta;   /* Broadcast status */
1059    long     preiodicity;    /* si periodicity */
1060    long     sibType;
1061    long     sibValTag;      /* Value tag */
1062 }SiSchedInfo;
1063
1064 typedef struct pdcchCfgCommon
1065 {
1066    uint8_t  present;
1067    long     ctrlRsrcSetZero;  /* Control resource set zero */
1068    long     searchSpcZero;    /* Search space zero */
1069    long     searchSpcId;      /* Search space id */
1070    long     ctrlRsrcSetId;    /* Control resource set id */
1071    uint8_t  monitorSlotPrdAndOffPresent;
1072    long     monitorSlotPrdAndOff;     /* Monitoring slot periodicity and offset */
1073    uint8_t  monitorSymbolsInSlot[2];  /* Monitoring symbols within slot */
1074    long     numCandAggLvl1;        /* Number of candiates at aggregation level 1 */
1075    long     numCandAggLvl2;        /* Number of candiates at aggregation level 2 */
1076    long     numCandAggLvl4;        /* Number of candiates at aggregation level 4 */
1077    long     numCandAggLvl8;        /* Number of candiates at aggregation level 8 */
1078    long     numCandAggLvl16;       /* Number of candiates at aggregation level 16 */
1079    uint8_t  searchSpcType;        /*  Search Space type */
1080    uint8_t  commSrchSpcDciFrmt;    /* DCI format of common search space type */
1081    long     searchSpcSib1;         /* Id of serch space for SIB1 */
1082    long     pagingSearchSpc;       /* Id of search space for paging */
1083    long     raSearchSpc;           /* Id of search space for Random Access proc */
1084 }PdcchCfgCommon;
1085
1086 typedef struct pdschTimeDomainRsrcAlloc
1087 {
1088    long     k0;
1089    long     mapType;              /* Mapping Type */
1090    uint16_t sliv;  
1091 }PdschTimeDomainRsrcAlloc;
1092
1093 typedef struct pdschCfgCommon
1094 {
1095    uint8_t  present;
1096    uint8_t  numTimeDomRsrcAlloc;
1097    PdschTimeDomainRsrcAlloc timeDomAlloc[MAX_NUM_DL_ALLOC];
1098 }PdschCfgCommon;
1099
1100 typedef struct bcchCfg
1101 {
1102    long   modPrdCoeff;          /* Modification period co-efficient */
1103 }BcchCfg;
1104
1105 typedef struct pcchCfg
1106 {
1107    long   dfltPagingCycle;      /* Default paging cycle */
1108    long   nAndPagingFrmOffPresent;
1109    long   nAndPagingFrmOff;     /* n and Paging Frame offset */
1110    long   numPagingOcc;         /* Number of paging occassions in paging frame */
1111 }PcchCfg;
1112
1113 typedef struct scsSpecCarrier
1114 {
1115    long   scsOffset;    /* Offset to point A considering subcarrier spacing */
1116    long   scs;          /* subcarrier spacing */
1117    long   scsBw;        /* Carrier bandwidth considering subcarrier spacing */
1118
1119 }ScsSpecCarrier;
1120
1121 typedef struct dlCfgCommon
1122 {
1123    long   freqBandInd;  /* Downlink frequency band indicator */
1124    long   offsetToPointA;       /* DL ofset to point A */
1125    long   locAndBw;     /* Frequency location and bandwidth */
1126    ScsSpecCarrier   dlScsCarrier;  /* SCS Specific carrier */
1127    PdcchCfgCommon   pdcchCfg;
1128    PdschCfgCommon   pdschCfg;
1129    BcchCfg          bcchCfg;
1130    PcchCfg          pcchCfg;
1131 }DlCfgCommon;
1132
1133 typedef struct rachCfgCommon
1134 {
1135    uint8_t present;
1136    long   prachCfgIdx;       /* PRACH configuration index */
1137    long   msg1Fdm;           /* Num of PRACH transmission occassions */
1138    long   msg1FreqStart;     /* Offset of lowest msg1 transmission occassion */
1139    long   zeroCorrZoneCfg;   /* Zero correlation zone configuration */
1140    long   preambleRcvdTgtPwr; /* Traget power level */
1141    long   preambleTransMax;  /* Max num of preamble transmission */
1142    long   pwrRampingStep;    /* Power ramping steps for PRACH */
1143    long   raRspWindow;       /* RA response window */
1144    long   numRaPreamble;     /* Total num of preamble used in random access */
1145    uint8_t ssbPerRachOccPresent;
1146    long   numSsbPerRachOcc;  /* Numer of SSBs per RACH Occassion */
1147    long   contResTimer;      /* Contention resolution timer */
1148    long   rsrpThreshSsb;
1149    uint8_t rootSeqIdxPresent;
1150    long   rootSeqIdx;        /* PRACH root sequence index */
1151    long   msg1Scs;           /* Msg1 subcarrier spacing */
1152    long   restrictedSetCfg;  /* Restricted set configuration */
1153 }RachCfgCommon;
1154
1155 typedef struct puschCfgCmnTimeDomAlloc
1156 {
1157    long     k2;
1158    long     mapType;
1159    uint16_t sliv;
1160 }PuschCfgCmnTimeDomAlloc;
1161
1162 typedef struct  puschCfgCommon
1163 {
1164    uint8_t  puschCfgPresent;
1165    uint8_t  numTimeDomRsrcAlloc;
1166    PuschCfgCmnTimeDomAlloc timeDomAllocList[MAX_UL_ALLOC];
1167    long     msg3DeltaPreamble;
1168    long     p0NominalWithGrant;
1169 }PuschCfgCommon;
1170
1171 typedef struct pucchCfgCommon
1172 {
1173    uint8_t present;
1174    long   rsrcComm;
1175    long   grpHop;
1176    long   p0Nominal;
1177 }PucchCfgCommon;
1178
1179 typedef struct ulCfgCommon
1180 {
1181    long   pMax;         /* Max UL transmission power that UE applies */
1182    long   locAndBw;     /* Frequency location and bandwidth */
1183    ScsSpecCarrier   ulScsCarrier; /* SCS Specific carrier */
1184    RachCfgCommon    rachCfg;
1185    PuschCfgCommon   puschCfg;
1186    PucchCfgCommon   pucchCfg;
1187    long   timeAlignTimerComm;
1188 }UlCfgCommon;
1189
1190 typedef struct tddUlDlCfgCommon
1191 {
1192    long   refScs;     /* Reference subcarrier spacing */
1193    long   txPrd;      /* Transmission periodicity */
1194    long   numDlSlots;
1195    long   numDlSymbols;
1196    long   numUlSlots;
1197    long   numUlSymbols;
1198 }TddUlDlCfgCommon;
1199
1200 typedef struct srvCellCfgCommSib
1201
1202    DlCfgCommon        dlCfg;
1203    UlCfgCommon        ulCfg;
1204    uint8_t            ssbPosInBurst;
1205    long               ssbPrdServingCell;
1206    TddUlDlCfgCommon   tddCfg;
1207    long               ssPbchBlockPwr;
1208 }SrvCellCfgCommSib;
1209
1210 typedef struct sib1Params
1211 {
1212    Plmn    plmn;
1213    uint8_t   tac;
1214    long      ranac;
1215    uint8_t   cellIdentity;
1216    long      cellResvdForOpUse;
1217    long      connEstFailCnt;
1218    long      connEstFailOffValidity;
1219    SiSchedInfo           siSchedInfo;
1220    SrvCellCfgCommSib     srvCellCfgCommSib;
1221 }Sib1Params;
1222
1223 typedef struct duCfgParams
1224 {
1225    SctpParams         sctpParams;                  /* SCTP Params */
1226    F1EgtpParams       egtpParams;                  /* EGTP Params */
1227    uint32_t           maxUe;
1228    uint32_t           duId;
1229    uint8_t            duName[CU_DU_NAME_LEN_MAX];
1230    SchedulerCfg       schedCfg;
1231    F1DuSrvdCellInfo   srvdCellLst[MAX_NUM_CELL];  /* Serving cell list *///TODO: this must be removed eventually
1232    F1RrcVersion       rrcVersion;                 /* RRC version */
1233    MacCellCfg          macCellCfg;                    /* MAC cell configuration */
1234    MibParams          mibParams;                  /* MIB Params */
1235    Sib1Params         sib1Params;                 /* SIB1 Params */
1236 }DuCfgParams;
1237
1238 /*function declarations */
1239 void FillSlotConfig();
1240 uint8_t readClCfg();
1241 uint8_t readCfg();
1242 uint8_t duReadCfg(); 
1243 uint16_t calcSliv(uint8_t startSymbol, uint8_t lengthSymbol);
1244
1245 #endif /* __DU_CONFIG_H__ */
1246
1247 /**********************************************************************
1248   End of file
1249  **********************************************************************/