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
canghaiwuhen
OpenXG-RAN
Commits
4b825183
Commit
4b825183
authored
Apr 20, 2016
by
Navid Nikaein
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
enabling SRB2
parent
15d50959
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
26 additions
and
20 deletions
+26
-20
openair2/LAYER2/PDCP_v10.1.0/pdcp.c
openair2/LAYER2/PDCP_v10.1.0/pdcp.c
+3
-3
openair2/LAYER2/PDCP_v10.1.0/pdcp_fifo.c
openair2/LAYER2/PDCP_v10.1.0/pdcp_fifo.c
+1
-1
openair2/RRC/LITE/rrc_eNB.c
openair2/RRC/LITE/rrc_eNB.c
+22
-16
No files found.
openair2/LAYER2/PDCP_v10.1.0/pdcp.c
View file @
4b825183
...
@@ -115,7 +115,7 @@ boolean_t pdcp_data_req(
...
@@ -115,7 +115,7 @@ boolean_t pdcp_data_req(
AssertError
(
rb_idP
<
NB_RB_MBMS_MAX
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
NB_RB_MBMS_MAX
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
AssertError
(
rb_idP
<
NB_RB_MBMS_MAX
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
NB_RB_MBMS_MAX
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
}
else
{
}
else
{
if
(
srb_flagP
)
{
if
(
srb_flagP
)
{
AssertError
(
rb_idP
<
2
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
2
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
AssertError
(
rb_idP
<
3
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
3
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
}
else
{
}
else
{
AssertError
(
rb_idP
<
maxDRB
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
maxDRB
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
AssertError
(
rb_idP
<
maxDRB
,
return
FALSE
,
"RB id is too high (%u/%d) %u %u!
\n
"
,
rb_idP
,
maxDRB
,
ctxt_pP
->
module_id
,
ctxt_pP
->
rnti
);
}
}
...
@@ -1475,8 +1475,8 @@ pdcp_config_req_asn1 (
...
@@ -1475,8 +1475,8 @@ pdcp_config_req_asn1 (
pdcp_pP
->
seq_num_size
=
5
;
pdcp_pP
->
seq_num_size
=
5
;
}
}
LOG_
D
(
PDCP
,
PROTOCOL_PDCP_CTXT_FMT
" Action MODIFY LCID %d "
LOG_
I
(
PDCP
,
PROTOCOL_PDCP_CTXT_FMT
" Action MODIFY LCID %d "
"RB id %d configured with SN size %d and RLC %s
\n
"
,
"RB id %d
re
configured with SN size %d and RLC %s
\n
"
,
PROTOCOL_PDCP_CTXT_ARGS
(
ctxt_pP
,
pdcp_pP
),
PROTOCOL_PDCP_CTXT_ARGS
(
ctxt_pP
,
pdcp_pP
),
lc_idP
,
lc_idP
,
rb_idP
,
rb_idP
,
...
...
openair2/LAYER2/PDCP_v10.1.0/pdcp_fifo.c
View file @
4b825183
...
@@ -482,7 +482,7 @@ int pdcp_fifo_read_input_sdus (const protocol_ctxt_t* const ctxt_pP)
...
@@ -482,7 +482,7 @@ int pdcp_fifo_read_input_sdus (const protocol_ctxt_t* const ctxt_pP)
ctxt
.
enb_flag
=
ENB_FLAG_NO
;
ctxt
.
enb_flag
=
ENB_FLAG_NO
;
ctxt
.
module_id
=
pdcp_read_header_g
.
inst
-
oai_emulation
.
info
.
nb_enb_local
+
oai_emulation
.
info
.
first_ue_local
;
ctxt
.
module_id
=
pdcp_read_header_g
.
inst
-
oai_emulation
.
info
.
nb_enb_local
+
oai_emulation
.
info
.
first_ue_local
;
ctxt
.
rnti
=
pdcp_UE_UE_module_id_to_rnti
[
ctxt
.
module_id
];
ctxt
.
rnti
=
pdcp_UE_UE_module_id_to_rnti
[
ctxt
.
module_id
];
rab_id
=
pdcp_read_header_g
.
rb_id
;
rab_id
=
pdcp_read_header_g
.
rb_id
%
maxDRB
;
}
}
CHECK_CTXT_ARGS
(
&
ctxt
);
CHECK_CTXT_ARGS
(
&
ctxt
);
...
...
openair2/RRC/LITE/rrc_eNB.c
View file @
4b825183
...
@@ -1153,6 +1153,8 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
...
@@ -1153,6 +1153,8 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
//*DRB_configList = CALLOC(1, sizeof(*DRB_configList));
//*DRB_configList = CALLOC(1, sizeof(*DRB_configList));
*
DRB_configList
=
CALLOC
(
1
,
sizeof
(
**
DRB_configList
));
*
DRB_configList
=
CALLOC
(
1
,
sizeof
(
**
DRB_configList
));
dedicatedInfoNASList
=
CALLOC
(
1
,
sizeof
(
struct
RRCConnectionReconfiguration_r8_IEs__dedicatedInfoNASList
));
dedicatedInfoNASList
=
CALLOC
(
1
,
sizeof
(
struct
RRCConnectionReconfiguration_r8_IEs__dedicatedInfoNASList
));
int
e_rab_done
=
0
;
for
(
i
=
0
;
for
(
i
=
0
;
i
<
ue_context_pP
->
ue_context
.
setup_e_rabs
;
i
<
ue_context_pP
->
ue_context
.
setup_e_rabs
;
...
@@ -1167,9 +1169,10 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
...
@@ -1167,9 +1169,10 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
DRB_config
=
CALLOC
(
1
,
sizeof
(
*
DRB_config
));
DRB_config
=
CALLOC
(
1
,
sizeof
(
*
DRB_config
));
DRB_config
->
eps_BearerIdentity
=
CALLOC
(
1
,
sizeof
(
long
));
DRB_config
->
eps_BearerIdentity
=
CALLOC
(
1
,
sizeof
(
long
));
*
(
DRB_config
->
eps_BearerIdentity
)
=
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
e_rab_id
;
// allowed value 5..15, value : x+4
*
(
DRB_config
->
eps_BearerIdentity
)
=
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
e_rab_id
+
4
;
DRB_config
->
drb_Identity
=
1
+
drb_identity_index
;
// + i ;// (DRB_Identity_t) ue_context_pP->ue_context.e_rab[i].param.e_rab_id;
DRB_config
->
drb_Identity
=
1
+
drb_identity_index
+
e_rab_done
;
// + i ;// (DRB_Identity_t) ue_context_pP->ue_context.e_rab[i].param.e_rab_id;
// 1 + drb_identiy_index;
// 1 + drb_identiy_index;
DRB_config
->
logicalChannelIdentity
=
CALLOC
(
1
,
sizeof
(
long
));
DRB_config
->
logicalChannelIdentity
=
CALLOC
(
1
,
sizeof
(
long
));
...
@@ -1273,12 +1276,14 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
...
@@ -1273,12 +1276,14 @@ rrc_eNB_generate_dedicatedRRCConnectionReconfiguration(const protocol_ctxt_t* co
}
}
/* If list is empty free the list and reset the address */
/* If list is empty free the list and reset the address */
if
(
dedicatedInfoNASList
->
list
.
count
==
0
)
{
if
(
dedicatedInfoNASList
!=
NULL
)
{
free
(
dedicatedInfoNASList
);
if
(
dedicatedInfoNASList
->
list
.
count
==
0
)
{
dedicatedInfoNASList
=
NULL
;
free
(
dedicatedInfoNASList
);
}
dedicatedInfoNASList
=
NULL
;
}
}
}
}
e_rab_done
++
;
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
=
E_RAB_STATUS_DONE
;
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
=
E_RAB_STATUS_DONE
;
ue_context_pP
->
ue_context
.
e_rab
[
i
].
xid
=
rrc_eNB_get_next_transaction_identifier
(
ctxt_pP
->
module_id
);
//Transaction_id,
ue_context_pP
->
ue_context
.
e_rab
[
i
].
xid
=
rrc_eNB_get_next_transaction_identifier
(
ctxt_pP
->
module_id
);
//Transaction_id,
...
@@ -1477,7 +1482,9 @@ rrc_eNB_generate_defaultRRCConnectionReconfiguration(const protocol_ctxt_t* cons
...
@@ -1477,7 +1482,9 @@ rrc_eNB_generate_defaultRRCConnectionReconfiguration(const protocol_ctxt_t* cons
SRB2_ul_SpecificParameters
->
logicalChannelGroup
=
logicalchannelgroup
;
SRB2_ul_SpecificParameters
->
logicalChannelGroup
=
logicalchannelgroup
;
SRB2_lchan_config
->
choice
.
explicitValue
.
ul_SpecificParameters
=
SRB2_ul_SpecificParameters
;
SRB2_lchan_config
->
choice
.
explicitValue
.
ul_SpecificParameters
=
SRB2_ul_SpecificParameters
;
// this list has the configuration for SRB1 and SRB2
ASN_SEQUENCE_ADD
(
&
SRB_configList
->
list
,
SRB2_config
);
ASN_SEQUENCE_ADD
(
&
SRB_configList
->
list
,
SRB2_config
);
// this list has only the configuration for SRB2
ASN_SEQUENCE_ADD
(
&
SRB_configList2
->
list
,
SRB2_config
);
ASN_SEQUENCE_ADD
(
&
SRB_configList2
->
list
,
SRB2_config
);
// Configure DRB
// Configure DRB
...
@@ -1898,7 +1905,7 @@ rrc_eNB_generate_defaultRRCConnectionReconfiguration(const protocol_ctxt_t* cons
...
@@ -1898,7 +1905,7 @@ rrc_eNB_generate_defaultRRCConnectionReconfiguration(const protocol_ctxt_t* cons
size
=
do_RRCConnectionReconfiguration
(
ctxt_pP
,
size
=
do_RRCConnectionReconfiguration
(
ctxt_pP
,
buffer
,
buffer
,
rrc_eNB_get_next_transaction_identifier
(
ctxt_pP
->
module_id
),
//Transaction_id,
rrc_eNB_get_next_transaction_identifier
(
ctxt_pP
->
module_id
),
//Transaction_id,
(
SRB_ToAddModList_t
*
)
NULL
,
/// NN: do not reconfig srb1: SRB_configList2,
(
SRB_ToAddModList_t
*
)
SRB_configList
,
// SRB_configList
(
DRB_ToAddModList_t
*
)
*
DRB_configList
,
(
DRB_ToAddModList_t
*
)
*
DRB_configList
,
(
DRB_ToReleaseList_t
*
)
NULL
,
// DRB2_list,
(
DRB_ToReleaseList_t
*
)
NULL
,
// DRB2_list,
(
struct
SPS_Config
*
)
NULL
,
// *sps_Config,
(
struct
SPS_Config
*
)
NULL
,
// *sps_Config,
...
@@ -3306,7 +3313,7 @@ rrc_eNB_process_RRCConnectionReconfigurationComplete(
...
@@ -3306,7 +3313,7 @@ rrc_eNB_process_RRCConnectionReconfigurationComplete(
rrc_pdcp_config_asn1_req
(
rrc_pdcp_config_asn1_req
(
ctxt_pP
,
ctxt_pP
,
NULL
,
//LG-RK 14/05/2014 SRB_configList,
SRB_configList
,
//
NULL, //LG-RK 14/05/2014 SRB_configList,
DRB_configList
,
DRB_configList
,
(
DRB_ToReleaseList_t
*
)
NULL
,
(
DRB_ToReleaseList_t
*
)
NULL
,
/*eNB_rrc_inst[ctxt_pP->module_id].ciphering_algorithm[ue_mod_idP] |
/*eNB_rrc_inst[ctxt_pP->module_id].ciphering_algorithm[ue_mod_idP] |
...
@@ -3323,7 +3330,7 @@ rrc_eNB_process_RRCConnectionReconfigurationComplete(
...
@@ -3323,7 +3330,7 @@ rrc_eNB_process_RRCConnectionReconfigurationComplete(
// Refresh SRBs/DRBs
// Refresh SRBs/DRBs
rrc_rlc_config_asn1_req
(
rrc_rlc_config_asn1_req
(
ctxt_pP
,
ctxt_pP
,
NULL
,
//LG-RK 14/05/2014 SRB_configList,
SRB_configList
,
//
NULL, //LG-RK 14/05/2014 SRB_configList,
DRB_configList
,
DRB_configList
,
(
DRB_ToReleaseList_t
*
)
NULL
(
DRB_ToReleaseList_t
*
)
NULL
#ifdef Rel10
#ifdef Rel10
...
@@ -4581,9 +4588,9 @@ void rrc_eNB_reconfigure_DRBs (const protocol_ctxt_t* const ctxt_pP,
...
@@ -4581,9 +4588,9 @@ void rrc_eNB_reconfigure_DRBs (const protocol_ctxt_t* const ctxt_pP,
rrc_eNB_ue_context_t
*
ue_context_pP
){
rrc_eNB_ue_context_t
*
ue_context_pP
){
int
i
;
int
i
;
int
e_rab_done
=
0
;
for
(
i
=
0
;
for
(
i
=
0
;
i
<
NB_RB_MAX
-
3
;
// S1AP_MAX_E_RAB
i
<
3
;
//
NB_RB_MAX - 3; // S1AP_MAX_E_RAB
i
++
)
{
i
++
)
{
if
(
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
<
E_RAB_STATUS_DONE
){
if
(
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
<
E_RAB_STATUS_DONE
){
...
@@ -4600,14 +4607,13 @@ void rrc_eNB_reconfigure_DRBs (const protocol_ctxt_t* const ctxt_pP,
...
@@ -4600,14 +4607,13 @@ void rrc_eNB_reconfigure_DRBs (const protocol_ctxt_t* const ctxt_pP,
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
gtp_teid
=
0
;
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
gtp_teid
=
0
;
ue_context_pP
->
ue_context
.
nb_of_e_rabs
++
;
ue_context_pP
->
ue_context
.
nb_of_e_rabs
++
;
e_rab_done
++
;
LOG_I
(
RRC
,
"setting up the dedicated DRBs %d (index %d) status %d
\n
"
,
LOG_I
(
RRC
,
"setting up the dedicated DRBs %d (index %d) status %d
\n
"
,
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
e_rab_id
,
i
,
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
);
ue_context_pP
->
ue_context
.
e_rab
[
i
].
param
.
e_rab_id
,
i
,
ue_context_pP
->
ue_context
.
e_rab
[
i
].
status
);
}
}
ue_context_pP
->
ue_context
.
setup_e_rabs
+=
ue_context_pP
->
ue_context
.
nb_of_e_rabs
;
}
}
ue_context_pP
->
ue_context
.
setup_e_rabs
+=
e_rab_done
;
rrc_eNB_generate_dedicatedRRCConnectionReconfiguration
(
ctxt_pP
,
ue_context_pP
,
0
);
rrc_eNB_generate_dedicatedRRCConnectionReconfiguration
(
ctxt_pP
,
ue_context_pP
,
0
);
}
}
...
...
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