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
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
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
OpenXG
OpenXG-RAN
Commits
bc9f95c9
Commit
bc9f95c9
authored
Mar 18, 2024
by
Robert Schmidt
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/fixes-gtp-f1' into integration_2024_w11
parents
b6aefac5
73d21d6d
Changes
5
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
378 additions
and
562 deletions
+378
-562
openair2/F1AP/f1ap_cu_ue_context_management.c
openair2/F1AP/f1ap_cu_ue_context_management.c
+151
-396
openair2/F1AP/f1ap_du_rrc_message_transfer.c
openair2/F1AP/f1ap_du_rrc_message_transfer.c
+0
-2
openair2/F1AP/f1ap_du_task.c
openair2/F1AP/f1ap_du_task.c
+14
-0
openair2/F1AP/f1ap_du_ue_context_management.c
openair2/F1AP/f1ap_du_ue_context_management.c
+124
-162
openair2/LAYER2/NR_MAC_gNB/mac_rrc_dl_handler.c
openair2/LAYER2/NR_MAC_gNB/mac_rrc_dl_handler.c
+89
-2
No files found.
openair2/F1AP/f1ap_cu_ue_context_management.c
View file @
bc9f95c9
This diff is collapsed.
Click to expand it.
openair2/F1AP/f1ap_du_rrc_message_transfer.c
View file @
bc9f95c9
...
@@ -50,7 +50,6 @@
...
@@ -50,7 +50,6 @@
#include "asn1_msg.h"
#include "asn1_msg.h"
#include "intertask_interface.h"
#include "intertask_interface.h"
#include "LAYER2/NR_MAC_gNB/mac_proto.h"
#include "LAYER2/NR_MAC_gNB/mac_proto.h"
#include <openair3/ocp-gtpu/gtp_itf.h>
#include "openair2/LAYER2/NR_MAC_gNB/mac_rrc_dl_handler.h"
#include "openair2/LAYER2/NR_MAC_gNB/mac_rrc_dl_handler.h"
...
@@ -83,7 +82,6 @@ int DU_handle_DL_RRC_MESSAGE_TRANSFER(instance_t instance, sctp_assoc_t assoc_id
...
@@ -83,7 +82,6 @@ int DU_handle_DL_RRC_MESSAGE_TRANSFER(instance_t instance, sctp_assoc_t assoc_id
/* strange: it is not named OLD_GNB_DU_UE... */
/* strange: it is not named OLD_GNB_DU_UE... */
old_gNB_DU_ue_id_stack
=
ie
->
value
.
choice
.
GNB_DU_UE_F1AP_ID_1
;
old_gNB_DU_ue_id_stack
=
ie
->
value
.
choice
.
GNB_DU_UE_F1AP_ID_1
;
old_gNB_DU_ue_id
=
&
old_gNB_DU_ue_id_stack
;
old_gNB_DU_ue_id
=
&
old_gNB_DU_ue_id_stack
;
gtpv1u_update_ue_id
(
getCxt
(
instance
)
->
gtpInst
,
old_gNB_DU_ue_id_stack
,
du_ue_f1ap_id
);
}
}
/* mandatory */
/* mandatory */
...
...
openair2/F1AP/f1ap_du_task.c
View file @
bc9f95c9
...
@@ -40,6 +40,16 @@
...
@@ -40,6 +40,16 @@
//Fixme: Uniq dirty DU instance, by global var, datamodel need better management
//Fixme: Uniq dirty DU instance, by global var, datamodel need better management
instance_t
DUuniqInstance
=
0
;
instance_t
DUuniqInstance
=
0
;
static
instance_t
du_create_gtpu_instance_to_cu
(
const
f1ap_net_config_t
*
nc
)
{
openAddr_t
tmp
=
{
0
};
strncpy
(
tmp
.
originHost
,
nc
->
DU_f1_ip_address
.
ipv4_address
,
sizeof
(
tmp
.
originHost
)
-
1
);
strncpy
(
tmp
.
destinationHost
,
nc
->
CU_f1_ip_address
.
ipv4_address
,
sizeof
(
tmp
.
destinationHost
)
-
1
);
sprintf
(
tmp
.
originService
,
"%d"
,
nc
->
DUport
);
sprintf
(
tmp
.
destinationService
,
"%d"
,
nc
->
CUport
);
return
gtpv1Init
(
tmp
);
}
void
du_task_send_sctp_association_req
(
instance_t
instance
,
f1ap_net_config_t
*
nc
)
void
du_task_send_sctp_association_req
(
instance_t
instance
,
f1ap_net_config_t
*
nc
)
{
{
DevAssert
(
nc
!=
NULL
);
DevAssert
(
nc
!=
NULL
);
...
@@ -116,6 +126,10 @@ void *F1AP_DU_task(void *arg) {
...
@@ -116,6 +126,10 @@ void *F1AP_DU_task(void *arg) {
f1ap_net_config_t
*
nc
=
&
F1AP_DU_REGISTER_REQ
(
msg
).
net_config
;
f1ap_net_config_t
*
nc
=
&
F1AP_DU_REGISTER_REQ
(
msg
).
net_config
;
createF1inst
(
myInstance
,
msgSetup
,
nc
);
createF1inst
(
myInstance
,
msgSetup
,
nc
);
du_task_send_sctp_association_req
(
myInstance
,
nc
);
du_task_send_sctp_association_req
(
myInstance
,
nc
);
instance_t
gtpInst
=
du_create_gtpu_instance_to_cu
(
nc
);
AssertFatal
(
gtpInst
!=
0
,
"cannot create DU F1-U GTP module
\n
"
);
getCxt
(
myInstance
)
->
gtpInst
=
gtpInst
;
DUuniqInstance
=
gtpInst
;
}
break
;
}
break
;
case
F1AP_GNB_CU_CONFIGURATION_UPDATE_ACKNOWLEDGE
:
case
F1AP_GNB_CU_CONFIGURATION_UPDATE_ACKNOWLEDGE
:
...
...
openair2/F1AP/f1ap_du_ue_context_management.c
View file @
bc9f95c9
This diff is collapsed.
Click to expand it.
openair2/LAYER2/NR_MAC_gNB/mac_rrc_dl_handler.c
View file @
bc9f95c9
...
@@ -23,8 +23,11 @@
...
@@ -23,8 +23,11 @@
#include "mac_proto.h"
#include "mac_proto.h"
#include "openair2/F1AP/f1ap_ids.h"
#include "openair2/F1AP/f1ap_ids.h"
#include "openair2/F1AP/f1ap_common.h"
#include "openair2/LAYER2/nr_rlc/nr_rlc_oai_api.h"
#include "openair2/LAYER2/nr_rlc/nr_rlc_oai_api.h"
#include "F1AP_CauseRadioNetwork.h"
#include "F1AP_CauseRadioNetwork.h"
#include "openair3/ocp-gtpu/gtp_itf.h"
#include "openair2/LAYER2/nr_pdcp/nr_pdcp_oai_api.h"
#include "uper_decoder.h"
#include "uper_decoder.h"
#include "uper_encoder.h"
#include "uper_encoder.h"
...
@@ -34,6 +37,59 @@ const uint64_t qos_fiveqi[26] = {1, 2, 3, 4, 65, 66, 67, 71, 72, 73, 74, 76, 5,
...
@@ -34,6 +37,59 @@ const uint64_t qos_fiveqi[26] = {1, 2, 3, 4, 65, 66, 67, 71, 72, 73, 74, 76, 5,
const
uint64_t
qos_priority
[
26
]
=
{
20
,
40
,
30
,
50
,
7
,
20
,
15
,
56
,
56
,
56
,
56
,
56
,
10
,
const
uint64_t
qos_priority
[
26
]
=
{
20
,
40
,
30
,
50
,
7
,
20
,
15
,
56
,
56
,
56
,
56
,
56
,
10
,
60
,
70
,
80
,
90
,
5
,
55
,
65
,
68
,
19
,
22
,
24
,
21
,
18
};
60
,
70
,
80
,
90
,
5
,
55
,
65
,
68
,
19
,
22
,
24
,
21
,
18
};
static
instance_t
get_f1_gtp_instance
(
void
)
{
const
f1ap_cudu_inst_t
*
inst
=
getCxt
(
0
);
if
(
!
inst
)
return
-
1
;
// means no F1
return
inst
->
gtpInst
;
}
static
int
drb_gtpu_create
(
instance_t
instance
,
uint32_t
ue_id
,
int
incoming_id
,
int
outgoing_id
,
int
qfi
,
in_addr_t
tlAddress
,
// only IPv4 now
teid_t
outgoing_teid
,
gtpCallback
callBack
,
gtpCallbackSDAP
callBackSDAP
,
gtpv1u_gnb_create_tunnel_resp_t
*
create_tunnel_resp
)
{
gtpv1u_gnb_create_tunnel_req_t
create_tunnel_req
=
{
0
};
create_tunnel_req
.
incoming_rb_id
[
0
]
=
incoming_id
;
create_tunnel_req
.
pdusession_id
[
0
]
=
outgoing_id
;
memcpy
(
&
create_tunnel_req
.
dst_addr
[
0
].
buffer
,
&
tlAddress
,
sizeof
(
uint8_t
)
*
4
);
create_tunnel_req
.
dst_addr
[
0
].
length
=
32
;
create_tunnel_req
.
outgoing_teid
[
0
]
=
outgoing_teid
;
create_tunnel_req
.
outgoing_qfi
[
0
]
=
qfi
;
create_tunnel_req
.
num_tunnels
=
1
;
create_tunnel_req
.
ue_id
=
ue_id
;
// we use gtpv1u_create_ngu_tunnel because it returns the interface
// address and port of the interface; apart from that, we also might call
// newGtpuCreateTunnel() directly
return
gtpv1u_create_ngu_tunnel
(
instance
,
&
create_tunnel_req
,
create_tunnel_resp
,
callBack
,
callBackSDAP
);
}
bool
DURecvCb
(
protocol_ctxt_t
*
ctxt_pP
,
const
srb_flag_t
srb_flagP
,
const
rb_id_t
rb_idP
,
const
mui_t
muiP
,
const
confirm_t
confirmP
,
const
sdu_size_t
sdu_buffer_sizeP
,
unsigned
char
*
const
sdu_buffer_pP
,
const
pdcp_transmission_mode_t
modeP
,
const
uint32_t
*
sourceL2Id
,
const
uint32_t
*
destinationL2Id
)
{
// The buffer comes from the stack in gtp-u thread, we have a make a separate buffer to enqueue in a inter-thread message queue
uint8_t
*
sdu
=
malloc16
(
sdu_buffer_sizeP
);
memcpy
(
sdu
,
sdu_buffer_pP
,
sdu_buffer_sizeP
);
du_rlc_data_req
(
ctxt_pP
,
srb_flagP
,
false
,
rb_idP
,
muiP
,
confirmP
,
sdu_buffer_sizeP
,
sdu
);
return
true
;
}
static
long
get_lcid_from_drbid
(
int
drb_id
)
static
long
get_lcid_from_drbid
(
int
drb_id
)
{
{
return
drb_id
+
3
;
/* LCID is DRB + 3 */
return
drb_id
+
3
;
/* LCID is DRB + 3 */
...
@@ -133,6 +189,7 @@ static int handle_ue_context_drbs_setup(int rnti,
...
@@ -133,6 +189,7 @@ static int handle_ue_context_drbs_setup(int rnti,
NR_CellGroupConfig_t
*
cellGroupConfig
)
NR_CellGroupConfig_t
*
cellGroupConfig
)
{
{
DevAssert
(
req_drbs
!=
NULL
&&
resp_drbs
!=
NULL
&&
cellGroupConfig
!=
NULL
);
DevAssert
(
req_drbs
!=
NULL
&&
resp_drbs
!=
NULL
&&
cellGroupConfig
!=
NULL
);
instance_t
f1inst
=
get_f1_gtp_instance
();
/* Note: the actual GTP tunnels are created in the F1AP breanch of
/* Note: the actual GTP tunnels are created in the F1AP breanch of
* ue_context_*_response() */
* ue_context_*_response() */
...
@@ -140,12 +197,32 @@ static int handle_ue_context_drbs_setup(int rnti,
...
@@ -140,12 +197,32 @@ static int handle_ue_context_drbs_setup(int rnti,
AssertFatal
(
*
resp_drbs
!=
NULL
,
"out of memory
\n
"
);
AssertFatal
(
*
resp_drbs
!=
NULL
,
"out of memory
\n
"
);
for
(
int
i
=
0
;
i
<
drbs_len
;
i
++
)
{
for
(
int
i
=
0
;
i
<
drbs_len
;
i
++
)
{
const
f1ap_drb_to_be_setup_t
*
drb
=
&
req_drbs
[
i
];
const
f1ap_drb_to_be_setup_t
*
drb
=
&
req_drbs
[
i
];
f1ap_drb_to_be_setup_t
*
resp_drb
=
&
(
*
resp_drbs
)[
i
];
NR_RLC_BearerConfig_t
*
rlc_BearerConfig
=
get_bearerconfig_from_drb
(
drb
);
NR_RLC_BearerConfig_t
*
rlc_BearerConfig
=
get_bearerconfig_from_drb
(
drb
);
nr_rlc_add_drb
(
rnti
,
drb
->
drb_id
,
rlc_BearerConfig
);
nr_rlc_add_drb
(
rnti
,
drb
->
drb_id
,
rlc_BearerConfig
);
(
*
resp_drbs
)[
i
]
=
*
drb
;
*
resp_drb
=
*
drb
;
// just put same number of tunnels in DL as in UL
// just put same number of tunnels in DL as in UL
(
*
resp_drbs
)[
i
].
up_dl_tnl_length
=
drb
->
up_ul_tnl_length
;
DevAssert
(
drb
->
up_ul_tnl_length
==
1
);
resp_drb
->
up_dl_tnl_length
=
drb
->
up_ul_tnl_length
;
if
(
f1inst
>=
0
)
{
// we actually use F1-U
int
qfi
=
-
1
;
// don't put PDU session marker in GTP
gtpv1u_gnb_create_tunnel_resp_t
resp_f1
=
{
0
};
int
ret
=
drb_gtpu_create
(
f1inst
,
rnti
,
drb
->
drb_id
,
drb
->
drb_id
,
qfi
,
drb
->
up_ul_tnl
[
0
].
tl_address
,
drb
->
up_ul_tnl
[
0
].
teid
,
DURecvCb
,
NULL
,
&
resp_f1
);
AssertFatal
(
ret
>=
0
,
"Unable to create GTP Tunnel for F1-U
\n
"
);
memcpy
(
&
resp_drb
->
up_dl_tnl
[
0
].
tl_address
,
&
resp_f1
.
gnb_addr
.
buffer
,
4
);
resp_drb
->
up_dl_tnl
[
0
].
teid
=
resp_f1
.
gnb_NGu_teid
[
0
];
}
int
ret
=
ASN_SEQUENCE_ADD
(
&
cellGroupConfig
->
rlc_BearerToAddModList
->
list
,
rlc_BearerConfig
);
int
ret
=
ASN_SEQUENCE_ADD
(
&
cellGroupConfig
->
rlc_BearerToAddModList
->
list
,
rlc_BearerConfig
);
DevAssert
(
ret
==
0
);
DevAssert
(
ret
==
0
);
...
@@ -159,6 +236,7 @@ static int handle_ue_context_drbs_release(int rnti,
...
@@ -159,6 +236,7 @@ static int handle_ue_context_drbs_release(int rnti,
NR_CellGroupConfig_t
*
cellGroupConfig
)
NR_CellGroupConfig_t
*
cellGroupConfig
)
{
{
DevAssert
(
req_drbs
!=
NULL
&&
cellGroupConfig
!=
NULL
);
DevAssert
(
req_drbs
!=
NULL
&&
cellGroupConfig
!=
NULL
);
instance_t
f1inst
=
get_f1_gtp_instance
();
cellGroupConfig
->
rlc_BearerToReleaseList
=
calloc
(
1
,
sizeof
(
*
cellGroupConfig
->
rlc_BearerToReleaseList
));
cellGroupConfig
->
rlc_BearerToReleaseList
=
calloc
(
1
,
sizeof
(
*
cellGroupConfig
->
rlc_BearerToReleaseList
));
AssertFatal
(
cellGroupConfig
->
rlc_BearerToReleaseList
!=
NULL
,
"out of memory
\n
"
);
AssertFatal
(
cellGroupConfig
->
rlc_BearerToReleaseList
!=
NULL
,
"out of memory
\n
"
);
...
@@ -178,6 +256,8 @@ static int handle_ue_context_drbs_release(int rnti,
...
@@ -178,6 +256,8 @@ static int handle_ue_context_drbs_release(int rnti,
}
}
if
(
idx
<
cellGroupConfig
->
rlc_BearerToAddModList
->
list
.
count
)
{
if
(
idx
<
cellGroupConfig
->
rlc_BearerToAddModList
->
list
.
count
)
{
nr_rlc_release_entity
(
rnti
,
lcid
);
nr_rlc_release_entity
(
rnti
,
lcid
);
if
(
f1inst
>=
0
)
newGtpuDeleteOneTunnel
(
f1inst
,
rnti
,
drb
->
rb_id
);
asn_sequence_del
(
&
cellGroupConfig
->
rlc_BearerToAddModList
->
list
,
idx
,
1
);
asn_sequence_del
(
&
cellGroupConfig
->
rlc_BearerToAddModList
->
list
,
idx
,
1
);
long
*
plcid
=
malloc
(
sizeof
(
*
plcid
));
long
*
plcid
=
malloc
(
sizeof
(
*
plcid
));
AssertFatal
(
plcid
!=
NULL
,
"out of memory
\n
"
);
AssertFatal
(
plcid
!=
NULL
,
"out of memory
\n
"
);
...
@@ -557,6 +637,10 @@ void ue_context_release_command(const f1ap_ue_context_release_cmd_t *cmd)
...
@@ -557,6 +637,10 @@ void ue_context_release_command(const f1ap_ue_context_release_cmd_t *cmd)
return
;
return
;
}
}
instance_t
f1inst
=
get_f1_gtp_instance
();
if
(
f1inst
>=
0
)
newGtpuDeleteAllTunnels
(
f1inst
,
cmd
->
gNB_DU_ue_id
);
if
(
UE
->
UE_sched_ctrl
.
ul_failure
||
cmd
->
rrc_container_length
==
0
)
{
if
(
UE
->
UE_sched_ctrl
.
ul_failure
||
cmd
->
rrc_container_length
==
0
)
{
/* The UE is already not connected anymore or we have nothing to forward*/
/* The UE is already not connected anymore or we have nothing to forward*/
nr_mac_release_ue
(
mac
,
cmd
->
gNB_DU_ue_id
);
nr_mac_release_ue
(
mac
,
cmd
->
gNB_DU_ue_id
);
...
@@ -632,6 +716,9 @@ void dl_rrc_message_transfer(const f1ap_dl_rrc_message_t *dl_rrc)
...
@@ -632,6 +716,9 @@ void dl_rrc_message_transfer(const f1ap_dl_rrc_message_t *dl_rrc)
pthread_mutex_unlock
(
&
mac
->
sched_lock
);
pthread_mutex_unlock
(
&
mac
->
sched_lock
);
nr_rlc_remove_ue
(
dl_rrc
->
gNB_DU_ue_id
);
nr_rlc_remove_ue
(
dl_rrc
->
gNB_DU_ue_id
);
nr_rlc_update_rnti
(
*
dl_rrc
->
old_gNB_DU_ue_id
,
dl_rrc
->
gNB_DU_ue_id
);
nr_rlc_update_rnti
(
*
dl_rrc
->
old_gNB_DU_ue_id
,
dl_rrc
->
gNB_DU_ue_id
);
instance_t
f1inst
=
get_f1_gtp_instance
();
if
(
f1inst
>=
0
)
// we actually use F1-U
gtpv1u_update_ue_id
(
f1inst
,
*
dl_rrc
->
old_gNB_DU_ue_id
,
dl_rrc
->
gNB_DU_ue_id
);
}
}
/* the DU ue id is the RNTI */
/* the DU ue id is the RNTI */
...
...
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