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
0de51bcd
Commit
0de51bcd
authored
Mar 16, 2023
by
francescomani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
scheduling aperiodic SRS at UE
parent
79d351fb
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
145 additions
and
68 deletions
+145
-68
nfapi/open-nFAPI/nfapi/public_inc/fapi_nr_ue_interface.h
nfapi/open-nFAPI/nfapi/public_inc/fapi_nr_ue_interface.h
+0
-4
openair2/LAYER2/NR_MAC_UE/mac_proto.h
openair2/LAYER2/NR_MAC_UE/mac_proto.h
+2
-0
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
+8
-2
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
+135
-62
No files found.
nfapi/open-nFAPI/nfapi/public_inc/fapi_nr_ue_interface.h
View file @
0de51bcd
...
@@ -423,9 +423,6 @@ typedef struct {
...
@@ -423,9 +423,6 @@ typedef struct {
typedef
struct
{
typedef
struct
{
fapi_nr_dl_config_dci_dl_pdu_rel15_t
dci_config_rel15
;
fapi_nr_dl_config_dci_dl_pdu_rel15_t
dci_config_rel15
;
}
fapi_nr_dl_config_dci_pdu
;
}
fapi_nr_dl_config_dci_pdu
;
typedef
struct
{
uint8_t
aperiodicSRS_ResourceTrigger
;
}
fapi_nr_dl_srs_config_t
;
typedef
enum
{
vrb_to_prb_mapping_non_interleaved
=
0
,
vrb_to_prb_mapping_interleaved
=
1
}
vrb_to_prb_mapping_t
;
typedef
enum
{
vrb_to_prb_mapping_non_interleaved
=
0
,
vrb_to_prb_mapping_interleaved
=
1
}
vrb_to_prb_mapping_t
;
...
@@ -462,7 +459,6 @@ typedef struct {
...
@@ -462,7 +459,6 @@ typedef struct {
uint16_t
dmrs_ports
;
uint16_t
dmrs_ports
;
uint8_t
n_front_load_symb
;
uint8_t
n_front_load_symb
;
uint8_t
tci_state
;
uint8_t
tci_state
;
fapi_nr_dl_srs_config_t
srs_config
;
uint8_t
cbgti
;
uint8_t
cbgti
;
uint8_t
codeBlockGroupFlushIndicator
;
uint8_t
codeBlockGroupFlushIndicator
;
// to be check the fields needed to L1 with NR_DL_UE_HARQ_t and NR_UE_DLSCH_t
// to be check the fields needed to L1 with NR_DL_UE_HARQ_t and NR_UE_DLSCH_t
...
...
openair2/LAYER2/NR_MAC_UE/mac_proto.h
View file @
0de51bcd
...
@@ -189,6 +189,8 @@ int8_t nr_ue_process_csirs_measurements(module_id_t module_id, frame_t frame, in
...
@@ -189,6 +189,8 @@ int8_t nr_ue_process_csirs_measurements(module_id_t module_id, frame_t frame, in
uint32_t
get_ssb_frame
(
uint32_t
test
);
uint32_t
get_ssb_frame
(
uint32_t
test
);
void
nr_ue_aperiodic_srs_scheduling
(
NR_UE_MAC_INST_t
*
mac
,
long
resource_trigger
,
int
frame
,
int
slot
);
bool
trigger_periodic_scheduling_request
(
NR_UE_MAC_INST_t
*
mac
,
bool
trigger_periodic_scheduling_request
(
NR_UE_MAC_INST_t
*
mac
,
PUCCH_sched_t
*
pucch
,
PUCCH_sched_t
*
pucch
,
frame_t
frame
,
frame_t
frame
,
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
View file @
0de51bcd
...
@@ -536,6 +536,11 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
...
@@ -536,6 +536,11 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
// - SECOND_DAI
// - SECOND_DAI
// - SRS_RESOURCE_IND
// - SRS_RESOURCE_IND
/* SRS_REQUEST */
AssertFatal
(
dci
->
srs_request
.
nbits
==
2
,
"If SUL is supported in the cell, there is an additional bit in SRS request field
\n
"
);
if
(
dci
->
srs_request
.
val
>
0
)
nr_ue_aperiodic_srs_scheduling
(
mac
,
dci
->
srs_request
.
val
,
frame
,
slot
);
// Schedule PUSCH
// Schedule PUSCH
tda_info
=
get_ul_tda_info
(
current_UL_BWP
,
coreset_type
,
dci_ind
->
ss_type
,
get_rnti_type
(
mac
,
rnti
),
dci
->
time_domain_assignment
.
val
);
tda_info
=
get_ul_tda_info
(
current_UL_BWP
,
coreset_type
,
dci_ind
->
ss_type
,
get_rnti_type
(
mac
,
rnti
),
dci
->
time_domain_assignment
.
val
);
if
(
tda_info
.
nrOfSymbols
==
0
)
if
(
tda_info
.
nrOfSymbols
==
0
)
...
@@ -1072,8 +1077,9 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
...
@@ -1072,8 +1077,9 @@ int8_t nr_ue_process_dci(module_id_t module_id, int cc_id, uint8_t gNB_index, fr
dlsch_config_pdu_1_1
->
tci_state
=
dci
->
transmission_configuration_indication
.
val
;
dlsch_config_pdu_1_1
->
tci_state
=
dci
->
transmission_configuration_indication
.
val
;
}
}
/* SRS_REQUEST */
/* SRS_REQUEST */
// if SUL is supported in the cell, there is an additional bit in this field and the value of this bit represents table 7.1.1.1-1 TS 38.212 FIXME!!!
AssertFatal
(
dci
->
srs_request
.
nbits
==
2
,
"If SUL is supported in the cell, there is an additional bit in SRS request field
\n
"
);
dlsch_config_pdu_1_1
->
srs_config
.
aperiodicSRS_ResourceTrigger
=
(
dci
->
srs_request
.
val
&
0x11
);
// as per Table 7.3.1.1.2-24 TS 38.212
if
(
dci
->
srs_request
.
val
>
0
)
nr_ue_aperiodic_srs_scheduling
(
mac
,
dci
->
srs_request
.
val
,
frame
,
slot
);
/* CBGTI */
/* CBGTI */
dlsch_config_pdu_1_1
->
cbgti
=
dci
->
cbgti
.
val
;
dlsch_config_pdu_1_1
->
cbgti
=
dci
->
cbgti
.
val
;
/* CBGFI */
/* CBGFI */
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
View file @
0de51bcd
...
@@ -789,55 +789,13 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac, NR_tda_info_t *tda_info, nfapi_nr
...
@@ -789,55 +789,13 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac, NR_tda_info_t *tda_info, nfapi_nr
}
}
// Periodic SRS scheduling
void
configure_srs_pdu
(
NR_UE_MAC_INST_t
*
mac
,
bool
nr_ue_periodic_srs_scheduling
(
module_id_t
mod_id
,
frame_t
frame
,
slot_t
slot
)
{
NR_SRS_Resource_t
*
srs_resource
,
fapi_nr_ul_config_srs_pdu
*
srs_config_pdu
,
bool
srs_scheduled
=
false
;
int
period
,
int
offset
)
{
NR_UE_MAC_INST_t
*
mac
=
get_mac_inst
(
mod_id
);
NR_UE_UL_BWP_t
*
current_UL_BWP
=
&
mac
->
current_UL_BWP
;
NR_UE_UL_BWP_t
*
current_UL_BWP
=
&
mac
->
current_UL_BWP
;
NR_SRS_Config_t
*
srs_config
=
current_UL_BWP
->
srs_Config
;
if
(
!
srs_config
)
{
return
false
;
}
for
(
int
rs
=
0
;
rs
<
srs_config
->
srs_ResourceSetToAddModList
->
list
.
count
;
rs
++
)
{
// Find periodic resource set
NR_SRS_ResourceSet_t
*
srs_resource_set
=
srs_config
->
srs_ResourceSetToAddModList
->
list
.
array
[
rs
];
if
(
srs_resource_set
->
resourceType
.
present
!=
NR_SRS_ResourceSet__resourceType_PR_periodic
)
{
continue
;
}
// Find the corresponding srs resource
NR_SRS_Resource_t
*
srs_resource
=
NULL
;
for
(
int
r1
=
0
;
r1
<
srs_resource_set
->
srs_ResourceIdList
->
list
.
count
;
r1
++
)
{
for
(
int
r2
=
0
;
r2
<
srs_config
->
srs_ResourceToAddModList
->
list
.
count
;
r2
++
)
{
if
((
*
srs_resource_set
->
srs_ResourceIdList
->
list
.
array
[
r1
]
==
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
srs_ResourceId
)
&&
(
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
resourceType
.
present
==
NR_SRS_Resource__resourceType_PR_periodic
))
{
srs_resource
=
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
];
break
;
}
}
}
if
(
srs_resource
==
NULL
)
{
continue
;
}
uint16_t
period
=
srs_period
[
srs_resource
->
resourceType
.
choice
.
periodic
->
periodicityAndOffset_p
.
present
];
uint16_t
offset
=
get_nr_srs_offset
(
srs_resource
->
resourceType
.
choice
.
periodic
->
periodicityAndOffset_p
);
int
n_slots_frame
=
nr_slots_per_frame
[
current_UL_BWP
->
scs
];
// Check if UE should transmit the SRS
if
((
frame
*
n_slots_frame
+
slot
-
offset
)
%
period
==
0
)
{
fapi_nr_ul_config_request_t
*
ul_config
=
get_ul_config_request
(
mac
,
slot
);
fapi_nr_ul_config_srs_pdu
*
srs_config_pdu
=
&
ul_config
->
ul_config_list
[
ul_config
->
number_pdus
].
srs_config_pdu
;
srs_config_pdu
->
rnti
=
mac
->
crnti
;
srs_config_pdu
->
rnti
=
mac
->
crnti
;
srs_config_pdu
->
handle
=
0
;
srs_config_pdu
->
handle
=
0
;
srs_config_pdu
->
bwp_size
=
current_UL_BWP
->
BWPSize
;
srs_config_pdu
->
bwp_size
=
current_UL_BWP
->
BWPSize
;
...
@@ -871,8 +829,10 @@ bool nr_ue_periodic_srs_scheduling(module_id_t mod_id, frame_t frame, slot_t slo
...
@@ -871,8 +829,10 @@ bool nr_ue_periodic_srs_scheduling(module_id_t mod_id, frame_t frame, slot_t slo
srs_config_pdu
->
frequency_hopping
=
srs_resource
->
freqHopping
.
b_hop
;
srs_config_pdu
->
frequency_hopping
=
srs_resource
->
freqHopping
.
b_hop
;
srs_config_pdu
->
group_or_sequence_hopping
=
srs_resource
->
groupOrSequenceHopping
;
srs_config_pdu
->
group_or_sequence_hopping
=
srs_resource
->
groupOrSequenceHopping
;
srs_config_pdu
->
resource_type
=
srs_resource
->
resourceType
.
present
-
1
;
srs_config_pdu
->
resource_type
=
srs_resource
->
resourceType
.
present
-
1
;
if
(
srs_config_pdu
->
resource_type
>
0
)
{
// not aperiodic
srs_config_pdu
->
t_srs
=
period
;
srs_config_pdu
->
t_srs
=
period
;
srs_config_pdu
->
t_offset
=
offset
;
srs_config_pdu
->
t_offset
=
offset
;
}
#ifdef SRS_DEBUG
#ifdef SRS_DEBUG
LOG_I
(
NR_MAC
,
"Frame = %i, slot = %i
\n
"
,
frame
,
slot
);
LOG_I
(
NR_MAC
,
"Frame = %i, slot = %i
\n
"
,
frame
,
slot
);
...
@@ -900,6 +860,119 @@ bool nr_ue_periodic_srs_scheduling(module_id_t mod_id, frame_t frame, slot_t slo
...
@@ -900,6 +860,119 @@ bool nr_ue_periodic_srs_scheduling(module_id_t mod_id, frame_t frame, slot_t slo
LOG_I
(
NR_MAC
,
"srs_config_pdu->t_srs = %u
\n
"
,
srs_config_pdu
->
t_srs
);
LOG_I
(
NR_MAC
,
"srs_config_pdu->t_srs = %u
\n
"
,
srs_config_pdu
->
t_srs
);
LOG_I
(
NR_MAC
,
"srs_config_pdu->t_offset = %u
\n
"
,
srs_config_pdu
->
t_offset
);
LOG_I
(
NR_MAC
,
"srs_config_pdu->t_offset = %u
\n
"
,
srs_config_pdu
->
t_offset
);
#endif
#endif
}
// Aperiodic SRS scheduling
void
nr_ue_aperiodic_srs_scheduling
(
NR_UE_MAC_INST_t
*
mac
,
long
resource_trigger
,
int
frame
,
int
slot
)
{
NR_UE_UL_BWP_t
*
current_UL_BWP
=
&
mac
->
current_UL_BWP
;
NR_SRS_Config_t
*
srs_config
=
current_UL_BWP
->
srs_Config
;
if
(
!
srs_config
)
{
LOG_E
(
NR_MAC
,
"DCI is triggering aperiodic SRS but there is no SRS configuration
\n
"
);
return
;
}
int
slot_offset
=
0
;
NR_SRS_Resource_t
*
srs_resource
=
NULL
;
for
(
int
rs
=
0
;
rs
<
srs_config
->
srs_ResourceSetToAddModList
->
list
.
count
;
rs
++
)
{
// Find aperiodic resource set
NR_SRS_ResourceSet_t
*
srs_resource_set
=
srs_config
->
srs_ResourceSetToAddModList
->
list
.
array
[
rs
];
if
(
srs_resource_set
->
resourceType
.
present
!=
NR_SRS_ResourceSet__resourceType_PR_aperiodic
)
continue
;
// the resource trigger need to match the DCI one
if
(
srs_resource_set
->
resourceType
.
choice
.
aperiodic
->
aperiodicSRS_ResourceTrigger
!=
resource_trigger
)
continue
;
// if slotOffset is null -> offset = 0
if
(
srs_resource_set
->
resourceType
.
choice
.
aperiodic
->
slotOffset
)
slot_offset
=
*
srs_resource_set
->
resourceType
.
choice
.
aperiodic
->
slotOffset
;
// Find the corresponding srs resource
for
(
int
r1
=
0
;
r1
<
srs_resource_set
->
srs_ResourceIdList
->
list
.
count
;
r1
++
)
{
for
(
int
r2
=
0
;
r2
<
srs_config
->
srs_ResourceToAddModList
->
list
.
count
;
r2
++
)
{
if
((
*
srs_resource_set
->
srs_ResourceIdList
->
list
.
array
[
r1
]
==
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
srs_ResourceId
)
&&
(
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
resourceType
.
present
==
NR_SRS_Resource__resourceType_PR_aperiodic
))
{
srs_resource
=
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
];
break
;
}
}
}
}
if
(
srs_resource
==
NULL
)
{
LOG_E
(
NR_MAC
,
"Couldn't find SRS aperiodic resource with trigger %ld
\n
"
,
resource_trigger
);
return
;
}
AssertFatal
(
slot_offset
>=
DURATION_RX_TO_TX
,
"Slot offset between DCI and aperiodic SRS (%d) cannot be less than DURATION_RX_TO_TX (%d)
\n
"
,
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
;
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
;
}
int
sched_frame
=
frame
+
(
slot
+
slot_offset
>=
n_slots_frame
)
%
1024
;
fapi_nr_ul_config_request_t
*
ul_config
=
get_ul_config_request
(
mac
,
sched_slot
);
fapi_nr_ul_config_srs_pdu
*
srs_config_pdu
=
&
ul_config
->
ul_config_list
[
ul_config
->
number_pdus
].
srs_config_pdu
;
configure_srs_pdu
(
mac
,
srs_resource
,
srs_config_pdu
,
0
,
0
);
fill_ul_config
(
ul_config
,
sched_frame
,
sched_slot
,
FAPI_NR_UL_CONFIG_TYPE_SRS
);
}
// Periodic SRS scheduling
bool
nr_ue_periodic_srs_scheduling
(
module_id_t
mod_id
,
frame_t
frame
,
slot_t
slot
)
{
bool
srs_scheduled
=
false
;
NR_UE_MAC_INST_t
*
mac
=
get_mac_inst
(
mod_id
);
NR_UE_UL_BWP_t
*
current_UL_BWP
=
&
mac
->
current_UL_BWP
;
NR_SRS_Config_t
*
srs_config
=
current_UL_BWP
->
srs_Config
;
if
(
!
srs_config
)
{
return
false
;
}
for
(
int
rs
=
0
;
rs
<
srs_config
->
srs_ResourceSetToAddModList
->
list
.
count
;
rs
++
)
{
// Find periodic resource set
NR_SRS_ResourceSet_t
*
srs_resource_set
=
srs_config
->
srs_ResourceSetToAddModList
->
list
.
array
[
rs
];
if
(
srs_resource_set
->
resourceType
.
present
!=
NR_SRS_ResourceSet__resourceType_PR_periodic
)
{
continue
;
}
// Find the corresponding srs resource
NR_SRS_Resource_t
*
srs_resource
=
NULL
;
for
(
int
r1
=
0
;
r1
<
srs_resource_set
->
srs_ResourceIdList
->
list
.
count
;
r1
++
)
{
for
(
int
r2
=
0
;
r2
<
srs_config
->
srs_ResourceToAddModList
->
list
.
count
;
r2
++
)
{
if
((
*
srs_resource_set
->
srs_ResourceIdList
->
list
.
array
[
r1
]
==
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
srs_ResourceId
)
&&
(
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
]
->
resourceType
.
present
==
NR_SRS_Resource__resourceType_PR_periodic
))
{
srs_resource
=
srs_config
->
srs_ResourceToAddModList
->
list
.
array
[
r2
];
break
;
}
}
}
if
(
srs_resource
==
NULL
)
{
continue
;
}
uint16_t
period
=
srs_period
[
srs_resource
->
resourceType
.
choice
.
periodic
->
periodicityAndOffset_p
.
present
];
uint16_t
offset
=
get_nr_srs_offset
(
srs_resource
->
resourceType
.
choice
.
periodic
->
periodicityAndOffset_p
);
int
n_slots_frame
=
nr_slots_per_frame
[
current_UL_BWP
->
scs
];
// Check if UE should transmit the SRS
if
((
frame
*
n_slots_frame
+
slot
-
offset
)
%
period
==
0
)
{
fapi_nr_ul_config_request_t
*
ul_config
=
get_ul_config_request
(
mac
,
slot
);
fapi_nr_ul_config_srs_pdu
*
srs_config_pdu
=
&
ul_config
->
ul_config_list
[
ul_config
->
number_pdus
].
srs_config_pdu
;
configure_srs_pdu
(
mac
,
srs_resource
,
srs_config_pdu
,
period
,
offset
);
fill_ul_config
(
ul_config
,
frame
,
slot
,
FAPI_NR_UL_CONFIG_TYPE_SRS
);
fill_ul_config
(
ul_config
,
frame
,
slot
,
FAPI_NR_UL_CONFIG_TYPE_SRS
);
srs_scheduled
=
true
;
srs_scheduled
=
true
;
...
...
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