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
1a8ed864
Commit
1a8ed864
authored
Aug 29, 2024
by
Guido Casati
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use F1AP lib for UL RRC Message Trasfer in stack
parent
cc0ad07a
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
101 deletions
+57
-101
openair2/F1AP/f1ap_cu_rrc_message_transfer.c
openair2/F1AP/f1ap_cu_rrc_message_transfer.c
+42
-51
openair2/F1AP/f1ap_du_rrc_message_transfer.c
openair2/F1AP/f1ap_du_rrc_message_transfer.c
+15
-50
No files found.
openair2/F1AP/f1ap_cu_rrc_message_transfer.c
View file @
1a8ed864
...
...
@@ -96,76 +96,67 @@ int CU_send_DL_RRC_MESSAGE_TRANSFER(sctp_assoc_t assoc_id, f1ap_dl_rrc_message_t
*/
int
CU_handle_UL_RRC_MESSAGE_TRANSFER
(
instance_t
instance
,
sctp_assoc_t
assoc_id
,
uint32_t
stream
,
F1AP_F1AP_PDU_t
*
pdu
)
{
LOG_D
(
F1AP
,
"CU_handle_UL_RRC_MESSAGE_TRANSFER
\n
"
);
F1AP_ULRRCMessageTransfer_t
*
container
;
F1AP_ULRRCMessageTransferIEs_t
*
ie
;
uint64_t
cu_ue_f1ap_id
;
uint64_t
du_ue_f1ap_id
;
uint64_t
srb_id
;
DevAssert
(
pdu
!=
NULL
);
if
(
stream
!=
0
)
{
LOG_E
(
F1AP
,
"[SCTP %d] Received F1 on stream != 0 (%d)
\n
"
,
assoc_id
,
stream
);
return
-
1
;
}
container
=
&
pdu
->
choice
.
initiatingMessage
->
value
.
choice
.
ULRRCMessageTransfer
;
/* GNB_CU_UE_F1AP_ID */
F1AP_FIND_PROTOCOLIE_BY_ID
(
F1AP_ULRRCMessageTransferIEs_t
,
ie
,
container
,
F1AP_ProtocolIE_ID_id_gNB_CU_UE_F1AP_ID
,
true
);
cu_ue_f1ap_id
=
ie
->
value
.
choice
.
GNB_CU_UE_F1AP_ID
;
/* GNB_DU_UE_F1AP_ID */
F1AP_FIND_PROTOCOLIE_BY_ID
(
F1AP_ULRRCMessageTransferIEs_t
,
ie
,
container
,
F1AP_ProtocolIE_ID_id_gNB_DU_UE_F1AP_ID
,
true
);
du_ue_f1ap_id
=
ie
->
value
.
choice
.
GNB_DU_UE_F1AP_ID
;
if
(
!
cu_exists_f1_ue_data
(
cu_ue_f1ap_id
))
{
LOG_E
(
F1AP
,
"unknown CU UE ID %ld
\n
"
,
cu_ue_f1ap_id
);
return
1
;
f1ap_ul_rrc_message_t
msg
=
{
0
}
;
LOG_D
(
F1AP
,
"CU_handle_UL_RRC_MESSAGE_TRANSFER
\n
"
);
if
(
!
decode_ul_rrc_message_transfer
(
pdu
,
&
msg
))
{
LOG_E
(
F1AP
,
"cannot decode F1 UL RRC message Transfer
\n
"
)
;
free_ul_rrc_message_transfer
(
&
msg
);
return
-
1
;
}
if
(
!
cu_exists_f1_ue_data
(
msg
.
gNB_CU_ue_id
))
{
LOG_E
(
F1AP
,
"unknown CU UE ID %d
\n
"
,
msg
.
gNB_CU_ue_id
);
free_ul_rrc_message_transfer
(
&
msg
);
return
-
1
;
}
/* the RLC-PDCP does not transport the DU UE ID (yet), so we drop it here.
* For the moment, let's hope this won't become relevant; to sleep in peace,
* let's put an assert to check that it is the expected DU UE ID. */
f1_ue_data_t
ue_data
=
cu_get_f1_ue_data
(
cu_ue_f1ap_id
);
if
(
ue_data
.
secondary_ue
!=
du_ue_f1ap_id
)
{
LOG_E
(
F1AP
,
"unexpected DU UE ID %u received, expected it to be %lu
\n
"
,
ue_data
.
secondary_ue
,
du_ue_f1ap_id
);
return
1
;
f1_ue_data_t
ue_data
=
cu_get_f1_ue_data
(
msg
.
gNB_CU_ue_id
);
if
(
ue_data
.
secondary_ue
!=
msg
.
gNB_DU_ue_id
)
{
LOG_E
(
F1AP
,
"unexpected DU UE ID %u received, expected it to be %u
\n
"
,
ue_data
.
secondary_ue
,
msg
.
gNB_DU_ue_id
);
free_ul_rrc_message_transfer
(
&
msg
);
return
-
1
;
}
/* mandatory */
/* SRBID */
F1AP_FIND_PROTOCOLIE_BY_ID
(
F1AP_ULRRCMessageTransferIEs_t
,
ie
,
container
,
F1AP_ProtocolIE_ID_id_SRBID
,
true
);
srb_id
=
ie
->
value
.
choice
.
SRBID
;
if
(
srb_id
<
1
)
LOG_E
(
F1AP
,
"Unexpected UL RRC MESSAGE for srb_id %lu
\n
"
,
srb_id
);
if
(
msg
.
srb_id
<
1
)
LOG_E
(
F1AP
,
"Unexpected UL RRC MESSAGE for SRB %d
\n
"
,
msg
.
srb_id
);
else
LOG_D
(
F1AP
,
"UL RRC MESSAGE for srb_id %lu in DCCH
\n
"
,
srb_id
);
// issue in here
/* mandatory */
/* RRC Container */
F1AP_FIND_PROTOCOLIE_BY_ID
(
F1AP_ULRRCMessageTransferIEs_t
,
ie
,
container
,
F1AP_ProtocolIE_ID_id_RRCContainer
,
true
);
protocol_ctxt_t
ctxt
=
{
0
};
ctxt
.
instance
=
instance
;
ctxt
.
module_id
=
instance
;
ctxt
.
rntiMaybeUEid
=
cu_ue_f1ap_id
;
ctxt
.
enb_flag
=
1
;
ctxt
.
eNB_index
=
0
;
uint8_t
*
mb
=
malloc16
(
ie
->
value
.
choice
.
RRCContainer
.
size
);
memcpy
(
mb
,
ie
->
value
.
choice
.
RRCContainer
.
buf
,
ie
->
value
.
choice
.
RRCContainer
.
size
);
LOG_D
(
F1AP
,
"Calling pdcp_data_ind for UE RNTI %lx srb_id %lu with size %ld (DCCH)
\n
"
,
ctxt
.
rntiMaybeUEid
,
srb_id
,
ie
->
value
.
choice
.
RRCContainer
.
size
);
LOG_D
(
F1AP
,
"UL RRC MESSAGE for SRB %d in DCCH
\n
"
,
msg
.
srb_id
);
protocol_ctxt_t
ctxt
=
{
.
instance
=
instance
,
.
module_id
=
instance
,
.
enb_flag
=
1
,
.
eNB_index
=
0
,
.
rntiMaybeUEid
=
msg
.
gNB_CU_ue_id
,
};
LOG_D
(
F1AP
,
"[UE %lx] calling pdcp_data_ind for SRB %d with size %d (DCCH)
\n
"
,
ctxt
.
rntiMaybeUEid
,
msg
.
srb_id
,
msg
.
rrc_container_length
);
uint8_t
*
mb
=
malloc16
(
msg
.
rrc_container_length
);
memcpy
(
mb
,
msg
.
rrc_container
,
msg
.
rrc_container_length
);
nr_pdcp_data_ind
(
&
ctxt
,
1
,
// srb_flag
0
,
// embms_flag
srb_id
,
ie
->
value
.
choice
.
RRCContainer
.
size
,
msg
.
srb_id
,
msg
.
rrc_container_length
,
mb
,
NULL
,
NULL
);
/* Free UL RRC Message Transfer */
free_ul_rrc_message_transfer
(
&
msg
);
return
0
;
}
openair2/F1AP/f1ap_du_rrc_message_transfer.c
View file @
1a8ed864
...
...
@@ -100,64 +100,29 @@ int DU_send_INITIAL_UL_RRC_MESSAGE_TRANSFER(sctp_assoc_t assoc_id, const f1ap_in
int
DU_send_UL_NR_RRC_MESSAGE_TRANSFER
(
sctp_assoc_t
assoc_id
,
const
f1ap_ul_rrc_message_t
*
msg
)
{
F1AP_F1AP_PDU_t
pdu
=
{
0
};
F1AP_ULRRCMessageTransfer_t
*
out
;
uint8_t
*
buffer
=
NULL
;
uint32_t
len
;
LOG_D
(
F1AP
,
"size %d UE RNTI %x in SRB %d
\n
"
,
msg
->
rrc_container_length
,
msg
->
gNB_DU_ue_id
,
msg
->
srb_id
);
//for (int i = 0;i < msg->rrc_container_length; i++)
// printf("%02x ", msg->rrc_container[i]);
//printf("\n");
/* Create */
/* 0. Message Type */
pdu
.
present
=
F1AP_F1AP_PDU_PR_initiatingMessage
;
asn1cCalloc
(
pdu
.
choice
.
initiatingMessage
,
tmp
);
tmp
->
procedureCode
=
F1AP_ProcedureCode_id_ULRRCMessageTransfer
;
tmp
->
criticality
=
F1AP_Criticality_ignore
;
tmp
->
value
.
present
=
F1AP_InitiatingMessage__value_PR_ULRRCMessageTransfer
;
out
=
&
tmp
->
value
.
choice
.
ULRRCMessageTransfer
;
/* mandatory */
/* c1. GNB_CU_UE_F1AP_ID */
asn1cSequenceAdd
(
out
->
protocolIEs
.
list
,
F1AP_ULRRCMessageTransferIEs_t
,
ie1
);
ie1
->
id
=
F1AP_ProtocolIE_ID_id_gNB_CU_UE_F1AP_ID
;
ie1
->
criticality
=
F1AP_Criticality_reject
;
ie1
->
value
.
present
=
F1AP_ULRRCMessageTransferIEs__value_PR_GNB_CU_UE_F1AP_ID
;
ie1
->
value
.
choice
.
GNB_CU_UE_F1AP_ID
=
msg
->
gNB_CU_ue_id
;
/* mandatory */
/* c2. GNB_DU_UE_F1AP_ID */
asn1cSequenceAdd
(
out
->
protocolIEs
.
list
,
F1AP_ULRRCMessageTransferIEs_t
,
ie2
);
ie2
->
id
=
F1AP_ProtocolIE_ID_id_gNB_DU_UE_F1AP_ID
;
ie2
->
criticality
=
F1AP_Criticality_reject
;
ie2
->
value
.
present
=
F1AP_ULRRCMessageTransferIEs__value_PR_GNB_DU_UE_F1AP_ID
;
ie2
->
value
.
choice
.
GNB_DU_UE_F1AP_ID
=
msg
->
gNB_DU_ue_id
;
/* mandatory */
/* c3. SRBID */
asn1cSequenceAdd
(
out
->
protocolIEs
.
list
,
F1AP_ULRRCMessageTransferIEs_t
,
ie3
);
ie3
->
id
=
F1AP_ProtocolIE_ID_id_SRBID
;
ie3
->
criticality
=
F1AP_Criticality_reject
;
ie3
->
value
.
present
=
F1AP_ULRRCMessageTransferIEs__value_PR_SRBID
;
ie3
->
value
.
choice
.
SRBID
=
msg
->
srb_id
;
// issue in here
/* mandatory */
/* c4. RRCContainer */
asn1cSequenceAdd
(
out
->
protocolIEs
.
list
,
F1AP_ULRRCMessageTransferIEs_t
,
ie4
);
ie4
->
id
=
F1AP_ProtocolIE_ID_id_RRCContainer
;
ie4
->
criticality
=
F1AP_Criticality_reject
;
ie4
->
value
.
present
=
F1AP_ULRRCMessageTransferIEs__value_PR_RRCContainer
;
OCTET_STRING_fromBuf
(
&
ie4
->
value
.
choice
.
RRCContainer
,
(
const
char
*
)
msg
->
rrc_container
,
msg
->
rrc_container_length
);
/* encode */
if
(
f1ap_encode_pdu
(
&
pdu
,
&
buffer
,
&
len
)
<
0
)
{
/* encode UL RRC Message Transfer */
F1AP_F1AP_PDU_t
*
pdu
=
encode_ul_rrc_message_transfer
(
msg
);
if
(
pdu
==
NULL
)
{
LOG_E
(
F1AP
,
"Failed to encode F1 UL RRC MESSAGE TRANSFER: cannot send message
\n
"
);
ASN_STRUCT_FREE
(
asn_DEF_F1AP_F1AP_PDU
,
pdu
);
return
-
1
;
}
/* encode F1AP PDU */
uint8_t
*
buffer
=
NULL
;
uint32_t
len
;
if
(
f1ap_encode_pdu
(
pdu
,
&
buffer
,
&
len
)
<
0
)
{
LOG_E
(
F1AP
,
"Failed to encode F1 UL RRC MESSAGE TRANSFER
\n
"
);
ASN_STRUCT_FREE
(
asn_DEF_F1AP_F1AP_PDU
,
pdu
);
return
-
1
;
}
/* Free F1AP PDU */
ASN_STRUCT_FREE
(
asn_DEF_F1AP_F1AP_PDU
,
pdu
);
/* Send to ITTI */
f1ap_itti_send_sctp_data_req
(
assoc_id
,
buffer
,
len
);
return
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