ran_context.h 3.46 KB
Newer Older
knopp's avatar
knopp committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/*
 * 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
 */

/*! \file PHY/impl_defs_lte.h
* \brief LTE Physical channel configuration and variable structure definitions
* \author R. Knopp, F. Kaltenberger
* \date 2011
* \version 0.1
* \company Eurecom
* \email: knopp@eurecom.fr,florian.kaltenberger@eurecom.fr
* \note
* \warning
*/

#ifndef __RAN_CONTEXT_H__
#define __RAN_CONTEXT_H__

#include <pthread.h>
#include "COMMON/platform_constants.h"
#include "PHY/defs.h"
#include "PHY/types.h"
#include "PHY/impl_defs_top.h"
#include "PHY/impl_defs_lte.h"
#include "RRC/LITE/defs.h"
43
#include "flexran_agent_defs.h"
knopp's avatar
knopp committed
44
45
46
47
48
49
50

#include "gtpv1u.h"
#include "NwGtpv1u.h"
#include "NwGtpv1uMsg.h"
#include "NwGtpv1uPrivate.h"
#include "gtpv1u_eNB_defs.h"

oai's avatar
oai committed
51
52
#include "PHY/defs_L1_NB_IoT.h"
#include "RRC/LITE/defs_NB_IoT.h"
knopp's avatar
knopp committed
53
54
55
typedef struct {
  /// RAN context config file name
  char *config_file_name;
56
  /// Number of RRC instances in this node
knopp's avatar
knopp committed
57
58
59
  int nb_inst;
  /// Number of Component Carriers per instance in this node
  int *nb_CC;
60
61
  /// Number of NB_IoT instances in this node
  int nb_nb_iot_rrc_inst;
62
63
  /// Number of MACRLC instances in this node
  int nb_macrlc_inst;
64
65
  /// Number of NB_IoT MACRLC instances in this node
  int nb_nb_iot_macrlc_inst;
66
67
  /// Number of component carriers per instance in this node
  int *nb_mac_CC;
68
69
  /// Number of L1 instances in this node
  int nb_L1_inst;
70
71
  /// Number of NB_IoT L1 instances in this node
  int nb_nb_iot_L1_inst;
72
73
74
  /// Number of Component Carriers per instance in this node
  int *nb_L1_CC;
  /// Number of RU instances in this node
knopp's avatar
knopp committed
75
  int nb_RU;
76
77
  /// FlexRAN context variables
  flexran_agent_info_t **flexran;
knopp's avatar
knopp committed
78
79
  /// eNB context variables
  struct PHY_VARS_eNB_s ***eNB;
80
  /// NB_IoT L1 context variables
oai's avatar
oai committed
81
  struct PHY_VARS_eNB_NB_IoT_s **L1_NB_IoT;
knopp's avatar
knopp committed
82
83
  /// RRC context variables
  struct eNB_RRC_INST_s **rrc;
84
85
86
  /// NB_IoT RRC context variables
  //struct eNB_RRC_INST_NB_IoT_s **nb_iot_rrc;
  /// MAC context variables
knopp's avatar
knopp committed
87
  struct eNB_MAC_INST_s **mac;
88
  /// NB_IoT MAC context variables
oai's avatar
oai committed
89
  struct eNB_MAC_INST_NB_IoT_s **nb_iot_mac;
knopp's avatar
knopp committed
90
91
92
93
94
95
96
97
98
99
100
101
102
103
  /// GTPu descriptor 
  gtpv1u_data_t *gtpv1u_data_g;
  /// RU descriptors. These describe what each radio unit is supposed to do and contain the necessary functions for fronthaul interfaces
  struct RU_t_s **ru;
  /// Mask to indicate fronthaul setup status of RU (hard-limit to 64 RUs)
  uint64_t ru_mask;
  /// Mutex for protecting ru_mask
  pthread_mutex_t ru_mutex;
  /// condition variable for signaling setup completion of an RU
  pthread_cond_t ru_cond;
} RAN_CONTEXT_t;


#endif