defs.h 35.4 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/*
 * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The OpenAirInterface Software Alliance licenses this file to You under
 * the OAI Public License, Version 1.0  (the "License"); you may not use this file
 * except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.openairinterface.org/?page_id=698
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *-------------------------------------------------------------------------------
 * For more information about the OpenAirInterface (OAI) Software Alliance:
 *      contact@openairinterface.org
 */

22
/*! \file LAYER2/MAC/defs.h
23
* \brief MAC data structures, constant, and function prototype
24
* \author Navid Nikaein and Raymond Knopp
25
26
* \date 2011
* \version 0.5
27
* \email navid.nikaein@eurecom.fr
28
29

*/
30
31
32
33
/** @defgroup _oai2  openair2 Reference Implementation
 * @ingroup _ref_implementation_
 * @{
 */
34

35
/*@}*/
36

37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#ifndef __LAYER2_MAC_DEFS_H__
#define __LAYER2_MAC_DEFS_H__



#ifdef USER_MODE
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#endif

//#include "COMMON/openair_defs.h"

#include "COMMON/platform_constants.h"
#include "COMMON/mac_rrc_primitives.h"
#include "PHY/defs.h"
#include "RadioResourceConfigCommon.h"
#include "RadioResourceConfigDedicated.h"
#include "MeasGapConfig.h"
#include "TDD-Config.h"
#include "RACH-ConfigCommon.h"
#include "MeasObjectToAddModList.h"
59
#include "MobilityControlInfo.h"
60
61
62
63
#ifdef Rel10
#include "MBSFN-AreaInfoList-r9.h"
#include "MBSFN-SubframeConfigList.h"
#include "PMCH-InfoList-r9.h"
knopp's avatar
   
knopp committed
64
#include "SCellToAddMod-r10.h"
65
66
67
68
69
70
#endif

//#ifdef PHY_EMUL
//#include "SIMULATION/PHY_EMULATION/impl_defs.h"
//#endif

71
72
/** @defgroup _mac  MAC
 * @ingroup _oai2
73
74
75
 * @{
 */

76
#define BCCH_PAYLOAD_SIZE_MAX 128
77
#define CCCH_PAYLOAD_SIZE_MAX 128
78
#define PCCH_PAYLOAD_SIZE_MAX 128
79

80
81
82
83
84
#define SCH_PAYLOAD_SIZE_MAX 4096
/// Logical channel ids from 36-311 (Note BCCH is not specified in 36-311, uses the same as first DRB)

#ifdef Rel10

85
// Mask for identifying subframe for MBMS
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#define MBSFN_TDD_SF3 0x80// for TDD
#define MBSFN_TDD_SF4 0x40
#define MBSFN_TDD_SF7 0x20
#define MBSFN_TDD_SF8 0x10
#define MBSFN_TDD_SF9 0x08
#define MBSFN_FDD_SF1 0x80// for FDD
#define MBSFN_FDD_SF2 0x40
#define MBSFN_FDD_SF3 0x20
#define MBSFN_FDD_SF6 0x10
#define MBSFN_FDD_SF7 0x08
#define MBSFN_FDD_SF8 0x04

#define MAX_MBSFN_AREA 8
#define MAX_PMCH_perMBSFN 15
100
/*!\brief MAX MCCH payload size  */
101
#define MCCH_PAYLOAD_SIZE_MAX 128
102
//#define MCH_PAYLOAD_SIZE_MAX 16384// this value is using in case mcs and TBS index are high
103
104
105
106
107
108
#endif

#ifdef USER_MODE
#define printk printf
#endif //USER_MODE

109
/*!\brief Maximum number of logical channl group IDs */
110
#define MAX_NUM_LCGID 4
111
112
113
114
115
116
117
118
119
/*!\brief logical channl group ID 0 */
#define LCGID0 0
/*!\brief logical channl group ID 1 */
#define LCGID1 1
/*!\brief logical channl group ID 2 */
#define LCGID2 2
/*!\brief logical channl group ID 3 */
#define LCGID3 3
/*!\brief Maximum number of logical chanels */
120
#define MAX_NUM_LCID 11
121
/*!\brief Maximum number od control elemenets */
122
#define MAX_NUM_CE 5
123
/*!\brief Maximum number of random access process */
124
#define NB_RA_PROC_MAX 4
125
/*!\brief size of buffer status report table */
126
#define BSR_TABLE_SIZE 64
127
/*!\brief The power headroom reporting range is from -23 ...+40 dB and beyond, with step 1 */
128
#define PHR_MAPPING_OFFSET 23  // if ( x>= -23 ) val = floor (x + 23) 
129
/*!\brief maximum number of resource block groups */
130
#define N_RBG_MAX 25 // for 20MHz channel BW
131
/*!\brief minimum value for channel quality indicator */
132
#define MIN_CQI_VALUE  0
133
/*!\brief maximum value for channel quality indicator */
134
#define MAX_CQI_VALUE  15
135
136
137
138
/*!\briefmaximum number of supported bandwidth (1.4, 5, 10, 20 MHz) */
#define MAX_SUPPORTED_BW  4  
/*!\brief CQI values range from 1 to 15 (4 bits) */
#define CQI_VALUE_RANGE 16 
139

Bilel's avatar
Bilel committed
140
/*!\brief value for indicating BSR Timer is not running */
Bilel's avatar
Bilel committed
141
#define MAC_UE_BSR_TIMER_NOT_RUNNING   (0xFFFF)
142

143
144
145
#define LCID_EMPTY 0
#define LCID_NOT_EMPTY 1

Bilel's avatar
Bilel committed
146
147
148
149
150
151
/*!\brief minimum RLC PDU size to be transmitted = min RLC Status PDU or RLC UM PDU SN 5 bits */
#define MIN_RLC_PDU_SIZE    (2)

/*!\brief minimum MAC data needed for transmitting 1 min RLC PDU size + 1 byte MAC subHeader */
#define MIN_MAC_HDR_RLC_SIZE    (1 + MIN_RLC_PDU_SIZE)

152
153
154
/* 
 * eNB part 
 */ 
155

156
157
158
159
160

/* 
 * UE/ENB common part 
 */ 
/*!\brief MAC header of Random Access Response for Random access preamble identifier (RAPID) */
161
typedef struct {
gauthier's avatar
gauthier committed
162
163
164
  uint8_t RAPID:6;
  uint8_t T:1;
  uint8_t E:1;
165
166
} __attribute__((__packed__))RA_HEADER_RAPID;

167
/*!\brief  MAC header of Random Access Response for backoff indicator (BI)*/
168
typedef struct {
gauthier's avatar
gauthier committed
169
170
171
172
  uint8_t BI:4;
  uint8_t R:2;
  uint8_t T:1;
  uint8_t E:1;
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
} __attribute__((__packed__))RA_HEADER_BI;
/*
typedef struct {
  uint64_t padding:16;
  uint64_t t_crnti:16;
  uint64_t hopping_flag:1;
  uint64_t rb_alloc:10;
  uint64_t mcs:4;
  uint64_t TPC:3;
  uint64_t UL_delay:1;
  uint64_t cqi_req:1;
  uint64_t Timing_Advance_Command:11;  // first/2nd octet LSB
  uint64_t R:1;                        // octet MSB
  } __attribute__((__packed__))RAR_PDU;

typedef struct {
  uint64_t padding:16;
  uint64_t R:1;                        // octet MSB
  uint64_t Timing_Advance_Command:11;  // first/2nd octet LSB
  uint64_t cqi_req:1;
  uint64_t UL_delay:1;
  uint64_t TPC:3;
  uint64_t mcs:4;
  uint64_t rb_alloc:10;
  uint64_t hopping_flag:1;
  uint64_t t_crnti:16;
  } __attribute__((__packed__))RAR_PDU;

#define sizeof_RAR_PDU 6
*/
203
/*!\brief  MAC subheader short with 7bit Length field */
204
typedef struct {
gauthier's avatar
gauthier committed
205
206
207
208
209
  uint8_t LCID:5;  // octet 1 LSB
  uint8_t E:1;
  uint8_t R:2;     // octet 1 MSB
  uint8_t L:7;     // octet 2 LSB
  uint8_t F:1;     // octet 2 MSB
210
} __attribute__((__packed__))SCH_SUBHEADER_SHORT;
211
/*!\brief  MAC subheader long  with 15bit Length field */
212
typedef struct {
gauthier's avatar
gauthier committed
213
214
215
216
217
218
219
  uint8_t LCID:5;   // octet 1 LSB
  uint8_t E:1;
  uint8_t R:2;      // octet 1 MSB
  uint8_t L_MSB:7;
  uint8_t F:1;      // octet 2 MSB
  uint8_t L_LSB:8;
  uint8_t padding;
220
} __attribute__((__packed__))SCH_SUBHEADER_LONG;
221
/*!\brief MAC subheader short without length field */
222
typedef struct {
gauthier's avatar
gauthier committed
223
224
225
  uint8_t LCID:5;
  uint8_t E:1;
  uint8_t R:2;
226
227
} __attribute__((__packed__))SCH_SUBHEADER_FIXED;

228
/*!\brief  mac control element: short buffer status report for a specific logical channel group ID*/
229
typedef struct {
gauthier's avatar
gauthier committed
230
231
  uint8_t Buffer_size:6;  // octet 1 LSB
  uint8_t LCGID:2;        // octet 1 MSB
232
233
234
} __attribute__((__packed__))BSR_SHORT;

typedef BSR_SHORT BSR_TRUNCATED;
235
/*!\brief  mac control element: long buffer status report for all logical channel group ID*/
236
typedef struct {
fnabet's avatar
fnabet committed
237
238
239
240
  uint8_t Buffer_size3:6;
  uint8_t Buffer_size2:6;
  uint8_t Buffer_size1:6;
  uint8_t Buffer_size0:6;
241
242
243
} __attribute__((__packed__))BSR_LONG;

#define BSR_LONG_SIZE  (sizeof(BSR_LONG))
244
/*!\brief  mac control element: timing advance  */
245
typedef struct {
gauthier's avatar
gauthier committed
246
247
  uint8_t TA:6;
  uint8_t R:2;
248
} __attribute__((__packed__))TIMING_ADVANCE_CMD;
249
/*!\brief  mac control element: power headroom report  */
250
typedef struct {
gauthier's avatar
gauthier committed
251
252
  uint8_t PH:6;
  uint8_t R:2;
253
254
} __attribute__((__packed__))POWER_HEADROOM_CMD;

