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
93469ed5
Commit
93469ed5
authored
Aug 07, 2023
by
Robert Schmidt
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/NR_UE_MAC_remove_scc' into integration_2023_w31
parents
a181c78b
75c2f9e5
Changes
12
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
172 additions
and
297 deletions
+172
-297
executables/nr-ue.c
executables/nr-ue.c
+4
-22
executables/nr-uesoftmodem.c
executables/nr-uesoftmodem.c
+1
-2
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.c
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.c
+32
-27
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.h
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.h
+2
-2
openair2/LAYER2/NR_MAC_UE/config_ue.c
openair2/LAYER2/NR_MAC_UE/config_ue.c
+70
-94
openair2/LAYER2/NR_MAC_UE/mac_defs.h
openair2/LAYER2/NR_MAC_UE/mac_defs.h
+8
-2
openair2/LAYER2/NR_MAC_UE/mac_proto.h
openair2/LAYER2/NR_MAC_UE/mac_proto.h
+0
-2
openair2/LAYER2/NR_MAC_UE/nr_ra_procedures.c
openair2/LAYER2/NR_MAC_UE/nr_ra_procedures.c
+8
-16
openair2/LAYER2/NR_MAC_UE/nr_ue_power_procedures.c
openair2/LAYER2/NR_MAC_UE/nr_ue_power_procedures.c
+7
-8
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
+8
-23
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
+21
-83
openair2/NR_UE_PHY_INTERFACE/NR_IF_Module.c
openair2/NR_UE_PHY_INTERFACE/NR_IF_Module.c
+11
-16
No files found.
executables/nr-ue.c
View file @
93469ed5
...
...
@@ -306,10 +306,6 @@ static void *NRUE_phy_stub_standalone_pnf_task(void *arg)
process_queued_nr_nfapi_msgs
(
mac
,
sfn_slot
);
}
bool
only_dl
=
false
;
if
(
mac
->
scc
==
NULL
&&
mac
->
scc_SIB
==
NULL
)
only_dl
=
true
;
int
CC_id
=
0
;
uint8_t
gNB_id
=
0
;
nr_uplink_indication_t
ul_info
;
...
...
@@ -332,10 +328,7 @@ static void *NRUE_phy_stub_standalone_pnf_task(void *arg)
free_and_zero
(
ch_info
);
}
if
(
only_dl
||
is_nr_DL_slot
(
get_softmodem_params
()
->
nsa
?
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
:
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
,
if
(
is_nr_DL_slot
(
mac
->
tdd_UL_DL_ConfigurationCommon
,
ul_info
.
slot_rx
))
{
memset
(
&
mac
->
dl_info
,
0
,
sizeof
(
mac
->
dl_info
));
mac
->
dl_info
.
cc_id
=
CC_id
;
...
...
@@ -350,10 +343,7 @@ static void *NRUE_phy_stub_standalone_pnf_task(void *arg)
if
(
pthread_mutex_unlock
(
&
mac
->
mutex_dl_info
))
abort
();
if
(
!
only_dl
&&
is_nr_UL_slot
(
get_softmodem_params
()
->
nsa
?
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
:
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
,
if
(
is_nr_UL_slot
(
mac
->
tdd_UL_DL_ConfigurationCommon
,
ul_info
.
slot_tx
,
mac
->
frame_type
))
{
LOG_D
(
NR_MAC
,
"Slot %d. calling nr_ue_ul_ind()
\n
"
,
ul_info
.
slot_tx
);
nr_ue_ul_scheduler
(
&
ul_info
);
...
...
@@ -517,16 +507,8 @@ static void RU_write(nr_rxtx_thread_data_t *rxtxD) {
!
get_softmodem_params
()
->
continuous_tx
)
{
uint8_t
tdd_period
=
mac
->
phy_config
.
config_req
.
tdd_table
.
tdd_period_in_slots
;
int
nrofUplinkSlots
,
nrofUplinkSymbols
;
if
(
mac
->
scc
)
{
nrofUplinkSlots
=
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSlots
;
nrofUplinkSymbols
=
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSymbols
;
}
else
{
nrofUplinkSlots
=
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSlots
;
nrofUplinkSymbols
=
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSymbols
;
}
int
nrofUplinkSlots
=
mac
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSlots
;
int
nrofUplinkSymbols
=
mac
->
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofUplinkSymbols
;
int
slot_tx_usrp
=
proc
->
nr_slot_tx
;
uint8_t
num_UL_slots
=
nrofUplinkSlots
+
(
nrofUplinkSymbols
!=
0
);
uint8_t
first_tx_slot
=
tdd_period
-
num_UL_slots
;
...
...
executables/nr-uesoftmodem.c
View file @
93469ed5
...
...
@@ -528,8 +528,7 @@ int main( int argc, char **argv ) {
mac
->
phy_config_request_sent
=
true
;
fapi_nr_config_request_t
*
nrUE_config
=
&
UE
[
CC_id
]
->
nrUE_config
;
nr_init_frame_parms_ue
(
&
UE
[
CC_id
]
->
frame_parms
,
nrUE_config
,
*
mac
->
scc
->
downlinkConfigCommon
->
frequencyInfoDL
->
frequencyBandList
.
list
.
array
[
0
]);
nr_init_frame_parms_ue
(
&
UE
[
CC_id
]
->
frame_parms
,
nrUE_config
,
mac
->
nr_band
);
}
init_nr_ue_vars
(
UE
[
CC_id
],
0
,
abstraction_flag
);
...
...
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.c
View file @
93469ed5
...
...
@@ -3635,12 +3635,12 @@ int ul_ant_bits(NR_DMRS_UplinkConfig_t *NR_DMRS_UplinkConfig, long transformPrec
int
tdd_period_to_num
[
8
]
=
{
500
,
625
,
1000
,
1250
,
2000
,
2500
,
5000
,
10000
};
int
is_nr_DL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slot
)
{
int
period
,
period1
,
period2
=
0
;
if
(
tdd_UL_DL_ConfigurationCommon
==
NULL
)
return
(
1
);
bool
is_nr_DL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slot
)
{
if
(
tdd_UL_DL_ConfigurationCommon
==
NULL
)
return
true
;
int
period1
,
period2
=
0
;
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
&&
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
->
dl_UL_TransmissionPeriodicity_v1530
)
period1
=
3000
+*
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
...
...
@@ -3650,49 +3650,54 @@ int is_nr_DL_slot(NR_TDD_UL_DL_ConfigCommon_t *tdd_UL_DL_ConfigurationCommon,slo
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern2
)
{
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
&&
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
)
period2
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
period2
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
else
period2
=
tdd_period_to_num
[
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
dl_UL_TransmissionPeriodicity
];
}
period
=
period1
+
period2
;
int
scs
=
tdd_UL_DL_ConfigurationCommon
->
referenceSubcarrierSpacing
;
int
slots
=
period
*
(
1
<<
scs
)
/
1000
;
int
slots1
=
period1
*
(
1
<<
scs
)
/
1000
;
int
period
=
period1
+
period2
;
int
scs
=
tdd_UL_DL_ConfigurationCommon
->
referenceSubcarrierSpacing
;
int
slots
=
period
*
(
1
<<
scs
)
/
1000
;
int
slots1
=
period1
*
(
1
<<
scs
)
/
1000
;
int
slot_in_period
=
slot
%
slots
;
if
(
slot_in_period
<
slots1
)
return
(
slot_in_period
<=
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofDownlinkSlots
?
1
:
0
);
else
return
(
slot_in_period
<=
slots1
+
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
nrofDownlinkSlots
?
1
:
0
);
if
(
slot_in_period
<
slots1
)
return
slot_in_period
<=
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofDownlinkSlots
;
else
return
slot_in_period
<=
slots1
+
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
nrofDownlinkSlots
;
}
int
is_nr_UL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slot
,
frame_type_t
frame_type
)
{
int
period
,
period1
,
period2
=
0
;
bool
is_nr_UL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slot
,
frame_type_t
frame_type
)
{
// Note: condition on frame_type
// goal: the UL scheduler assumes mode is TDD therefore this hack is needed to make FDD work
if
(
tdd_UL_DL_ConfigurationCommon
==
NULL
||
frame_type
==
FDD
)
{
return
(
1
);
}
if
(
frame_type
==
FDD
)
return
true
;
if
(
tdd_UL_DL_ConfigurationCommon
==
NULL
)
// before receiving TDD information all slots should be considered to be DL
return
false
;
int
period1
,
period2
=
0
;
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
&&
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
->
dl_UL_TransmissionPeriodicity_v1530
)
period1
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
period1
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
else
period1
=
tdd_period_to_num
[
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
dl_UL_TransmissionPeriodicity
];
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern2
)
{
if
(
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
&&
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
)
period2
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
period2
=
3000
+
*
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
ext1
->
dl_UL_TransmissionPeriodicity_v1530
;
else
period2
=
tdd_period_to_num
[
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
dl_UL_TransmissionPeriodicity
];
}
period
=
period1
+
period2
;
int
scs
=
tdd_UL_DL_ConfigurationCommon
->
referenceSubcarrierSpacing
;
int
slots
=
period
*
(
1
<<
scs
)
/
1000
;
int
slots1
=
period1
*
(
1
<<
scs
)
/
1000
;
int
period
=
period1
+
period2
;
int
scs
=
tdd_UL_DL_ConfigurationCommon
->
referenceSubcarrierSpacing
;
int
slots
=
period
*
(
1
<<
scs
)
/
1000
;
int
slots1
=
period1
*
(
1
<<
scs
)
/
1000
;
int
slot_in_period
=
slot
%
slots
;
if
(
slot_in_period
<
slots1
)
return
(
slot_in_period
>=
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofDownlinkSlots
?
1
:
0
);
else
return
(
slot_in_period
>=
slots1
+
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
nrofDownlinkSlots
?
1
:
0
);
if
(
slot_in_period
<
slots1
)
return
slot_in_period
>=
tdd_UL_DL_ConfigurationCommon
->
pattern1
.
nrofDownlinkSlots
;
else
return
slot_in_period
>=
slots1
+
tdd_UL_DL_ConfigurationCommon
->
pattern2
->
nrofDownlinkSlots
;
}
int16_t
fill_dmrs_mask
(
const
NR_PDSCH_Config_t
*
pdsch_Config
,
...
...
openair2/LAYER2/NR_MAC_COMMON/nr_mac_common.h
View file @
93469ed5
...
...
@@ -67,9 +67,9 @@ int16_t fill_dmrs_mask(const NR_PDSCH_Config_t *pdsch_Config,
mappingType_t
mappingtype
,
int
length
);
int
is_nr_DL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slotP
);
bool
is_nr_DL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slotP
);
int
is_nr_UL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slotP
,
frame_type_t
frame_type
);
bool
is_nr_UL_slot
(
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
,
slot_t
slotP
,
frame_type_t
frame_type
);
uint8_t
compute_srs_resource_indicator
(
NR_PUSCH_ServingCellConfig_t
*
pusch_servingcellconfig
,
NR_PUSCH_Config_t
*
pusch_Config
,
...
...
openair2/LAYER2/NR_MAC_UE/config_ue.c
View file @
93469ed5
This diff is collapsed.
Click to expand it.
openair2/LAYER2/NR_MAC_UE/mac_defs.h
View file @
93469ed5
...
...
@@ -422,8 +422,6 @@ typedef struct ssb_list_info {
/*!\brief Top level UE MAC structure */
typedef
struct
{
NR_UE_L2_STATE_t
state
;
NR_ServingCellConfigCommon_t
*
scc
;
NR_ServingCellConfigCommonSIB_t
*
scc_SIB
;
NR_CellGroupConfig_t
*
cg
;
int
servCellIndex
;
NR_CSI_ReportConfig_t
*
csirc
;
...
...
@@ -445,6 +443,9 @@ typedef struct {
NR_UE_DL_BWP_t
current_DL_BWP
;
NR_UE_UL_BWP_t
current_UL_BWP
;
NR_BWP_DownlinkCommon_t
*
bwp_dlcommon
;
NR_BWP_UplinkCommon_t
*
bwp_ulcommon
;
NR_UL_TIME_ALIGNMENT_t
ul_time_alignment
;
NR_SearchSpace_t
*
otherSI_SS
;
...
...
@@ -455,6 +456,8 @@ typedef struct {
NR_SearchSpace_t
*
BWP_searchspaces
[
FAPI_NR_MAX_SS
];
NR_SearchSpace_t
*
search_space_zero
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
;
bool
phy_config_request_sent
;
frame_type_t
frame_type
;
...
...
@@ -508,6 +511,9 @@ typedef struct {
/// PHR
uint8_t
PHR_reporting_active
;
int
dmrs_TypeA_Position
;
NR_P_Max_t
*
p_Max
;
NR_Type0_PDCCH_CSS_config_t
type0_PDCCH_CSS_config
;
frequency_range_t
frequency_range
;
uint16_t
nr_band
;
...
...
openair2/LAYER2/NR_MAC_UE/mac_proto.h
View file @
93469ed5
...
...
@@ -238,8 +238,6 @@ void config_dci_pdu(NR_UE_MAC_INST_t *mac,
void
ue_dci_configuration
(
NR_UE_MAC_INST_t
*
mac
,
fapi_nr_dl_config_request_t
*
dl_config
,
const
frame_t
frame
,
const
int
slot
);
NR_BWP_DownlinkCommon_t
*
get_bwp_downlink_common
(
NR_UE_MAC_INST_t
*
mac
,
NR_BWP_Id_t
dl_bwp_id
);
uint8_t
nr_ue_get_sdu
(
module_id_t
module_idP
,
int
cc_id
,
frame_t
frameP
,
...
...
openair2/LAYER2/NR_MAC_UE/nr_ra_procedures.c
View file @
93469ed5
...
...
@@ -72,14 +72,14 @@ void init_RA(module_id_t mod_id,
ra
->
starting_preamble_nb
=
0
;
ra
->
RA_backoff_cnt
=
0
;
fapi_nr_config_request_t
*
cfg
=
&
mac
->
phy_config
.
config_req
;
prach_resources
->
RA_PREAMBLE_BACKOFF
=
0
;
NR_SubcarrierSpacing_t
prach_scs
=
*
nr_rach_ConfigCommon
->
msg1_SubcarrierSpacing
;
int
n_prbs
=
get_N_RA_RB
(
prach_scs
,
mac
->
current_UL_BWP
.
scs
);
int
start_prb
=
rach_ConfigGeneric
->
msg1_FrequencyStart
+
mac
->
current_UL_BWP
.
BWPStart
;
int
carrier_bandwidth
=
mac
->
scc_SIB
?
mac
->
scc_SIB
->
uplinkConfigCommon
->
frequencyInfoUL
.
scs_SpecificCarrierList
.
list
.
array
[
0
]
->
carrierBandwidth
:
mac
->
scc
->
uplinkConfigCommon
->
frequencyInfoUL
->
scs_SpecificCarrierList
.
list
.
array
[
0
]
->
carrierBandwidth
;
// PRACH shall be as specified for QPSK modulated DFT-s-OFDM of equivalent RB allocation (38.101-1)
prach_resources
->
RA_PCMAX
=
nr_get_Pcmax
(
mac
,
2
,
false
,
prach_scs
,
c
arrier_bandwidth
,
true
,
n_prbs
,
start_prb
);
prach_resources
->
RA_PCMAX
=
nr_get_Pcmax
(
mac
,
2
,
false
,
prach_scs
,
c
fg
->
carrier_config
.
dl_grid_size
[
prach_scs
]
,
true
,
n_prbs
,
start_prb
);
prach_resources
->
RA_PREAMBLE_TRANSMISSION_COUNTER
=
1
;
prach_resources
->
RA_PREAMBLE_POWER_RAMPING_COUNTER
=
1
;
prach_resources
->
POWER_OFFSET_2STEP_RA
=
0
;
...
...
@@ -810,25 +810,17 @@ uint8_t nr_ue_get_rach(module_id_t mod_id,
return
ra
->
ra_state
;
}
void
nr_get_RA_window
(
NR_UE_MAC_INST_t
*
mac
){
uint8_t
mu
,
ra_ResponseWindow
;
void
nr_get_RA_window
(
NR_UE_MAC_INST_t
*
mac
)
{
RA_config_t
*
ra
=
&
mac
->
ra
;
NR_RACH_ConfigCommon_t
*
setup
=
mac
->
current_UL_BWP
.
rach_ConfigCommon
;
AssertFatal
(
&
setup
->
rach_ConfigGeneric
!=
NULL
,
"In %s: FATAL! rach_ConfigGeneric is NULL...
\n
"
,
__FUNCTION__
);
NR_RACH_ConfigGeneric_t
*
rach_ConfigGeneric
=
&
setup
->
rach_ConfigGeneric
;
long
scs
=
(
mac
->
scc
)
?
mac
->
scc
->
downlinkConfigCommon
->
frequencyInfoDL
->
scs_SpecificCarrierList
.
list
.
array
[
0
]
->
subcarrierSpacing
:
mac
->
scc_SIB
->
downlinkConfigCommon
.
frequencyInfoDL
.
scs_SpecificCarrierList
.
list
.
array
[
0
]
->
subcarrierSpacing
;
ra_ResponseWindow
=
rach_ConfigGeneric
->
ra_ResponseWindow
;
if
(
setup
->
msg1_SubcarrierSpacing
)
mu
=
*
setup
->
msg1_SubcarrierSpacing
;
else
mu
=
scs
;
int
ra_ResponseWindow
=
rach_ConfigGeneric
->
ra_ResponseWindow
;
int
mu
=
mac
->
current_DL_BWP
.
scs
;
ra
->
RA_window_cnt
=
ra
->
RA_offset
*
nr_slots_per_frame
[
mu
];
// taking into account the 2 frames gap introduced by OAI gNB
ra
->
RA_window_cnt
=
ra
->
RA_offset
*
nr_slots_per_frame
[
mu
];
// taking into account the 2 frames gap introduced by OAI gNB
switch
(
ra_ResponseWindow
)
{
case
NR_RACH_ConfigGeneric__ra_ResponseWindow_sl1
:
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_power_procedures.c
View file @
93469ed5
...
...
@@ -57,12 +57,11 @@ int nr_get_Pcmax(NR_UE_MAC_INST_t *mac, int Qm, bool powerBoostPi2BPSK, int scs,
if
(
mac
->
frequency_range
==
FR1
)
{
//TODO configure P-MAX from the upper layers according to 38.331
long
*
p_emax
=
(
mac
->
scc
!=
NULL
)
?
mac
->
scc
->
uplinkConfigCommon
->
frequencyInfoUL
->
p_Max
:
mac
->
scc_SIB
->
uplinkConfigCommon
->
frequencyInfoUL
.
p_Max
;
int
p_powerclass
=
23
;
// dBm assuming poweclass 3 UE
int
p_emax
=
mac
->
p_Max
?
*
mac
->
p_Max
:
0
;
int
delta_P_powerclass
=
0
;
// for powerclass 2 needs to be changed
if
(
p_em
ax
&&
Qm
==
1
&&
powerBoostPi2BPSK
&&
(
nr_band
==
40
||
nr_band
==
41
||
nr_band
==
77
||
nr_band
==
78
||
nr_band
==
79
))
{
*
p_emax
+=
3
;
if
(
mac
->
p_M
ax
&&
Qm
==
1
&&
powerBoostPi2BPSK
&&
(
nr_band
==
40
||
nr_band
==
41
||
nr_band
==
77
||
nr_band
==
78
||
nr_band
==
79
))
{
p_emax
+=
3
;
delta_P_powerclass
-=
3
;
}
...
...
@@ -137,10 +136,10 @@ int nr_get_Pcmax(NR_UE_MAC_INST_t *mac, int Qm, bool powerBoostPi2BPSK, int scs,
if
(
P_MPR
>
total_reduction
)
total_reduction
=
P_MPR
;
int
pcmax_high
,
pcmax_low
;
if
(
p_em
ax
)
{
pcmax_high
=
*
p_emax
<
(
p_powerclass
-
delta_P_powerclass
)
?
*
p_emax
:
(
p_powerclass
-
delta_P_powerclass
);
pcmax_low
=
(
*
p_emax
-
delta_TC
)
<
(
p_powerclass
-
delta_P_powerclass
-
total_reduction
)
?
(
*
p_emax
-
delta_TC
)
:
(
p_powerclass
-
delta_P_powerclass
-
total_reduction
);
if
(
mac
->
p_M
ax
)
{
pcmax_high
=
p_emax
<
(
p_powerclass
-
delta_P_powerclass
)
?
p_emax
:
(
p_powerclass
-
delta_P_powerclass
);
pcmax_low
=
(
p_emax
-
delta_TC
)
<
(
p_powerclass
-
delta_P_powerclass
-
total_reduction
)
?
(
p_emax
-
delta_TC
)
:
(
p_powerclass
-
delta_P_powerclass
-
total_reduction
);
}
else
{
pcmax_high
=
p_powerclass
-
delta_P_powerclass
;
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
View file @
93469ed5
...
...
@@ -207,18 +207,6 @@ void nr_ue_mac_default_configs(NR_UE_MAC_INST_t *mac)
memset
(
&
mac
->
ul_time_alignment
,
0
,
sizeof
(
mac
->
ul_time_alignment
));
}
NR_BWP_DownlinkCommon_t
*
get_bwp_downlink_common
(
NR_UE_MAC_INST_t
*
mac
,
NR_BWP_Id_t
dl_bwp_id
)
{
NR_BWP_DownlinkCommon_t
*
bwp_Common
=
NULL
;
if
(
dl_bwp_id
>
0
&&
mac
->
cg
->
spCellConfig
->
spCellConfigDedicated
->
downlinkBWP_ToAddModList
)
{
bwp_Common
=
mac
->
cg
->
spCellConfig
->
spCellConfigDedicated
->
downlinkBWP_ToAddModList
->
list
.
array
[
dl_bwp_id
-
1
]
->
bwp_Common
;
}
else
if
(
mac
->
scc
)
{
bwp_Common
=
mac
->
scc
->
downlinkConfigCommon
->
initialDownlinkBWP
;
}
else
if
(
mac
->
scc_SIB
)
{
bwp_Common
=
&
mac
->
scc_SIB
->
downlinkConfigCommon
.
initialDownlinkBWP
;
}
return
bwp_Common
;
}
int
get_rnti_type
(
NR_UE_MAC_INST_t
*
mac
,
uint16_t
rnti
)
{
...
...
@@ -288,6 +276,7 @@ int8_t nr_ue_decode_mib(module_id_t module_id,
#endif
mac
->
ssb_subcarrier_offset
=
ssb_subcarrier_offset
;
mac
->
dmrs_TypeA_Position
=
mac
->
mib
->
dmrs_TypeA_Position
;
if
(
mac
->
first_sync_frame
==
-
1
)
mac
->
first_sync_frame
=
frame
;
...
...
@@ -647,7 +636,7 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
dlsch_config_pdu_1_0
->
rb_offset
-=
dlsch_config_pdu_1_0
->
BWPStart
;
/* TIME_DOM_RESOURCE_ASSIGNMENT */
int
dmrs_typeA_pos
=
(
mac
->
scc
!=
NULL
)
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
;
int
dmrs_typeA_pos
=
mac
->
dmrs_TypeA_Position
;
NR_tda_info_t
tda_info
=
get_dl_tda_info
(
current_DL_BWP
,
dci_ind
->
ss_type
,
dci
->
time_domain_assignment
.
val
,
dmrs_typeA_pos
,
mux_pattern
,
get_rnti_type
(
mac
,
rnti
),
coreset_type
,
mac
->
get_sib1
);
...
...
@@ -669,7 +658,7 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
/* dmrs symbol positions*/
dlsch_config_pdu_1_0
->
dlDmrsSymbPos
=
fill_dmrs_mask
(
pdsch_config
,
NR_DL_DCI_FORMAT_1_0
,
mac
->
scc
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
,
mac
->
dmrs_TypeA_Position
,
dlsch_config_pdu_1_0
->
number_symbols
,
dlsch_config_pdu_1_0
->
start_symbol
,
tda_info
.
mapping_type
,
...
...
@@ -868,7 +857,7 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
}
dlsch_config_pdu_1_1
->
rb_offset
=
dlsch_config_pdu_1_1
->
start_rb
+
dlsch_config_pdu_1_1
->
BWPStart
;
/* TIME_DOM_RESOURCE_ASSIGNMENT */
int
dmrs_typeA_pos
=
(
mac
->
scc
!=
NULL
)
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
;
int
dmrs_typeA_pos
=
mac
->
dmrs_TypeA_Position
;
NR_tda_info_t
tda_info
=
get_dl_tda_info
(
current_DL_BWP
,
dci_ind
->
ss_type
,
dci
->
time_domain_assignment
.
val
,
dmrs_typeA_pos
,
mux_pattern
,
get_rnti_type
(
mac
,
rnti
),
coreset_type
,
false
);
...
...
@@ -1059,7 +1048,7 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
/* dmrs symbol positions*/
dlsch_config_pdu_1_1
->
dlDmrsSymbPos
=
fill_dmrs_mask
(
pdsch_Config
,
NR_DL_DCI_FORMAT_1_1
,
mac
->
scc
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
,
mac
->
dmrs_TypeA_Position
,
dlsch_config_pdu_1_1
->
number_symbols
,
dlsch_config_pdu_1_1
->
start_symbol
,
tda_info
.
mapping_type
,
...
...
@@ -4151,17 +4140,13 @@ int nr_ue_process_rar(nr_downlink_indication_t *dl_info, int pdu_id)
// - referenceSignalPower: dBm/RE (average EPRE of the resources elements that carry secondary synchronization signals in dBm)
int16_t
compute_nr_SSB_PL
(
NR_UE_MAC_INST_t
*
mac
,
short
ssb_rsrp_dBm
)
{
long
referenceSignalP
ower
;
fapi_nr_config_request_t
*
cfg
=
&
mac
->
phy_config
.
config_req
;
int
referenceSignalPower
=
cfg
->
ssb_config
.
ss_pbch_p
ower
;
//TODO improve PL measurements. Probably not correct as it is.
if
(
mac
->
scc
)
referenceSignalPower
=
mac
->
scc
->
ss_PBCH_BlockPower
;
else
referenceSignalPower
=
mac
->
scc_SIB
->
ss_PBCH_BlockPower
;
int16_t
pathloss
=
(
int16_t
)(
referenceSignalPower
-
ssb_rsrp_dBm
);
LOG_D
(
NR_MAC
,
"pathloss %d dB, referenceSignalPower %
l
d dBm/RE (%f mW), RSRP %d dBm (%f mW)
\n
"
,
LOG_D
(
NR_MAC
,
"pathloss %d dB, referenceSignalPower %d dBm/RE (%f mW), RSRP %d dBm (%f mW)
\n
"
,
pathloss
,
referenceSignalPower
,
pow
(
10
,
referenceSignalPower
/
10
),
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
View file @
93469ed5
...
...
@@ -111,7 +111,7 @@ void fill_scheduled_response(nr_scheduled_response_t *scheduled_response,
fapi_nr_ul_config_request_t
*
get_ul_config_request
(
NR_UE_MAC_INST_t
*
mac
,
int
slot
,
int
fb_time
)
{
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
mac
->
scc
==
NULL
?
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
:
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
mac
->
tdd_UL_DL_ConfigurationCommon
;
//Check if requested on the right slot
AssertFatal
(
is_nr_UL_slot
(
tdd_config
,
slot
,
mac
->
frame_type
)
!=
0
,
"UL config_request called at wrong slot %d
\n
"
,
slot
);
...
...
@@ -483,8 +483,12 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac,
pusch_config_pdu
->
start_symbol_index
=
tda_info
->
startSymbolIndex
;
pusch_config_pdu
->
nr_of_symbols
=
tda_info
->
nrOfSymbols
;
l_prime_mask
=
get_l_prime
(
tda_info
->
nrOfSymbols
,
tda_info
->
mapping_type
,
add_pos
,
dmrslength
,
tda_info
->
startSymbolIndex
,
mac
->
scc
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
);
l_prime_mask
=
get_l_prime
(
tda_info
->
nrOfSymbols
,
tda_info
->
mapping_type
,
add_pos
,
dmrslength
,
tda_info
->
startSymbolIndex
,
mac
->
dmrs_TypeA_Position
);
LOG_D
(
NR_MAC
,
"MSG3 start_sym:%d NR Symb:%d mappingtype:%d, DMRS_MASK:%x
\n
"
,
pusch_config_pdu
->
start_symbol_index
,
pusch_config_pdu
->
nr_of_symbols
,
tda_info
->
mapping_type
,
l_prime_mask
);
#ifdef DEBUG_MSG3
...
...
@@ -655,7 +659,7 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac,
l_prime_mask
=
get_l_prime
(
pusch_config_pdu
->
nr_of_symbols
,
mappingtype
,
add_pos
,
dmrslength
,
pusch_config_pdu
->
start_symbol_index
,
mac
->
scc
?
mac
->
scc
->
dmrs_TypeA_Position
:
mac
->
mib
->
dmrs_TypeA_Position
);
mac
->
dmrs_TypeA_Position
);
// Num PRB Overhead from PUSCH-ServingCellConfig
if
(
current_UL_BWP
->
pusch_servingcellconfig
&&
current_UL_BWP
->
pusch_servingcellconfig
->
xOverhead
)
...
...
@@ -859,7 +863,7 @@ void nr_ue_aperiodic_srs_scheduling(NR_UE_MAC_INST_t *mac, long resource_trigger
slot_offset
,
DURATION_RX_TO_TX
);
int
n_slots_frame
=
nr_slots_per_frame
[
current_UL_BWP
->
scs
];
int
sched_slot
=
(
slot
+
slot_offset
)
%
n_slots_frame
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
mac
->
scc
==
NULL
?
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
:
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
mac
->
tdd_UL_DL_ConfigurationCommon
;
if
(
!
is_nr_UL_slot
(
tdd_config
,
sched_slot
,
mac
->
frame_type
))
{
LOG_E
(
NR_MAC
,
"Slot for scheduling aperiodic SRS %d is not an UL slot
\n
"
,
sched_slot
);
return
;
...
...
@@ -1655,84 +1659,20 @@ static void build_ssb_list(NR_UE_MAC_INST_t *mac) {
// Create the list of transmitted SSBs
// ===================================
BIT_STRING_t
*
ssb_bitmap
;
uint64_t
ssb_positionsInBurst
;
uint8_t
ssb_idx
=
0
;
ssb_list_info_t
*
ssb_list
=
&
mac
->
ssb_list
;
fapi_nr_config_request_t
*
cfg
=
&
mac
->
phy_config
.
config_req
;
ssb_list
->
nb_tx_ssb
=
0
;
if
(
mac
->
scc
)
{
NR_ServingCellConfigCommon_t
*
scc
=
mac
->
scc
;
switch
(
scc
->
ssb_PositionsInBurst
->
present
)
{
case
NR_ServingCellConfigCommon__ssb_PositionsInBurst_PR_shortBitmap
:
ssb_bitmap
=
&
scc
->
ssb_PositionsInBurst
->
choice
.
shortBitmap
;
ssb_positionsInBurst
=
BIT_STRING_to_uint8
(
ssb_bitmap
);
LOG_D
(
NR_MAC
,
"SSB config: SSB_positions_in_burst 0x%lx
\n
"
,
ssb_positionsInBurst
);
for
(
uint8_t
bit_nb
=
3
;
bit_nb
<=
3
;
bit_nb
--
)
{
// If SSB is transmitted
if
((
ssb_positionsInBurst
>>
bit_nb
)
&
0x01
)
{
ssb_list
->
nb_tx_ssb
++
;
ssb_list
->
tx_ssb
[
ssb_idx
].
transmitted
=
true
;
LOG_D
(
NR_MAC
,
"SSB idx %d transmitted
\n
"
,
ssb_idx
);
}
ssb_idx
++
;
}
break
;
case
NR_ServingCellConfigCommon__ssb_PositionsInBurst_PR_mediumBitmap
:
ssb_bitmap
=
&
scc
->
ssb_PositionsInBurst
->
choice
.
mediumBitmap
;
ssb_positionsInBurst
=
BIT_STRING_to_uint8
(
ssb_bitmap
);
LOG_D
(
NR_MAC
,
"SSB config: SSB_positions_in_burst 0x%lx
\n
"
,
ssb_positionsInBurst
);
for
(
uint8_t
bit_nb
=
7
;
bit_nb
<=
7
;
bit_nb
--
)
{
// If SSB is transmitted
if
((
ssb_positionsInBurst
>>
bit_nb
)
&
0x01
)
{
ssb_list
->
nb_tx_ssb
++
;
ssb_list
->
tx_ssb
[
ssb_idx
].
transmitted
=
true
;
LOG_D
(
NR_MAC
,
"SSB idx %d transmitted
\n
"
,
ssb_idx
);
}
ssb_idx
++
;
}
break
;
case
NR_ServingCellConfigCommon__ssb_PositionsInBurst_PR_longBitmap
:
ssb_bitmap
=
&
scc
->
ssb_PositionsInBurst
->
choice
.
longBitmap
;
ssb_positionsInBurst
=
BIT_STRING_to_uint64
(
ssb_bitmap
);
LOG_D
(
NR_MAC
,
"SSB config: SSB_positions_in_burst 0x%lx
\n
"
,
ssb_positionsInBurst
);
for
(
uint8_t
bit_nb
=
63
;
bit_nb
<=
63
;
bit_nb
--
)
{
// If SSB is transmitted
if
((
ssb_positionsInBurst
>>
bit_nb
)
&
0x01
)
{
ssb_list
->
nb_tx_ssb
++
;
ssb_list
->
tx_ssb
[
ssb_idx
].
transmitted
=
true
;
LOG_D
(
NR_MAC
,
"SSB idx %d transmitted
\n
"
,
ssb_idx
);
}
ssb_idx
++
;
}
break
;
default:
AssertFatal
(
false
,
"ssb_PositionsInBurst not present
\n
"
);
break
;
}
}
else
{
// This is configuration from SIB1
AssertFatal
(
mac
->
scc_SIB
->
ssb_PositionsInBurst
.
groupPresence
==
NULL
,
"Handle case for >8 SSBs
\n
"
);
ssb_bitmap
=
&
mac
->
scc_SIB
->
ssb_PositionsInBurst
.
inOneGroup
;
ssb_positionsInBurst
=
BIT_STRING_to_uint8
(
ssb_bitmap
);
LOG_D
(
NR_MAC
,
"SSB config: SSB_positions_in_burst 0x%lx
\n
"
,
ssb_positionsInBurst
);
for
(
uint8_t
bit_nb
=
7
;
bit_nb
<=
7
;
bit_nb
--
)
{
// If SSB is transmitted
if
((
ssb_positionsInBurst
>>
bit_nb
)
&
0x01
)
{
ssb_list
->
nb_tx_ssb
++
;
ssb_list
->
tx_ssb
[
ssb_idx
].
transmitted
=
true
;
LOG_D
(
NR_MAC
,
"SSB idx %d transmitted
\n
"
,
ssb_idx
);
}
ssb_idx
++
;
for
(
int
ssb_index
=
0
;
ssb_index
<
64
;
ssb_index
++
)
{
uint32_t
curr_mask
=
cfg
->
ssb_table
.
ssb_mask_list
[
ssb_index
/
32
].
ssb_mask
;
// check if if current SSB is transmitted
if
((
curr_mask
>>
(
31
-
(
ssb_index
%
32
)))
&
0x01
)
{
ssb_list
->
nb_tx_ssb
++
;
ssb_list
->
tx_ssb
[
ssb_index
].
transmitted
=
true
;
LOG_D
(
NR_MAC
,
"SSB idx %d transmitted
\n
"
,
ssb_index
);
}
else
ssb_list
->
tx_ssb
[
ssb_index
].
transmitted
=
false
;
}
}
...
...
@@ -2512,12 +2452,10 @@ static void nr_ue_prach_scheduler(module_id_t module_idP, frame_t frameP, sub_fr
fapi_nr_prach_config_t
*
prach_config
=
&
cfg
->
prach_config
;
nr_scheduled_response_t
scheduled_response
;
NR_ServingCellConfigCommon_t
*
scc
=
mac
->
scc
;
NR_ServingCellConfigCommonSIB_t
*
scc_SIB
=
mac
->
scc_SIB
;
NR_RACH_ConfigCommon_t
*
setup
=
mac
->
current_UL_BWP
.
rach_ConfigCommon
;
NR_RACH_ConfigGeneric_t
*
rach_ConfigGeneric
=
&
setup
->
rach_ConfigGeneric
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
scc
==
NULL
?
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
:
sc
c
->
tdd_UL_DL_ConfigurationCommon
;
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_config
=
ma
c
->
tdd_UL_DL_ConfigurationCommon
;
if
(
is_nr_UL_slot
(
tdd_config
,
slotP
,
mac
->
frame_type
))
{
...
...
openair2/NR_UE_PHY_INTERFACE/NR_IF_Module.c
View file @
93469ed5
...
...
@@ -346,7 +346,7 @@ static bool is_my_dci(NR_UE_MAC_INST_t *mac, nfapi_nr_dl_dci_pdu_t *received_pdu
if
(
get_softmodem_params
()
->
sa
)
{
if
(
mac
->
state
==
UE_NOT_SYNC
)
return
false
;
if
(
received_pdu
->
RNTI
==
0xFFFF
&&
mac
->
scc_SIB
)
if
(
received_pdu
->
RNTI
==
0xFFFF
&&
mac
->
phy_config_request_sent
)
return
false
;
if
(
received_pdu
->
RNTI
!=
mac
->
crnti
&&
mac
->
ra
.
ra_state
==
RA_SUCCEEDED
)
return
false
;
...
...
@@ -742,19 +742,17 @@ void check_and_process_dci(nfapi_nr_dl_tti_request_t *dl_tti_request,
int
slots_per_frame
=
20
;
//30 kHZ subcarrier spacing
int
slot_ahead
=
2
;
// TODO: Make this dynamic
if
(
mac
->
scc
||
mac
->
scc_SIB
)
{
if
(
is_nr_UL_slot
(
mac
->
scc
?
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
:
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
,
(
slot
+
slot_ahead
)
%
slots_per_frame
,
mac
->
frame_type
)
&&
mac
->
ra
.
ra_state
!=
RA_SUCCEEDED
)
{
// If we filled dl_info AFTER we got the slot indication, we want to check if we should fill tx_req:
nr_uplink_indication_t
ul_info
=
{
if
(
is_nr_UL_slot
(
mac
->
tdd_UL_DL_ConfigurationCommon
,
(
slot
+
slot_ahead
)
%
slots_per_frame
,
mac
->
frame_type
)
&&
mac
->
ra
.
ra_state
!=
RA_SUCCEEDED
)
{
// If we filled dl_info AFTER we got the slot indication, we want to check if we should fill tx_req:
nr_uplink_indication_t
ul_info
=
{
.
frame_rx
=
frame
,
.
slot_rx
=
slot
,
.
slot_tx
=
(
slot
+
slot_ahead
)
%
slots_per_frame
,
.
frame_tx
=
(
ul_info
.
slot_rx
+
slot_ahead
>=
slots_per_frame
)
?
ul_info
.
frame_rx
+
1
:
ul_info
.
frame_rx
};
nr_ue_ul_scheduler
(
&
ul_info
);
}
nr_ue_ul_scheduler
(
&
ul_info
);
}
}
...
...
@@ -1133,10 +1131,7 @@ int nr_ue_ul_indication(nr_uplink_indication_t *ul_info)
LOG_T
(
NR_MAC
,
"In %s():%d not calling scheduler mac->ra.ra_state = %d
\n
"
,
__FUNCTION__
,
__LINE__
,
mac
->
ra
.
ra_state
);
NR_TDD_UL_DL_ConfigCommon_t
*
tdd_UL_DL_ConfigurationCommon
=
mac
->
scc
!=
NULL
?
mac
->
scc
->
tdd_UL_DL_ConfigurationCommon
:
(
mac
->
scc_SIB
?
mac
->
scc_SIB
->
tdd_UL_DL_ConfigurationCommon
:
NULL
);
if
(
mac
->
phy_config_request_sent
&&
is_nr_UL_slot
(
tdd_UL_DL_ConfigurationCommon
,
ul_info
->
slot_tx
,
mac
->
frame_type
))
if
(
mac
->
phy_config_request_sent
&&
is_nr_UL_slot
(
mac
->
tdd_UL_DL_ConfigurationCommon
,
ul_info
->
slot_tx
,
mac
->
frame_type
))
nr_ue_ul_scheduler
(
ul_info
);
pthread_mutex_unlock
(
&
mac_IF_mutex
);
...
...
@@ -1251,8 +1246,8 @@ int nr_ue_dl_indication(nr_downlink_indication_t *dl_info)
return
ret_mask
;
}
nr_ue_if_module_t
*
nr_ue_if_module_init
(
uint32_t
module_id
)
{
nr_ue_if_module_t
*
nr_ue_if_module_init
(
uint32_t
module_id
)
{
if
(
nr_ue_if_module_inst
[
module_id
]
==
NULL
)
{
nr_ue_if_module_inst
[
module_id
]
=
(
nr_ue_if_module_t
*
)
malloc
(
sizeof
(
nr_ue_if_module_t
));
memset
((
void
*
)
nr_ue_if_module_inst
[
module_id
],
0
,
sizeof
(
nr_ue_if_module_t
));
...
...
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