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
f325d02d
Commit
f325d02d
authored
Jun 05, 2024
by
Bartosz Podrygajlo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix several ASN.1 message related memory leaks in NR
parent
514537e6
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
114 additions
and
7 deletions
+114
-7
openair2/RRC/NR/MESSAGES/CMakeLists.txt
openair2/RRC/NR/MESSAGES/CMakeLists.txt
+3
-0
openair2/RRC/NR/MESSAGES/asn1_msg.c
openair2/RRC/NR/MESSAGES/asn1_msg.c
+17
-7
openair2/RRC/NR/MESSAGES/tests/CMakeLists.txt
openair2/RRC/NR/MESSAGES/tests/CMakeLists.txt
+5
-0
openair2/RRC/NR/MESSAGES/tests/test_asn1_msg.cpp
openair2/RRC/NR/MESSAGES/tests/test_asn1_msg.cpp
+89
-0
No files found.
openair2/RRC/NR/MESSAGES/CMakeLists.txt
View file @
f325d02d
...
...
@@ -36,3 +36,6 @@ target_link_libraries(asn1_nr_rrc PUBLIC asn1_nr_rrc_hdrs)
target_compile_options
(
asn1_nr_rrc
PRIVATE -DASN_DISABLE_OER_SUPPORT -w
PUBLIC -DNR_RRC_VERSION=
${
NR_RRC_RELEASE
}
)
if
(
ENABLE_TESTS
)
add_subdirectory
(
tests
)
endif
()
openair2/RRC/NR/MESSAGES/asn1_msg.c
View file @
f325d02d
...
...
@@ -241,6 +241,7 @@ int do_SIB23_NR(rrc_gNB_carrier_data_t *carrier)
100
);
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
ASN_STRUCT_FREE
(
asn_DEF_NR_BCCH_DL_SCH_Message
,
sib_message
);
return
((
enc_rval
.
encoded
+
7
)
/
8
);
}
...
...
@@ -249,7 +250,6 @@ int do_RRCReject(uint8_t *const buffer)
asn_enc_rval_t
enc_rval
;
NR_DL_CCCH_Message_t
dl_ccch_msg
;
NR_RRCReject_t
*
rrcReject
;
NR_RejectWaitTime_t
waitTime
=
1
;
memset
((
void
*
)
&
dl_ccch_msg
,
0
,
sizeof
(
NR_DL_CCCH_Message_t
));
dl_ccch_msg
.
message
.
present
=
NR_DL_CCCH_MessageType_PR_c1
;
...
...
@@ -261,9 +261,9 @@ int do_RRCReject(uint8_t *const buffer)
rrcReject
->
criticalExtensions
.
choice
.
rrcReject
=
CALLOC
(
1
,
sizeof
(
struct
NR_RRCReject_IEs
));
rrcReject
->
criticalExtensions
.
choice
.
rrcReject
->
waitTime
=
CALLOC
(
1
,
sizeof
(
NR_RejectWaitTime_t
));
*
rrcReject
->
criticalExtensions
.
choice
.
rrcReject
->
waitTime
=
1
;
rrcReject
->
criticalExtensions
.
present
=
NR_RRCReject__criticalExtensions_PR_rrcReject
;
rrcReject
->
criticalExtensions
.
choice
.
rrcReject
->
waitTime
=
&
waitTime
;
if
(
LOG_DEBUGFLAG
(
DEBUG_ASN1
)
)
{
xer_fprint
(
stdout
,
&
asn_DEF_NR_DL_CCCH_Message
,
(
void
*
)
&
dl_ccch_msg
);
...
...
@@ -277,6 +277,7 @@ int do_RRCReject(uint8_t *const buffer)
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_DL_CCCH_Message
,
&
dl_ccch_msg
);
LOG_D
(
NR_RRC
,
"RRCReject Encoded %zd bits (%zd bytes)
\n
"
,
enc_rval
.
encoded
,(
enc_rval
.
encoded
+
7
)
/
8
);
...
...
@@ -608,6 +609,7 @@ int do_NR_SA_UECapabilityEnquiry(const protocol_ctxt_t *const ctxt_pP,
if
(
LOG_DEBUGFLAG
(
DEBUG_ASN1
)
)
{
xer_fprint
(
stdout
,
&
asn_DEF_NR_UE_CapabilityRequestFilterNR
,
(
void
*
)
sa_band_filter
);
}
ASN_STRUCT_FREE
(
asn_DEF_NR_UE_CapabilityRequestFilterNR
,
sa_band_filter
);
ue_capabilityrat_request
->
capabilityRequestFilter
=
req_freq
;
...
...
@@ -843,6 +845,7 @@ int do_NR_RRCReconfigurationComplete_for_nsa(
buffer_size
);
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_RRCReconfigurationComplete
,
&
rrc_complete_msg
);
LOG_A
(
NR_RRC
,
"rrcReconfigurationComplete Encoded %zd bits (%zd bytes)
\n
"
,
enc_rval
.
encoded
,
(
enc_rval
.
encoded
+
7
)
/
8
);
return
((
enc_rval
.
encoded
+
7
)
/
8
);
}
...
...
@@ -962,6 +965,8 @@ int do_NR_ULInformationTransfer(uint8_t **buffer, uint32_t pdu_length, uint8_t *
encoded
=
uper_encode_to_new_buffer
(
&
asn_DEF_NR_UL_DCCH_Message
,
NULL
,
(
void
*
)
&
ul_dcch_msg
,
(
void
**
)
buffer
);
AssertFatal
(
encoded
>
0
,
"ASN1 message encoding failed (%s, %ld)!
\n
"
,
"ULInformationTransfer"
,
encoded
);
ulInformationTransfer
->
dedicatedNAS_Message
->
buf
=
NULL
;
// Let caller decide when to free it
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_UL_DCCH_Message
,
&
ul_dcch_msg
);
LOG_D
(
NR_RRC
,
"ULInformationTransfer Encoded %zd bytes
\n
"
,
encoded
);
return
encoded
;
...
...
@@ -1004,6 +1009,9 @@ int do_RRCReestablishmentRequest(uint8_t *buffer,
buffer
,
100
);
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
// shortMAC_I.buf is on the stack, cannot free useing ASN_STRUCT_FREE macro
rrcReestablishmentRequest
->
rrcReestablishmentRequest
.
ue_Identity
.
shortMAC_I
.
buf
=
NULL
;
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_UL_CCCH_Message
,
&
ul_ccch_msg
);
LOG_D
(
NR_RRC
,
"[UE] RRCReestablishmentRequest Encoded %zd bits (%zd bytes)
\n
"
,
enc_rval
.
encoded
,
(
enc_rval
.
encoded
+
7
)
/
8
);
return
((
enc_rval
.
encoded
+
7
)
/
8
);
}
...
...
@@ -1055,6 +1063,7 @@ int do_RRCReestablishment(rrc_gNB_ue_context_t *const ue_context_pP,
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_DL_DCCH_Message
,
&
dl_dcch_msg
);
LOG_D
(
NR_RRC
,
"RRCReestablishment Encoded %u bits (%u bytes)
\n
"
,
(
uint32_t
)
enc_rval
.
encoded
,
(
uint32_t
)(
enc_rval
.
encoded
+
7
)
/
8
);
return
((
enc_rval
.
encoded
+
7
)
/
8
);
...
...
@@ -1090,6 +1099,7 @@ int do_RRCReestablishmentComplete(uint8_t *buffer, size_t buffer_size, int64_t r
buffer_size
);
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %lu)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
LOG_D
(
NR_RRC
,
"[UE] RRCReestablishmentComplete Encoded %zd bits (%zd bytes)
\n
"
,
enc_rval
.
encoded
,
(
enc_rval
.
encoded
+
7
)
/
8
);
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_UL_DCCH_Message
,
&
ul_dcch_msg
);
return
((
enc_rval
.
encoded
+
7
)
/
8
);
}
...
...
@@ -1336,7 +1346,7 @@ void free_MeasConfig(NR_MeasConfig_t *mc)
int
do_NR_Paging
(
uint8_t
Mod_id
,
uint8_t
*
buffer
,
uint32_t
tmsi
)
{
LOG_D
(
NR_RRC
,
"[gNB %d] do_NR_Paging start
\n
"
,
Mod_id
);
NR_PCCH_Message_t
pcch_msg
;
NR_PCCH_Message_t
pcch_msg
=
{
0
}
;
pcch_msg
.
message
.
present
=
NR_PCCH_MessageType_PR_c1
;
asn1cCalloc
(
pcch_msg
.
message
.
choice
.
c1
,
c1
);
c1
->
present
=
NR_PCCH_MessageType__c1_PR_paging
;
...
...
@@ -1359,6 +1369,10 @@ int do_NR_Paging(uint8_t Mod_id, uint8_t *buffer, uint32_t tmsi)
Mod_id
,
c1
->
choice
.
paging
->
pagingRecordList
->
list
.
count
);
asn_enc_rval_t
enc_rval
=
uper_encode_to_buffer
(
&
asn_DEF_NR_PCCH_Message
,
NULL
,
(
void
*
)
&
pcch_msg
,
buffer
,
RRC_BUF_SIZE
);
if
(
LOG_DEBUGFLAG
(
DEBUG_ASN1
)
)
{
xer_fprint
(
stdout
,
&
asn_DEF_NR_PCCH_Message
,
(
void
*
)
&
pcch_msg
);
}
ASN_STRUCT_FREE_CONTENTS_ONLY
(
asn_DEF_NR_PCCH_Message
,
&
pcch_msg
);
if
(
enc_rval
.
encoded
==
-
1
)
{
LOG_I
(
NR_RRC
,
"[gNB AssertFatal]ASN1 message encoding failed (%s, %lu)!
\n
"
,
...
...
@@ -1366,9 +1380,5 @@ int do_NR_Paging(uint8_t Mod_id, uint8_t *buffer, uint32_t tmsi)
return
-
1
;
}
if
(
LOG_DEBUGFLAG
(
DEBUG_ASN1
)
)
{
xer_fprint
(
stdout
,
&
asn_DEF_NR_PCCH_Message
,
(
void
*
)
&
pcch_msg
);
}
return
((
enc_rval
.
encoded
+
7
)
/
8
);
}
openair2/RRC/NR/MESSAGES/tests/CMakeLists.txt
0 → 100644
View file @
f325d02d
add_executable
(
test_asn1_msg test_asn1_msg.cpp
)
target_link_libraries
(
test_asn1_msg PRIVATE nr_rrc SECURITY minimal_lib GTest::gtest UTIL
)
add_dependencies
(
tests test_asn1_msg
)
add_test
(
NAME test_asn1_msg
COMMAND ./test_asn1_msg
)
openair2/RRC/NR/MESSAGES/tests/test_asn1_msg.cpp
0 → 100644
View file @
f325d02d
/*
* Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The OpenAirInterface Software Alliance licenses this file to You under
* the OAI Public License, Version 1.1 (the "License"); you may not use this file
* except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.openairinterface.org/?page_id=698
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*-------------------------------------------------------------------------------
* For more information about the OpenAirInterface (OAI) Software Alliance:
* contact@openairinterface.org
*/
#include <gtest/gtest.h>
extern
"C"
{
#include "openair2/RRC/NR/MESSAGES/asn1_msg.h"
#include "common/ran_context.h"
#include <stdbool.h>
#include "common/utils/assertions.h"
#include "common/utils/LOG/log.h"
RAN_CONTEXT_t
RC
;
}
TEST
(
nr_asn1
,
rrc_reject
)
{
unsigned
char
buf
[
1000
];
EXPECT_GT
(
do_RRCReject
(
buf
),
0
);
}
TEST
(
nr_asn1
,
sa_capability_enquiry
)
{
protocol_ctxt_t
ctxt
=
{
0
};
unsigned
char
buf
[
1000
];
EXPECT_GT
(
do_NR_SA_UECapabilityEnquiry
(
&
ctxt
,
buf
,
0
),
0
);
}
TEST
(
nr_asn1
,
rrc_reconfiguration_complete_for_nsa
)
{
unsigned
char
buf
[
1000
];
EXPECT_GT
(
do_NR_RRCReconfigurationComplete_for_nsa
(
buf
,
1000
,
0
),
0
);
}
TEST
(
nr_asn1
,
ul_information_transfer
)
{
unsigned
char
*
buf
=
NULL
;
unsigned
char
pdu
[
20
]
=
{
0
};
EXPECT_GT
(
do_NR_ULInformationTransfer
(
&
buf
,
20
,
pdu
),
0
);
EXPECT_NE
(
buf
,
nullptr
);
free
(
buf
);
}
TEST
(
nr_asn1
,
rrc_reestablishment_request
)
{
unsigned
char
buf
[
1000
];
const
uint16_t
c_rnti
=
1
;
const
uint32_t
cell_id
=
177
;
EXPECT_GT
(
do_RRCReestablishmentRequest
(
buf
,
NR_ReestablishmentCause_reconfigurationFailure
,
cell_id
,
c_rnti
),
0
);
}
TEST
(
nr_asn1
,
rrc_reestablishment
)
{
rrc_gNB_ue_context_t
ue_context_pP
;
memset
(
&
ue_context_pP
,
0
,
sizeof
(
ue_context_pP
));
unsigned
char
buf
[
1000
];
const
uint32_t
physical_cell_id
=
177
;
NR_ARFCN_ValueNR_t
absoluteFrequencySSB
=
2700000
;
EXPECT_GT
(
do_RRCReestablishment
(
&
ue_context_pP
,
buf
,
1000
,
0
,
physical_cell_id
,
absoluteFrequencySSB
),
0
);
}
TEST
(
nr_asn1
,
paging
)
{
unsigned
char
buf
[
1000
];
EXPECT_GT
(
do_NR_Paging
(
0
,
buf
,
0
),
0
);
}
int
main
(
int
argc
,
char
**
argv
)
{
logInit
();
testing
::
InitGoogleTest
(
&
argc
,
argv
);
return
RUN_ALL_TESTS
();
}
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