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