255
/*!\brief  DCI PDU filled by MAC for the PHY  */
256
typedef struct {
gauthier's avatar
gauthier committed
257
258
  uint8_t Num_ue_spec_dci ;
  uint8_t Num_common_dci  ;
259
  //  uint32_t nCCE;
260
  uint32_t num_pdcch_symbols;
261
262
  DCI_ALLOC_t dci_alloc[NUM_DCI_MAX] ;
} DCI_PDU;
263
/*! \brief CCCH payload */
264
typedef struct {
265
  uint8_t payload[CCCH_PAYLOAD_SIZE_MAX] ;
266
} __attribute__((__packed__))CCCH_PDU;
267
/*! \brief BCCH payload */
268
typedef struct {
269
  uint8_t payload[BCCH_PAYLOAD_SIZE_MAX] ;
270
} __attribute__((__packed__))BCCH_PDU;
271
272
273
274
/*! \brief BCCH payload */
typedef struct {
  uint8_t payload[PCCH_PAYLOAD_SIZE_MAX] ;
} __attribute__((__packed__))PCCH_PDU;
275
276

#ifdef Rel10
277
/*! \brief MCCH payload */
278
typedef struct {
279
  uint8_t payload[MCCH_PAYLOAD_SIZE_MAX] ;
280
} __attribute__((__packed__))MCCH_PDU;
281
/*!< \brief MAC control element for activation and deactivation of component carriers */
282
283
284
285
286
287
288
289
290
291
typedef struct {
  uint8_t C7:1;/*!< \brief Component carrier 7 */
  uint8_t C6:1;/*!< \brief Component carrier 6 */
  uint8_t C5:1;/*!< \brief Component carrier 5 */
  uint8_t C4:1;/*!< \brief Component carrier 4 */
  uint8_t C3:1;/*!< \brief Component carrier 3 */
  uint8_t C2:1;/*!< \brief Component carrier 2 */
  uint8_t C1:1;/*!< \brief Component carrier 1 */
  uint8_t R:1;/*!< \brief Reserved  */
} __attribute__((__packed__))CC_ELEMENT;
292
/*! \brief MAC control element: MCH Scheduling Information */
293
typedef struct {
gauthier's avatar
gauthier committed
294
295
296
  uint8_t stop_sf_MSB:3; // octet 1 LSB
  uint8_t lcid:5;        // octet 2 MSB
  uint8_t stop_sf_LSB:8;
297
} __attribute__((__packed__))MSI_ELEMENT;
298
299
#endif
/*! \brief Values of CCCH LCID for DLSCH */ 
300
#define CCCH_LCHANID 0
301
302
/*!\brief Values of BCCH logical channel */
#define BCCH 3  // SI 
303
304
/*!\brief Values of PCCH logical channel */
#define PCCH 4  // Paging 
305
306
307
308
309
310
311
312
313
314
315
316
317
318
/*!\brief Value of CCCH / SRB0 logical channel */
#define CCCH 0  // srb0
/*!\brief DCCH / SRB1 logical channel */
#define DCCH 1  // srb1
/*!\brief DCCH1 / SRB2  logical channel */
#define DCCH1 2 // srb2
/*!\brief DTCH DRB1  logical channel */
#define DTCH 3 // LCID
/*!\brief MCCH logical channel */
#define MCCH 4 
/*!\brief MTCH logical channel */
#define MTCH 1 
// DLSCH LCHAN ID
/*!\brief LCID of UE contention resolution identity for DLSCH*/
319
#define UE_CONT_RES 28
320
/*!\brief LCID of timing advance for DLSCH */
321
#define TIMING_ADV_CMD 29
322
/*!\brief LCID of discontinous reception mode for DLSCH */
323
#define DRX_CMD 30
324
/*!\brief LCID of padding LCID for DLSCH */
325
326
327
328
#define SHORT_PADDING 31

#ifdef Rel10
// MCH LCHAN IDs (table6.2.1-4 TS36.321)
329
/*!\brief LCID of MCCH for DL */
330
#define MCCH_LCHANID 0
331
332
333
/*!\brief LCID of MCH scheduling info for DL */
#define MCH_SCHDL_INFO 3
/*!\brief LCID of Carrier component activation/deactivation */
334
#define CC_ACT_DEACT 27
335
336
337
#endif

// ULSCH LCHAN IDs
338
/*!\brief LCID of extended power headroom for ULSCH */
339
#define EXTENDED_POWER_HEADROOM 25
340
/*!\brief LCID of power headroom for ULSCH */
341
#define POWER_HEADROOM 26
342
/*!\brief LCID of CRNTI for ULSCH */
343
#define CRNTI 27
344
/*!\brief LCID of truncated BSR for ULSCH */
345
#define TRUNCATED_BSR 28
346
/*!\brief LCID of short BSR for ULSCH */
347
#define SHORT_BSR 29
348
/*!\brief LCID of long BSR for ULSCH */
349
#define LONG_BSR 30
fnabet's avatar
fnabet committed
350
351
352
353
354
/*!\bitmaps for BSR Triggers */
#define	BSR_TRIGGER_NONE		(0)			/* No BSR Trigger */
#define	BSR_TRIGGER_REGULAR		(1)			/* For Regular and ReTxBSR Expiry Triggers */
#define	BSR_TRIGGER_PERIODIC	(2)			/* For BSR Periodic Timer Expiry Trigger */
#define	BSR_TRIGGER_PADDING		(4)			/* For Padding BSR Trigger */
355
356


357
/*! \brief Downlink SCH PDU Structure */
358
typedef struct {
gauthier's avatar
gauthier committed
359
360
  int8_t payload[8][SCH_PAYLOAD_SIZE_MAX];
  uint16_t Pdu_size[8];
361
362
} __attribute__ ((__packed__)) DLSCH_PDU;

