Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangjie
OpenXG-RAN
Commits
17c94ff8
Commit
17c94ff8
authored
Aug 23, 2017
by
Matthieu Kanj
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
renaming in file: openair2/RRC/LITE/extern_NB_IoT.h
parent
443af7af
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
183 additions
and
183 deletions
+183
-183
openair2/RRC/LITE/L2_interface_NB_IoT.c
openair2/RRC/LITE/L2_interface_NB_IoT.c
+27
-27
openair2/RRC/LITE/defs_NB_IoT.h
openair2/RRC/LITE/defs_NB_IoT.h
+2
-2
openair2/RRC/LITE/extern.h
openair2/RRC/LITE/extern.h
+1
-1
openair2/RRC/LITE/extern_NB_IoT.h
openair2/RRC/LITE/extern_NB_IoT.h
+12
-12
openair2/RRC/LITE/proto_NB_IoT.h
openair2/RRC/LITE/proto_NB_IoT.h
+4
-4
openair2/RRC/LITE/rrc_common_NB_IoT.c
openair2/RRC/LITE/rrc_common_NB_IoT.c
+16
-16
openair2/RRC/LITE/rrc_eNB_NB_IoT.c
openair2/RRC/LITE/rrc_eNB_NB_IoT.c
+100
-100
openair2/RRC/LITE/rrc_eNB_UE_context.c
openair2/RRC/LITE/rrc_eNB_UE_context.c
+5
-5
openair2/RRC/LITE/rrc_eNB_UE_context.h
openair2/RRC/LITE/rrc_eNB_UE_context.h
+5
-5
openair2/RRC/LITE/vars_NB_IoT.c
openair2/RRC/LITE/vars_NB_IoT.c
+11
-11
No files found.
openair2/RRC/LITE/L2_interface_NB_IoT.c
View file @
17c94ff8
...
...
@@ -1129,33 +1129,33 @@ int8_t mac_rrc_data_req_eNB_NB_IoT(
if
(
mib_flag
==
MIB_FLAG_YES
){
//XXX to be check when MIB-NB should be initialized
if
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
==
255
)
{
LOG_E
(
RRC
,
"[eNB %d] MAC Request for MIB-NB and MIB-NB not initialized
\n
"
,
Mod_idP
);
mac_xface
->
macphy_exit
(
"mac_rrc_data_req_eNB_NB_IoT: MAC Request for MIB-NB and MIB-NB not initialized"
);
}
memcpy
(
&
buffer_pP
[
0
],
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
MIB_NB
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
);
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
MIB_NB
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
);
//XXX RRC_MAC_BCCH_DATA_REQ message not implemented in MAC layer (eNB_scheduler.c under ITTI)
#ifdef DEBUG_RRC
LOG_T
(
RRC
,
"[eNB %d] Frame %d : BCCH request => MIB_NB
\n
"
,
Mod_idP
,
frameP
);
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
;
i
++
)
{
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
;
i
++
)
{
LOG_T
(
RRC
,
"%x."
,
buffer_pP
[
i
]);
}
LOG_T
(
RRC
,
"
\n
"
);
#endif
return
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
);
//exit from the function
return
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_MIB_NB
);
//exit from the function
}
//Requesting for SI Message
//XXX to be check when it is initialized
if
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
SI
.
Active
==
0
)
{
//is set when we call openair_rrc_on function
if
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
SI
.
Active
==
0
)
{
//is set when we call openair_rrc_on function
LOG_E
(
RRC
,
"SI value on the carrier = 0"
);
return
0
;
}
...
...
@@ -1168,12 +1168,12 @@ int8_t mac_rrc_data_req_eNB_NB_IoT(
/*check if SIBs are initialized*/
//FIXME to be check when both are initialize and if make sense to have it
if
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
==
255
)
{
LOG_E
(
RRC
,
"[eNB %d] MAC Request for SIB1-NB and SIB1-NB not initialized
\n
"
,
Mod_idP
);
mac_xface
->
macphy_exit
(
"mac_rrc_data_req_eNB_NB_IoT: MAC Request for SIB1-NB and SIB1-NB not initialized"
);
}
if
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
==
255
)
{
LOG_E
(
RRC
,
"[eNB %d] MAC Request for SIB23-NB and SIB23-NB not initialized
\n
"
,
Mod_idP
);
mac_xface
->
macphy_exit
(
"mac_rrc_data_req_eNB_NB_IoT: MAC Request for SIB23-NB and SIB23-NB not initialized"
);
}
...
...
@@ -1185,8 +1185,8 @@ int8_t mac_rrc_data_req_eNB_NB_IoT(
if
(
subframeP
==
4
&&
is_SIB1_start_NB_IoT
(
frameP
,
schedulingInfoSIB1
,
physCellId
)
!=
-
1
){
memcpy
(
&
buffer_pP
[
0
],
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
SIB1_NB
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
);
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
SIB1_NB
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
);
//XXX RRC_MAC_BCCH_DATA_REQ message not implemented in MAC layer (eNB_scheduler.c under ITTI)
...
...
@@ -1194,41 +1194,41 @@ int8_t mac_rrc_data_req_eNB_NB_IoT(
#ifdef DEBUG_RRC
LOG_T
(
RRC
,
"[eNB %d] Frame %d : BCCH request => SIB1_NB
\n
"
,
Mod_idP
,
frameP
);
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
;
i
++
)
{
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
;
i
++
)
{
LOG_T
(
RRC
,
"%x."
,
buffer_pP
[
i
]);
}
LOG_T
(
RRC
,
"
\n
"
);
#endif
return
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
);
return
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB1_NB
);
}
//check for SIB23-Transmission
for
(
int
i
=
0
;
i
<
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
count
;
i
++
){
for
(
int
i
=
0
;
i
<
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
count
;
i
++
){
if
(
is_SIB23_NB_IoT
(
frameP
,
h_frameP
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
array
[
i
]
->
si_Periodicity_r13
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
si_WindowLength_r13
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
si_RadioFrameOffset_r13
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
array
[
i
]
->
si_RepetitionPattern_r13
))
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
array
[
i
]
->
si_Periodicity_r13
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
si_WindowLength_r13
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
si_RadioFrameOffset_r13
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sib1_NB
->
schedulingInfoList_r13
.
list
.
array
[
i
]
->
si_RepetitionPattern_r13
))
{
memcpy
(
&
buffer_pP
[
0
],
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
SIB23_NB
,
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
);
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
SIB23_NB
,
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
);
#ifdef DEBUG_RRC
LOG_T
(
RRC
,
"[eNB %d] Frame %d BCCH request => SIB 2-3
\n
"
,
Mod_idP
,
frameP
);
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
;
i
++
)
{
for
(
i
=
0
;
i
<
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
;
i
++
)
{
LOG_T
(
RRC
,
"%x."
,
buffer_pP
[
i
]);
}
LOG_T
(
RRC
,
"
\n
"
);
#endif
return
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
);
return
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
sizeof_SIB23_NB
);
}
}
return
(
0
);
...
...
@@ -1238,12 +1238,12 @@ int8_t mac_rrc_data_req_eNB_NB_IoT(
if
(
(
Srb_id
&
RAB_OFFSET
)
==
CCCH
)
{
LOG_T
(
RRC
,
"[eNB %d] Frame %d CCCH request (Srb_id %d)
\n
"
,
Mod_idP
,
frameP
,
Srb_id
);
if
(
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
Srb0
.
Active
==
0
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
Srb0
.
Active
==
0
)
{
LOG_E
(
RRC
,
"[eNB %d] CCCH Not active
\n
"
,
Mod_idP
);
return
-
1
;
}
Srb_info
=&
eNB_rrc_inst_NB
[
Mod_idP
].
carrier
[
CC_id
].
Srb0
;
Srb_info
=&
eNB_rrc_inst_NB
_IoT
[
Mod_idP
].
carrier
[
CC_id
].
Srb0
;
// check if data is there for MAC
if
(
Srb_info
->
Tx_buffer
.
payload_size
>
0
)
{
//Fill buffer
...
...
@@ -1286,7 +1286,7 @@ int8_t NB_mac_rrc_data_ind_eNB(
PROTOCOL_CTXT_SET_BY_MODULE_ID
(
&
ctxt
,
module_idP
,
ENB_FLAG_YES
,
rntiP
,
frameP
,
sub_frameP
,
module_idP
);
Srb_info
=
&
eNB_rrc_inst_NB
[
module_idP
].
carrier
[
CC_id
].
Srb0
;
Srb_info
=
&
eNB_rrc_inst_NB
_IoT
[
module_idP
].
carrier
[
CC_id
].
Srb0
;
LOG_T
(
RRC
,
"[eNB %d] Received SDU for CCCH on SRB %d
\n
"
,
module_idP
,
Srb_info
->
Srb_id
);
...
...
@@ -1337,7 +1337,7 @@ void mac_eNB_rrc_ul_failure_NB_IoT(
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
mod_idP
],
&
eNB_rrc_inst_NB
_IoT
[
mod_idP
],
rntiP
);
if
(
ue_context_p
!=
NULL
)
{
...
...
@@ -1443,7 +1443,7 @@ void mac_eNB_rrc_ul_in_sync_NB_IoT(
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
mod_idP
],
&
eNB_rrc_inst_NB
_IoT
[
mod_idP
],
rntiP
);
if
(
ue_context_p
!=
NULL
)
{
...
...
@@ -1464,7 +1464,7 @@ int mac_eNB_get_rrc_status_NB_IoT(
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
Mod_idP
],
&
eNB_rrc_inst_NB
_IoT
[
Mod_idP
],
rntiP
);
if
(
ue_context_p
!=
NULL
)
{
...
...
openair2/RRC/LITE/defs_NB_IoT.h
View file @
17c94ff8
...
...
@@ -501,7 +501,7 @@ typedef struct {
//---NB-IoT---(completely change)---------------------
typedef
struct
eNB_RRC_INST_NB_s
{
typedef
struct
eNB_RRC_INST_NB_
IoT_
s
{
rrc_eNB_carrier_data_NB_t
carrier
[
MAX_NUM_CCs
];
...
...
@@ -532,7 +532,7 @@ typedef struct eNB_RRC_INST_NB_s {
int
srs_enable
[
MAX_NUM_CCs
];
}
eNB_RRC_INST_NB
;
}
eNB_RRC_INST_NB
_IoT
;
#define MAX_UE_CAPABILITY_SIZE 255
...
...
openair2/RRC/LITE/extern.h
View file @
17c94ff8
...
...
@@ -38,7 +38,7 @@
///NB_IoT
#include "defs_NB_IoT.h"
extern
eNB_RRC_INST_NB
*
eNB_rrc_inst_NB
;
extern
eNB_RRC_INST_NB
_IoT
*
eNB_rrc_inst_NB_IoT
;
extern
UE_RRC_INST
*
UE_rrc_inst
;
extern
eNB_RRC_INST
*
eNB_rrc_inst
;
...
...
openair2/RRC/LITE/extern_NB_IoT.h
View file @
17c94ff8
...
...
@@ -40,20 +40,20 @@
//MP: NOTE:XXX some of the parameters defined in vars_nb_iot are called by the extern.h file so not replicated here
extern
eNB_RRC_INST_NB
*
eNB_rrc_inst_NB
;
extern
eNB_RRC_INST_NB
_IoT
*
eNB_rrc_inst_NB_IoT
;
extern
PHY_Config_t
*
config_INFO
;
extern
rlc_info_t
Rlc_info_am_NB
,
Rlc_info_am_config_NB
;
extern
uint8_t
DRB2LCHAN_NB
[
2
];
extern
LogicalChannelConfig_NB_r13_t
SRB1bis_
NB_logicalChannelConfig_defaultValue
;
extern
LogicalChannelConfig_NB_r13_t
SRB1_
NB_logicalChannelConfig_defaultValue
;
extern
uint16_t
T300_NB
[
8
];
extern
uint16_t
T301_NB
[
8
];
extern
uint16_t
T310_NB
[
8
];
extern
uint16_t
T311_NB
[
8
];
extern
uint16_t
N310_NB
[
8
];
extern
uint16_t
N311_NB
[
8
];
extern
rlc_info_t
Rlc_info_am_NB
_IoT
,
Rlc_info_am_config_NB_IoT
;
extern
uint8_t
DRB2LCHAN_NB
_IoT
[
2
];
extern
LogicalChannelConfig_NB_r13_t
SRB1bis_
logicalChannelConfig_defaultValue_NB_IoT
;
extern
LogicalChannelConfig_NB_r13_t
SRB1_
logicalChannelConfig_defaultValue_NB_IoT
;
extern
uint16_t
T300_NB
_IoT
[
8
];
extern
uint16_t
T301_NB
_IoT
[
8
];
extern
uint16_t
T310_NB
_IoT
[
8
];
extern
uint16_t
T311_NB
_IoT
[
8
];
extern
uint16_t
N310_NB
_IoT
[
8
];
extern
uint16_t
N311_NB
_IoT
[
8
];
#endif
...
...
openair2/RRC/LITE/proto_NB_IoT.h
View file @
17c94ff8
openair2/RRC/LITE/rrc_common_NB_IoT.c
View file @
17c94ff8
...
...
@@ -94,7 +94,7 @@ rrc_t310_expiration_NB(
SRB_FLAG_YES
,
CONFIG_ACTION_REMOVE
,
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Srb2
[
eNB_index
].
Srb_info
.
Srb_id
,
Rlc_info_am_NB
);
Rlc_info_am_NB
_IoT
);
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Srb2
[
eNB_index
].
Active
=
0
;
...
...
@@ -123,10 +123,10 @@ void openair_eNB_rrc_on_NB_IoT(
LOG_I
(
RRC
,
PROTOCOL_RRC_CTXT_FMT
" OPENAIR RRC-NB IN....
\n
"
,
PROTOCOL_RRC_CTXT_ARGS
(
ctxt_pP
));
for
(
CC_id
=
0
;
CC_id
<
MAX_NUM_CCs
;
CC_id
++
)
{
rrc_config_buffer_NB_IoT
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SI
,
BCCH
,
1
);
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SI
.
Active
=
1
;
rrc_config_buffer_NB_IoT
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
,
CCCH
,
1
);
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Active
=
1
;
rrc_config_buffer_NB_IoT
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SI
,
BCCH
,
1
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SI
.
Active
=
1
;
rrc_config_buffer_NB_IoT
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
,
CCCH
,
1
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Active
=
1
;
}
//no UE side
}
...
...
@@ -162,10 +162,10 @@ int rrc_init_global_param_NB_IoT( void )
//DCCH_LCHAN_DESC.transport_block_size = 4;....
//Setting of this values????
Rlc_info_am_config_NB
.
rlc_mode
=
RLC_MODE_AM
;
//only allowed for NB-IoT
Rlc_info_am_config_NB
.
rlc
.
rlc_am_info_NB
.
max_retx_threshold_NB
=
50
;
Rlc_info_am_config_NB
.
rlc
.
rlc_am_info_NB
.
t_poll_retransmit_NB
=
15
;
Rlc_info_am_config_NB
.
rlc
.
rlc_am_info_NB
.
enableStatusReportSN_Gap
=
NULL
;
//should be disabled
Rlc_info_am_config_NB
_IoT
.
rlc_mode
=
RLC_MODE_AM
;
//only allowed for NB-IoT
Rlc_info_am_config_NB
_IoT
.
rlc
.
rlc_am_info_NB
.
max_retx_threshold_NB
=
50
;
Rlc_info_am_config_NB
_IoT
.
rlc
.
rlc_am_info_NB
.
t_poll_retransmit_NB
=
15
;
Rlc_info_am_config_NB
_IoT
.
rlc
.
rlc_am_info_NB
.
enableStatusReportSN_Gap
=
NULL
;
//should be disabled
#ifndef NO_RRM
...
...
@@ -251,16 +251,16 @@ void openair_rrc_top_init_eNB_NB_IoT(void)//MP: XXX Raymond put this directly th
//not consider UE part
if
(
NB_eNB_INST
>
0
)
{
eNB_rrc_inst_NB
=
(
eNB_RRC_INST_NB
*
)
malloc16
(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
));
memset
(
eNB_rrc_inst_NB
,
0
,
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
));
LOG_D
(
RRC
,
"ALLOCATE %d Bytes for eNB_RRC_INST NB-IoT @ %p
\n
"
,
(
unsigned
int
)(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
)),
eNB_rrc_inst_NB
);
eNB_rrc_inst_NB
_IoT
=
(
eNB_RRC_INST_NB_IoT
*
)
malloc16
(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB_IoT
));
memset
(
eNB_rrc_inst_NB
_IoT
,
0
,
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB_IoT
));
LOG_D
(
RRC
,
"ALLOCATE %d Bytes for eNB_RRC_INST NB-IoT @ %p
\n
"
,
(
unsigned
int
)(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
_IoT
)),
eNB_rrc_inst_NB_IoT
);
//no CBA, no LOcalization, no MBMS flag
LOG_D
(
RRC
,
"ALLOCATE %d Bytes for eNB_RRC_INST_NB @ %p
\n
"
,
(
unsigned
int
)(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
)),
eNB_rrc_inst_NB
);
"ALLOCATE %d Bytes for eNB_RRC_INST_NB @ %p
\n
"
,
(
unsigned
int
)(
NB_eNB_INST
*
sizeof
(
eNB_RRC_INST_NB
_IoT
)),
eNB_rrc_inst_NB_IoT
);
}
else
{
eNB_rrc_inst_NB
=
NULL
;
eNB_rrc_inst_NB
_IoT
=
NULL
;
}
...
...
@@ -293,7 +293,7 @@ rrc_rx_tx_NB_IoT(
"[UE %d][RAPROC] Frame %d T300 Count %d ms
\n
"
,
ctxt_pP
->
module_id
,
ctxt_pP
->
frame
,
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Info
[
enb_indexP
].
T300_cnt
);
if
(
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Info
[
enb_indexP
].
T300_cnt
==
T300_NB
[
UE_rrc_inst
[
ctxt_pP
->
module_id
].
sib2
[
enb_indexP
]
->
ue_TimersAndConstants
.
t300
])
{
==
T300_NB
_IoT
[
UE_rrc_inst
[
ctxt_pP
->
module_id
].
sib2
[
enb_indexP
]
->
ue_TimersAndConstants
.
t300
])
{
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Info
[
enb_indexP
].
T300_active
=
0
;
// ALLOW CCCH to be used
UE_rrc_inst
[
ctxt_pP
->
module_id
].
Srb0
[
enb_indexP
].
Tx_buffer
.
payload_size
=
0
;
...
...
@@ -384,7 +384,7 @@ rrc_rx_tx_NB_IoT(
// counter, and get the value and aggregate
// check for UL failure
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
if
((
ctxt_pP
->
frame
==
0
)
&&
(
ctxt_pP
->
subframe
==
0
))
{
if
(
ue_context_p
->
ue_context
.
Initialue_identity_s_TMSI
.
presence
==
TRUE
)
{
LOG_I
(
RRC
,
"UE rnti %x:S-TMSI %x failure timer %d/20000
\n
"
,
...
...
openair2/RRC/LITE/rrc_eNB_NB_IoT.c
View file @
17c94ff8
...
...
@@ -160,7 +160,7 @@ void rrc_eNB_free_UE_NB_IoT(const module_id_t enb_mod_idP,const struct rrc_eNB_u
rrc_eNB_remove_ue_context_NB
(
&
ctxt
,
&
eNB_rrc_inst_NB
[
enb_mod_idP
],
&
eNB_rrc_inst_NB
_IoT
[
enb_mod_idP
],
(
struct
rrc_eNB_ue_context_NB_s
*
)
ue_context_pP
);
}
}
...
...
@@ -242,15 +242,15 @@ void rrc_eNB_generate_RRCConnectionReestablishmentReject_NB_IoT(
T
(
T_ENB_RRC_CONNECTION_REESTABLISHMENT_REJECT
,
T_INT
(
ctxt_pP
->
module_id
),
T_INT
(
ctxt_pP
->
frame
),
T_INT
(
ctxt_pP
->
subframe
),
T_INT
(
ctxt_pP
->
rnti
));
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
do_RRCConnectionReestablishmentReject_NB
(
ctxt_pP
->
module_id
,
(
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
);
(
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
);
#ifdef RRC_MSG_PRINT
LOG_F
(
RRC
,
"[MSG] RRCConnectionReestablishmentReject
\n
"
);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
}
LOG_F
(
RRC
,
"
\n
"
);
...
...
@@ -259,17 +259,17 @@ void rrc_eNB_generate_RRCConnectionReestablishmentReject_NB_IoT(
MSC_LOG_TX_MESSAGE
(
MSC_RRC_ENB
,
MSC_RRC_UE
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
MSC_AS_TIME_FMT
" RRCConnectionReestablishmentReject UE %x size %u"
,
MSC_AS_TIME_ARGS
(
ctxt_pP
),
ue_context_pP
==
NULL
?
-
1
:
ue_context_pP
->
ue_context
.
rnti
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
LOG_I
(
RRC
,
PROTOCOL_RRC_CTXT_UE_FMT
" [RAPROC] Logical Channel DL-CCCH, Generating RRCConnectionReestablishmentReject (bytes %d)
\n
"
,
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
),
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
}
//-----------------------------------------------------------------------------
...
...
@@ -330,7 +330,7 @@ rrc_eNB_ue_context_random_exist_NB(
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
//FIXME: there is a warning related to the new type rrc_ue_tree_NB_s
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
if
(
ue_context_p
->
ue_context
.
random_ue_identity
==
ue_identityP
)
return
ue_context_p
;
}
...
...
@@ -348,11 +348,11 @@ rrc_eNB_get_next_free_ue_context_NB(
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
);
if
(
ue_context_p
==
NULL
)
{
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
if
(
ue_context_p
->
ue_context
.
random_ue_identity
==
ue_identityP
)
{
LOG_D
(
RRC
,
PROTOCOL_RRC_CTXT_UE_FMT
" Cannot create new UE context, already exist rand UE id 0x%"
PRIx64
", uid %u
\n
"
,
...
...
@@ -362,7 +362,7 @@ rrc_eNB_get_next_free_ue_context_NB(
return
NULL
;
}
}
ue_context_p
=
rrc_eNB_allocate_new_UE_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
]);
ue_context_p
=
rrc_eNB_allocate_new_UE_context_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
]);
if
(
ue_context_p
==
NULL
)
{
LOG_E
(
RRC
,
...
...
@@ -374,7 +374,7 @@ rrc_eNB_get_next_free_ue_context_NB(
ue_context_p
->
ue_id_rnti
=
ctxt_pP
->
rnti
;
// here ue_id_rnti is just a key, may be something else
ue_context_p
->
ue_context
.
rnti
=
ctxt_pP
->
rnti
;
// yes duplicate, 1 may be removed
ue_context_p
->
ue_context
.
random_ue_identity
=
ue_identityP
;
RB_INSERT
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
RB_INSERT
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
LOG_D
(
RRC
,
PROTOCOL_RRC_CTXT_UE_FMT
" Created new UE context uid %u
\n
"
,
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
),
...
...
@@ -400,7 +400,7 @@ rrc_eNB_ue_context_stmsi_exist_NB(
//-----------------------------------------------------------------------------
{
struct
rrc_eNB_ue_context_NB_s
*
ue_context_p
=
NULL
;
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
RB_FOREACH
(
ue_context_p
,
rrc_ue_tree_NB_s
,
&
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
))
{
LOG_I
(
RRC
,
"checking for UE S-TMSI %x, mme %x (%p): rnti %x"
,
m_tmsiP
,
mme_codeP
,
ue_context_p
,
ue_context_p
->
ue_context
.
rnti
);
...
...
@@ -446,15 +446,15 @@ void rrc_eNB_generate_RRCConnectionReject_NB_IoT(
T
(
T_ENB_RRC_CONNECTION_REJECT
,
T_INT
(
ctxt_pP
->
module_id
),
T_INT
(
ctxt_pP
->
frame
),
T_INT
(
ctxt_pP
->
subframe
),
T_INT
(
ctxt_pP
->
rnti
));
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
do_RRCConnectionReject_NB
(
ctxt_pP
->
module_id
,
(
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
);
(
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
);
#ifdef RRC_MSG_PRINT
LOG_F
(
RRC
,
"[MSG] RRCConnectionReject-NB
\n
"
);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
}
LOG_F
(
RRC
,
"
\n
"
);
...
...
@@ -463,17 +463,17 @@ void rrc_eNB_generate_RRCConnectionReject_NB_IoT(
MSC_LOG_TX_MESSAGE
(
MSC_RRC_ENB
,
MSC_RRC_UE
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
MSC_AS_TIME_FMT
" RRCConnectionReject-NB UE %x size %u"
,
MSC_AS_TIME_ARGS
(
ctxt_pP
),
ue_context_pP
==
NULL
?
-
1
:
ue_context_pP
->
ue_context
.
rnti
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
LOG_I
(
RRC
,
PROTOCOL_RRC_CTXT_UE_FMT
" [RAPROC] Logical Channel DL-CCCH, Generating RRCConnectionReject-NB (bytes %d)
\n
"
,
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
),
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
}
//-----------------------------------------------------------------------------
...
...
@@ -509,11 +509,11 @@ void rrc_eNB_generate_RRCConnectionSetup_NB_IoT(
SRB_configList
=
&
ue_context_pP
->
ue_context
.
SRB_configList
;
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
=
do_RRCConnectionSetup_NB
(
ctxt_pP
,
ue_context_pP
,
CC_id
,
(
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
,
(
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Payload
,
rrc_eNB_get_next_transaction_identifier
(
ctxt_pP
->
module_id
),
fp
,
SRB_configList
,
//MP:should contain only SRb1bis for the moment
...
...
@@ -522,8 +522,8 @@ void rrc_eNB_generate_RRCConnectionSetup_NB_IoT(
#ifdef RRC_MSG_PRINT
LOG_F
(
RRC
,
"[MSG] RRC Connection Setup
\n
"
);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
for
(
cnt
=
0
;
cnt
<
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
;
cnt
++
)
{
LOG_F
(
RRC
,
"%02x "
,
((
uint8_t
*
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
Srb0
.
Tx_buffer
.
Payload
)[
cnt
]);
}
LOG_F
(
RRC
,
"
\n
"
);
...
...
@@ -545,10 +545,10 @@ void rrc_eNB_generate_RRCConnectionSetup_NB_IoT(
SRB1bis_logicalChannelConfig
=
&
SRB1bis_config
->
logicalChannelConfig_r13
->
choice
.
explicitValue
;
}
else
{
SRB1bis_logicalChannelConfig
=
&
SRB1bis_
NB_logicalChannelConfig_defaultValue
;
SRB1bis_logicalChannelConfig
=
&
SRB1bis_
logicalChannelConfig_defaultValue_NB_IoT
;
}
}
else
{
SRB1bis_logicalChannelConfig
=
&
SRB1bis_
NB_logicalChannelConfig_defaultValue
;
SRB1bis_logicalChannelConfig
=
&
SRB1bis_
logicalChannelConfig_defaultValue_NB_IoT
;
}
LOG_D
(
RRC
,
...
...
@@ -592,18 +592,18 @@ void rrc_eNB_generate_RRCConnectionSetup_NB_IoT(
MSC_LOG_TX_MESSAGE
(
MSC_RRC_ENB
,
MSC_RRC_UE
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
// LG WARNING
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
Header
,
// LG WARNING
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
,
MSC_AS_TIME_FMT
" RRCConnectionSetup-NB UE %x size %u"
,
MSC_AS_TIME_ARGS
(
ctxt_pP
),
ue_context_pP
->
ue_context
.
rnti
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
LOG_I
(
RRC
,
PROTOCOL_RRC_CTXT_UE_FMT
" [RAPROC] Logical Channel DL-CCCH, Generating RRCConnectionSetup-NB (bytes %d)
\n
"
,
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
),
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Srb0
.
Tx_buffer
.
payload_size
);
// activate release timer, if RRCSetupComplete-NB not received after 10 frames, remove UE
ue_context_pP
->
ue_context
.
ue_release_timer
=
1
;
...
...
@@ -784,10 +784,10 @@ void rrc_eNB_process_RRCConnectionReconfigurationComplete_NB_IoT(
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
));
if
(
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
)
{
DRB2LCHAN_NB
[
i
]
=
(
uint8_t
)
*
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
;
//set in RRCConnectionReconfiguration (x+3)
DRB2LCHAN_NB
_IoT
[
i
]
=
(
uint8_t
)
*
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
;
//set in RRCConnectionReconfiguration (x+3)
}
//MP: for each DRB I send a rrc_mac_config_req--> what change is the DRB2LCHAN_NB and logicalChannelConfig_r13
//MP: for each DRB I send a rrc_mac_config_req--> what change is the DRB2LCHAN_NB
_IoT
and logicalChannelConfig_r13
rrc_mac_config_req_eNB_NB_IoT
(
ctxt_pP
->
module_id
,
ue_context_pP
->
ue_context
.
primaryCC_id
,
...
...
@@ -811,7 +811,7 @@ void rrc_eNB_process_RRCConnectionReconfigurationComplete_NB_IoT(
(
RadioResourceConfigCommonSIB_NB_r13_t
*
)
NULL
,
ue_context_pP
->
ue_context
.
physicalConfigDedicated_NB
,
ue_context_pP
->
ue_context
.
mac_MainConfig_NB
,
DRB2LCHAN_NB
[
i
],
//over the logical channel id of the DRB (>=4)
DRB2LCHAN_NB
_IoT
[
i
],
//over the logical channel id of the DRB (>=4)
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelConfig_r13
);
...
...
@@ -823,7 +823,7 @@ void rrc_eNB_process_RRCConnectionReconfigurationComplete_NB_IoT(
*/
if
(
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
)
{
DRB2LCHAN_NB
[
i
]
=
(
uint8_t
)
*
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
;
//set in RRCConnectionReconfiguration (x+3)
DRB2LCHAN_NB
_IoT
[
i
]
=
(
uint8_t
)
*
DRB_configList2
->
list
.
array
[
i
]
->
logicalChannelIdentity_r13
;
//set in RRCConnectionReconfiguration (x+3)
}
LOG_D
(
RRC
,
...
...
@@ -855,7 +855,7 @@ void rrc_eNB_process_RRCConnectionReconfigurationComplete_NB_IoT(
(
RadioResourceConfigCommonSIB_NB_r13_t
*
)
NULL
,
ue_context_pP
->
ue_context
.
physicalConfigDedicated_NB
,
ue_context_pP
->
ue_context
.
mac_MainConfig_NB
,
DRB2LCHAN_NB
[
i
],
//over the logical channel id of the DRB (>=4)
DRB2LCHAN_NB
_IoT
[
i
],
//over the logical channel id of the DRB (>=4)
(
LogicalChannelConfig_NB_r13_t
*
)
NULL
);
}
...
...
@@ -1306,7 +1306,7 @@ void rrc_eNB_generate_defaultRRCConnectionReconfiguration_NB_IoT(const protocol_
int
i
;
// configure SRB1, PhysicalConfigDedicated, MAC_MainConfig for UE
//eNB_RRC_INST_NB
* rrc_inst = &eNB_rrc_inst_NB
[ctxt_pP->module_id];
//eNB_RRC_INST_NB
_IoT* rrc_inst = &eNB_rrc_inst_NB_IoT
[ctxt_pP->module_id];
struct
PhysicalConfigDedicated_NB_r13
**
physicalConfigDedicated_NB
=
&
ue_context_pP
->
ue_context
.
physicalConfigDedicated_NB
;
...
...
@@ -1616,29 +1616,29 @@ init_SI_NB(
//copy basic parameters
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
physCellId
=
configuration
->
Nid_cell
[
CC_id
];
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_eNB
=
configuration
->
nb_antenna_ports
[
CC_id
];
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_rx_eNB
=
configuration
->
nb_antenna_ports_rx
[
CC_id
];
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp
=
configuration
->
prefix_type
[
CC_id
];
//DL Cyclic prefix
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp_UL
=
configuration
->
prefix_type_UL
[
CC_id
];
//UL cyclic prefix
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
dl_CarrierFreq
=
configuration
->
downlink_frequency
[
CC_id
];
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
ul_CarrierFreq
=
configuration
->
downlink_frequency
[
CC_id
]
+
configuration
->
uplink_frequency_offset
[
CC_id
];
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
physCellId
=
configuration
->
Nid_cell
[
CC_id
];
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_eNB
=
configuration
->
nb_antenna_ports
[
CC_id
];
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_rx_eNB
=
configuration
->
nb_antenna_ports_rx
[
CC_id
];
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp
=
configuration
->
prefix_type
[
CC_id
];
//DL Cyclic prefix
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp_UL
=
configuration
->
prefix_type_UL
[
CC_id
];
//UL cyclic prefix
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
dl_CarrierFreq
=
configuration
->
downlink_frequency
[
CC_id
];
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
ul_CarrierFreq
=
configuration
->
downlink_frequency
[
CC_id
]
+
configuration
->
uplink_frequency_offset
[
CC_id
];
//TODO: verify who allocate memory for sib1_NB, sib2_NB, sib3_NB and mib_nb in the carrier before being passed as parameter
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
=
0
;
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
=
0
;
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
=
0
;
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
=
0
;
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
=
0
;
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
=
0
;
//MIB
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
MIB_NB
=
(
uint8_t
*
)
malloc16
(
32
);
//MIB is 34 bits=5bytes needed
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
MIB_NB
=
(
uint8_t
*
)
malloc16
(
32
);
//MIB is 34 bits=5bytes needed
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
MIB_NB
)
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
MIB_NB
)
{
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
=
do_MIB_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
=
do_MIB_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
configuration
->
N_RB_DL
[
CC_id
],
0
//FIXME is correct to pass frame = 0??
);
...
...
@@ -1650,18 +1650,18 @@ init_SI_NB(
}
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_MIB_NB
==
255
)
{
mac_xface
->
macphy_exit
(
"[RRC][init_SI] FATAL, eNB_rrc_inst_NB[enb_mod_idP].carrier[CC_id].sizeof_MIB_NB == 255"
);
}
//SIB1_NB
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB1_NB
=
(
uint8_t
*
)
malloc16
(
32
);
//allocation of buffer memory for SIB1_NB
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB1_NB
=
(
uint8_t
*
)
malloc16
(
32
);
//allocation of buffer memory for SIB1_NB
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB1_NB
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
=
do_SIB1_NB
(
//follow the new implementation
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB1_NB
)
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
=
do_SIB1_NB
(
//follow the new implementation
ctxt_pP
->
module_id
,
CC_id
,
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
configuration
,
0
//FIXME is correct to pass frame = 0??
);
...
...
@@ -1672,22 +1672,22 @@ init_SI_NB(
mac_xface
->
macphy_exit
(
"[RRC][init_SI] FATAL, no memory for SIB1_NB allocated"
);
}
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB1_NB
==
255
)
{
mac_xface
->
macphy_exit
(
"[RRC][init_SI] FATAL, eNB_rrc_inst_NB[enb_mod_idP].carrier[CC_id].sizeof_SIB1_NB == 255"
);
}
//SIB23_NB
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB23_NB
=
(
uint8_t
*
)
malloc16
(
64
);
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB23_NB
=
(
uint8_t
*
)
malloc16
(
64
);
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB23_NB
)
{
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
=
do_SIB23_NB
(
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
SIB23_NB
)
{
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
=
do_SIB23_NB
(
ctxt_pP
->
module_id
,
CC_id
,
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
],
configuration
);
if
(
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
==
255
)
{
if
(
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sizeof_SIB23_NB
==
255
)
{
mac_xface
->
macphy_exit
(
"[RRC][init_SI] FATAL, eNB_rrc_inst_NB[mod].carrier[CC_id].sizeof_SIB23_NB == 255"
);
}
...
...
@@ -1702,7 +1702,7 @@ init_SI_NB(
//Use the following as an example
// LOG_T(RRC, PROTOCOL_RRC_CTXT_FMT" npusch_config_common.groupAssignmentNPUSCH = %ld\n",
// PROTOCOL_RRC_CTXT_ARGS(ctxt_pP),
// eNB_rrc_inst_NB[ctxt_pP->module_id].carrier[CC_id].sib2_NB->radioResourceConfigCommon_r13.npusch_ConfigCommon_r13.
// eNB_rrc_inst_NB
_IoT
[ctxt_pP->module_id].carrier[CC_id].sib2_NB->radioResourceConfigCommon_r13.npusch_ConfigCommon_r13.
// ul_ReferenceSignalsNPUSCH_r13.groupAssignmentNPUSCH_r13);
...
...
@@ -1715,25 +1715,25 @@ init_SI_NB(
rrc_mac_config_req_eNB_NB_IoT
(
ctxt_pP
->
module_id
,
CC_id
,
0
,
//rnti
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
physCellId
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_eNB
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_rx_eNB
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp_UL
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
freqBandIndicator_r13
,
//eutra_band
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
freqBandInfo_r13
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
multiBandInfoList_r13
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
downlinkBitmap_r13
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
eutraControlRegionSize_r13
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
nrs_CRS_PowerOffset_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
physCellId
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_eNB
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
p_rx_eNB
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
Ncp_UL
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
freqBandIndicator_r13
,
//eutra_band
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
freqBandInfo_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
multiBandInfoList_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
downlinkBitmap_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
eutraControlRegionSize_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib1_NB
->
nrs_CRS_PowerOffset_r13
,
// &SIwindowsize,
// &SIperiod,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
dl_CarrierFreq
,
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
ul_CarrierFreq
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
dl_CarrierFreq
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
ul_CarrierFreq
,
(
BCCH_BCH_Message_NB_t
*
)
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
mib_NB
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
mib_NB
,
(
RadioResourceConfigCommonSIB_NB_r13_t
*
)
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib2_NB
->
radioResourceConfigCommon_r13
,
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
carrier
[
CC_id
].
sib2_NB
->
radioResourceConfigCommon_r13
,
(
struct
PhysicalConfigDedicated_NB_r13
*
)
NULL
,
(
MAC_MainConfig_NB_r13_t
*
)
NULL
,
0
,
// MP:logicalChannelID //TODO still have to be properly managed in the interface
...
...
@@ -1763,27 +1763,27 @@ char openair_rrc_eNB_configuration_NB_IoT(
PROTOCOL_RRC_CTXT_ARGS
(
&
ctxt
));
#if OCP_FRAMEWORK
while
(
eNB_rrc_inst_NB
==
NULL
)
{
LOG_E
(
RRC
,
"eNB_rrc_inst_NB not yet initialized, waiting 1 second
\n
"
);
while
(
eNB_rrc_inst_NB
_IoT
==
NULL
)
{
LOG_E
(
RRC
,
"eNB_rrc_inst_NB
_IoT
not yet initialized, waiting 1 second
\n
"
);
sleep
(
1
);
}
#endif
AssertFatal
(
eNB_rrc_inst_NB
!=
NULL
,
"eNB_rrc_nb_iot_inst not initialized!"
);
AssertFatal
(
eNB_rrc_inst_NB
_IoT
!=
NULL
,
"eNB_rrc_nb_iot_inst not initialized!"
);
AssertFatal
(
NUMBER_OF_UE_MAX
<
(
module_id_t
)
0xFFFFFFFFFFFFFFFF
,
" variable overflow"
);
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
Nb_ue
=
0
;
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
Nb_ue
=
0
;
for
(
CC_id
=
0
;
CC_id
<
MAX_NUM_CCs
;
CC_id
++
)
{
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
carrier
[
CC_id
].
Srb0
.
Active
=
0
;
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
carrier
[
CC_id
].
Srb0
.
Active
=
0
;
}
uid_linear_allocator_init_NB
(
&
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
uid_allocator
);
//rrc_eNB_UE_context
RB_INIT
(
&
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
rrc_ue_head
);
uid_linear_allocator_init_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
uid_allocator
);
//rrc_eNB_UE_context
RB_INIT
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
rrc_ue_head
);
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
initial_id2_s1ap_ids
=
hashtable_create
(
NUMBER_OF_UE_MAX
*
2
,
NULL
,
NULL
);
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
s1ap_id2_s1ap_ids
=
hashtable_create
(
NUMBER_OF_UE_MAX
*
2
,
NULL
,
NULL
);
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
initial_id2_s1ap_ids
=
hashtable_create
(
NUMBER_OF_UE_MAX
*
2
,
NULL
,
NULL
);
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
s1ap_id2_s1ap_ids
=
hashtable_create
(
NUMBER_OF_UE_MAX
*
2
,
NULL
,
NULL
);
memcpy
(
&
eNB_rrc_inst_NB
[
ctxt
.
module_id
].
configuration
,
configuration
,
sizeof
(
RrcConfigurationReq
));
memcpy
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt
.
module_id
].
configuration
,
configuration
,
sizeof
(
RrcConfigurationReq
));
/// System Information INIT
...
...
@@ -1919,7 +1919,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
ue_mod_id = rrc_eNB_get_UE_index(enb_mod_idP, c_rnti);
}
if ((eNB_rrc_inst_NB[enb_mod_idP].phyCellId == rrcConnectionReestablishmentRequest.UE_identity.physCellId) &&
if ((eNB_rrc_inst_NB
_IoT
[enb_mod_idP].phyCellId == rrcConnectionReestablishmentRequest.UE_identity.physCellId) &&
(ue_mod_id != UE_INDEX_INVALID)){
rrc_eNB_generate_RRCConnectionReestablishment(enb_mod_idP, frameP, ue_mod_id);
}else {
...
...
@@ -1930,7 +1930,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
//MP:for the moment we only reject
rrc_eNB_generate_RRCConnectionReestablishmentReject_NB_IoT
(
ctxt_pP
,
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
CC_id
);
break
;
...
...
@@ -1953,7 +1953,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
));
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
//XXX define new function in rrc_eNB_UE_context
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
);
if
(
ue_context_p
!=
NULL
)
{
//MP: i receive a ConnectionRequest from a UE which have already a context
...
...
@@ -2013,11 +2013,11 @@ int rrc_eNB_decode_ccch_NB_IoT(
/* for that, remove the context from the RB tree */
///FIXME MP: warning --> implicit declaration because I insert the new type "rrc_ue_tree_NB_s"
RB_REMOVE
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
RB_REMOVE
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
/* and insert again, after changing rnti everywhere it has to be changed */
ue_context_p
->
ue_id_rnti
=
ctxt_pP
->
rnti
;
ue_context_p
->
ue_context
.
rnti
=
ctxt_pP
->
rnti
;
RB_INSERT
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
RB_INSERT
(
rrc_ue_tree_NB_s
,
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
rrc_ue_head
,
ue_context_p
);
/* reset timers */
ue_context_p
->
ue_context
.
ul_failure_timer
=
0
;
ue_context_p
->
ue_context
.
ue_release_timer
=
0
;
...
...
@@ -2054,7 +2054,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
PROTOCOL_RRC_CTXT_UE_ARGS
(
ctxt_pP
));
rrc_eNB_generate_RRCConnectionReject_NB_IoT
(
ctxt_pP
,
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
CC_id
);
break
;
}
...
...
@@ -2091,7 +2091,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
// ue_context_p->ue_context.random_ue_identity);
//#endif
if
(
stmsi_received
==
0
)
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
].
Nb_ue
++
;
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
].
Nb_ue
++
;
}
else
{
// no context available
...
...
@@ -2191,7 +2191,7 @@ int rrc_eNB_decode_ccch_NB_IoT(
//MP: only reject for now
rrc_eNB_generate_RRCConnectionReject_NB_IoT
(
ctxt_pP
,
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
),
CC_id
);
break
;
...
...
@@ -2273,7 +2273,7 @@ int rrc_eNB_decode_dcch_NB_IoT(
}
ue_context_p
=
rrc_eNB_get_ue_context_NB
(
&
eNB_rrc_inst_NB
[
ctxt_pP
->
module_id
],
&
eNB_rrc_inst_NB
_IoT
[
ctxt_pP
->
module_id
],
ctxt_pP
->
rnti
);
if
(
ul_dcch_msg_NB
->
message
.
present
==
UL_DCCH_MessageType_NB_PR_c1
)
{
...
...
@@ -2811,7 +2811,7 @@ void* rrc_enb_task_NB_IoT(
CC_id
=
RRC_MAC_CCCH_DATA_IND
(
msg_p
).
CC_id
;
///SRB0
srb_info_p
=
&
eNB_rrc_inst_NB
[
instance
].
carrier
[
CC_id
].
Srb0
;
srb_info_p
=
&
eNB_rrc_inst_NB
_IoT
[
instance
].
carrier
[
CC_id
].
Srb0
;
memcpy
(
srb_info_p
->
Rx_buffer
.
Payload
,
RRC_MAC_CCCH_DATA_IND
(
msg_p
).
sdu
,
...
...
openair2/RRC/LITE/rrc_eNB_UE_context.c
View file @
17c94ff8
...
...
@@ -207,7 +207,7 @@ uid_linear_allocator_init_NB(
//------------------------------------------------------------------------------
uid_t
uid_linear_allocator_new_NB
(
eNB_RRC_INST_NB
*
const
rrc_instance_pP
eNB_RRC_INST_NB
_IoT
*
const
rrc_instance_pP
)
//------------------------------------------------------------------------------
{
...
...
@@ -237,7 +237,7 @@ uid_linear_allocator_new_NB(
//------------------------------------------------------------------------------
void
uid_linear_allocator_free_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
uid_t
uidP
)
//------------------------------------------------------------------------------
...
...
@@ -276,7 +276,7 @@ RB_GENERATE(rrc_ue_tree_NB_s, rrc_eNB_ue_context_NB_s, entries,
//------------------------------------------------------------------------------
struct
rrc_eNB_ue_context_NB_s
*
rrc_eNB_allocate_new_UE_context_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
)
//------------------------------------------------------------------------------
{
...
...
@@ -296,7 +296,7 @@ rrc_eNB_allocate_new_UE_context_NB(
struct
rrc_eNB_ue_context_NB_s
*
rrc_eNB_get_ue_context_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
rnti_t
rntiP
)
//------------------------------------------------------------------------------
{
...
...
@@ -310,7 +310,7 @@ rrc_eNB_get_ue_context_NB(
//------------------------------------------------------------------------------
void
rrc_eNB_remove_ue_context_NB
(
const
protocol_ctxt_t
*
const
ctxt_pP
,
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
struct
rrc_eNB_ue_context_NB_s
*
ue_context_pP
)
//------------------------------------------------------------------------------
{
...
...
openair2/RRC/LITE/rrc_eNB_UE_context.h
View file @
17c94ff8
...
...
@@ -92,12 +92,12 @@ uid_linear_allocator_init_NB(
uid_t
uid_linear_allocator_new_NB
(
eNB_RRC_INST_NB
*
const
rrc_instance_pP
eNB_RRC_INST_NB
_IoT
*
const
rrc_instance_pP
);
void
uid_linear_allocator_free_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
uid_t
uidP
);
...
...
@@ -109,17 +109,17 @@ RB_PROTOTYPE(rrc_ue_tree_NB_s, rrc_eNB_ue_context_NB_s, entries, rrc_eNB_compare
struct
rrc_eNB_ue_context_NB_s
*
rrc_eNB_allocate_new_UE_context_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
);
struct
rrc_eNB_ue_context_NB_s
*
rrc_eNB_get_ue_context_NB
(
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
rnti_t
rntiP
);
void
rrc_eNB_remove_ue_context_NB
(
const
protocol_ctxt_t
*
const
ctxt_pP
,
eNB_RRC_INST_NB
*
rrc_instance_pP
,
eNB_RRC_INST_NB
_IoT
*
rrc_instance_pP
,
struct
rrc_eNB_ue_context_NB_s
*
ue_context_pP
);
#endif
openair2/RRC/LITE/vars_NB_IoT.c
View file @
17c94ff8
...
...
@@ -66,8 +66,8 @@ unsigned short Data_to_read;
#include "LAYER2/MAC/extern.h"
#define MAX_U32 0xFFFFFFFF
eNB_RRC_INST_NB
*
eNB_rrc_inst_NB
;
uint8_t
DRB2LCHAN_NB
[
2
];
//max can be 2 DRBs for NB_IoT --> it used for saving the LCID of DRBs
eNB_RRC_INST_NB
_IoT
*
eNB_rrc_inst_NB_IoT
;
uint8_t
DRB2LCHAN_NB
_IoT
[
2
];
//max can be 2 DRBs for NB_IoT --> it used for saving the LCID of DRBs
//structure for FAPI-like configuration (memory for this is allocated in init_SI)
PHY_Config_t
*
config_INFO
;
...
...
@@ -76,11 +76,11 @@ BOOLEAN_t logicalChannelSR_Prohibit = 1;
long
priority
=
1
;
// Default SRB configurations from 36.331 (9.2.1.1 pag 641 V14.2.1)
struct
LogicalChannelConfig_NB_r13
SRB1bis_
NB_logicalChannelConfig_defaultValue
=
{
struct
LogicalChannelConfig_NB_r13
SRB1bis_
logicalChannelConfig_defaultValue_NB_IoT
=
{
priority_r13:
&
priority
,
//priority
logicalChannelSR_Prohibit_r13:
&
logicalChannelSR_Prohibit
//set to TRUE
};
struct
LogicalChannelConfig_NB_r13
SRB1_
NB_logicalChannelConfig_defaultValue
=
{
struct
LogicalChannelConfig_NB_r13
SRB1_
logicalChannelConfig_defaultValue_NB_IoT
=
{
priority_r13:
&
priority
,
//priority
logicalChannelSR_Prohibit_r13:
&
logicalChannelSR_Prohibit
//set to TRUE
};
...
...
@@ -88,18 +88,18 @@ struct LogicalChannelConfig_NB_r13 SRB1_NB_logicalChannelConfig_defaultValue = {
//CONSTANTS
rlc_info_t
Rlc_info_am_NB
,
Rlc_info_am_config_NB
;
rlc_info_t
Rlc_info_am_NB
_IoT
,
Rlc_info_am_config_NB_IoT
;
//MP: LCHAN_DESC (mac_rrc_primitives) is not needed, was only an old implementation for storing LCH information
// timers (TS 36.331 v14.2.1 "UE-TimersAndConstants-NB" pag 622) (milliseconds)
//seems to be not used or only at UE side
uint16_t
T300_NB
[
8
]
=
{
2500
,
4000
,
6000
,
10000
,
15000
,
25000
,
40000
,
60000
};
uint16_t
T301_NB
[
8
]
=
{
2500
,
4000
,
6000
,
10000
,
15000
,
25000
,
40000
,
60000
};
//MP: this start at RRCconnectionReestablishmentReq (not implemented in OAI)
uint16_t
T310_NB
[
8
]
=
{
0
,
200
,
500
,
1000
,
2000
,
4000
,
8000
};
uint16_t
T311_NB
[
8
]
=
{
1000
,
3000
,
5000
,
10000
,
15000
,
20000
,
30000
};
//MP: may not used
uint16_t
N310_NB
[
8
]
=
{
1
,
2
,
3
,
4
,
6
,
8
,
10
,
20
};
uint16_t
N311_NB
[
8
]
=
{
1
,
2
,
3
,
4
,
5
,
6
,
8
,
10
};
uint16_t
T300_NB
_IoT
[
8
]
=
{
2500
,
4000
,
6000
,
10000
,
15000
,
25000
,
40000
,
60000
};
uint16_t
T301_NB
_IoT
[
8
]
=
{
2500
,
4000
,
6000
,
10000
,
15000
,
25000
,
40000
,
60000
};
//MP: this start at RRCconnectionReestablishmentReq (not implemented in OAI)
uint16_t
T310_NB
_IoT
[
8
]
=
{
0
,
200
,
500
,
1000
,
2000
,
4000
,
8000
};
uint16_t
T311_NB
_IoT
[
8
]
=
{
1000
,
3000
,
5000
,
10000
,
15000
,
20000
,
30000
};
//MP: may not used
uint16_t
N310_NB
_IoT
[
8
]
=
{
1
,
2
,
3
,
4
,
6
,
8
,
10
,
20
};
uint16_t
N311_NB
_IoT
[
8
]
=
{
1
,
2
,
3
,
4
,
5
,
6
,
8
,
10
};
// MP: TimeToTrigger not used in NB-IoT
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment