51fece286718b7c68957e021cbaaba0595373592
[o-du/l2.git] / src / cm / mac_sch_interface.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 /* events */
20 #define EVENT_SCH_GEN_CFG            1
21 #define EVENT_SCH_CELL_CFG           2
22 #define EVENT_SCH_CELL_CFG_CFM       3
23 #define EVENT_DL_SCH_INFO            4 
24 #define EVENT_UL_SCH_INFO            5 
25 #define EVENT_RACH_IND_TO_SCH        6
26 #define EVENT_CRC_IND_TO_SCH         7
27 #define EVENT_DL_RLC_BO_INFO_TO_SCH  8
28 #define EVENT_ADD_UE_CONFIG_REQ_TO_SCH   9
29 #define EVENT_UE_CONFIG_RSP_TO_MAC   10
30 #define EVENT_SLOT_IND_TO_SCH        11
31 #define EVENT_SHORT_BSR              12
32 #define EVENT_UCI_IND_TO_SCH         13
33 #define EVENT_MODIFY_UE_CONFIG_REQ_TO_SCH 14
34 #define EVENT_UE_RECONFIG_RSP_TO_MAC 15
35 #define EVENT_UE_DELETE_REQ_TO_SCH   16
36 #define EVENT_UE_DELETE_RSP_TO_MAC   17
37 #define EVENT_CELL_DELETE_REQ_TO_SCH 18
38 #define EVENT_CELL_DELETE_RSP_TO_MAC 19
39 #define EVENT_LONG_BSR               20
40 #define EVENT_SLICE_CFG_REQ_TO_SCH   21
41 #define EVENT_SLICE_CFG_RSP_TO_MAC   22
42 #define EVENT_SLICE_RECFG_REQ_TO_SCH 23
43 #define EVENT_SLICE_RECFG_RSP_TO_MAC 24
44 #define EVENT_RACH_RESOURCE_REQUEST_TO_SCH 25
45 #define EVENT_RACH_RESOURCE_RESPONSE_TO_MAC 26
46 #define EVENT_PAGING_IND_TO_SCH 27
47
48 /*macros*/
49 #define MAX_SSB_IDX 1 /* forcing it as 1 for now. Right value is 64 */
50 #define SCH_SSB_MASK_SIZE   1
51
52 #define MAX_NUM_PRG     1 /* max value should be later 275 */
53 #define MAX_DIG_BF_INTERFACES 0 /* max value should be later 255 */
54 #define MAX_CODEWORDS  1  /* max should be 2 */
55 #define SCH_HARQ_PROC_ID 1 /* harq proc id */
56 #define SCH_ALLOC_TYPE_1 1 /*sch res alloc type */
57
58 /* Datatype in UL SCH Info */
59 #define SCH_DATATYPE_PUSCH 1
60 #define SCH_DATATYPE_PUSCH_UCI 2
61 #define SCH_DATATYPE_UCI 4
62 #define SCH_DATATYPE_SRS 8
63 #define SCH_DATATYPE_PRACH 16
64
65 #define MAX_NUMBER_OF_CRC_IND_BITS 1
66 #define MAX_NUMBER_OF_UCI_IND_BITS 1
67 #define MAX_SR_BITS_IN_BYTES       1
68 #define MAX_NUM_LOGICAL_CHANNEL_GROUPS 8
69 #define MAX_NUM_SR_CFG_PER_CELL_GRP 8   /* Max number of scheduling request config per cell group */
70 #define MAX_NUM_TAGS 4                  /* Max number of timing advance groups */
71 #define MAX_NUM_BWP  4                  /* Max number of BWP per serving cell */
72 #define MAX_NUM_CRSET  3                /* Max number of control resource set in add/modify/release list */
73 #define MAX_NUM_SEARCH_SPC  10          /* Max number of search space in add/modify/release list */
74 #define FREQ_DOM_RSRC_SIZE  6           /* i.e. 6 bytes because Size of frequency domain resource is 45 bits */
75 #define MONITORING_SYMB_WITHIN_SLOT_SIZE 2  /* i.e. 2 bytes because size of monitoring symbols within slot is 14 bits */
76 #define MAX_NUM_DL_ALLOC 16             /* Max number of pdsch time domain downlink allocation */
77 #define MAX_NUM_UL_ALLOC 16             /* Max number of pusch time domain uplink allocation */
78
79 /* PUCCH Configuration Macro */
80 #define MAX_NUM_PUCCH_RESRC 128
81 #define MAX_NUM_PUCCH_RESRC_SET 4
82 #define MAX_NUM_PUCCH_PER_RESRC_SET 32
83 #define MAX_NUM_SPATIAL_RELATIONS 8
84 #define MAX_NUM_PUCCH_P0_PER_SET 8
85 #define MAX_NUM_PATH_LOSS_REF_RS 4
86 #define MAX_NUM_DL_DATA_TO_UL_ACK 15
87 #define QPSK_MODULATION 2
88
89 #define RAR_PAYLOAD_SIZE 10             /* As per spec 38.321, sections 6.1.5 and 6.2.3, RAR PDU is 8 bytes long and 2 bytes of padding */
90 #define TX_PAYLOAD_HDR_LEN 32           /* Intel L1 requires adding a 32 byte header to transmitted payload */
91 #define UL_TX_BUFFER_SIZE 5
92
93 #define MAX_NUM_CONFIG_SLOTS 160  /*Max number of slots as per the numerology*/
94 #define MAX_NUM_K0_IDX 16 /* Max number of pdsch time domain downlink allocation */
95 #define MAX_NUM_K1_IDX 8  /* As per spec 38.213 section 9.2.3 Max number of PDSCH-to-HARQ resource indication */
96 #define MIN_NUM_K1_IDX 4  /* Min K1 values */
97 #define MAX_NUM_K2_IDX 16 /* PUSCH time domain UL resource allocation list */
98 #define DEFAULT_K0_VALUE 0 /* As per 38.331, PDSCH-TimeDomainResourceAllocation field descriptions */
99 /* As per 38.331, PUSCH-TimeDomainResourceAllocationList field descriptions */
100 #define DEFAULT_K2_VALUE_FOR_SCS15  1 
101 #define DEFAULT_K2_VALUE_FOR_SCS30  1 
102 #define DEFAULT_K2_VALUE_FOR_SCS60  2
103 #define DEFAULT_K2_VALUE_FOR_SCS120 3 
104
105 #define ADD_DELTA_TO_TIME(crntTime, toFill, incr)          \
106 {                                                          \
107    if ((crntTime.slot + incr) > (MAX_SLOTS - 1))           \
108    {                                                       \
109       toFill.sfn = (crntTime.sfn + 1);                     \
110    }                                                       \
111    else                                                    \
112    {                                                       \
113       toFill.sfn = crntTime.sfn;                           \
114    }                                                       \
115    toFill.slot = (crntTime.slot + incr) % MAX_SLOTS;       \
116    if (toFill.sfn >= MAX_SFN)                              \
117    {                                                       \
118       toFill.sfn%=MAX_SFN;                                 \
119    }                                                       \
120 }
121
122 typedef enum
123 {
124    PRB_RSRC,
125    DRB_RSRC,
126    RRC_CONNECTED_USERS_RSRC
127 }SchResourceType;
128
129 typedef enum
130 {
131    SLICE_FOUND,
132    SLICE_NOT_FOUND
133 }RspCause;
134
135 typedef enum
136 {
137    NO_TRANSMISSION,
138    NEW_TRANSMISSION,
139    REPEATITION 
140 }PduTxOccsaion;
141
142 typedef enum
143 {
144    UNSPECIFIED_CAUSE,
145    INVALID_PARAM_VALUE,
146    RESOURCE_UNAVAILABLE,
147    SYSTEM_ERROR
148 }SchFailureCause;
149
150 typedef enum
151 {
152    SR_PROHIBIT_MS1,
153    SR_PROHIBIT_MS2,
154    SR_PROHIBIT_MS4,
155    SR_PROHIBIT_MS8,
156    SR_PROHIBIT_MS16,
157    SR_PROHIBIT_MS32,
158    SR_PROHIBIT_MS64,
159    SR_PROHIBIT_MS128
160 }SchSrProhibitTimer;
161
162 typedef enum
163 {
164    NOT_APPLICABLE,
165    INVALID_CELLID,
166    INVALID_UEID
167 }ErrorCause;
168
169 typedef enum
170 {
171    SR_TRANS_MAX_N4,
172    SR_TRANS_MAX_N8,
173    SR_TRANS_MAX_N16,
174    SR_TRANS_MAX_N32,
175    SR_TRANS_MAX_N64,
176    SR_TRANS_MAX_SPARE3,
177    SR_TRANS_MAX_SPARE2,
178    SR_TRANS_MAX_SPARE1
179 }SchSrTransMax;
180
181 typedef enum
182 {
183    TIME_ALIGNMENT_TIMER_MS500,
184    TIME_ALIGNMENT_TIMER_MS750,
185    TIME_ALIGNMENT_TIMER_MS1280,
186    TIME_ALIGNMENT_TIMER_MS1920,
187    TIME_ALIGNMENT_TIMER_MS2560,
188    TIME_ALIGNMENT_TIMER_MS5120,
189    TIME_ALIGNMENT_TIMER_MS10240,
190    TIME_ALIGNMENT_TIMER_INFINITE
191 }SchTimeAlignmentTimer;
192
193 typedef enum
194 {
195    PHR_PERIODIC_TIMER_SF10,
196    PHR_PERIODIC_TIMER_SF20,
197    PHR_PERIODIC_TIMER_SF50,
198    PHR_PERIODIC_TIMER_SF100,
199    PHR_PERIODIC_TIMER_SF200,
200    PHR_PERIODIC_TIMER_SF500,
201    PHR_PERIODIC_TIMER_SF1000,
202    PHR_PERIODIC_TIMER_INFINITE
203 }SchPhrPeriodicTimer;
204
205 typedef enum
206 {
207    PHR_PROHIBIT_TIMER_SF0,
208    PHR_PROHIBIT_TIMER_SF10,
209    PHR_PROHIBIT_TIMER_SF20,
210    PHR_PROHIBIT_TIMER_SF50,
211    PHR_PROHIBIT_TIMER_SF100,
212    PHR_PROHIBIT_TIMER_SF200,
213    PHR_PROHIBIT_TIMER_SF500,
214    PHR_PROHIBIT_TIMER_SF1000
215 }SchPhrProhibitTimer;
216
217 typedef enum
218 {
219    PHR_TX_PWR_FACTOR_CHANGE_DB1,
220    PHR_TX_PWR_FACTOR_CHANGE_DB3,
221    PHR_TX_PWR_FACTOR_CHANGE_DB6,
222    PHR_TX_PWR_FACTOR_CHANGE_INFINITE
223 }SchPhrTxPwrFactorChange;
224
225 typedef enum
226 {
227    PHR_MODE_REAL,
228    PHR_MODE_VIRTUAL
229 }SchPhrModeOtherCG;
230
231 typedef enum
232 {
233    HARQ_ACK_CODEBOOK_SEMISTATIC,
234    HARQ_ACK_CODEBOOK_DYNAMIC
235 }SchPdschHarqAckCodebook;
236
237 typedef enum
238 {
239    NUM_HARQ_PROC_FOR_PDSCH_N2,
240    NUM_HARQ_PROC_FOR_PDSCH_N4,
241    NUM_HARQ_PROC_FOR_PDSCH_N6,
242    NUM_HARQ_PROC_FOR_PDSCH_N10,
243    NUM_HARQ_PROC_FOR_PDSCH_N16
244 }SchNumHarqProcForPdsch;
245
246 typedef enum
247 {
248    MAX_CODE_BLOCK_GROUP_PER_TB_N2,
249    MAX_CODE_BLOCK_GROUP_PER_TB_N4,
250    MAX_CODE_BLOCK_GROUP_PER_TB_N6,
251    MAX_CODE_BLOCK_GROUP_PER_TB_N8
252 }SchMaxCodeBlkGrpPerTB;
253
254 typedef enum
255 {
256    PDSCH_X_OVERHEAD_XOH_6,
257    PDSCH_X_OVERHEAD_XOH_12,
258    PDSCH_X_OVERHEAD_XOH_18
259 }SchPdschXOverhead;
260
261 typedef enum
262 {
263    DMRS_ADDITIONAL_POS0,
264    DMRS_ADDITIONAL_POS1,
265    DMRS_ADDITIONAL_POS3
266 }SchDmrsAdditionPosition;
267
268 typedef enum
269 {
270    RESOURCE_ALLOCTION_TYPE_0,
271    RESOURCE_ALLOCTION_TYPE_1,
272    RESOURCE_ALLOCTION_DYN_SWITCH
273 }SchResourceAllocType;
274
275 typedef enum
276 {
277    TIME_DOMAIN_RSRC_ALLOC_MAPPING_TYPE_A,
278    TIME_DOMAIN_RSRC_ALLOC_MAPPING_TYPE_B
279 }SchTimeDomRsrcAllocMappingType;
280
281 typedef enum
282 {
283    ENABLED_TRANSFORM_PRECODER,
284    DISABLED_TRANSFORM_PRECODER
285 }SchTransformPrecoder;
286
287 typedef enum
288 {
289    INTERLEAVED_CCE_REG_MAPPING = 1,
290    NONINTERLEAVED_CCE_REG_MAPPING
291 }SchREGMappingType;
292
293 typedef enum
294 {
295    SLOT_PERIODICITY_AND_OFFSET_SL_1 = 1,
296    SLOT_PERIODICITY_AND_OFFSET_SL_2,
297    SLOT_PERIODICITY_AND_OFFSET_SL_4,
298    SLOT_PERIODICITY_AND_OFFSET_SL_5,
299    SLOT_PERIODICITY_AND_OFFSET_SL_8,
300    SLOT_PERIODICITY_AND_OFFSET_SL_10,
301    SLOT_PERIODICITY_AND_OFFSET_SL_16,
302    SLOT_PERIODICITY_AND_OFFSET_SL_20,
303    SLOT_PERIODICITY_AND_OFFSET_SL_40,
304    SLOT_PERIODICITY_AND_OFFSET_SL_80,
305    SLOT_PERIODICITY_AND_OFFSET_SL_160,
306    SLOT_PERIODICITY_AND_OFFSET_SL_320,
307    SLOT_PERIODICITY_AND_OFFSET_SL_640,
308    SLOT_PERIODICITY_AND_OFFSET_SL_1280,
309    SLOT_PERIODICITY_AND_OFFSET_SL_2560
310 }SchMSlotPeriodAndOffset;
311
312 typedef enum
313 {
314    SAME_AS_REG_BUNDLE,
315    ALL_CONTIGUOUS_RB
316 }SchPrecoderGranul;
317
318 typedef enum
319 {
320    SEARCH_SPACE_TYPE_COMMON = 1,
321    SEARCH_SPACE_TYPE_UE_SPECIFIC
322 }SchSearchSpaceType;
323
324 typedef enum
325 {
326    SCH_QOS_NON_DYNAMIC = 1,
327    SCH_QOS_DYNAMIC
328 }SchQosType;
329
330 typedef enum
331 {
332    AGGREGATION_LEVEL_N0,
333    AGGREGATION_LEVEL_N1,
334    AGGREGATION_LEVEL_N2,
335    AGGREGATION_LEVEL_N3,
336    AGGREGATION_LEVEL_N4,
337    AGGREGATION_LEVEL_N5,
338    AGGREGATION_LEVEL_N6,
339    AGGREGATION_LEVEL_N8
340 }SchAggrLevel;
341
342 typedef enum
343 {
344    RBG_SIZE_CONFIG_1,
345    RBG_SIZE_CONFIG_2
346 }SchRBGSize;
347
348 typedef enum
349 {
350    CODE_WORDS_SCHED_BY_DCI_N1,
351    CODE_WORDS_SCHED_BY_DCI_N2
352 }SchCodeWordsSchedByDci;
353
354 typedef enum
355 {
356    STATIC_BUNDLING_TYPE = 1,
357    DYNAMIC_BUNDLING_TYPE
358 }SchBundlingType;
359
360 typedef enum
361 {
362    SCH_SET1_SIZE_N4,
363    SCH_SET1_SIZE_WIDEBAND,
364    SCH_SET1_SIZE_N2_WIDEBAND,
365    SCH_SET1_SIZE_N4_WIDEBAND
366 }SchBundlingSizeSet1;
367
368 typedef enum
369 {
370    SCH_SET2_SIZE_N4,
371    SCH_SET2_SIZE_WIDEBAND
372 }SchBundlingSizeSet2;
373
374 typedef enum
375 {
376    DUPLEX_MODE_FDD,
377    DUPLEX_MODE_TDD
378 }SchDuplexMode;
379
380 typedef enum
381 {
382    SSB_PRDCTY_MS5,
383    SSB_PRDCTY_MS10,
384    SSB_PRDCTY_MS20,
385    SSB_PRDCTY_MS40,
386    SSB_PRDCTY_MS80,
387    SSB_PRDCTY_MS160
388 }SchSSBPeriod;
389
390 typedef enum
391 {
392    RSP_OK,
393    RSP_NOK
394 }SchMacRsp;
395
396 typedef enum
397 {
398    SHORT_BSR,
399    LONG_BSR,
400    SHORT_TRUNCATED_BSR,
401    LONG_TRUNCATED_BSR
402 }BsrType;
403
404 typedef enum
405 {
406    FORMAT0_0,
407    FORMAT0_1,
408    FORMAT1_0,
409    FORMAT1_1
410 }FormatType;
411
412 typedef enum
413 {
414    SCH_MCS_TABLE_QAM_64,
415    SCH_MCS_TABLE_QAM_256,
416    SCH_MCS_TABLE_QAM_64_LOW_SE
417 }SchMcsTable;
418
419 typedef enum
420 {
421    NONE,
422    PDCCH_PDU,
423    PDSCH_PDU,
424    BOTH
425 }DlPduType;
426
427 typedef enum
428 {
429    DATA_TRANSMISSION_ALLOWED,
430    STOP_DATA_TRANSMISSION,
431    RESTART_DATA_TRANSMISSION
432 }SchDataTransmission;
433
434 /*structures*/
435 typedef struct timeDomainAlloc
436 {
437    uint16_t startSymb;
438    uint16_t numSymb;
439 }TimeDomainAlloc;
440
441 typedef struct freqDomainAlloc
442 {
443    uint16_t startPrb;
444    uint16_t numPrb;
445 }FreqDomainAlloc;
446
447
448 typedef struct
449 {
450    uint32_t    ssbPbchPwr;       /* SSB block power */
451    uint8_t     scsCommon;           /* subcarrier spacing for common [0-3]*/
452    uint8_t     ssbOffsetPointA;  /* SSB sub carrier offset from point A */
453    SchSSBPeriod   ssbPeriod;        /* SSB Periodicity in msec */
454    uint8_t     ssbSubcOffset;    /* Subcarrier Offset(Kssb) */
455    uint32_t    nSSBMask[SCH_SSB_MASK_SIZE];      /* Bitmap for actually transmitted SSB. */
456    
457    /*Ref:Spec 38.331 "ssb-PositionsInBurst", Value 0 in Bitmap => corresponding SS/PBCH block is not transmitted
458     *value 1 => corresponding SS/PBCH block is transmitted*/
459    uint8_t     totNumSsb;       /*S = Total Number of Actual SSB transmitted*/
460 }SchSsbCfg;
461
462 typedef struct bwpCfg
463 {
464    uint8_t         subcarrierSpacing;
465    uint8_t         cyclicPrefix;
466    FreqDomainAlloc freqAlloc;   
467 }BwpCfg;
468
469 typedef struct prg
470 {
471    uint16_t pmIdx;
472    uint16_t beamIdx[MAX_DIG_BF_INTERFACES];
473 } Prg;
474
475 typedef struct beamformingInfo
476 {
477    uint16_t numPrgs;
478    uint16_t prgSize;
479    uint8_t  digBfInterfaces;
480    Prg  prg[MAX_NUM_PRG];
481 } BeamformingInfo;
482
483 /* SIB1 PDSCH structures */
484
485 typedef struct codewordinfo
486 {
487    uint16_t targetCodeRate;
488    uint8_t  qamModOrder;
489    uint8_t  mcsIndex;
490    uint8_t  mcsTable;
491    uint8_t  rvIndex;
492    uint32_t tbSize;
493 } CodewordInfo;
494
495 typedef struct dmrsInfo
496 {
497    uint16_t dlDmrsSymbPos;
498    uint8_t  dmrsConfigType;
499    uint16_t dlDmrsScramblingId;
500    uint8_t  scid;
501    uint8_t  numDmrsCdmGrpsNoData;
502    uint16_t dmrsPorts;
503    uint8_t mappingType;
504    uint8_t nrOfDmrsSymbols;
505    uint8_t dmrsAddPos;
506 } DmrsInfo;
507
508 typedef struct pdschFreqAlloc
509 {
510    uint8_t  resourceAllocType;
511    /* since we are using type-1, rbBitmap excluded */
512    FreqDomainAlloc freqAlloc;
513    uint8_t  vrbPrbMapping;
514 } PdschFreqAlloc;
515
516 typedef struct pdschTimeAlloc
517 {
518    uint8_t         rowIndex;
519    TimeDomainAlloc timeAlloc;
520 } PdschTimeAlloc;
521
522 typedef struct txPowerPdschInfo
523 {
524    uint8_t powerControlOffset;
525    uint8_t powerControlOffsetSS;
526 } TxPowerPdschInfo;
527
528 typedef struct pdschCfg
529 {
530    uint16_t         pduBitmap;
531    uint16_t         rnti;
532    uint16_t         pduIndex;
533    uint8_t          numCodewords;
534    CodewordInfo     codeword[MAX_CODEWORDS];
535    uint16_t         dataScramblingId;
536    uint8_t          numLayers;
537    uint8_t          transmissionScheme;
538    uint8_t          refPoint;
539    DmrsInfo         dmrs;
540    PdschFreqAlloc   pdschFreqAlloc;
541    PdschTimeAlloc   pdschTimeAlloc;
542    BeamformingInfo  beamPdschInfo;
543    TxPowerPdschInfo txPdschPower;
544 } PdschCfg;
545 /* SIB1 PDSCH structures end */
546
547 /* SIB1 interface structure */
548
549 typedef struct coresetCfg
550 {
551    uint8_t coreSetSize;
552    uint8_t startSymbolIndex;
553    uint8_t durationSymbols;
554    uint8_t freqDomainResource[6];
555    uint8_t cceRegMappingType;
556    uint8_t regBundleSize;
557    uint8_t interleaverSize;
558    uint8_t coreSetType;
559    uint16_t shiftIndex;
560    uint8_t precoderGranularity;
561    uint8_t cceIndex;
562    uint8_t aggregationLevel;
563 } CoresetCfg;
564
565 typedef struct txPowerPdcchInfo
566 {
567    uint8_t powerValue;
568    uint8_t powerControlOffsetSS;
569 } TxPowerPdcchInfo;
570
571 typedef struct dlDCI
572 {
573    uint16_t rnti;
574    uint16_t scramblingId;
575    uint16_t scramblingRnti;
576    uint8_t cceIndex;
577    uint8_t aggregLevel;
578    BeamformingInfo beamPdcchInfo;
579    TxPowerPdcchInfo txPdcchPower;
580    PdschCfg     *pdschCfg;
581 } DlDCI;
582
583 typedef struct pdcchCfg
584 {
585    /* coreset-0 configuration */
586    CoresetCfg coresetCfg;
587
588    uint16_t numDlDci;
589    DlDCI    dci; /* as of now its only one DCI, later it will be numDlCi */
590 } PdcchCfg;
591 /* end of SIB1 PDCCH structures */
592
593 typedef struct pageCfg
594 {
595    uint8_t  numPO;                    /*Derived from Ns*/
596    bool     poPresent;                /*FirstPDCCH-MonitoringPO is present or not*/
597    uint16_t pagingOcc[MAX_PO_PER_PF]; /*FirstPDCCH-Monitoring Paging Occasion*/
598 }PageCfg;
599
600 typedef struct
601 {
602    /* parameters recieved from DU-APP */
603    uint16_t sib1PduLen;
604    uint16_t sib1RepetitionPeriod;
605    uint8_t  coresetZeroIndex;     /* derived from 4 LSB of pdcchSib1 present in MIB */
606    uint8_t  searchSpaceZeroIndex; /* derived from 4 MSB of pdcchSib1 present in MIB */
607    uint16_t sib1Mcs;
608
609    /* parameters derived in scheduler */
610    uint8_t   n0;
611    BwpCfg    bwp;
612    PdcchCfg  sib1PdcchCfg;
613    PdschCfg  sib1PdschCfg;
614    PageCfg   pageCfg;         /*Config of Paging*/
615 }SchSib1Cfg;
616
617 typedef struct schRachCfg
618 {
619    uint8_t      prachCfgIdx;       /* PRACH config idx */
620    uint8_t      prachSubcSpacing;  /* Subcarrier spacing of RACH */
621    uint16_t     msg1FreqStart;     /* Msg1-FrequencyStart */
622    uint8_t      msg1Fdm;           /* PRACH FDM (1,2,4,8) */
623    uint8_t      rootSeqLen;        /* root sequence length */
624    uint16_t     rootSeqIdx;        /* Root sequence index */
625    uint8_t      numRootSeq;        /* Number of root sequences required for FD */
626    uint16_t     k1;                /* Frequency Offset for each FD */
627    uint8_t      totalNumRaPreamble; /* Total number of RA preambles */
628    uint8_t      ssbPerRach;        /* SSB per RACH occassion */
629    uint8_t      numCbPreamblePerSsb; /* Number of CB preamble per SSB */
630    uint8_t      prachMultCarrBand; /* Presence of Multiple carriers in Band */
631    uint8_t      raContResTmr;      /* RA Contention Resoultion Timer */
632    uint8_t      rsrpThreshSsb;     /* RSRP Threshold SSB */
633    uint8_t      raRspWindow;       /* RA Response Window */
634 }SchRachCfg;
635
636 typedef struct schBwpParams
637 {
638    FreqDomainAlloc freqAlloc;
639    uint8_t         scs;
640    uint8_t         cyclicPrefix;
641 }SchBwpParams;
642
643 typedef struct schCandidatesInfo
644 {
645    uint8_t aggLevel1;
646    uint8_t aggLevel2;
647    uint8_t aggLevel4;
648    uint8_t aggLevel8;
649    uint8_t aggLevel16;
650 }SchCandidatesInfo;
651
652 typedef struct schSearchSpaceCfg
653 {
654    uint8_t  searchSpaceId;
655    uint8_t  coresetId;
656    uint8_t  freqDomainRsrc[FREQ_DOM_RSRC_SIZE];  /* Frequency domain resource */
657    uint16_t monitoringSlot;
658    uint16_t duration;
659    uint16_t monitoringSymbol;
660    SchCandidatesInfo candidate;
661 }SchSearchSpaceCfg;
662
663 typedef struct schPdcchCfgCmn
664 {
665    SchSearchSpaceCfg commonSearchSpace;
666    uint8_t raSearchSpaceId;
667 }SchPdcchCfgCmn;
668
669 typedef struct schPdschCfgCmnTimeDomRsrcAlloc
670 {
671    uint8_t k0;
672    uint8_t mappingType;
673    uint8_t startSymbol;
674    uint8_t lengthSymbol;
675 }SchPdschCfgCmnTimeDomRsrcAlloc;
676
677 typedef struct schPdschCfgCmn
678 {
679    uint8_t   numTimeDomAlloc;
680    SchPdschCfgCmnTimeDomRsrcAlloc timeDomRsrcAllocList[MAX_NUM_DL_ALLOC];
681 }SchPdschCfgCmn;
682
683 typedef struct schPucchCfgCmn
684 {
685    uint8_t pucchResourceCommon;
686    uint8_t pucchGroupHopping;
687 }SchPucchCfgCmn;
688
689 /* PUSCH Time Domain Resource Allocation */
690 typedef struct schPuschTimeDomRsrcAlloc
691 {
692    uint8_t   k2;
693    SchTimeDomRsrcAllocMappingType   mappingType;
694    uint8_t   startSymbol;
695    uint8_t   symbolLength;
696 }SchPuschTimeDomRsrcAlloc;
697
698 typedef struct schPuschCfgCmn
699 {
700    uint8_t                    numTimeDomRsrcAlloc;
701    SchPuschTimeDomRsrcAlloc   timeDomRsrcAllocList[MAX_NUM_UL_ALLOC]; /* PUSCH time domain UL resource allocation list */
702 }SchPuschCfgCmn;
703
704 typedef struct schK1TimingInfo
705 {
706    uint8_t numK1;
707    uint8_t k1Indexes[MAX_NUM_K1_IDX];
708 }SchK1TimingInfo;
709
710 typedef struct schK0TimingInfo
711 {
712    uint8_t k0Index;
713    SchK1TimingInfo k1TimingInfo;
714 }SchK0TimingInfo;
715
716 typedef struct schK0K1TimingInfo
717 {
718    uint8_t numK0;
719    SchK0TimingInfo k0Indexes[MAX_NUM_K0_IDX];
720 }SchK0K1TimingInfo;
721
722 typedef struct schK0K1TimingInfoTbl
723 {
724    uint16_t tblSize;
725    SchK0K1TimingInfo k0k1TimingInfo[MAX_NUM_CONFIG_SLOTS];
726 }SchK0K1TimingInfoTbl;
727
728 typedef struct schBwpDlCfg
729 {
730    SchBwpParams   bwp;
731    SchPdcchCfgCmn pdcchCommon;
732    SchPdschCfgCmn pdschCommon;
733    SchK0K1TimingInfoTbl k0K1InfoTbl;
734 }SchBwpDlCfg;
735
736 typedef struct schK2TimingInfo
737 {
738    uint8_t numK2; 
739    uint8_t k2Indexes[MAX_NUM_K2_IDX]; 
740 }SchK2TimingInfo;
741
742 typedef struct schK2TimingInfoTbl
743 {
744    uint16_t tblSize; 
745    SchK2TimingInfo k2TimingInfo[MAX_NUM_CONFIG_SLOTS]; 
746 }SchK2TimingInfoTbl;
747
748 typedef struct schBwpUlCfg
749 {
750    SchBwpParams   bwp;
751    SchPucchCfgCmn pucchCommon;
752    SchPuschCfgCmn puschCommon;
753    SchK2TimingInfoTbl msg3K2InfoTbl;
754    SchK2TimingInfoTbl k2InfoTbl;
755 }SchBwpUlCfg;
756
757 typedef struct schPlmnInfoList
758 {
759    Plmn           plmn;
760    uint8_t        numSliceSupport; /* Total slice supporting */
761    Snssai         **snssai;         /* List of supporting snssai*/
762 }SchPlmnInfoList;
763
764 typedef struct schCellCfg
765 {
766    uint16_t       cellId;           /* Cell Id */
767    uint16_t       phyCellId;        /* Physical cell id */
768    uint8_t        numerology;       /* Supported numerology */
769    SchDuplexMode  dupMode;          /* Duplex type: TDD/FDD */
770    uint8_t        bandwidth;        /* Supported B/W */
771    uint32_t       dlFreq;           /* DL Frequency */
772    uint32_t       ulFreq;           /* UL Frequency */
773    SchSsbCfg      ssbSchCfg;        /* SSB config */
774    SchSib1Cfg     sib1SchCfg;       /* SIB1 config */
775    SchRachCfg     schRachCfg;       /* PRACH config */
776    SchBwpDlCfg    schInitialDlBwp;  /* Initial DL BWP */
777    SchBwpUlCfg    schInitialUlBwp;  /* Initial UL BWP */
778    SchPlmnInfoList plmnInfoList;     /* Consits of PlmnId and Snssai list */
779 #ifdef NR_TDD
780    TDDCfg         tddCfg;           /* TDD Cfg */ 
781 #endif  
782 }SchCellCfg;
783
784 typedef struct schCellCfgCfm
785 {
786    uint16_t         cellId;     /* Cell Id */
787    SchMacRsp   rsp;   
788 }SchCellCfgCfm;
789
790 typedef struct ssbInfo
791 {
792    uint8_t         ssbIdx;          /* SSB Index */
793    TimeDomainAlloc tdAlloc; /* Time domain allocation */
794    FreqDomainAlloc fdAlloc; /* Freq domain allocation */
795 }SsbInfo;
796
797 typedef struct sib1AllocInfo
798 {
799    BwpCfg bwp;
800    PdcchCfg sib1PdcchCfg;
801    PdschCfg sib1PdschCfg;
802 } Sib1AllocInfo;
803
804 typedef struct prachSchInfo
805 {
806    uint8_t  numPrachOcas;   /* Num Prach Ocassions */
807    uint8_t  prachFormat;    /* PRACH Format */
808    uint8_t  numRa;          /* Freq domain ocassion */
809    uint8_t  prachStartSymb; /* Freq domain ocassion */
810 }PrachSchInfo;
811
812 /* Interface structure signifying DL broadcast allocation for SSB, SIB1 */
813 typedef struct dlBrdcstAlloc
814 {
815    /* Ssb transmission is determined as follows:
816     * 0 : No tranamission
817     * 1 : SSB Transmission
818     * 2 : SSB Repetition */
819    uint8_t ssbTrans;
820    uint8_t ssbIdxSupported;
821    SsbInfo ssbInfo[MAX_SSB_IDX];
822    /* Sib1 transmission is determined as follows:
823     * 0 : No tranamission
824     * 1 : SIB1 Transmission
825     * 2 : SIB1 Repetition */
826    uint8_t sib1Trans;
827    Sib1AllocInfo sib1Alloc;
828 }DlBrdcstAlloc;
829
830 typedef struct msg3UlGrant
831 {
832    uint8_t         freqHopFlag;
833    uint16_t        bwpSize;
834    FreqDomainAlloc msg3FreqAlloc;
835    uint8_t         k2Index;
836    uint8_t         mcs;
837    uint8_t         tpc;
838    uint8_t         csiReq;
839 }Msg3UlGrant;
840
841 typedef struct rarInfo
842 {
843    uint16_t        raRnti;
844    uint8_t         RAPID;
845    uint16_t        ta;
846    Msg3UlGrant     ulGrant;
847    uint16_t        tcrnti;
848    uint8_t         rarPdu[RAR_PAYLOAD_SIZE];
849    uint8_t         rarPduLen;
850 }RarInfo;
851
852 typedef struct rarAlloc
853 {
854    DlPduType  pduPres;
855    uint8_t    pdschSlot;
856    RarInfo rarInfo;
857    BwpCfg  bwp;
858    PdcchCfg rarPdcchCfg;
859    PdschCfg rarPdschCfg;
860 }RarAlloc;
861
862 typedef struct dlMsgInfo
863 {
864    uint16_t crnti;
865    uint8_t  ndi;
866    uint8_t  harqProcNum;
867    uint8_t  dlAssignIdx;
868    uint8_t  pucchTpc;
869    uint8_t  pucchResInd;
870    uint8_t  harqFeedbackInd;
871    uint8_t  dciFormatId;
872    bool     isMsg4Pdu;
873    uint16_t  dlMsgPduLen;
874    uint8_t  *dlMsgPdu;
875 }DlMsgInfo;
876
877 typedef struct lcSchInfo
878 {
879    uint8_t   lcId;
880    uint32_t  schBytes; /* Number of scheduled bytes */
881 }LcSchInfo;
882
883 typedef struct dlMsgSchedInfo
884 {
885    uint8_t    numLc;
886    LcSchInfo  lcSchInfo[MAX_NUM_LC]; /* Scheduled LC info */
887    BwpCfg     bwp;
888    PdcchCfg   dlMsgPdcchCfg;
889    PdschCfg   dlMsgPdschCfg;
890    DlPduType  pduPres;
891    uint8_t    pdschSlot;
892    DlMsgInfo  dlMsgInfo;
893 }DlMsgSchInfo;
894
895 typedef struct dlMsgAlloc
896 {
897    uint16_t     crnti;
898    uint8_t      numSchedInfo;
899    DlMsgSchInfo dlMsgSchedInfo[2];
900 }DlMsgAlloc;
901
902 typedef struct schSlotValue
903 {
904    SlotTimingInfo currentTime;
905    SlotTimingInfo broadcastTime;
906    SlotTimingInfo rarTime;
907    SlotTimingInfo dlMsgTime;
908    SlotTimingInfo ulDciTime;
909 }SchSlotValue;
910
911 typedef struct format0_0
912 {
913    uint8_t         resourceAllocType;
914    /* since we are using type-1, hence rbBitmap excluded */
915    FreqDomainAlloc freqAlloc;
916    TimeDomainAlloc timeAlloc;
917    uint16_t        rowIndex;
918    uint8_t         mcs;
919    uint8_t         harqProcId;   /* HARQ Process ID */
920    bool            puschHopFlag;
921    bool            freqHopFlag;
922    uint8_t         ndi;    /* NDI */
923    uint8_t         rv;     /* Redundancy Version */
924    uint8_t         tpcCmd;
925    bool            sUlCfgd;
926 }Format0_0;
927
928 typedef struct format0_1
929 {
930 /* TBD */
931
932 }Format0_1;
933
934 typedef struct format1_0
935 {
936 /* TBD */
937
938 }Format1_0;
939
940 typedef struct format1_1
941 {
942 /* TBD */
943 }Format1_1;
944
945 typedef struct dciInfo
946 {
947    uint16_t      cellId;   
948    uint16_t      crnti;          /* CRNI */
949    SlotTimingInfo   slotIndInfo;    /* Slot Info: sfn, slot number */
950    BwpCfg        bwpCfg;         /* BWP Cfg */
951    CoresetCfg    coresetCfg;     /* Coreset1 Cfg */
952    FormatType    formatType;     /* DCI Format */
953    union
954    {
955       Format0_0  format0_0;      /* Format 0_0 */
956       Format0_1  format0_1;      /* Format 0_1 */
957       Format1_0  format1_0;      /* Format 1_0 */
958       Format1_1  format1_1;      /* Format 1_1 */
959    }format;
960    DlDCI    dciInfo;
961 }DciInfo;
962
963
964 typedef struct dlSchedInfo
965 {
966    uint16_t cellId;  /* Cell Id */
967    SchSlotValue schSlotValue;
968
969    /* Allocation for broadcast messages */
970    bool isBroadcastPres;
971    DlBrdcstAlloc brdcstAlloc;
972
973    /* Allocation for RAR message */
974    RarAlloc *rarAlloc[MAX_NUM_UE];
975
976    /* UL grant in response to BSR */
977    DciInfo    *ulGrant;
978
979    /* Allocation from dedicated DL msg */
980    DlMsgAlloc *dlMsgAlloc[MAX_NUM_UE];
981
982 }DlSchedInfo;
983
984 typedef struct tbInfo
985 {
986    uint8_t  qamOrder;  /* Modulation Order */
987    uint8_t  mcs;       /* MCS */
988    SchMcsTable  mcsTable;  /* MCS Table */
989    uint8_t  ndi;       /* NDI */
990    uint8_t  rv;        /* Redundancy Version */
991    uint16_t tbSize;    /* TB Size */
992 }TbInfo;
993
994 typedef struct schPuschInfo
995 {
996    uint16_t         crnti;
997    uint8_t          harqProcId;   /* HARQ Process ID */
998    uint8_t          resAllocType; /* Resource allocation type */
999    FreqDomainAlloc  fdAlloc;      /* Freq domain allocation */
1000    TimeDomainAlloc  tdAlloc;      /* Time domain allocation */
1001    TbInfo           tbInfo;       /* TB info */
1002    uint8_t          dmrsMappingType;
1003    uint8_t          nrOfDmrsSymbols;
1004    uint8_t          dmrsAddPos;
1005 }SchPuschInfo;
1006
1007 typedef struct schPucchFormatCfg
1008 {
1009    uint8_t interSlotFreqHop;
1010    uint8_t addDmrs;
1011    uint8_t maxCodeRate;
1012    uint8_t numSlots;
1013    bool    pi2BPSK;
1014    bool    harqAckCSI;
1015 }SchPucchFormatCfg;
1016
1017 typedef struct schPucchInfo
1018 {
1019    uint16_t         rnti;
1020    uint8_t          pucchFormat;
1021    FreqDomainAlloc  fdAlloc;      /* Freq domain allocation */
1022    TimeDomainAlloc  tdAlloc;      /* Time domain allocation */
1023    uint8_t          srFlag;
1024    uint8_t          harqFlag;
1025    uint8_t          numHarqBits;
1026    uint8_t          uciFlag;
1027    uint8_t          numUciBits;
1028    uint8_t          intraFreqHop;
1029    uint16_t         secondPrbHop;
1030    uint8_t          initialCyclicShift;
1031    uint8_t          occLen;
1032    uint8_t          occIdx;
1033    uint8_t          timeDomOCC;
1034    SchPucchFormatCfg cmnFormatCfg;
1035 }SchPucchInfo;
1036
1037 typedef struct ulSchedInfo
1038 {
1039    uint16_t      cellId;         /* Cell Id */
1040    uint16_t      crnti;          /* CRNI */
1041    SlotTimingInfo   slotIndInfo;    /* Slot Info: sfn, slot number */
1042    uint8_t       dataType;       /* Type of info being scheduled */
1043    PrachSchInfo  prachSchInfo;   /* Prach scheduling info */
1044    SchPuschInfo  schPuschInfo;   /* Pusch scheduling info */
1045    SchPucchInfo  schPucchInfo;   /* Pusch scheduling info */
1046 }UlSchedInfo;
1047
1048 typedef struct rachIndInfo
1049 {
1050    uint16_t    cellId;
1051    uint16_t    crnti;
1052    SlotTimingInfo timingInfo;
1053    uint8_t     slotIdx;
1054    uint8_t     symbolIdx;
1055    uint8_t     freqIdx;
1056    uint8_t     preambleIdx;
1057    uint16_t    timingAdv;
1058 }RachIndInfo;
1059
1060
1061 typedef struct crcIndInfo
1062 {
1063    uint16_t    cellId;
1064    uint16_t    crnti;
1065    SlotTimingInfo timingInfo;
1066    uint16_t    numCrcInd;
1067    uint8_t     crcInd[MAX_NUMBER_OF_CRC_IND_BITS];
1068 }CrcIndInfo;
1069
1070 typedef struct boInfo
1071 {
1072    uint8_t   lcId;
1073    uint32_t  dataVolume;
1074 }BOInfo;
1075
1076 typedef struct dlRlcBOInfo
1077 {
1078    uint16_t    cellId;
1079    uint16_t    crnti;
1080    uint8_t     lcId;
1081    uint32_t    dataVolume;
1082 }DlRlcBoInfo;
1083
1084 /* Info of Scheduling Request to Add/Modify */
1085 typedef struct schSchedReqInfo
1086 {
1087    uint8_t              schedReqId;
1088    SchSrProhibitTimer   srProhibitTmr;
1089    SchSrTransMax        srTransMax;
1090 }SchSchedReqInfo;
1091
1092 /* Scheduling Request Configuration */
1093 typedef struct schSchedReqCfg
1094 {
1095    uint8_t          addModListCount;
1096    SchSchedReqInfo  addModList[MAX_NUM_SR_CFG_PER_CELL_GRP];   /* List of Scheduling req to be added/modified */
1097    uint8_t          relListCount;
1098    uint8_t          relList[MAX_NUM_SR_CFG_PER_CELL_GRP];      /* list of scheduling request Id to be deleted */
1099 }SchSchedReqCfg;
1100
1101 /* Info of Tag to Add/Modify */
1102 typedef struct schTagInfo
1103 {
1104    uint8_t       tagId;
1105    SchTimeAlignmentTimer  timeAlignmentTmr;
1106 }SchTagInfo;
1107
1108 /* Timing Advance Group Configuration */
1109 typedef struct schTagCfg
1110 {
1111    uint8_t      addModListCount;
1112    SchTagInfo   addModList[MAX_NUM_TAGS];    /* List of Tag to Add/Modify */
1113    uint8_t      relListCount;
1114    uint8_t      relList[MAX_NUM_TAGS];       /* list of Tag Id to release */
1115 }SchTagCfg;
1116
1117 /* Configuration for Power headroom reporting */
1118 typedef struct schPhrCfg
1119 {
1120    SchPhrPeriodicTimer       periodicTmr;
1121    SchPhrProhibitTimer       prohibitTmr;
1122    SchPhrTxPwrFactorChange   txpowerFactorChange;
1123    bool                      multiplePhr;
1124    bool                      dummy;
1125    bool                      type2OtherCell;
1126    SchPhrModeOtherCG         modeOtherCG;
1127 }SchPhrCfg;
1128
1129 /* MAC cell Group configuration */
1130 typedef struct schMacCellGrpCfg
1131 {
1132    SchSchedReqCfg   schedReqCfg;
1133    SchTagCfg        tagCfg;
1134    SchPhrCfg        phrCfg;             /* To be used only if phrCfgSetupPres is true */      
1135 }SchMacCellGrpCfg;
1136
1137 /* Physical Cell Group Configuration */
1138 typedef struct schPhyCellGrpCfg
1139 {
1140    SchPdschHarqAckCodebook    pdschHarqAckCodebook;
1141    int8_t     pNrFr1;
1142 }SchPhyCellGrpCfg;
1143
1144 /* Control resource set info */
1145 typedef struct schControlRsrcSet
1146 {
1147    uint8_t             cRSetId;                /* Control resource set id */
1148    uint8_t             freqDomainRsrc[FREQ_DOM_RSRC_SIZE];  /* Frequency domain resource */
1149    uint8_t             duration;
1150    SchREGMappingType   cceRegMappingType;
1151    SchPrecoderGranul   precoderGranularity;
1152    uint16_t            dmrsScramblingId;
1153 }SchControlRsrcSet;
1154
1155 /* Search Space info */
1156 typedef struct schSearchSpace
1157 {
1158    uint8_t                  searchSpaceId;
1159    uint8_t                  cRSetId;
1160    SchMSlotPeriodAndOffset  mSlotPeriodicityAndOffset;
1161    uint8_t                  mSymbolsWithinSlot[MONITORING_SYMB_WITHIN_SLOT_SIZE];
1162    SchAggrLevel             numCandidatesAggLevel1;      /* Number of candidates for aggregation level 1 */
1163    SchAggrLevel             numCandidatesAggLevel2;      /* Number of candidates for aggregation level 2 */
1164    SchAggrLevel             numCandidatesAggLevel4;      /* Number of candidates for aggregation level 4 */
1165    SchAggrLevel             numCandidatesAggLevel8;      /* Number of candidates for aggregation level 8 */
1166    SchAggrLevel             numCandidatesAggLevel16;     /* Number of candidates for aggregation level 16 */
1167    SchSearchSpaceType       searchSpaceType;
1168    uint8_t                  ueSpecificDciFormat;
1169 }SchSearchSpace;
1170
1171 /* PDCCH cofniguration */
1172 typedef struct schPdcchConfig
1173 {
1174    uint8_t           numCRsetToAddMod;
1175    SchControlRsrcSet  cRSetToAddModList[MAX_NUM_CRSET];           /* List of control resource set to add/modify */
1176    uint8_t           numCRsetToRel;
1177    uint8_t           cRSetToRelList[MAX_NUM_CRSET];              /* List of control resource set to release */
1178    uint8_t           numSearchSpcToAddMod;
1179    SchSearchSpace    searchSpcToAddModList[MAX_NUM_SEARCH_SPC];  /* List of search space to add/modify */
1180    uint8_t           numSearchSpcToRel;
1181    uint8_t           searchSpcToRelList[MAX_NUM_SEARCH_SPC];     /* List of search space to release */
1182 }SchPdcchConfig;
1183
1184 /* PDSCH time domain resource allocation */
1185 typedef struct schPdschTimeDomRsrcAlloc
1186 {
1187    uint8_t    *k0;
1188    SchTimeDomRsrcAllocMappingType    mappingType;
1189    uint8_t    startSymbol;
1190    uint8_t    symbolLength;
1191 }SchPdschTimeDomRsrcAlloc;
1192
1193
1194 typedef struct schPdschBundling
1195 {
1196    struct schStaticBundling
1197    {
1198      SchBundlingSizeSet2 size;
1199    }SchStaticBundling;
1200    struct schDynamicBundling
1201    {
1202      SchBundlingSizeSet1 sizeSet1;
1203      SchBundlingSizeSet2 sizeSet2;
1204    }SchDynamicBundling;
1205 }SchPdschBundling;
1206
1207 /* DMRS downlink configuration */
1208 typedef struct schDmrsDlCfg
1209 {
1210    SchDmrsAdditionPosition   addPos;       /* DMRS additional position */
1211 }SchDmrsDlCfg;
1212
1213 /* PDSCH Configuration */
1214 typedef struct schPdschConfig
1215 {
1216    SchDmrsDlCfg               dmrsDlCfgForPdschMapTypeA;
1217    SchResourceAllocType       resourceAllocType;
1218    uint8_t                    numTimeDomRsrcAlloc;
1219    SchPdschTimeDomRsrcAlloc   timeDomRsrcAllociList[MAX_NUM_DL_ALLOC]; /* PDSCH time domain DL resource allocation list */
1220    SchRBGSize                 rbgSize;
1221    SchCodeWordsSchedByDci     numCodeWordsSchByDci;                    /* Number of code words scheduled by DCI */
1222    SchBundlingType            bundlingType;
1223    SchPdschBundling           bundlingInfo;
1224 }SchPdschConfig;
1225
1226 /* Initial Downlink BWP */
1227 typedef struct schInitalDlBwp
1228 {
1229    bool             pdcchCfgPres;
1230    SchPdcchConfig   pdcchCfg;
1231    bool             pdschCfgPres;
1232    SchPdschConfig   pdschCfg;
1233    bool             k0K1TblPrsnt;
1234    SchK0K1TimingInfoTbl k0K1InfoTbl;
1235 }SchInitalDlBwp;
1236
1237 /* BWP Downlink common */
1238 typedef struct schBwpDlCommon
1239 {
1240 }SchBwpDlCommon;
1241
1242 /* Downlink BWP information */
1243 typedef struct schDlBwpInfo
1244 {
1245    uint8_t          bwpId;
1246 }SchDlBwpInfo;
1247
1248 /* PDCCH Serving Cell configuration */
1249 typedef struct schPdschServCellCfg
1250 {
1251    uint8_t                  *maxMimoLayers;           
1252    SchNumHarqProcForPdsch   numHarqProcForPdsch;
1253    SchMaxCodeBlkGrpPerTB    *maxCodeBlkGrpPerTb;
1254    bool                     *codeBlkGrpFlushInd;
1255    SchPdschXOverhead        *xOverhead;
1256 }SchPdschServCellCfg;
1257
1258 /* PUCCH Configuration */
1259 typedef struct schPucchResrcSetInfo
1260 {
1261    uint8_t resrcSetId;
1262    uint8_t resrcListCount;
1263    uint8_t resrcList[MAX_NUM_PUCCH_PER_RESRC_SET];
1264    uint8_t maxPayLoadSize;
1265 }SchPucchResrcSetInfo;
1266
1267 typedef struct schPucchResrcSetCfg
1268 {
1269    uint8_t resrcSetToAddModListCount;
1270    SchPucchResrcSetInfo resrcSetToAddModList[MAX_NUM_PUCCH_RESRC_SET];
1271    uint8_t resrcSetToRelListCount;
1272    uint8_t resrcSetToRelList[MAX_NUM_PUCCH_RESRC];
1273 }SchPucchResrcSetCfg;
1274
1275 typedef struct schPucchFormat0
1276 {
1277    uint8_t initialCyclicShift;
1278    uint8_t numSymbols;
1279    uint8_t startSymbolIdx;
1280 }SchPucchFormat0;
1281
1282 typedef struct schPucchFormat1
1283 {
1284    uint8_t initialCyclicShift;
1285    uint8_t numSymbols;
1286    uint8_t startSymbolIdx;
1287    uint8_t timeDomOCC;
1288 }SchPucchFormat1;
1289
1290 typedef struct schPucchFormat2_3
1291 {
1292    uint8_t numPrbs;
1293    uint8_t numSymbols;
1294    uint8_t startSymbolIdx;
1295 }SchPucchFormat2_3;
1296
1297 typedef struct schPucchFormat4
1298 {
1299    uint8_t numSymbols;
1300    uint8_t occLen;
1301    uint8_t occIdx;
1302    uint8_t startSymbolIdx;
1303 }SchPucchFormat4;
1304
1305 typedef struct schPucchResrcInfo
1306 {
1307    uint8_t  resrcId;
1308    uint16_t startPrb;
1309    uint8_t  intraFreqHop;
1310    uint16_t secondPrbHop;
1311    uint8_t  pucchFormat;
1312    union{
1313       SchPucchFormat0   *format0; 
1314       SchPucchFormat1   *format1;
1315       SchPucchFormat2_3 *format2;
1316       SchPucchFormat2_3 *format3;
1317       SchPucchFormat4   *format4;
1318    }SchPucchFormat;
1319 }SchPucchResrcInfo;
1320
1321 typedef struct schPucchResrcCfg
1322 {
1323    uint8_t resrcToAddModListCount;
1324    SchPucchResrcInfo resrcToAddModList[MAX_NUM_PUCCH_RESRC];
1325    uint8_t resrcToRelListCount;
1326    uint8_t resrcToRelList[MAX_NUM_PUCCH_RESRC];
1327 }SchPucchResrcCfg;
1328
1329
1330 typedef struct schSchedReqResrcInfo
1331 {
1332    uint8_t resrcId;
1333    uint8_t requestId;
1334    uint8_t periodicity;
1335    uint16_t offset;
1336    uint8_t resrc;
1337 }SchSchedReqResrcInfo;
1338
1339 typedef struct schPucchSchedReqCfg
1340 {
1341    uint8_t           schedAddModListCount;
1342    SchSchedReqResrcInfo schedAddModList[MAX_NUM_SR_CFG_PER_CELL_GRP];
1343    uint8_t           schedRelListCount;
1344    uint8_t           schedRelList[MAX_NUM_SR_CFG_PER_CELL_GRP];
1345 }SchPucchSchedReqCfg;
1346
1347 typedef struct schSpatialRelationInfo
1348 {
1349    uint8_t spatialRelationId;
1350    uint8_t servCellIdx;
1351    uint8_t pathLossRefRSId;
1352    uint8_t p0PucchId;
1353    uint8_t closeLoopIdx;
1354 }SchSpatialRelationInfo;
1355
1356 typedef struct schPucchSpatialCfg
1357 {
1358    uint8_t spatialAddModListCount;
1359    SchSpatialRelationInfo spatialAddModList[MAX_NUM_SPATIAL_RELATIONS];
1360    uint8_t spatialRelListCount;
1361    uint8_t spatialRelList[MAX_NUM_SPATIAL_RELATIONS];
1362 }SchPucchSpatialCfg;
1363
1364 typedef struct schP0PucchCfg
1365 {
1366    uint8_t p0PucchId;
1367    int     p0PucchVal;
1368 }SchP0PucchCfg;
1369
1370 typedef struct schPathLossRefRSCfg
1371 {
1372    uint8_t pathLossRefRSId;
1373 }SchPathLossRefRSCfg;
1374
1375 typedef struct schPucchMultiCsiCfg
1376 {
1377    uint8_t  multiCsiResrcListCount;
1378    uint8_t  multiCsiResrcList[MAX_NUM_PUCCH_RESRC-1];
1379 }SchPucchMultiCsiCfg;
1380
1381 typedef struct schPucchDlDataToUlAck
1382 {
1383    uint8_t  dlDataToUlAckListCount;
1384    uint8_t  dlDataToUlAckList[MAX_NUM_DL_DATA_TO_UL_ACK];
1385 }SchPucchDlDataToUlAck;
1386
1387 typedef struct schPucchPowerControl
1388 {
1389    int deltaF_Format0;
1390    int deltaF_Format1;
1391    int deltaF_Format2;
1392    int deltaF_Format3;
1393    int deltaF_Format4;
1394    uint8_t p0SetCount;
1395    SchP0PucchCfg p0Set[MAX_NUM_PUCCH_P0_PER_SET];
1396    uint8_t pathLossRefRSListCount;
1397    SchPathLossRefRSCfg pathLossRefRSList[MAX_NUM_PATH_LOSS_REF_RS];
1398 }SchPucchPowerControl;
1399
1400 typedef struct schPucchCfg
1401 {
1402    SchPucchResrcSetCfg   *resrcSet;
1403    SchPucchResrcCfg      *resrc;
1404    SchPucchFormatCfg     *format1; 
1405    SchPucchFormatCfg     *format2; 
1406    SchPucchFormatCfg     *format3; 
1407    SchPucchFormatCfg     *format4;
1408    SchPucchSchedReqCfg   *schedReq;
1409    SchPucchMultiCsiCfg   *multiCsiCfg;
1410    SchPucchSpatialCfg    *spatialInfo;
1411    SchPucchDlDataToUlAck *dlDataToUlAck;
1412    SchPucchPowerControl  *powerControl;
1413 }SchPucchCfg;
1414
1415 /* Transform precoding disabled */
1416 typedef struct schTransPrecodDisabled
1417 {
1418    uint16_t   scramblingId0;
1419 }SchTransPrecodDisabled;
1420
1421 /* DMRS Uplink configuration */
1422 typedef struct SchDmrsUlCfg
1423 {
1424    SchDmrsAdditionPosition    addPos;               /* DMRS additional position */
1425    SchTransPrecodDisabled     transPrecodDisabled;  /* Transform precoding disabled */
1426 }SchDmrsUlCfg;
1427
1428 /* PUSCH Configuration */
1429 typedef struct schPuschCfg
1430 {
1431    uint8_t                    dataScramblingId;
1432    SchDmrsUlCfg               dmrsUlCfgForPuschMapTypeA;
1433    SchResourceAllocType       resourceAllocType;
1434    uint8_t                    numTimeDomRsrcAlloc;
1435    SchPuschTimeDomRsrcAlloc   timeDomRsrcAllocList[MAX_NUM_UL_ALLOC]; /* PUSCH time domain UL resource allocation list */
1436    SchTransformPrecoder       transformPrecoder;
1437 }SchPuschCfg;
1438
1439 /* Initial Uplink BWP */
1440 typedef struct schInitialUlBwp
1441 {
1442    bool          pucchCfgPres;
1443    SchPucchCfg   pucchCfg;
1444    bool          puschCfgPres;
1445    SchPuschCfg   puschCfg;
1446    bool          k2TblPrsnt;
1447    SchK2TimingInfoTbl k2InfoTbl;
1448 }SchInitialUlBwp;
1449
1450 /* Uplink BWP information */
1451 typedef struct schUlBwpInfo
1452 {
1453    uint8_t        bwpId;
1454 }SchUlBwpInfo;
1455
1456 /* Serving cell configuration */
1457 typedef struct schServCellCfgInfo
1458 {
1459    SchInitalDlBwp        initDlBwp;
1460    uint8_t               numDlBwpToAdd;
1461    SchDlBwpInfo          DlBwpToAddList[MAX_NUM_BWP];
1462    uint8_t               firstActvDlBwpId;
1463    uint8_t               defaultDlBwpId;
1464    uint8_t               *bwpInactivityTmr;
1465    SchPdschServCellCfg   pdschServCellCfg;
1466    SchInitialUlBwp       initUlBwp;
1467    uint8_t               numUlBwpToAdd;
1468    SchUlBwpInfo          UlBwpToAddList[MAX_NUM_BWP];
1469    uint8_t               firstActvUlBwpId;
1470 }SchServCellCfgInfo;
1471
1472 typedef struct schNonDynFiveQi
1473 {
1474    uint16_t   fiveQi;
1475    uint8_t    priorLevel;
1476    uint16_t   avgWindow;
1477    uint16_t   maxDataBurstVol;
1478 }SchNonDynFiveQi;
1479
1480 typedef struct schDynFiveQi
1481 {
1482    uint8_t    priorLevel;
1483    uint16_t   packetDelayBudget;
1484    uint8_t    packetErrRateScalar;
1485    uint8_t    packetErrRateExp;
1486    uint16_t   fiveQi;
1487    uint8_t    delayCritical;
1488    uint16_t   avgWindow;
1489    uint16_t   maxDataBurstVol;
1490 }SchDynFiveQi;
1491
1492 typedef struct schNgRanAllocAndRetPri
1493 {
1494    uint8_t priorityLevel;
1495    uint8_t preEmptionCap;
1496    uint8_t preEmptionVul;
1497 }SchNgRanAllocAndRetPri;
1498
1499 typedef struct schGrbQosFlowInfo
1500 {
1501    uint32_t maxFlowBitRateDl;
1502    uint32_t maxFlowBitRateUl;
1503    uint32_t guarFlowBitRateDl;
1504    uint32_t guarFlowBitRateUl;
1505 }SchGrbQosFlowInfo;
1506
1507 /* DRB QoS */
1508 typedef struct schDrbQos
1509 {
1510    SchQosType  fiveQiType;   /* Dynamic or non-dynamic */ 
1511    union
1512    {
1513       SchNonDynFiveQi   nonDyn5Qi;
1514       SchDynFiveQi      dyn5Qi;
1515    }u;
1516    SchNgRanAllocAndRetPri  ngRanRetPri;
1517    SchGrbQosFlowInfo       grbQosFlowInfo;
1518    uint16_t                pduSessionId;
1519    uint32_t                ulPduSessAggMaxBitRate;   /* UL PDU Session Aggregate max bit rate */
1520 }SchDrbQosInfo;
1521
1522 /* Special cell configuration */
1523 typedef struct schSpCellCfg
1524 {
1525    uint8_t           servCellIdx;
1526    SchServCellCfgInfo   servCellCfg;
1527 }SchSpCellCfg;
1528
1529 /* Uplink logical channel configuration */
1530 typedef struct SchUlLcCfg
1531 {
1532    uint8_t priority;
1533    uint8_t lcGroup;
1534    uint8_t schReqId;
1535    uint8_t pbr;        // prioritisedBitRate
1536    uint8_t bsd;        // bucketSizeDuration
1537 }SchUlLcCfg;
1538
1539 /* Downlink logical channel configuration */
1540 typedef struct schDlLcCfg
1541 {
1542    uint8_t lcp;      // logical Channel Prioritization
1543 }SchDlLcCfg;
1544
1545 /* Logical Channel configuration */
1546 typedef struct schLcCfg
1547 {
1548    ConfigType     configType;
1549    uint8_t        lcId;
1550    SchDrbQosInfo  *drbQos;
1551    Snssai         *snssai;
1552    SchDlLcCfg     dlLcCfg;
1553    SchUlLcCfg     ulLcCfg;
1554 }SchLcCfg;
1555
1556 /* Aggregate max bit rate */
1557 typedef struct schAmbrCfg
1558 {
1559    uint32_t   ulBr;   /* Ul BitRate */
1560 }SchAmbrCfg;
1561
1562 typedef struct schModulationInfo
1563 {
1564    uint8_t      modOrder;
1565    uint8_t      mcsIndex;
1566    SchMcsTable  mcsTable;
1567 }SchModulationInfo;
1568
1569 /* UE configuration */
1570 typedef struct schUeCfg
1571 {
1572    uint16_t        cellId;
1573    uint8_t         ueId;
1574    uint16_t        crnti;
1575    bool macCellGrpCfgPres;
1576    SchMacCellGrpCfg   macCellGrpCfg;
1577    bool phyCellGrpCfgPres;
1578    SchPhyCellGrpCfg   phyCellGrpCfg;
1579    bool spCellCfgPres;
1580    SchSpCellCfg       spCellCfg;
1581    SchAmbrCfg         *ambrCfg;
1582    SchModulationInfo  dlModInfo;
1583    SchModulationInfo  ulModInfo;
1584    uint8_t            numLcs;
1585    SchLcCfg           schLcCfg[MAX_NUM_LC];
1586    SchDataTransmission dataTransmissionInfo;
1587 }SchUeCfg;
1588
1589 typedef struct schUeCfgRsp
1590 {
1591    uint16_t   cellId;
1592    uint16_t   ueId;
1593    uint16_t   crnti;
1594    SchMacRsp  rsp;
1595    SchFailureCause cause;
1596 }SchUeCfgRsp;
1597
1598 typedef struct schRachRsrcReq
1599 {
1600    uint16_t cellId;
1601    uint16_t crnti;
1602    uint8_t  numSsb;
1603    uint8_t  ssbIdx[MAX_NUM_SSB];
1604 }SchRachRsrcReq;
1605
1606 typedef struct schCfraSsbResource
1607 {
1608    uint8_t  ssbIdx;
1609    uint8_t  raPreambleIdx;
1610 }SchCfraSsbResource;
1611
1612 typedef struct schCfraRsrc
1613 {
1614    uint8_t   numSsb;
1615    SchCfraSsbResource ssbResource[MAX_NUM_SSB];
1616 }SchCfraResource;
1617
1618 typedef struct schRachRsrcRsp
1619 {
1620    uint16_t   cellId;
1621    uint16_t   crnti;
1622    SchMacRsp  result;
1623    SchCfraResource  cfraResource;
1624 }SchRachRsrcRsp;
1625
1626 typedef struct schUeDelete
1627 {
1628    uint16_t   cellId;
1629    uint16_t   crnti;
1630 }SchUeDelete;
1631
1632 typedef struct schUeDeleteRsp
1633 {
1634    uint16_t   cellId;
1635    uint16_t   crnti;
1636    SchMacRsp  rsp;
1637    ErrorCause cause;
1638 }SchUeDeleteRsp;
1639
1640 typedef struct schCellDelete 
1641 {
1642    uint16_t   cellId;
1643 }SchCellDelete;
1644
1645
1646 typedef struct schCellDeleteRsp
1647 {
1648    uint16_t   cellId;
1649    SchMacRsp  rsp;
1650 }SchCellDeleteRsp;
1651
1652 typedef struct dataVolInfo
1653 {
1654    uint8_t  lcgId;
1655    uint32_t dataVol;
1656 }DataVolInfo;
1657
1658 typedef struct ulBufferStatusRptInd
1659 {
1660    uint16_t    cellId;
1661    uint16_t    crnti;
1662    BsrType     bsrType;
1663    uint8_t     numLcg;
1664    DataVolInfo dataVolInfo[MAX_NUM_LOGICAL_CHANNEL_GROUPS];
1665 }UlBufferStatusRptInd;
1666
1667 typedef struct srUciIndInfo
1668 {
1669    uint16_t    cellId;
1670    uint16_t    crnti;
1671    SlotTimingInfo slotInd;
1672    uint8_t     numSrBits;
1673    uint8_t     srPayload[MAX_SR_BITS_IN_BYTES];
1674 }SrUciIndInfo;
1675
1676 typedef struct schRrmPolicyRatio
1677 {
1678    uint8_t policyMaxRatio;
1679    uint8_t policyMinRatio;
1680    uint8_t policyDedicatedRatio;
1681 }SchRrmPolicyRatio;
1682
1683 typedef struct schRrmPolicyOfSlice
1684 {
1685    Snssai  snssai;
1686    SchRrmPolicyRatio *rrmPolicyRatioInfo;
1687 }SchRrmPolicyOfSlice;
1688
1689 typedef struct schSliceCfgReq
1690 {
1691    uint8_t  numOfConfiguredSlice;
1692    SchRrmPolicyOfSlice **listOfConfirguration;
1693 }SchSliceCfgReq;
1694
1695 typedef struct sliceRsp
1696 {
1697    Snssai     snssai;
1698    SchMacRsp  rsp;
1699    RspCause   cause;
1700 }SliceRsp;
1701
1702 typedef struct schSliceRsp
1703 {
1704    uint8_t    numSliceCfgRsp;
1705    SliceRsp   **listOfSliceCfgRsp;
1706 }SchSliceCfgRsp;
1707
1708 typedef struct schPageInd
1709 {
1710    uint16_t  cellId;
1711    uint16_t  pf;
1712    uint8_t   i_s;
1713    uint16_t  pduLen;
1714    uint8_t  *pagePdu;
1715 }SchPageInd;
1716
1717 /* function pointers */
1718 typedef uint8_t (*SchCellCfgCfmFunc)    ARGS((
1719          Pst            *pst,           /* Post Structure */                         
1720          SchCellCfgCfm  *schCellCfgCfm  /* Cell Cfg Cfm */
1721          ));
1722
1723 typedef uint8_t (*SchCellCfgFunc)    ARGS((
1724          Pst         *pst,           /* Post Structure */                         
1725          SchCellCfg  *schCellCfg     /* Cell Cfg  */
1726          ));
1727
1728 typedef uint8_t (*SchMacDlAllocFunc)     ARGS((                     
1729          Pst            *pst,          /* Post Structure */                         
1730          DlSchedInfo    *dlSchedInfo   /* dl allocation Info */                      
1731          ));
1732
1733 typedef uint8_t (*SchMacUlSchInfoFunc)     ARGS((                     
1734          Pst         *pst,           /* Post Structure */                         
1735          UlSchedInfo *ulSchedInfo    /* UL Alloc Sch  Info */                      
1736          ));
1737
1738 typedef uint8_t (*MacSchRachIndFunc) ARGS((
1739          Pst         *pst,         /* Post structure */
1740          RachIndInfo *rachInd));    /* Rach Indication Info */
1741
1742 typedef uint8_t (*MacSchCrcIndFunc) ARGS(( 
1743          Pst         *pst,         /* Post structure */
1744          CrcIndInfo  *crcInd));     /* CRC Info */
1745
1746 typedef uint8_t (*MacSchDlRlcBoInfoFunc) ARGS((
1747          Pst         *pst,         /* Post structure */
1748          DlRlcBoInfo *dlBoInfo));   /* DL BO Info */
1749
1750 typedef uint8_t (*MacSchAddUeConfigReqFunc) ARGS((
1751          Pst         *pst,           /* Post structure */
1752          SchUeCfg    *ueCfgToSch));   /* Scheduler UE Cfg */
1753
1754 typedef uint8_t (*SchUeCfgRspFunc) ARGS((
1755          Pst         *pst,           /* Post structure */
1756          SchUeCfgRsp *cfgRsp));       /* Scheduler UE Cfg response */
1757
1758 typedef uint8_t (*MacSchSlotIndFunc) ARGS((
1759          Pst         *pst,          /* Post structure */
1760          SlotTimingInfo *slotInd));    /* Slot Info */
1761
1762 typedef uint8_t (*MacSchBsrFunc)       ARGS((
1763    Pst                  *pst,
1764    UlBufferStatusRptInd *bsrInd
1765 ));
1766
1767 typedef uint8_t (*MacSchSrUciIndFunc) ARGS(( 
1768          Pst         *pst,         /* Post structure */
1769          SrUciIndInfo  *uciInd));    /* UCI IND Info */
1770
1771 typedef uint8_t (*MacSchModUeConfigReqFunc) ARGS((
1772          Pst         *pst,           /* Post structure */
1773          SchUeCfg    *ueCfgToSch));   /* Scheduler UE Cfg */
1774
1775 typedef uint8_t (*SchUeReCfgRspFunc) ARGS((
1776          Pst         *pst,           /* Post structure */
1777          SchUeCfgRsp *cfgRsp));       /* Scheduler UE Cfg response */
1778
1779 typedef uint8_t (*MacSchRachRsrcReqFunc) ARGS((
1780     Pst         *pst,                    /* Post structure */
1781     SchRachRsrcReq *schRachRsrcReq));    /* RACH resource request to SCH */
1782
1783 typedef uint8_t (*SchRachRsrcRspFunc) ARGS((
1784    Pst            *pst,                 /* Post structure */
1785    SchRachRsrcRsp *schRachRsrcRsp));    /* RACH resource request to MAC */
1786
1787 typedef uint8_t (*MacSchUeDeleteReqFunc) ARGS((
1788    Pst         *pst,           /* Post structure */
1789    SchUeDelete *schUeDel)); /*Scheduler UE Del*/
1790
1791 typedef uint8_t (*SchUeDeleteRspFunc) ARGS((
1792    Pst          *pst,           /* Post structure */
1793    SchUeDeleteRsp *delRsp));       /* Scheduler UE delete response */
1794
1795 typedef uint8_t (*MacSchCellDeleteReqFunc) ARGS((
1796    Pst         *pst,           /* Post structure */
1797    SchCellDelete *schCellDelete)); /*Scheduler UE Del*/
1798
1799 typedef uint8_t (*SchCellDeleteRspFunc) ARGS((
1800    Pst          *pst,           /* Post structure */
1801    SchCellDeleteRsp *schCellDeleteRsp));       /* Scheduler UE delete response */
1802
1803 typedef uint8_t (*MacSchSliceCfgReqFunc) ARGS((
1804    Pst          *pst,           /* Post structure */
1805    SchSliceCfgReq *schSliceCfgReq));  /* Scheduler Slice Cfg Req */
1806
1807 typedef uint8_t (*SchSliceCfgRspFunc)    ARGS((
1808          Pst            *pst,            /* Post Structure */                         
1809          SchSliceCfgRsp  *schSliceCfgRsp /* Cell Cfg Cfm */
1810          ));
1811
1812 typedef uint8_t (*MacSchSliceReCfgReqFunc) ARGS((
1813    Pst          *pst,           /* Post structure */
1814    SchSliceCfgReq *schSliceReCfgReq));  /* Scheduler Slice ReCfg Req */
1815
1816 typedef uint8_t (*SchSliceReCfgRspFunc)    ARGS((
1817          Pst            *pst,            /* Post Structure */                         
1818          SchSliceCfgRsp  *schSliceReCfgRsp /* Cell ReCfg Cfm */
1819          ));
1820
1821 typedef uint8_t (*MacSchPagingIndFunc) ARGS((
1822    Pst         *pst,           /* Post structure */
1823    SchPageInd *schPagingInd)); /* Paging Indication */
1824
1825 /* function declarations */
1826 uint8_t packMacSchSlotInd(Pst *pst, SlotTimingInfo *slotInd);
1827 uint8_t packSchMacDlAlloc(Pst *pst, DlSchedInfo  *dlSchedInfo);
1828 uint8_t packSchMacUlSchInfo(Pst *pst, UlSchedInfo *ulSchedInfo);
1829 uint8_t packSchCellCfg(Pst *pst, SchCellCfg  *schCellCfg);
1830 uint8_t packSchCellCfgCfm(Pst *pst, SchCellCfgCfm  *schCellCfgCfm);
1831 uint8_t MacProcDlAlloc(Pst *pst, DlSchedInfo *dlSchedInfo);
1832 uint8_t MacProcSchCellCfg(Pst *pst, SchCellCfg  *schCellCfg);
1833 uint8_t MacProcSchCellCfgCfm(Pst *pst, SchCellCfgCfm  *schCellCfgCfm);
1834 uint8_t SchHdlCellCfgReq(Pst *pst, SchCellCfg *schCellCfg);
1835 uint8_t schActvInit(Ent entity, Inst instId, Region region, Reason reason);
1836 uint8_t MacProcUlSchInfo(Pst *pst, UlSchedInfo *ulSchedInfo);
1837 uint8_t packMacSchRachInd(Pst *pst, RachIndInfo *rachInd);
1838 uint8_t MacSchRachInd(Pst *pst, RachIndInfo *rachInd);
1839 uint8_t packMacSchCrcInd(Pst *pst, CrcIndInfo *crcInd);
1840 uint8_t MacSchCrcInd(Pst *pst, CrcIndInfo *crcInd);
1841 uint8_t packMacSchDlRlcBoInfo(Pst *pst, DlRlcBoInfo *dlBoInfo);
1842 uint8_t MacSchDlRlcBoInfo(Pst *pst, DlRlcBoInfo *dlBoInfo);
1843 uint8_t packMacSchAddUeConfigReq(Pst *pst, SchUeCfg *ueCfgToSch);
1844 uint8_t MacSchAddUeConfigReq(Pst *pst, SchUeCfg *ueCfgToSch);
1845 uint8_t packSchUeCfgRsp(Pst *pst, SchUeCfgRsp *cfgRsp);
1846 uint8_t MacProcSchUeCfgRsp(Pst *pst, SchUeCfgRsp *cfgRsp);
1847 uint8_t MacSchSlotInd ARGS((Pst * pst, SlotTimingInfo * slotInd));
1848 uint8_t packMacSchSlotInd(Pst * pst, SlotTimingInfo * slotInd);
1849 uint8_t unpackMacSchSlotInd(MacSchSlotIndFunc func, Pst *pst, Buffer  *mBuf);
1850 uint8_t packMacSchBsr(Pst *pst, UlBufferStatusRptInd *bsrInd);
1851 uint8_t MacSchBsr(Pst *pst, UlBufferStatusRptInd *bsrInd);
1852 uint8_t packMacSchSrUciInd(Pst *pst, SrUciIndInfo *uciInd);
1853 uint8_t MacSchSrUciInd(Pst *pst, SrUciIndInfo *uciInd);
1854 uint8_t packMacSchModUeConfigReq(Pst *pst, SchUeCfg *ueCfgToSch);
1855 uint8_t MacSchModUeConfigReq(Pst *pst, SchUeCfg *ueCfgToSch);
1856 uint8_t packSchUeReconfigRsp(Pst *pst, SchUeCfgRsp *cfgRsp);
1857 uint8_t MacProcSchUeReconfigRsp(Pst *pst, SchUeCfgRsp *cfgRsp);
1858 uint8_t packMacSchRachRsrcReq(Pst *pst, SchRachRsrcReq *schRachRsrcReq);
1859 uint8_t MacSchRachRsrcReq(Pst *pst, SchRachRsrcReq *schRachRsrcReq);
1860 uint8_t packSchRachRsrcRsp(Pst *pst, SchRachRsrcRsp *schRachRsrcRsp);
1861 uint8_t MacProcSchRachRsrcRsp(Pst *pst, SchRachRsrcRsp *schRachRsrcRsp);
1862 uint8_t packMacSchUeDeleteReq(Pst *pst,  SchUeDelete *schUeDel);
1863 uint8_t MacSchUeDeleteReq(Pst *pst, SchUeDelete  *ueDelete);
1864 uint8_t packSchUeDeleteRsp(Pst *pst, SchUeDeleteRsp  *delRsp);
1865 uint8_t MacProcSchUeDeleteRsp(Pst *pst, SchUeDeleteRsp *schUeDelRsp);
1866 uint8_t packMacSchCellDeleteReq(Pst *pst,  SchCellDelete *schCellDelete);
1867 uint8_t MacSchCellDeleteReq(Pst *pst, SchCellDelete  *schCellDelete);
1868 uint8_t packSchCellDeleteRsp(Pst *pst, SchCellDeleteRsp  *schCellDeleteRsp);
1869 uint8_t MacProcSchCellDeleteRsp(Pst *pst, SchCellDeleteRsp *schCellDeleteRsp);
1870 uint8_t packMacSchSliceCfgReq(Pst *pst, SchSliceCfgReq *cfgReq);
1871 uint8_t MacSchSliceCfgReq(Pst *pst, SchSliceCfgReq *schSliceCfgReq);
1872 uint8_t packSchSliceCfgRsp(Pst *pst, SchSliceCfgRsp *cfgRsp);
1873 uint8_t MacProcSchSliceCfgRsp(Pst *pst, SchSliceCfgRsp *cfgRsp);
1874 uint8_t packMacSchSliceReCfgReq(Pst *pst, SchSliceCfgReq *cfgReq);
1875 uint8_t MacSchSliceReCfgReq(Pst *pst, SchSliceCfgReq *schSliceCfgReq);
1876 uint8_t packSchSliceReCfgRsp(Pst *pst, SchSliceCfgRsp *cfgRsp);
1877 uint8_t MacProcSchSliceReCfgRsp(Pst *pst, SchSliceCfgRsp *sliceReCfgrsp);
1878 uint8_t packMacSchPagingInd(Pst *pst,  SchPageInd *pageInd);
1879 uint8_t MacSchPagingInd(Pst *pst,  SchPageInd *pageInd);
1880 /**********************************************************************
1881   End of file
1882  **********************************************************************/
1883