363
/*! \brief MCH PDU Structure */
364
typedef struct {
gauthier's avatar
gauthier committed
365
366
  int8_t payload[SCH_PAYLOAD_SIZE_MAX];
  uint16_t Pdu_size;
367
  uint8_t mcs;
368
369
370
  uint8_t sync_area;
  uint8_t msi_active;
  uint8_t mcch_active;
371
  uint8_t mtch_active;
372
373
} __attribute__ ((__packed__)) MCH_PDU;

374
/*! \brief Uplink SCH PDU Structure */
375
typedef struct {
gauthier's avatar
gauthier committed
376
377
  int8_t payload[SCH_PAYLOAD_SIZE_MAX];         /*!< \brief SACH payload */
  uint16_t Pdu_size;
378
379
380
381
} __attribute__ ((__packed__)) ULSCH_PDU;

#include "PHY/impl_defs_top.h"

382
/*!\brief  UE ULSCH scheduling states*/
383
384
385
typedef enum {
  S_UL_NONE =0,
  S_UL_WAITING,
386
387
  S_UL_SCHEDULED,
  S_UL_BUFFERED,
388
389
390
  S_UL_NUM_STATUS
} UE_ULSCH_STATUS;

391
/*!\brief  UE DLSCH scheduling states*/
392
393
394
typedef enum {
  S_DL_NONE =0,
  S_DL_WAITING,
395
396
  S_DL_SCHEDULED,
  S_DL_BUFFERED,
397
398
399
  S_DL_NUM_STATUS
} UE_DLSCH_STATUS;

400
/*!\brief  scheduling policy for the contention-based access */
401
typedef enum {
402
403
404
405
406
  CBA_ES=0, /// equal share of RB among groups w
  CBA_ES_S,  /// equal share of RB among groups with small allocation
  CBA_PF, /// proportional fair (kind of)
  CBA_PF_S,  /// proportional fair (kind of) with small RB allocation
  CBA_RS /// random allocation
407
408
409
} CBA_POLICY;


