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
9aeacd34
Commit
9aeacd34
authored
Jul 18, 2024
by
Jaroslava Fiedlerova
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/fix-nsa-reattach' into integration_2024_w29
parents
e8a08376
32c23892
Changes
19
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
89 additions
and
148 deletions
+89
-148
doc/FEATURE_SET.md
doc/FEATURE_SET.md
+16
-5
openair1/SIMULATION/NR_PHY/dlsim.c
openair1/SIMULATION/NR_PHY/dlsim.c
+2
-3
openair1/SIMULATION/NR_PHY/ulsim.c
openair1/SIMULATION/NR_PHY/ulsim.c
+2
-3
openair2/GNB_APP/gnb_config.c
openair2/GNB_APP/gnb_config.c
+10
-0
openair2/LAYER2/NR_MAC_gNB/config.c
openair2/LAYER2/NR_MAC_gNB/config.c
+6
-14
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler.c
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler.c
+0
-6
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_RA.c
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_RA.c
+5
-4
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
+1
-1
openair2/LAYER2/NR_MAC_gNB/nr_mac_gNB.h
openair2/LAYER2/NR_MAC_gNB/nr_mac_gNB.h
+1
-1
openair2/LAYER2/nr_pdcp/nr_pdcp_ue_manager.c
openair2/LAYER2/nr_pdcp/nr_pdcp_ue_manager.c
+1
-1
openair2/RRC/NR/nr_rrc_config.c
openair2/RRC/NR/nr_rrc_config.c
+12
-38
openair2/RRC/NR/nr_rrc_config.h
openair2/RRC/NR/nr_rrc_config.h
+1
-1
openair2/RRC/NR/nr_rrc_defs.h
openair2/RRC/NR/nr_rrc_defs.h
+0
-3
openair2/RRC/NR/nr_rrc_proto.h
openair2/RRC/NR/nr_rrc_proto.h
+3
-11
openair2/RRC/NR/rrc_gNB.c
openair2/RRC/NR/rrc_gNB.c
+0
-3
openair2/RRC/NR/rrc_gNB_internode.c
openair2/RRC/NR/rrc_gNB_internode.c
+4
-9
openair2/RRC/NR/rrc_gNB_nsa.c
openair2/RRC/NR/rrc_gNB_nsa.c
+18
-35
openair2/RRC/NR/rrc_gNB_reconfig.c
openair2/RRC/NR/rrc_gNB_reconfig.c
+5
-8
openair2/X2AP/x2ap_eNB_encoder.c
openair2/X2AP/x2ap_eNB_encoder.c
+2
-2
No files found.
doc/FEATURE_SET.md
View file @
9aeacd34
...
...
@@ -36,13 +36,24 @@ The following features are valid for the gNB and the 5G-NR UE.
*
Encoder and decoder for short blocks
*
Support for UL transform precoding (SC-FDMA)
Furthermore, the gNB and UE support
*
"noS1" mode (DL and UL):
These modes of operation are supported:
*
"phy-test" mode (gNB, nrUE):
-
gNB and nrUE have hardcoded RNTI and radio configuration
-
gNB schedules the nrUE all the time, even if no UE connected
-
can be used for performance evaluation
*
"noS1" mode (DL and UL, gNB, nrUE):
-
Connection setup stops after RA; RRC configuration is exchanged through
files
-
Creates TUN interface to PDCP to inject and receive user-place traffic
-
No connection to the core network
*
Standalone (SA) mode:
-
UE can register with the 5G Core Network through the gNB, establish a PDU Session and exchange user-plane traffic
*
Standalone (SA) mode (gNB, nrUE):
-
UE can register with the 5G Core Network through the gNB, establish a PDU
Session and exchange user-plane traffic
-
Reestablishment supported
*
Non-standalone (NSA) mode (gNB):
-
UE can use the gNB for user plane traffic while connected to the 4G eNB
-
is unstable (only one UE connection)
## gNB PHY
...
...
openair1/SIMULATION/NR_PHY/dlsim.c
View file @
9aeacd34
...
...
@@ -711,6 +711,8 @@ int main(int argc, char **argv)
NR_ServingCellConfig_t
*
scd
=
calloc
(
1
,
sizeof
(
*
scd
));
prepare_scd
(
scd
);
/* removes unnecessary BWPs, if any */
fix_scd
(
scd
);
gNB
->
ap_N1
=
pdsch_AntennaPorts
.
N1
;
gNB
->
ap_N2
=
pdsch_AntennaPorts
.
N2
;
...
...
@@ -723,9 +725,6 @@ int main(int argc, char **argv)
NR_CellGroupConfig_t
*
secondaryCellGroup
=
get_default_secondaryCellGroup
(
scc
,
scd
,
UE_Capability_nr
,
0
,
1
,
&
conf
,
0
);
/* RRC parameter validation for secondaryCellGroup */
fix_scd
(
scd
);
/* -U option modify DMRS */
if
(
modify_dmrs
)
{
update_dmrs_config
(
secondaryCellGroup
,
dmrs_arg
);
...
...
openair1/SIMULATION/NR_PHY/ulsim.c
View file @
9aeacd34
...
...
@@ -630,6 +630,8 @@ int main(int argc, char *argv[])
NR_ServingCellConfig_t
*
scd
=
calloc
(
1
,
sizeof
(
NR_ServingCellConfig_t
));
prepare_scd
(
scd
);
/* removes unnecessary BWPs, if any */
fix_scd
(
scd
);
NR_UE_NR_Capability_t
*
UE_Capability_nr
=
CALLOC
(
1
,
sizeof
(
NR_UE_NR_Capability_t
));
prepare_sim_uecap
(
UE_Capability_nr
,
scc
,
mu
,
...
...
@@ -637,9 +639,6 @@ int main(int argc, char *argv[])
NR_CellGroupConfig_t
*
secondaryCellGroup
=
get_default_secondaryCellGroup
(
scc
,
scd
,
UE_Capability_nr
,
0
,
1
,
&
conf
,
0
);
/* RRC parameter validation for secondaryCellGroup */
fix_scd
(
scd
);
NR_BCCH_BCH_Message_t
*
mib
=
get_new_MIB_NR
(
scc
);
// UE dedicated configuration
...
...
openair2/GNB_APP/gnb_config.c
View file @
9aeacd34
...
...
@@ -621,6 +621,16 @@ void fix_scd(NR_ServingCellConfig_t *scd) {
}
}
if
(
scd
->
downlinkBWP_ToAddModList
->
list
.
count
==
0
)
{
free
(
scd
->
downlinkBWP_ToAddModList
);
scd
->
downlinkBWP_ToAddModList
=
NULL
;
}
if
(
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
->
list
.
count
==
0
)
{
free
(
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
);
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
=
NULL
;
}
}
static
void
verify_gnb_param_notset
(
paramdef_t
*
params
,
int
paramidx
,
const
char
*
paramname
)
...
...
openair2/LAYER2/NR_MAC_gNB/config.c
View file @
9aeacd34
...
...
@@ -603,7 +603,6 @@ void nr_mac_config_scc(gNB_MAC_INST *nrmac, NR_ServingCellConfigCommon_t *scc, c
DevAssert
(
nrmac
!=
NULL
);
DevAssert
(
scc
!=
NULL
);
DevAssert
(
config
!=
NULL
);
//NR_SCHED_LOCK(&nrmac->sched_lock);
AssertFatal
(
scc
->
ssb_PositionsInBurst
->
present
>
0
&&
scc
->
ssb_PositionsInBurst
->
present
<
4
,
"SSB Bitmap type %d is not valid
\n
"
,
...
...
@@ -668,19 +667,13 @@ void nr_mac_config_scc(gNB_MAC_INST *nrmac, NR_ServingCellConfigCommon_t *scc, c
nrmac
->
pre_processor_ul
=
nr_init_fr1_ulsch_preprocessor
(
0
);
}
if
(
get_softmodem_params
()
->
sa
>
0
)
{
NR_COMMON_channels_t
*
cc
=
&
nrmac
->
common_channels
[
0
];
NR_SCHED_LOCK
(
&
nrmac
->
sched_lock
);
for
(
int
n
=
0
;
n
<
NR_NB_RA_PROC_MAX
;
n
++
)
{
NR_RA_t
*
ra
=
&
cc
->
ra
[
n
];
ra
->
cfra
=
false
;
ra
->
rnti
=
0
;
ra
->
preambles
.
num_preambles
=
MAX_NUM_NR_PRACH_PREAMBLES
;
ra
->
preambles
.
preamble_list
=
malloc
(
MAX_NUM_NR_PRACH_PREAMBLES
*
sizeof
(
*
ra
->
preambles
.
preamble_list
));
for
(
int
i
=
0
;
i
<
MAX_NUM_NR_PRACH_PREAMBLES
;
i
++
)
ra
->
preambles
.
preamble_list
[
i
]
=
i
;
}
nr_clear_ra_proc
(
ra
);
}
//
NR_SCHED_UNLOCK(&nrmac->sched_lock);
NR_SCHED_UNLOCK
(
&
nrmac
->
sched_lock
);
}
void
nr_mac_configure_sib1
(
gNB_MAC_INST
*
nrmac
,
const
f1ap_plmn_t
*
plmn
,
uint64_t
cellID
,
int
tac
)
...
...
@@ -749,7 +742,6 @@ bool nr_mac_prepare_ra_ue(gNB_MAC_INST *nrmac, uint32_t rnti, NR_CellGroupConfig
struct
NR_CFRA
*
cfra
=
CellGroup
->
spCellConfig
->
reconfigurationWithSync
->
rach_ConfigDedicated
->
choice
.
uplink
->
cfra
;
uint8_t
num_preamble
=
cfra
->
resources
.
choice
.
ssb
->
ssb_ResourceList
.
list
.
count
;
ra
->
preambles
.
num_preambles
=
num_preamble
;
ra
->
preambles
.
preamble_list
=
calloc
(
ra
->
preambles
.
num_preambles
,
sizeof
(
*
ra
->
preambles
.
preamble_list
));
for
(
int
i
=
0
;
i
<
cc
->
num_active_ssb
;
i
++
)
{
for
(
int
j
=
0
;
j
<
num_preamble
;
j
++
)
{
if
(
cc
->
ssb_index
[
i
]
==
cfra
->
resources
.
choice
.
ssb
->
ssb_ResourceList
.
list
.
array
[
j
]
->
ssb
)
{
...
...
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler.c
View file @
9aeacd34
...
...
@@ -196,12 +196,6 @@ void gNB_dlsch_ulsch_scheduler(module_id_t module_idP, frame_t frame, sub_frame_
gNB_MAC_INST
*
gNB
=
RC
.
nrmac
[
module_idP
];
NR_COMMON_channels_t
*
cc
=
gNB
->
common_channels
;
NR_ServingCellConfigCommon_t
*
scc
=
cc
->
ServingCellConfigCommon
;
// Assert to detect segfault during gNB teardown. scc->ssbSubcarrierSpacing pointer is most likely overwritten
AssertFatal
(
*
scc
->
ssbSubcarrierSpacing
>=
0
&&
*
scc
->
ssbSubcarrierSpacing
<
sizeofArray
(
nr_slots_per_frame
),
"ssbSubcarrierSpacing %ld is out of range, ssbSubcarrierSpacing pointer (%p) might be overwritten, known segfault condition"
,
*
scc
->
ssbSubcarrierSpacing
,
scc
->
ssbSubcarrierSpacing
);
NR_SCHED_LOCK
(
&
gNB
->
sched_lock
);
...
...
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_RA.c
View file @
9aeacd34
...
...
@@ -2017,11 +2017,12 @@ void nr_clear_ra_proc(NR_RA_t *ra)
{
/* we assume that this function is mutex-protected from outside */
NR_SCHED_ENSURE_LOCKED
(
&
RC
.
nrmac
[
0
]
->
sched_lock
);
memset
(
ra
,
0
,
sizeof
(
*
ra
));
ra
->
ra_state
=
nrRA_gNB_IDLE
;
ra
->
timing_offset
=
0
;
ra
->
msg3_round
=
0
;
if
(
ra
->
cfra
==
false
)
{
ra
->
rnti
=
0
;
if
(
get_softmodem_params
()
->
sa
)
{
// in SA, prefill with allowed preambles
ra
->
preambles
.
num_preambles
=
MAX_NUM_NR_PRACH_PREAMBLES
;
for
(
int
i
=
0
;
i
<
MAX_NUM_NR_PRACH_PREAMBLES
;
i
++
)
ra
->
preambles
.
preamble_list
[
i
]
=
i
;
}
}
...
...
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
View file @
9aeacd34
...
...
@@ -857,8 +857,8 @@ static void _nr_rx_sdu(const module_id_t gnb_mod_idP,
nr_mac_reset_ul_failure
(
UE_scheduling_control
);
reset_dl_harq_list
(
UE_scheduling_control
);
reset_ul_harq_list
(
UE_scheduling_control
);
nr_clear_ra_proc
(
ra
);
process_addmod_bearers_cellGroupConfig
(
&
UE
->
UE_sched_ctrl
,
ra
->
CellGroup
->
rlc_BearerToAddModList
);
nr_clear_ra_proc
(
ra
);
}
else
{
LOG_A
(
NR_MAC
,
"[RAPROC] RA-Msg3 received (sdu_lenP %d)
\n
"
,
sdu_lenP
);
LOG_D
(
NR_MAC
,
"[RAPROC] Received Msg3:
\n
"
);
...
...
openair2/LAYER2/NR_MAC_gNB/nr_mac_gNB.h
View file @
9aeacd34
...
...
@@ -159,7 +159,7 @@ typedef struct nr_mac_config_t {
typedef
struct
NR_preamble_ue
{
uint8_t
num_preambles
;
uint8_t
*
preamble_list
;
uint8_t
preamble_list
[
MAX_NUM_NR_PRACH_PREAMBLES
]
;
}
NR_preamble_ue_t
;
typedef
struct
NR_sched_pdcch
{
...
...
openair2/LAYER2/nr_pdcp/nr_pdcp_ue_manager.c
View file @
9aeacd34
...
...
@@ -124,7 +124,7 @@ void nr_pdcp_manager_remove_ue(nr_pdcp_ue_manager_t *_m, ue_id_t UEid)
break
;
if
(
i
==
m
->
ue_count
)
{
LOG_
D
(
PDCP
,
"%s:%d:%s: warning: UE ID/RNTI 0x%"
PRIx64
" not found
\n
"
,
__FILE__
,
__LINE__
,
__FUNCTION__
,
UEid
);
LOG_
W
(
PDCP
,
"%s:%d:%s: warning: UE ID/RNTI 0x%"
PRIx64
" not found
\n
"
,
__FILE__
,
__LINE__
,
__FUNCTION__
,
UEid
);
return
;
}
...
...
openair2/RRC/NR/nr_rrc_config.c
View file @
9aeacd34
...
...
@@ -3025,40 +3025,22 @@ NR_CellGroupConfig_t *decode_cellGroupConfig(const uint8_t *buffer, int buffer_s
return
cellGroupConfig
;
}
/* TODO: this should disappear */
static
void
fix_servingcellconfigdedicated
(
NR_ServingCellConfig_t
*
scd
)
static
NR_ServingCellConfigCommon_t
*
clone_ServingCellConfigCommon
(
const
NR_ServingCellConfigCommon_t
*
scc
)
{
int
b
=
0
;
while
(
b
<
scd
->
downlinkBWP_ToAddModList
->
list
.
count
)
{
if
(
scd
->
downlinkBWP_ToAddModList
->
list
.
array
[
b
]
->
bwp_Common
->
genericParameters
.
locationAndBandwidth
==
0
)
{
asn_sequence_del
(
&
scd
->
downlinkBWP_ToAddModList
->
list
,
b
,
1
);
}
else
{
b
++
;
}
}
if
(
scd
->
downlinkBWP_ToAddModList
->
list
.
count
==
0
)
{
free
(
scd
->
downlinkBWP_ToAddModList
);
scd
->
downlinkBWP_ToAddModList
=
NULL
;
}
b
=
0
;
while
(
b
<
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
->
list
.
count
)
{
if
(
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
->
list
.
array
[
b
]
->
bwp_Common
->
genericParameters
.
locationAndBandwidth
==
0
)
{
asn_sequence_del
(
&
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
->
list
,
b
,
1
);
}
else
{
b
++
;
}
}
if
(
scc
==
NULL
)
return
NULL
;
if
(
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
->
list
.
count
==
0
)
{
free
(
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
);
scd
->
uplinkConfig
->
uplinkBWP_ToAddModList
=
NULL
;
}
uint8_t
buf
[
16384
];
asn_enc_rval_t
enc_rval
=
uper_encode_to_buffer
(
&
asn_DEF_NR_ServingCellConfigCommon
,
NULL
,
scc
,
buf
,
sizeof
(
buf
));
AssertFatal
(
enc_rval
.
encoded
>
0
&&
enc_rval
.
encoded
<
sizeof
(
buf
),
"could not clone NR_ServingCellConfigCommon: problem while encoding
\n
"
);
NR_ServingCellConfigCommon_t
*
clone
=
NULL
;
asn_dec_rval_t
dec_rval
=
uper_decode
(
NULL
,
&
asn_DEF_NR_ServingCellConfigCommon
,
(
void
**
)
&
clone
,
buf
,
enc_rval
.
encoded
,
0
,
0
);
AssertFatal
(
dec_rval
.
code
==
RC_OK
&&
dec_rval
.
consumed
==
enc_rval
.
encoded
,
"could not clone NR_ServingCellConfigCommon: problem while decoding
\n
"
);
return
clone
;
}
NR_CellGroupConfig_t
*
get_default_secondaryCellGroup
(
const
NR_ServingCellConfigCommon_t
*
servingcellconfigcommon
,
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
const
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
const
NR_UE_NR_Capability_t
*
uecap
,
int
scg_id
,
int
servCellIndex
,
...
...
@@ -3076,8 +3058,6 @@ NR_CellGroupConfig_t *get_default_secondaryCellGroup(const NR_ServingCellConfigC
LOG_E
(
RRC
,
"No UE Capabilities available when programming default CellGroup in NSA
\n
"
);
uint64_t
bitmap
=
get_ssb_bitmap
(
servingcellconfigcommon
);
// See comment at the end of this function regarding ServingCellConfig
fix_servingcellconfigdedicated
(
servingcellconfigdedicated
);
NR_CellGroupConfig_t
*
secondaryCellGroup
=
calloc
(
1
,
sizeof
(
*
secondaryCellGroup
));
secondaryCellGroup
->
cellGroupId
=
scg_id
;
...
...
@@ -3097,8 +3077,7 @@ NR_CellGroupConfig_t *get_default_secondaryCellGroup(const NR_ServingCellConfigC
calloc
(
1
,
sizeof
(
*
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
));
NR_ReconfigurationWithSync_t
*
reconfigurationWithSync
=
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
;
reconfigurationWithSync
->
spCellConfigCommon
=
(
NR_ServingCellConfigCommon_t
*
)
servingcellconfigcommon
;
reconfigurationWithSync
->
spCellConfigCommon
=
clone_ServingCellConfigCommon
(
servingcellconfigcommon
);
reconfigurationWithSync
->
newUE_Identity
=
(
get_softmodem_params
()
->
phy_test
==
1
)
?
0x1234
:
(
taus
()
&
0xffff
);
reconfigurationWithSync
->
t304
=
NR_ReconfigurationWithSync__t304_ms2000
;
...
...
@@ -3382,11 +3361,6 @@ NR_CellGroupConfig_t *get_default_secondaryCellGroup(const NR_ServingCellConfigC
secondaryCellGroup
->
spCellConfig
->
spCellConfigDedicated
->
pathlossReferenceLinking
=
NULL
;
secondaryCellGroup
->
spCellConfig
->
spCellConfigDedicated
->
servingCellMO
=
NULL
;
// this is pure evil: We should only pass in a ServingCellConfig, without
// modifying it! TODO: make a separate function that creates a
// ServingCellConfig, and reuse it here
*
servingcellconfigdedicated
=
*
secondaryCellGroup
->
spCellConfig
->
spCellConfigDedicated
;
if
(
LOG_DEBUGFLAG
(
DEBUG_ASN1
))
{
xer_fprint
(
stdout
,
&
asn_DEF_NR_SpCellConfig
,
(
void
*
)
secondaryCellGroup
->
spCellConfig
);
}
...
...
openair2/RRC/NR/nr_rrc_config.h
View file @
9aeacd34
...
...
@@ -91,7 +91,7 @@ NR_CellGroupConfig_t *decode_cellGroupConfig(const uint8_t *buffer, int max_buff
* configuration, but it will also overwrite the ServingCellConfig passed in
* parameter servingcellconfigdedicated! */
NR_CellGroupConfig_t
*
get_default_secondaryCellGroup
(
const
NR_ServingCellConfigCommon_t
*
servingcellconfigcommon
,
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
const
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
const
NR_UE_NR_Capability_t
*
uecap
,
int
scg_id
,
int
servCellIndex
,
...
...
openair2/RRC/NR/nr_rrc_defs.h
View file @
9aeacd34
...
...
@@ -269,9 +269,7 @@ typedef struct gNB_RRC_UE_s {
NR_UE_MRDC_Capability_t
*
UE_Capability_MRDC
;
int
UE_MRDC_Capability_size
;
NR_CellGroupConfig_t
*
secondaryCellGroup
;
NR_CellGroupConfig_t
*
masterCellGroup
;
NR_RRCReconfiguration_t
*
reconfig
;
NR_RadioBearerConfig_t
*
rb_config
;
ImsiMobileIdentity_t
imsi
;
...
...
@@ -318,7 +316,6 @@ typedef struct gNB_RRC_UE_s {
uint32_t
ue_rrc_inactivity_timer
;
uint32_t
ue_reestablishment_counter
;
uint32_t
ue_reconfiguration_counter
;
struct
NR_SpCellConfig
*
spCellConfig
;
/* NGUEContextSetup might come with PDU sessions, but setup needs to be
* delayed after security (and capability); PDU sessions are stored here */
...
...
openair2/RRC/NR/nr_rrc_proto.h
View file @
9aeacd34
...
...
@@ -66,17 +66,9 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
void
rrc_remove_nsa_user
(
gNB_RRC_INST
*
rrc
,
int
rnti
);
void
rrc_remove_ue
(
gNB_RRC_INST
*
rrc
,
rrc_gNB_ue_context_t
*
ue_context_p
);
void
fill_default_reconfig
(
NR_ServingCellConfigCommon_t
*
servingcellconfigcommon
,
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
NR_RRCReconfiguration_IEs_t
*
reconfig
,
NR_CellGroupConfig_t
*
secondaryCellGroup
,
NR_UE_NR_Capability_t
*
uecap
,
int
uid
);
int
generate_CG_Config
(
gNB_RRC_INST
*
rrc
,
NR_CG_Config_t
*
cg_Config
,
NR_RRCReconfiguration_t
*
reconfig
,
NR_RadioBearerConfig_t
*
rbconfig
);
NR_RRCReconfiguration_IEs_t
*
get_default_reconfig
(
const
NR_CellGroupConfig_t
*
secondaryCellGroup
);
NR_CG_Config_t
*
generate_CG_Config
(
const
NR_RRCReconfiguration_t
*
reconfig
,
const
NR_RadioBearerConfig_t
*
rbconfig
);
int
parse_CG_ConfigInfo
(
gNB_RRC_INST
*
rrc
,
NR_CG_ConfigInfo_t
*
CG_ConfigInfo
,
x2ap_ENDC_sgnb_addition_req_t
*
m
);
...
...
openair2/RRC/NR/rrc_gNB.c
View file @
9aeacd34
...
...
@@ -228,9 +228,6 @@ static void init_NR_SI(gNB_RRC_INST *rrc)
if
(
get_softmodem_params
()
->
phy_test
>
0
||
get_softmodem_params
()
->
do_ra
>
0
)
{
AssertFatal
(
NODE_IS_MONOLITHIC
(
rrc
->
node_type
),
"phy_test and do_ra only work in monolithic
\n
"
);
rrc_gNB_ue_context_t
*
ue_context_p
=
rrc_gNB_allocate_new_ue_context
(
rrc
);
gNB_RRC_UE_t
*
UE
=
&
ue_context_p
->
ue_context
;
UE
->
spCellConfig
=
calloc
(
1
,
sizeof
(
struct
NR_SpCellConfig
));
UE
->
spCellConfig
->
spCellConfigDedicated
=
RC
.
nrmac
[
0
]
->
common_channels
[
0
].
pre_ServingCellConfig
;
LOG_I
(
NR_RRC
,
"Adding new user (%p)
\n
"
,
ue_context_p
);
if
(
!
NODE_IS_CU
(
RC
.
nrrrc
[
0
]
->
node_type
))
{
rrc_add_nsa_user
(
rrc
,
ue_context_p
,
NULL
);
...
...
openair2/RRC/NR/rrc_gNB_internode.c
View file @
9aeacd34
...
...
@@ -79,17 +79,14 @@ int parse_CG_ConfigInfo(gNB_RRC_INST *rrc, NR_CG_ConfigInfo_t *CG_ConfigInfo, x2
return
(
0
);
}
int
generate_CG_Config
(
gNB_RRC_INST
*
rrc
,
NR_CG_Config_t
*
cg_Config
,
NR_RRCReconfiguration_t
*
reconfig
,
NR_RadioBearerConfig_t
*
rbconfig
)
{
NR_CG_Config_t
*
generate_CG_Config
(
const
NR_RRCReconfiguration_t
*
reconfig
,
const
NR_RadioBearerConfig_t
*
rbconfig
)
{
NR_CG_Config_t
*
cg_Config
=
calloc
(
1
,
sizeof
(
*
cg_Config
));
cg_Config
->
criticalExtensions
.
present
=
NR_CG_Config__criticalExtensions_PR_c1
;
cg_Config
->
criticalExtensions
.
choice
.
c1
=
calloc
(
1
,
sizeof
(
*
cg_Config
->
criticalExtensions
.
choice
.
c1
));
cg_Config
->
criticalExtensions
.
choice
.
c1
->
present
=
NR_CG_Config__criticalExtensions__c1_PR_cg_Config
;
cg_Config
->
criticalExtensions
.
choice
.
c1
->
choice
.
cg_Config
=
calloc
(
1
,
sizeof
(
NR_CG_Config_IEs_t
));
char
buffer
[
1024
];
int
total_size
;
asn_enc_rval_t
enc_rval
=
uper_encode_to_buffer
(
&
asn_DEF_NR_RRCReconfiguration
,
NULL
,
(
void
*
)
reconfig
,
buffer
,
1024
);
AssertFatal
(
enc_rval
.
encoded
>
0
,
"ASN1 message encoding failed (%s, %jd)!
\n
"
,
enc_rval
.
failed_type
->
name
,
enc_rval
.
encoded
);
...
...
@@ -97,7 +94,6 @@ int generate_CG_Config(gNB_RRC_INST *rrc,
OCTET_STRING_fromBuf
(
cg_Config
->
criticalExtensions
.
choice
.
c1
->
choice
.
cg_Config
->
scg_CellGroupConfig
,
(
const
char
*
)
buffer
,
(
enc_rval
.
encoded
+
7
)
>>
3
);
total_size
=
(
enc_rval
.
encoded
+
7
)
>>
3
;
FILE
*
fd
;
// file to be generated for nr-ue
if
(
get_softmodem_params
()
->
phy_test
==
1
||
get_softmodem_params
()
->
do_ra
>
0
||
get_softmodem_params
()
->
sa
==
1
)
{
...
...
@@ -140,8 +136,7 @@ int generate_CG_Config(gNB_RRC_INST *rrc,
}
}
total_size
=
total_size
+
((
enc_rval
.
encoded
+
7
)
>>
3
);
return
(
total_size
);
return
cg_Config
;
}
#endif
openair2/RRC/NR/rrc_gNB_nsa.c
View file @
9aeacd34
...
...
@@ -106,8 +106,6 @@ void rrc_parse_ue_capabilities(gNB_RRC_INST *rrc, NR_UE_CapabilityRAT_ContainerL
LOG_A
(
NR_RRC
,
"Successfully decoded UE NR capabilities (NR and MRDC)
\n
"
);
AssertFatal
(
NODE_IS_MONOLITHIC
(
rrc
->
node_type
),
"phy_test and do_ra only work in monolithic
\n
"
);
UE
->
spCellConfig
=
calloc
(
1
,
sizeof
(
struct
NR_SpCellConfig
));
UE
->
spCellConfig
->
spCellConfigDedicated
=
RC
.
nrmac
[
0
]
->
common_channels
[
0
].
pre_ServingCellConfig
;
LOG_I
(
NR_RRC
,
"Adding new NSA user (%p)
\n
"
,
ue_context_p
);
rrc_add_nsa_user
(
rrc
,
ue_context_p
,
m
);
}
...
...
@@ -155,12 +153,6 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
}
// NR RRCReconfiguration
UE
->
reconfig
=
calloc
(
1
,
sizeof
(
NR_RRCReconfiguration_t
));
memset
((
void
*
)
UE
->
reconfig
,
0
,
sizeof
(
NR_RRCReconfiguration_t
));
UE
->
reconfig
->
rrc_TransactionIdentifier
=
0
;
UE
->
reconfig
->
criticalExtensions
.
present
=
NR_RRCReconfiguration__criticalExtensions_PR_rrcReconfiguration
;
NR_RRCReconfiguration_IEs_t
*
reconfig_ies
=
calloc
(
1
,
sizeof
(
NR_RRCReconfiguration_IEs_t
));
UE
->
reconfig
->
criticalExtensions
.
choice
.
rrcReconfiguration
=
reconfig_ies
;
if
(
get_softmodem_params
()
->
phy_test
==
1
||
get_softmodem_params
()
->
do_ra
==
1
||
get_softmodem_params
()
->
sa
==
1
){
UE
->
rb_config
=
get_default_rbconfig
(
10
/* EPS bearer ID */
,
1
/* drb ID */
,
NR_CipheringAlgorithm_nea0
,
NR_SecurityConfig__keyToUse_master
);
}
else
{
...
...
@@ -244,27 +236,22 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
UE
->
rb_config
=
get_default_rbconfig
(
m
->
e_rabs_tobeadded
[
0
].
e_rab_id
,
m
->
e_rabs_tobeadded
[
0
].
drb_ID
,
cipher_algo
,
NR_SecurityConfig__keyToUse_secondary
);
}
NR_ServingCellConfig_t
*
scc
=
UE
->
spCellConfig
?
UE
->
spCellConfig
->
spCellConfigDedicated
:
NULL
;
NR_ServingCellConfig_t
*
scc
=
RC
.
nrmac
[
0
]
->
common_channels
[
0
].
pre_ServingCellConfig
;
// The MAC has the ServingCellConfigCommon; the below code is incorrect: the
// CU should send a UE Context Setup Request to request the creating of the
// MAC Context
NR_ServingCellConfigCommon_t
*
sccc
=
RC
.
nrmac
[
0
]
->
common_channels
[
0
].
ServingCellConfigCommon
;
UE
->
secondaryCellGroup
=
get_default_secondaryCellGroup
(
sccc
,
scc
,
UE
->
UE_Capability_nr
,
1
,
1
,
configuration
,
ue_context_p
->
ue_context
.
rrc_ue_id
);
AssertFatal
(
UE
->
secondaryCellGroup
!=
NULL
,
"out of memory
\n
"
);
xer_fprint
(
stdout
,
&
asn_DEF_NR_CellGroupConfig
,
UE
->
secondaryCellGroup
);
fill_default_reconfig
(
sccc
,
scc
,
reconfig_ies
,
UE
->
secondaryCellGroup
,
UE
->
UE_Capability_nr
,
ue_context_p
->
ue_context
.
rrc_ue_id
);
UE
->
rnti
=
UE
->
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
newUE_Identity
;
NR_CG_Config_t
*
CG_Config
=
calloc
(
1
,
sizeof
(
*
CG_Config
));
memset
((
void
*
)
CG_Config
,
0
,
sizeof
(
*
CG_Config
));
// int CG_Config_size = generate_CG_Config(rrc,CG_Config,UE->reconfig,UE->rb_config);
generate_CG_Config
(
rrc
,
CG_Config
,
UE
->
reconfig
,
UE
->
rb_config
);
NR_CellGroupConfig_t
*
secondaryCellGroup
=
get_default_secondaryCellGroup
(
sccc
,
scc
,
UE
->
UE_Capability_nr
,
1
,
1
,
configuration
,
ue_context_p
->
ue_context
.
rrc_ue_id
);
AssertFatal
(
secondaryCellGroup
!=
NULL
,
"out of memory
\n
"
);
NR_RRCReconfiguration_t
*
reconfig
=
calloc
(
1
,
sizeof
(
NR_RRCReconfiguration_t
));
reconfig
->
rrc_TransactionIdentifier
=
0
;
reconfig
->
criticalExtensions
.
present
=
NR_RRCReconfiguration__criticalExtensions_PR_rrcReconfiguration
;
reconfig
->
criticalExtensions
.
choice
.
rrcReconfiguration
=
get_default_reconfig
(
secondaryCellGroup
);
UE
->
rnti
=
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
newUE_Identity
;
NR_CG_Config_t
*
CG_Config
=
generate_CG_Config
(
reconfig
,
UE
->
rb_config
);
if
(
m
!=
NULL
)
{
uint8_t
inde_list
[
m
->
nb_e_rabs_tobeadded
];
...
...
@@ -335,7 +322,7 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
LOG_W
(
RRC
,
"No E-RAB to be added received from SgNB Addition Request message
\n
"
);
X2AP_ENDC_SGNB_ADDITION_REQ_ACK
(
msg
).
MeNB_ue_x2_id
=
m
->
ue_x2_id
;
X2AP_ENDC_SGNB_ADDITION_REQ_ACK
(
msg
).
SgNB_ue_x2_id
=
UE
->
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
newUE_Identity
;
X2AP_ENDC_SGNB_ADDITION_REQ_ACK
(
msg
).
SgNB_ue_x2_id
=
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
newUE_Identity
;
//X2AP_ENDC_SGNB_ADDITION_REQ_ACK(msg).rrc_buffer_size = CG_Config_size; //Need to verify correct value for the buffer_size
// Send to X2 entity to transport to MeNB
asn_enc_rval_t
enc_rval
=
uper_encode_to_buffer
(
&
asn_DEF_NR_CG_Config
,
...
...
@@ -351,8 +338,7 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
// layers use different IDs (MAC/RLC use RNTI as DU UE ID, above use NGAP ID
// as CU UE ID.
uint32_t
du_ue_id
=
ue_context_p
->
ue_context
.
rnti
;
static
uint32_t
rrc_ue_id
=
0
;
rrc_ue_id
++
;
uint32_t
rrc_ue_id
=
ue_context_p
->
ue_context
.
rrc_ue_id
;
f1_ue_data_t
du_ue_data
=
{.
secondary_ue
=
rrc_ue_id
};
du_add_f1_ue_data
(
du_ue_id
,
&
du_ue_data
);
f1_ue_data_t
cu_ue_data
=
{.
secondary_ue
=
du_ue_id
};
...
...
@@ -363,15 +349,14 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
bool
ret
=
false
;
if
(
get_softmodem_params
()
->
phy_test
)
{
// phytest mode: we don't set up RA, etc
ret
=
nr_mac_add_test_ue
(
RC
.
nrmac
[
rrc
->
module_id
],
du_ue_id
,
ue_context_p
->
ue_context
.
secondaryCellGroup
);
ret
=
nr_mac_add_test_ue
(
RC
.
nrmac
[
rrc
->
module_id
],
du_ue_id
,
secondaryCellGroup
);
}
else
{
NR_CellGroupConfig_t
*
secondaryCellGroup
=
ue_context_p
->
ue_context
.
secondaryCellGroup
;
DevAssert
(
secondaryCellGroup
->
spCellConfig
&&
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
&&
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
rach_ConfigDedicated
&&
secondaryCellGroup
->
spCellConfig
->
reconfigurationWithSync
->
rach_ConfigDedicated
->
choice
.
uplink
->
cfra
);
NR_SCHED_LOCK
(
&
RC
.
nrmac
[
rrc
->
module_id
]
->
sched_lock
);
ret
=
nr_mac_prepare_ra_ue
(
RC
.
nrmac
[
rrc
->
module_id
],
du_ue_id
,
ue_context_p
->
ue_context
.
secondaryCellGroup
);
ret
=
nr_mac_prepare_ra_ue
(
RC
.
nrmac
[
rrc
->
module_id
],
du_ue_id
,
secondaryCellGroup
);
NR_SCHED_UNLOCK
(
&
RC
.
nrmac
[
rrc
->
module_id
]
->
sched_lock
);
}
AssertFatal
(
ret
,
"cannot add NSA UE in MAC, aborting
\n
"
);
...
...
@@ -396,8 +381,7 @@ void rrc_add_nsa_user(gNB_RRC_INST *rrc, rrc_gNB_ue_context_t *ue_context_p, x2a
const
NR_DRB_ToAddModList_t
*
drb_list
=
ue_context_p
->
ue_context
.
rb_config
->
drb_ToAddModList
;
DevAssert
(
drb_list
->
list
.
count
==
1
);
const
NR_DRB_ToAddMod_t
*
drb
=
drb_list
->
list
.
array
[
0
];
const
struct
NR_CellGroupConfig__rlc_BearerToAddModList
*
bearer_list
=
ue_context_p
->
ue_context
.
secondaryCellGroup
->
rlc_BearerToAddModList
;
const
struct
NR_CellGroupConfig__rlc_BearerToAddModList
*
bearer_list
=
secondaryCellGroup
->
rlc_BearerToAddModList
;
const
NR_RLC_BearerConfig_t
*
bearer
=
bearer_list
->
list
.
array
[
0
];
DevAssert
(
bearer_list
->
list
.
count
==
1
);
DevAssert
(
drb
->
drb_Identity
==
bearer
->
servedRadioBearer
->
choice
.
drb_Identity
);
...
...
@@ -420,8 +404,7 @@ void rrc_remove_nsa_user(gNB_RRC_INST *rrc, int rnti) {
return
;
}
nr_pdcp_remove_UE
(
ctxt
.
rntiMaybeUEid
);
nr_pdcp_remove_UE
(
ue_context
->
ue_context
.
rrc_ue_id
);
rrc_rlc_remove_ue
(
&
ctxt
);
// lock the scheduler before removing the UE. Note: mac_remove_nr_ue() checks
...
...
openair2/RRC/NR/rrc_gNB_reconfig.c
View file @
9aeacd34
...
...
@@ -49,14 +49,10 @@
#include "nr_rrc_config.h"
#include "MESSAGES/asn1_msg.h"
void
fill_default_reconfig
(
NR_ServingCellConfigCommon_t
*
servingcellconfigcommon
,
NR_ServingCellConfig_t
*
servingcellconfigdedicated
,
NR_RRCReconfiguration_IEs_t
*
reconfig
,
NR_CellGroupConfig_t
*
secondaryCellGroup
,
NR_UE_NR_Capability_t
*
uecap
,
int
uid
)
{
AssertFatal
(
servingcellconfigcommon
!=
NULL
,
"servingcellconfigcommon is null
\n
"
);
AssertFatal
(
reconfig
!=
NULL
,
"reconfig is null
\n
"
);
NR_RRCReconfiguration_IEs_t
*
get_default_reconfig
(
const
NR_CellGroupConfig_t
*
secondaryCellGroup
)
{
NR_RRCReconfiguration_IEs_t
*
reconfig
=
calloc
(
1
,
sizeof
(
NR_RRCReconfiguration_IEs_t
));
AssertFatal
(
reconfig
!=
NULL
,
"out of memory
\n
"
);
AssertFatal
(
secondaryCellGroup
!=
NULL
,
"secondaryCellGroup is null
\n
"
);
// radioBearerConfig
reconfig
->
radioBearerConfig
=
NULL
;
...
...
@@ -74,6 +70,7 @@ void fill_default_reconfig(NR_ServingCellConfigCommon_t *servingcellconfigcommon
reconfig
->
lateNonCriticalExtension
=
NULL
;
// nonCriticalExtension
reconfig
->
nonCriticalExtension
=
NULL
;
return
reconfig
;
}
/* Function to set or overwrite PTRS DL RRC parameters */
...
...
openair2/X2AP/x2ap_eNB_encoder.c
View file @
9aeacd34
...
...
@@ -44,9 +44,9 @@ int x2ap_eNB_encode_pdu(X2AP_X2AP_PDU_t *pdu, uint8_t **buffer, uint32_t *len)
DevAssert
(
buffer
!=
NULL
);
DevAssert
(
len
!=
NULL
);
//
if (asn1_xer_print) {
if
(
asn1_xer_print
)
{
xer_fprint
(
stdout
,
&
asn_DEF_X2AP_X2AP_PDU
,
(
void
*
)
pdu
);
//
}
}
encoded
=
aper_encode_to_new_buffer
(
&
asn_DEF_X2AP_X2AP_PDU
,
0
,
pdu
,
(
void
**
)
buffer
);
...
...
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