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
spbro
OpenXG-RAN
Commits
31bad32b
Commit
31bad32b
authored
Aug 02, 2024
by
Robert Schmidt
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reestablishment with RRC setup fallback: release old UE if applicable
parent
4e7e8a6f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
4 deletions
+11
-4
openair2/RRC/NR/rrc_gNB.c
openair2/RRC/NR/rrc_gNB.c
+11
-4
No files found.
openair2/RRC/NR/rrc_gNB.c
View file @
31bad32b
...
@@ -1120,7 +1120,9 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1120,7 +1120,9 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
uint64_t
random_value
=
0
;
uint64_t
random_value
=
0
;
const
char
*
scause
=
get_reestab_cause
(
req
->
reestablishmentCause
);
const
char
*
scause
=
get_reestab_cause
(
req
->
reestablishmentCause
);
const
long
physCellId
=
req
->
ue_Identity
.
physCellId
;
const
long
physCellId
=
req
->
ue_Identity
.
physCellId
;
LOG_D
(
NR_RRC
,
"UE %04x physCellId %ld NR_RRCReestablishmentRequest cause %s
\n
"
,
msg
->
crnti
,
physCellId
,
scause
);
long
ngap_cause
=
NGAP_CAUSE_RADIO_NETWORK_UNSPECIFIED
;
/* cause in case of NGAP release req */
rrc_gNB_ue_context_t
*
ue_context_p
=
NULL
;
LOG_I
(
NR_RRC
,
"UE %04x physCellId %ld NR_RRCReestablishmentRequest cause %s
\n
"
,
msg
->
crnti
,
physCellId
,
scause
);
const
nr_rrc_du_container_t
*
du
=
get_du_by_assoc_id
(
rrc
,
assoc_id
);
const
nr_rrc_du_container_t
*
du
=
get_du_by_assoc_id
(
rrc
,
assoc_id
);
if
(
du
==
NULL
)
{
if
(
du
==
NULL
)
{
...
@@ -1137,7 +1139,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1137,7 +1139,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
}
}
rnti_t
old_rnti
=
req
->
ue_Identity
.
c_RNTI
;
rnti_t
old_rnti
=
req
->
ue_Identity
.
c_RNTI
;
rrc_gNB_ue_context_t
*
ue_context_p
=
rrc_gNB_get_ue_context_by_rnti
(
rrc
,
assoc_id
,
old_rnti
);
ue_context_p
=
rrc_gNB_get_ue_context_by_rnti
(
rrc
,
assoc_id
,
old_rnti
);
if
(
ue_context_p
==
NULL
)
{
if
(
ue_context_p
==
NULL
)
{
LOG_E
(
NR_RRC
,
"NR_RRCReestablishmentRequest without UE context, fallback to RRC setup
\n
"
);
LOG_E
(
NR_RRC
,
"NR_RRCReestablishmentRequest without UE context, fallback to RRC setup
\n
"
);
goto
fallback_rrc_setup
;
goto
fallback_rrc_setup
;
...
@@ -1150,6 +1152,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1150,6 +1152,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
"RRC Reestablishment Request from different physCellId (%ld) than current physCellId (%d), fallback to RRC setup
\n
"
,
"RRC Reestablishment Request from different physCellId (%ld) than current physCellId (%d), fallback to RRC setup
\n
"
,
physCellId
,
physCellId
,
cell_info
->
nr_pci
);
cell_info
->
nr_pci
);
ngap_cause
=
NGAP_CAUSE_RADIO_NETWORK_RELEASE_DUE_TO_NGRAN_GENERATED_REASON
;
/* 38.401 8.7: "If the UE accessed from a gNB-DU other than the original
/* 38.401 8.7: "If the UE accessed from a gNB-DU other than the original
* one, the gNB-CU should trigger the UE Context Setup procedure". Let's
* one, the gNB-CU should trigger the UE Context Setup procedure". Let's
* assume that the old DU will trigger a release request, also freeing the
* assume that the old DU will trigger a release request, also freeing the
...
@@ -1168,6 +1171,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1168,6 +1171,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
if
(
!
UE
->
as_security_active
)
{
if
(
!
UE
->
as_security_active
)
{
/* no active security context, need to restart entire connection */
/* no active security context, need to restart entire connection */
LOG_E
(
NR_RRC
,
"UE requested Reestablishment without activated AS security
\n
"
);
LOG_E
(
NR_RRC
,
"UE requested Reestablishment without activated AS security
\n
"
);
ngap_cause
=
NGAP_CAUSE_RADIO_NETWORK_RELEASE_DUE_TO_NGRAN_GENERATED_REASON
;
goto
fallback_rrc_setup
;
goto
fallback_rrc_setup
;
}
}
...
@@ -1176,6 +1180,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1176,6 +1180,7 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
// SSB ARFCN and can't do reestablishment. handle it gracefully by doing
// SSB ARFCN and can't do reestablishment. handle it gracefully by doing
// RRC setup procedure instead
// RRC setup procedure instead
LOG_E
(
NR_RRC
,
"no MeasurementTimingConfiguration for this cell, cannot perform reestablishment
\n
"
);
LOG_E
(
NR_RRC
,
"no MeasurementTimingConfiguration for this cell, cannot perform reestablishment
\n
"
);
ngap_cause
=
NGAP_CAUSE_RADIO_NETWORK_RELEASE_DUE_TO_NGRAN_GENERATED_REASON
;
goto
fallback_rrc_setup
;
goto
fallback_rrc_setup
;
}
}
...
@@ -1188,8 +1193,6 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
...
@@ -1188,8 +1193,6 @@ static void rrc_handle_RRCReestablishmentRequest(gNB_RRC_INST *rrc,
cu_remove_f1_ue_data
(
UE
->
rrc_ue_id
);
cu_remove_f1_ue_data
(
UE
->
rrc_ue_id
);
cu_add_f1_ue_data
(
UE
->
rrc_ue_id
,
&
ue_data
);
cu_add_f1_ue_data
(
UE
->
rrc_ue_id
,
&
ue_data
);
LOG_I
(
NR_RRC
,
"Accept Reestablishment Request UE physCellId %ld cause %s
\n
"
,
physCellId
,
scause
);
rrc_gNB_generate_RRCReestablishment
(
ue_context_p
,
msg
->
du2cu_rrc_container
,
old_rnti
,
du
);
rrc_gNB_generate_RRCReestablishment
(
ue_context_p
,
msg
->
du2cu_rrc_container
,
old_rnti
,
du
);
return
;
return
;
...
@@ -1197,6 +1200,10 @@ fallback_rrc_setup:
...
@@ -1197,6 +1200,10 @@ fallback_rrc_setup:
fill_random
(
&
random_value
,
sizeof
(
random_value
));
fill_random
(
&
random_value
,
sizeof
(
random_value
));
random_value
=
random_value
&
0x7fffffffff
;
/* random value is 39 bits */
random_value
=
random_value
&
0x7fffffffff
;
/* random value is 39 bits */
/* request release of the "old" UE in case it exists */
if
(
ue_context_p
!=
NULL
)
rrc_gNB_send_NGAP_UE_CONTEXT_RELEASE_REQ
(
0
,
ue_context_p
,
NGAP_CAUSE_RADIO_NETWORK
,
ngap_cause
);
rrc_gNB_ue_context_t
*
new
=
rrc_gNB_create_ue_context
(
assoc_id
,
msg
->
crnti
,
rrc
,
random_value
,
msg
->
gNB_DU_ue_id
);
rrc_gNB_ue_context_t
*
new
=
rrc_gNB_create_ue_context
(
assoc_id
,
msg
->
crnti
,
rrc
,
random_value
,
msg
->
gNB_DU_ue_id
);
activate_srb
(
&
new
->
ue_context
,
1
);
activate_srb
(
&
new
->
ue_context
,
1
);
rrc_gNB_generate_RRCSetup
(
0
,
msg
->
crnti
,
new
,
msg
->
du2cu_rrc_container
,
msg
->
du2cu_rrc_container_length
);
rrc_gNB_generate_RRCSetup
(
0
,
msg
->
crnti
,
new
,
msg
->
du2cu_rrc_container
,
msg
->
du2cu_rrc_container_length
);
...
...
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