410
/*! \brief temporary struct for ULSCH sched */
411
typedef struct {
gauthier's avatar
gauthier committed
412
  rnti_t rnti;
gauthier's avatar
gauthier committed
413
414
  uint16_t subframe;
  uint16_t serving_num;
415
416
  UE_ULSCH_STATUS status;
} eNB_ULSCH_INFO;
417
/*! \brief temp struct for DLSCH sched */
418
typedef struct {
gauthier's avatar
gauthier committed
419
  rnti_t rnti;
gauthier's avatar
gauthier committed
420
421
422
  uint16_t weight;
  uint16_t subframe;
  uint16_t serving_num;
423
424
  UE_DLSCH_STATUS status;
} eNB_DLSCH_INFO;
425
/*! \brief eNB overall statistics */
426
typedef struct {
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
  /// num BCCH PDU per CC 
  uint32_t total_num_bcch_pdu;
  /// BCCH buffer size  
  uint32_t bcch_buffer;
  /// total BCCH buffer size  
  uint32_t total_bcch_buffer;
  /// BCCH MCS
  uint32_t bcch_mcs;

  /// num CCCH PDU per CC 
  uint32_t total_num_ccch_pdu;
  /// BCCH buffer size  
  uint32_t ccch_buffer;
  /// total BCCH buffer size  
  uint32_t total_ccch_buffer;
  /// BCCH MCS
  uint32_t ccch_mcs;

/// num active users
446
447
448
449
450
  uint16_t num_dlactive_UEs;
  ///  available number of PRBs for a give SF
  uint16_t available_prbs;
  /// total number of PRB available for the user plane
  uint32_t total_available_prbs;
451
452
  /// aggregation
  /// total avilable nccc : num control channel element
453
  uint16_t available_ncces;
454
455
  // only for a new transmission, should be extended for retransmission
  // current dlsch  bit rate for all transport channels
456
457
458
459
460
  uint32_t dlsch_bitrate;
  //
  uint32_t dlsch_bytes_tx;
  //
  uint32_t dlsch_pdus_tx;
461
  //
462
463
464
465
466
  uint32_t total_dlsch_bitrate;
  //
  uint32_t total_dlsch_bytes_tx;
  //
  uint32_t total_dlsch_pdus_tx;
467
468
  
  // here for RX
469
470
471
472
473
  //
  uint32_t ulsch_bitrate;
  //
  uint32_t ulsch_bytes_rx;
  //
474
475
476
477
478
479
480
481
  uint64_t ulsch_pdus_rx; 

  uint32_t total_ulsch_bitrate;
  //
  uint32_t total_ulsch_bytes_rx;
  //
  uint32_t total_ulsch_pdus_rx;
  
482
483
484
485
486
487
488
  
  /// MAC agent-related stats
  /// total number of scheduling decisions
  int sched_decisions;
  /// missed deadlines
  int missed_deadlines;

489
} eNB_STATS;
490
/*! \brief eNB statistics for the connected UEs*/
491
typedef struct {
492
493

  /// CRNTI of UE
gauthier's avatar
gauthier committed
494
  rnti_t crnti; ///user id (rnti) of connected UEs
495
  // rrc status
496
497
498
  uint8_t rrc_status;
  /// harq pid
  uint8_t harq_pid;
499
  /// harq rounf
500
  uint8_t harq_round;
501
  /// DL Wideband CQI index (2 TBs)
502
503
504
505
506
  uint8_t dl_cqi;
  /// total available number of PRBs for a new transmission
  uint16_t rbs_used;
  /// total available number of PRBs for a retransmission
  uint16_t rbs_used_retx;
507
  /// total nccc used for a new transmission: num control channel element
508
  uint16_t ncce_used;
509
  /// total avilable nccc for a retransmission: num control channel element
510
  uint16_t ncce_used_retx;
511
512

  // mcs1 before the rate adaptaion
513
  uint8_t dlsch_mcs1;
514
  /// Target mcs2 after rate-adaptation
515
  uint8_t dlsch_mcs2;
516
  //  current TBS with mcs2
517
  uint32_t TBS;
518
  //  total TBS with mcs2
519
  //  uint32_t total_TBS;
520
  //  total rb used for a new transmission
521
  uint32_t total_rbs_used;
522
  //  total rb used for retransmission
523
  uint32_t total_rbs_used_retx;
524

525
   /// TX
526
527
528
529
530
531
532
533
  /// Num pkt
  uint32_t num_pdu_tx[NB_RB_MAX];
  /// num bytes
  uint32_t num_bytes_tx[NB_RB_MAX];
  /// num retransmission / harq
  uint32_t num_retransmission;
  /// instantaneous tx throughput for each TTI
  //  uint32_t tti_throughput[NB_RB_MAX];
534
535

  /// overall
536
  //
537
538
539
540
  uint32_t  dlsch_bitrate;
  //total
  uint32_t  total_dlsch_bitrate;
  /// headers+ CE +  padding bytes for a MAC PDU
541
  uint64_t overhead_bytes;
542
  /// headers+ CE +  padding bytes for a MAC PDU
543
  uint64_t total_overhead_bytes;
544
  /// headers+ CE +  padding bytes for a MAC PDU
545
  uint64_t avg_overhead_bytes;
546
  // MAC multiplexed payload
547
548
549
  uint64_t total_sdu_bytes;
  // total MAC pdu bytes
  uint64_t total_pdu_bytes;
550

551
552
553
554
  // total num pdu
  uint32_t total_num_pdus;
  //
  //  uint32_t avg_pdu_size;
555
556

  /// RX
557
558
559
560
561
562

  /// preassigned mcs after rate adaptation
  uint8_t ulsch_mcs1;
  /// adjusted mcs
  uint8_t ulsch_mcs2;

563
564
565
566
  /// estimated average pdu inter-departure time
  uint32_t avg_pdu_idt;
  /// estimated average pdu size
  uint32_t avg_pdu_ps;
567
  ///
568
569
  uint32_t aggregated_pdu_size;
  uint32_t aggregated_pdu_arrival;
570

571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
  ///  uplink transport block size
  uint32_t ulsch_TBS;

  ///  total rb used for a new uplink transmission
  uint32_t num_retransmission_rx;
  ///  total rb used for a new uplink transmission
  uint32_t rbs_used_rx;
   ///  total rb used for a new uplink retransmission
  uint32_t rbs_used_retx_rx;
  ///  total rb used for a new uplink transmission
  uint32_t total_rbs_used_rx;
  /// normalized rx power 
  int32_t      normalized_rx_power;
   /// target rx power 
  int32_t    target_rx_power;

587
  /// num rx pdu
588
  uint32_t num_pdu_rx[NB_RB_MAX];
589
  /// num bytes rx
590
  uint32_t num_bytes_rx[NB_RB_MAX];
591
  /// instantaneous rx throughput for each TTI
592
  //  uint32_t tti_goodput[NB_RB_MAX];
593
594
  /// errors
  uint32_t num_errors_rx;
595
596
597
598
599
600
601
602
603
604
  
  uint64_t overhead_bytes_rx;
  /// headers+ CE +  padding bytes for a MAC PDU
  uint64_t total_overhead_bytes_rx;
  /// headers+ CE +  padding bytes for a MAC PDU
  uint64_t avg_overhead_bytes_rx;
 //
  uint32_t  ulsch_bitrate;
  //total
  uint32_t  total_ulsch_bitrate;
605
  /// overall
606
607
  ///  MAC pdu bytes
  uint64_t pdu_bytes_rx;
608
  /// total MAC pdu bytes
609
  uint64_t total_pdu_bytes_rx;
610
  /// total num pdu
611
  uint32_t total_num_pdus_rx;
612
  /// num of error pdus
613
  uint32_t total_num_errors_rx;
614

615
} eNB_UE_STATS;
616
/*! \brief eNB template for UE context information  */
617
typedef struct {
618
  /// C-RNTI of UE
gauthier's avatar
gauthier committed
619
  rnti_t rnti;
620
621
622
623
  /// NDI from last scheduling
  uint8_t oldNDI[8];
  /// NDI from last UL scheduling
  uint8_t oldNDI_UL[8];
624
  /// Flag to indicate UL has been scheduled at least once
gauthier's avatar
gauthier committed
625
  boolean_t ul_active;
knopp's avatar
   
knopp committed
626
627
  /// Flag to indicate UE has been configured (ACK from RRCConnectionSetup received)
  boolean_t configured;
628

629
630
631
632
633
634
  /// MCS from last scheduling
  uint8_t mcs[8];

  /// TPC from last scheduling
  uint8_t oldTPC[8];

635
636
637
  // PHY interface info

  /// DCI format for DLSCH
gauthier's avatar
gauthier committed
638
  uint16_t DLSCH_dci_fmt;
639

640
  /// Current Aggregation Level for DCI
gauthier's avatar
gauthier committed
641
  uint8_t DCI_aggregation_min;
642

643
  /// size of DLSCH size in bit 
gauthier's avatar
gauthier committed
644
  uint8_t DLSCH_dci_size_bits;
645
646

  /// DCI buffer for DLSCH
647
648
649
  /* rounded to 32 bits unit (actual value should be 8 due to the logic
   * of the function generate_dci0) */
  uint8_t DLSCH_DCI[8][(((MAX_DCI_SIZE_BITS)+31)>>5)*4];
650
651

  /// Number of Allocated RBs for DL after scheduling (prior to frequency allocation)
652
  uint16_t nb_rb[8]; // num_max_harq
653
654

  /// Number of Allocated RBs for UL after scheduling (prior to frequency allocation)
655
  uint16_t nb_rb_ul[8]; // num_max_harq
656

657
658
  /// Number of Allocated RBs by the ulsch preprocessor
  uint8_t pre_allocated_nb_rb_ul;
659

660
661
  /// index of Allocated RBs by the ulsch preprocessor
  int8_t pre_allocated_rb_table_index_ul;
662

663
664
  /// total allocated RBs
  int8_t total_allocated_rbs;
665

666
  /// pre-assigned MCS by the ulsch preprocessor
667
  uint8_t pre_assigned_mcs_ul;
668
669
670
671

  /// assigned MCS by the ulsch scheduler
  uint8_t assigned_mcs_ul;

672
  /// DCI buffer for ULSCH
673
674
675
  /* rounded to 32 bits unit (actual value should be 8 due to the logic
   * of the function generate_dci0) */
  uint8_t ULSCH_DCI[8][(((MAX_DCI_SIZE_BITS)+31)>>5)*4];
676
677

  /// DL DAI
gauthier's avatar
gauthier committed
678
  uint8_t DAI;
679
680

  /// UL DAI
gauthier's avatar
gauthier committed
681
  uint8_t DAI_ul[10];
682
683

  /// UL Scheduling Request Received
gauthier's avatar
gauthier committed
684
  uint8_t ul_SR;
685

686
  ///Resource Block indication for each sub-band in MU-MIMO
gauthier's avatar
gauthier committed
687
  uint8_t rballoc_subband[8][50];
688
689
690

  // Logical channel info for link with RLC

691
  /// Last received UE BSR info for each logical channel group id
gauthier's avatar
gauthier committed
692
  uint8_t bsr_info[MAX_NUM_LCGID];
693

694
695
696
  /// LCGID mapping
  long lcgidmap[11];

697
  /// phr information
698
  int8_t phr_info;
699

700
701
702
  /// phr information
  int8_t phr_info_configured;

703
  ///dl buffer info
gauthier's avatar
gauthier committed
704
  uint32_t dl_buffer_info[MAX_NUM_LCID];
705
  /// total downlink buffer info
gauthier's avatar
gauthier committed
706
  uint32_t dl_buffer_total;
707
  /// total downlink pdus
gauthier's avatar
gauthier committed
708
  uint32_t dl_pdus_total;
709
  /// downlink pdus for each LCID
gauthier's avatar
gauthier committed
710
  uint32_t dl_pdus_in_buffer[MAX_NUM_LCID];
711
  /// creation time of the downlink buffer head for each LCID
gauthier's avatar
gauthier committed
712
  uint32_t dl_buffer_head_sdu_creation_time[MAX_NUM_LCID];
713
  /// maximum creation time of the downlink buffer head across all LCID
714
  uint32_t  dl_buffer_head_sdu_creation_time_max;
715
  /// a flag indicating that the downlink head SDU is segmented  
gauthier's avatar
gauthier committed
716
  uint8_t    dl_buffer_head_sdu_is_segmented[MAX_NUM_LCID];
717
  /// size of remaining size to send for the downlink head SDU
gauthier's avatar
gauthier committed
718
  uint32_t dl_buffer_head_sdu_remaining_size_to_send[MAX_NUM_LCID];
719

720
  /// total uplink buffer size 
721
  uint32_t ul_total_buffer;
722
  /// uplink buffer creation time for each LCID
723
  uint32_t ul_buffer_creation_time[MAX_NUM_LCGID];
724
  /// maximum uplink buffer creation time across all the LCIDs
725
  uint32_t ul_buffer_creation_time_max;
726
  /// uplink buffer size per LCID
727
728
  uint32_t ul_buffer_info[MAX_NUM_LCGID];

729
730
731
  /// UE tx power
  int32_t ue_tx_power;

kaltenbe's avatar
kaltenbe committed
732
  /// stores the frame where the last TPC was transmitted
knopp's avatar
knopp committed
733
734
735
736
  uint32_t pusch_tpc_tx_frame;
  uint32_t pusch_tpc_tx_subframe;
  uint32_t pucch_tpc_tx_frame;
  uint32_t pucch_tpc_tx_subframe;
kaltenbe's avatar
kaltenbe committed
737

738
739
740
#ifdef LOCALIZATION
  eNB_UE_estimated_distances distance;
#endif
741
742
} UE_TEMPLATE;

743
/*! \brief scheduling control information set through an API (not used)*/
744
typedef struct {
745
  ///UL transmission bandwidth in RBs
746
  uint8_t ul_bandwidth[MAX_NUM_LCID];
747
  ///DL transmission bandwidth in RBs
748
  uint8_t dl_bandwidth[MAX_NUM_LCID];
749

750
751
  //To do GBR bearer
  uint8_t min_ul_bandwidth[MAX_NUM_LCID];
752

753
  uint8_t min_dl_bandwidth[MAX_NUM_LCID];
754

755
  ///aggregated bit rate of non-gbr bearer per UE
756
  uint64_t  ue_AggregatedMaximumBitrateDL;
757
  ///aggregated bit rate of non-gbr bearer per UE
758
  uint64_t  ue_AggregatedMaximumBitrateUL;
759
  ///CQI scheduling interval in subframes.
760
  uint16_t cqiSchedInterval;
761
  ///Contention resolution timer used during random access
762
  uint8_t mac_ContentionResolutionTimer;
763

764
  uint16_t max_allowed_rbs[MAX_NUM_LCID];
765

766
  uint8_t max_mcs[MAX_NUM_LCID];
767

768
  uint16_t priority[MAX_NUM_LCID];
769

770
771
772
773
774
775
  // resource scheduling information
  uint8_t       harq_pid[MAX_NUM_CCs];
  uint8_t       round[MAX_NUM_CCs];
  uint8_t       dl_pow_off[MAX_NUM_CCs];
  uint16_t      pre_nb_available_rbs[MAX_NUM_CCs];
  unsigned char rballoc_sub_UE[MAX_NUM_CCs][N_RBG_MAX];
776
  uint16_t      ta_timer;
777
778
  int16_t       ta_update;
  int32_t       context_active_timer;
779
  int32_t       cqi_req_timer;
780
  int32_t       ul_inactivity_timer;
781
  int32_t       ul_failure_timer;
782
  int32_t       ul_scheduled;
783
  int32_t       ra_pdcch_order_sent;
Florian Kaltenberger's avatar
Florian Kaltenberger committed
784
  int32_t       ul_out_of_sync;
785
  int32_t       phr_received;
786
} UE_sched_ctrl;
787
/*! \brief eNB template for the Random access information */
788
789
typedef struct {
  /// Flag to indicate this process is active
gauthier's avatar
gauthier committed
790
  boolean_t RA_active;
791
  /// Size of DCI for RA-Response (bytes)
gauthier's avatar
gauthier committed
792
  uint8_t RA_dci_size_bytes1;
793
  /// Size of DCI for RA-Response (bits)
gauthier's avatar
gauthier committed
794
  uint8_t RA_dci_size_bits1;
795
  /// Actual DCI to transmit for RA-Response
gauthier's avatar
gauthier committed
796
  uint8_t RA_alloc_pdu1[(MAX_DCI_SIZE_BITS>>3)+1];
797
  /// DCI format for RA-Response (should be 1A)
gauthier's avatar
gauthier committed
798
  uint8_t RA_dci_fmt1;
799
  /// Size of DCI for Msg4/ContRes (bytes)
gauthier's avatar
gauthier committed
800
  uint8_t RA_dci_size_bytes2;
801
  /// Size of DCI for Msg4/ContRes (bits)
gauthier's avatar
gauthier committed
802
  uint8_t RA_dci_size_bits2;
803
  /// Actual DCI to transmit for Msg4/ContRes
gauthier's avatar
gauthier committed
804
  uint8_t RA_alloc_pdu2[(MAX_DCI_SIZE_BITS>>3)+1];
805
  /// DCI format for Msg4/ContRes (should be 1A)
gauthier's avatar
gauthier committed
806
  uint8_t RA_dci_fmt2;
807
  /// Flag to indicate the eNB should generate RAR.  This is triggered by detection of PRACH
gauthier's avatar
gauthier committed
808
  uint8_t generate_rar;
809
  /// Subframe where preamble was received
gauthier's avatar
gauthier committed
810
  uint8_t preamble_subframe;
811
  /// Subframe where Msg3 is to be sent
gauthier's avatar
gauthier committed
812
  uint8_t Msg3_subframe;
813
  /// Flag to indicate the eNB should generate Msg4 upon reception of SDU from RRC.  This is triggered by first ULSCH reception at eNB for new user.
814
  uint8_t generate_Msg4;
815
  /// Flag to indicate that eNB is waiting for ACK that UE has received Msg3.
gauthier's avatar
gauthier committed
816
  uint8_t wait_ack_Msg4;
817
  /// UE RNTI allocated during RAR
gauthier's avatar
gauthier committed
818
  rnti_t rnti;
819
  /// RA RNTI allocated from received PRACH
gauthier's avatar
gauthier committed
820
  uint16_t RA_rnti;
821
  /// Received preamble_index
gauthier's avatar
gauthier committed
822
  uint8_t preamble_index;
823
  /// Received UE Contention Resolution Identifier
gauthier's avatar
gauthier committed
824
  uint8_t cont_res_id[6];
825
  /// Timing offset indicated by PHY
gauthier's avatar
gauthier committed
826
  int16_t timing_offset;
827
  /// Timeout for RRC connection
gauthier's avatar
gauthier committed
828
  int16_t RRC_timer;
829
830
831
} RA_TEMPLATE;


832
/*! \brief subband bitmap confguration (for ALU icic algo purpose), in test phase */
833
834
835
836
837
838
839
typedef struct {
  uint8_t sbmap[NUMBER_OF_SUBBANDS_MAX]; //13 = number of SB MAX for 100 PRB
  uint8_t periodicity;
  uint8_t first_subframe;
  uint8_t sb_size;
  uint8_t nb_active_sb;
} SBMAP_CONF;
840
/*! \brief UE list used by eNB to order UEs/CC for scheduling*/ 
841
typedef struct {
842
  /// DLSCH pdu 
knopp's avatar
   
knopp committed
843
844
845
846
847
  DLSCH_PDU DLSCH_pdu[MAX_NUM_CCs][2][NUMBER_OF_UE_MAX];
  /// DCI template and MAC connection parameters for UEs
  UE_TEMPLATE UE_template[MAX_NUM_CCs][NUMBER_OF_UE_MAX];
  /// DCI template and MAC connection for RA processes
  int pCC_id[NUMBER_OF_UE_MAX];
848
  /// sorted downlink component carrier for the scheduler 
knopp's avatar
   
knopp committed
849
  int ordered_CCids[MAX_NUM_CCs][NUMBER_OF_UE_MAX];
850
  /// number of downlink active component carrier 
knopp's avatar
   
knopp committed
851
  int numactiveCCs[NUMBER_OF_UE_MAX];
852
  /// sorted uplink component carrier for the scheduler 
knopp's avatar
   
knopp committed
853
  int ordered_ULCCids[MAX_NUM_CCs][NUMBER_OF_UE_MAX];
854
  /// number of uplink active component carrier 
knopp's avatar
   
knopp committed
855
  int numactiveULCCs[NUMBER_OF_UE_MAX];
856
  /// number of downlink active component carrier 
857
  uint8_t dl_CC_bitmap[NUMBER_OF_UE_MAX];
858
  /// eNB to UE statistics
knopp's avatar
   
knopp committed
859
  eNB_UE_STATS eNB_UE_stats[MAX_NUM_CCs][NUMBER_OF_UE_MAX];
860
  /// scheduling control info
knopp's avatar
   
knopp committed
861
862
863
  UE_sched_ctrl UE_sched_ctrl[NUMBER_OF_UE_MAX];

  int next[NUMBER_OF_UE_MAX];
864
  int head;
865
866
  int next_ul[NUMBER_OF_UE_MAX];
  int head_ul;
knopp's avatar
   
knopp committed
867
868
869
870
  int avail;
  int num_UEs;
  boolean_t active[NUMBER_OF_UE_MAX];
} UE_list_t;
871

872
/*! \brief eNB common channels */ 
873
typedef struct {
874
875
876
877
  /// Outgoing DCI for PHY generated by eNB scheduler
  DCI_PDU DCI_pdu;
  /// Outgoing BCCH pdu for PHY
  BCCH_PDU BCCH_pdu;
878
879
  /// Outgoing BCCH DCI allocation
  uint32_t BCCH_alloc_pdu;
880
881
882
  /// Outgoing CCCH pdu for PHY
  CCCH_PDU CCCH_pdu;
  RA_TEMPLATE RA_template[NB_RA_PROC_MAX];
883
884
  /// VRB map for common channels
  uint8_t vrb_map[100];
885
886
  /// MBSFN SubframeConfig
  struct MBSFN_SubframeConfig *mbsfn_SubframeConfig[8];
887
  /// number of subframe allocation pattern available for MBSFN sync area
gauthier's avatar
gauthier committed
888
  uint8_t num_sf_allocation_pattern;
889
#ifdef Rel10
890
  /// MBMS Flag
gauthier's avatar
gauthier committed
891
  uint8_t MBMS_flag;
892
893
894
  /// Outgoing MCCH pdu for PHY
  MCCH_PDU MCCH_pdu;
  /// MCCH active flag
gauthier's avatar
gauthier committed
895
  uint8_t msi_active;
896
  /// MCCH active flag
gauthier's avatar
gauthier committed
897
  uint8_t mcch_active;
898
  /// MTCH active flag
gauthier's avatar
gauthier committed
899
  uint8_t mtch_active;
900
  /// number of active MBSFN area
gauthier's avatar
gauthier committed
901
  uint8_t num_active_mbsfn_area;
902
903
904
905
906
907
908
909
910
911
  /// MBSFN Area Info
  struct  MBSFN_AreaInfo_r9 *mbsfn_AreaInfo[MAX_MBSFN_AREA];
  /// PMCH Config
  struct PMCH_Config_r9 *pmch_Config[MAX_PMCH_perMBSFN];
  /// MBMS session info list
  struct MBMS_SessionInfoList_r9 *mbms_SessionList[MAX_PMCH_perMBSFN];
  /// Outgoing MCH pdu for PHY
  MCH_PDU MCH_pdu;
#endif
#ifdef CBA
912
  /// number of CBA groups 
913
  uint8_t num_active_cba_groups;
914
  /// RNTI for each CBA group 
915
  uint16_t cba_rnti[NUM_MAX_CBA_GROUP];
916
  /// MCS for each CBA group 
917
  uint8_t group_mcs[NUM_MAX_CBA_GROUP];
918
919
#endif
} COMMON_channels_t;
920
/*! \brief top level eNB MAC structure */ 
921
922
typedef struct {
  ///
knopp's avatar
   
knopp committed
923
924
925
926
927
928
929
930
  uint16_t Node_id;
  /// frame counter
  frame_t frame;
  /// subframe counter
  sub_frame_t subframe;
  /// Common cell resources
  COMMON_channels_t common_channels[MAX_NUM_CCs];
  UE_list_t UE_list;
931

932
933
  ///subband bitmap configuration
  SBMAP_CONF sbmap_conf;
934
935
  /// CCE table used to build DCI scheduling information
  int CCE_table[MAX_NUM_CCs][800];
936
  ///  active flag for Other lcid
937
  uint8_t lcid_active[NB_RB_MAX];
938
  /// eNB stats
939
  eNB_STATS eNB_stats[MAX_NUM_CCs];
940
  // MAC function execution peformance profiler
941
  /// processing time of eNB scheduler 
942
  time_stats_t eNB_scheduler;
943
  /// processing time of eNB scheduler for SI 
944
  time_stats_t schedule_si;
945
  /// processing time of eNB scheduler for Random access
946
  time_stats_t schedule_ra;
947
  /// processing time of eNB ULSCH scheduler 
948
  time_stats_t schedule_ulsch;
nikaeinn's avatar