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
c7c1cb2d
Commit
c7c1cb2d
authored
Jun 26, 2024
by
Bartosz Podrygajlo
Committed by
Robert Schmidt
Aug 02, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Enable PHR reporting for NR UE
parent
bd721c3b
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
184 additions
and
46 deletions
+184
-46
openair2/LAYER2/NR_MAC_UE/config_ue.c
openair2/LAYER2/NR_MAC_UE/config_ue.c
+15
-1
openair2/LAYER2/NR_MAC_UE/mac_defs.h
openair2/LAYER2/NR_MAC_UE/mac_defs.h
+26
-15
openair2/LAYER2/NR_MAC_UE/mac_proto.h
openair2/LAYER2/NR_MAC_UE/mac_proto.h
+4
-2
openair2/LAYER2/NR_MAC_UE/main_ue_nr.c
openair2/LAYER2/NR_MAC_UE/main_ue_nr.c
+6
-3
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
+8
-10
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
+115
-13
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
+10
-2
No files found.
openair2/LAYER2/NR_MAC_UE/config_ue.c
View file @
c7c1cb2d
...
@@ -1879,7 +1879,21 @@ static void configure_maccellgroup(NR_UE_MAC_INST_t *mac, const NR_MAC_CellGroup
...
@@ -1879,7 +1879,21 @@ static void configure_maccellgroup(NR_UE_MAC_INST_t *mac, const NR_MAC_CellGroup
}
}
}
}
if
(
mcg
->
phr_Config
)
{
if
(
mcg
->
phr_Config
)
{
// TODO configuration when PHR is implemented
nr_phr_info_t
*
phr_info
=
&
si
->
phr_info
;
phr_info
->
is_configured
=
mcg
->
phr_Config
->
choice
.
setup
!=
NULL
;
if
(
phr_info
->
is_configured
)
{
int
slots_per_subframe
=
nr_slots_per_frame
[
scs
]
/
10
;
struct
NR_PHR_Config
*
config
=
mcg
->
phr_Config
->
choice
.
setup
;
AssertFatal
(
config
->
multiplePHR
==
0
,
"mulitplePHR not supported"
);
phr_info
->
PathlossChange_db
=
config
->
phr_Tx_PowerFactorChange
;
const
int
periodic_timer_sf_enum_to_sf
[]
=
{
10
,
20
,
50
,
100
,
200
,
500
,
1000
,
UINT_MAX
};
int
periodic_timer_sf
=
periodic_timer_sf_enum_to_sf
[
config
->
phr_PeriodicTimer
];
nr_timer_setup
(
&
phr_info
->
periodicPHR_Timer
,
periodic_timer_sf
*
slots_per_subframe
,
1
);
const
int
prohibit_timer_sf_enum_to_sf
[]
=
{
0
,
10
,
20
,
50
,
100
,
200
,
500
,
1000
};
int
prohibit_timer_sf
=
prohibit_timer_sf_enum_to_sf
[
config
->
phr_ProhibitTimer
];
nr_timer_setup
(
&
phr_info
->
prohibitPHR_Timer
,
prohibit_timer_sf
*
slots_per_subframe
,
1
);
phr_info
->
phr_reporting
=
(
1
<<
phr_cause_phr_config
);
}
}
}
}
}
...
...
openair2/LAYER2/NR_MAC_UE/mac_defs.h
View file @
c7c1cb2d
...
@@ -172,6 +172,12 @@
...
@@ -172,6 +172,12 @@
UE_STATE(UE_CONNECTED) \
UE_STATE(UE_CONNECTED) \
UE_STATE(UE_DETACHING)
UE_STATE(UE_DETACHING)
typedef
enum
{
phr_cause_prohibit_timer
=
0
,
phr_cause_periodic_timer
,
phr_cause_phr_config
,
}
NR_UE_PHR_Reporting_cause_t
;
/*!\brief UE layer 2 status */
/*!\brief UE layer 2 status */
typedef
enum
{
typedef
enum
{
#define UE_STATE(state) state,
#define UE_STATE(state) state,
...
@@ -222,6 +228,24 @@ typedef struct {
...
@@ -222,6 +228,24 @@ typedef struct {
uint32_t
maxTransmissions
;
uint32_t
maxTransmissions
;
}
nr_sr_info_t
;
}
nr_sr_info_t
;
typedef
struct
{
bool
is_configured
;
///timer before triggering a periodic PHR
NR_timer_t
periodicPHR_Timer
;
///timer before triggering a prohibit PHR
NR_timer_t
prohibitPHR_Timer
;
///DL Pathloss change value
uint16_t
PathlossLastValue
;
///number of subframe before triggering a periodic PHR
int16_t
periodicPHR_SF
;
///number of subframe before triggering a prohibit PHR
int16_t
prohibitPHR_SF
;
///DL Pathloss Change in db
uint16_t
PathlossChange_db
;
int
phr_reporting
;
bool
was_mac_reset
;
}
nr_phr_info_t
;
// LTE structure, might need to be adapted for NR
// LTE structure, might need to be adapted for NR
typedef
struct
{
typedef
struct
{
// lcs scheduling info
// lcs scheduling info
...
@@ -240,18 +264,8 @@ typedef struct {
...
@@ -240,18 +264,8 @@ typedef struct {
NR_timer_t
retxBSR_Timer
;
NR_timer_t
retxBSR_Timer
;
/// periodicBSR-Timer
/// periodicBSR-Timer
NR_timer_t
periodicBSR_Timer
;
NR_timer_t
periodicBSR_Timer
;
///timer before triggering a periodic PHR
uint16_t
periodicPHR_Timer
;
nr_phr_info_t
phr_info
;
///timer before triggering a prohibit PHR
uint16_t
prohibitPHR_Timer
;
///DL Pathloss change value
uint16_t
PathlossChange
;
///number of subframe before triggering a periodic PHR
int16_t
periodicPHR_SF
;
///number of subframe before triggering a prohibit PHR
int16_t
prohibitPHR_SF
;
///DL Pathloss Change in db
uint16_t
PathlossChange_db
;
}
NR_UE_SCHEDULING_INFO
;
}
NR_UE_SCHEDULING_INFO
;
typedef
enum
{
typedef
enum
{
...
@@ -560,9 +574,6 @@ typedef struct NR_UE_MAC_INST_s {
...
@@ -560,9 +574,6 @@ typedef struct NR_UE_MAC_INST_s {
NR_UE_SCHEDULING_INFO
scheduling_info
;
NR_UE_SCHEDULING_INFO
scheduling_info
;
/// PHR
uint8_t
PHR_reporting_active
;
int
dmrs_TypeA_Position
;
int
dmrs_TypeA_Position
;
int
p_Max
;
int
p_Max
;
int
p_Max_alt
;
int
p_Max_alt
;
...
...
openair2/LAYER2/NR_MAC_UE/mac_proto.h
View file @
c7c1cb2d
...
@@ -173,7 +173,7 @@ void nr_ue_process_mac_pdu(NR_UE_MAC_INST_t *mac,nr_downlink_indication_t *dl_in
...
@@ -173,7 +173,7 @@ void nr_ue_process_mac_pdu(NR_UE_MAC_INST_t *mac,nr_downlink_indication_t *dl_in
int
nr_write_ce_ulsch_pdu
(
uint8_t
*
mac_ce
,
int
nr_write_ce_ulsch_pdu
(
uint8_t
*
mac_ce
,
NR_UE_MAC_INST_t
*
mac
,
NR_UE_MAC_INST_t
*
mac
,
uint8_t
power_headroom
,
// todo: NR_POWER_HEADROOM_CMD
*power_headroom,
NR_SINGLE_ENTRY_PHR_MAC_CE
*
power_headroom
,
uint16_t
*
crnti
,
uint16_t
*
crnti
,
NR_BSR_SHORT
*
truncated_bsr
,
NR_BSR_SHORT
*
truncated_bsr
,
NR_BSR_SHORT
*
short_bsr
,
NR_BSR_SHORT
*
short_bsr
,
...
@@ -193,7 +193,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
...
@@ -193,7 +193,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
sub_frame_t
subframe
,
sub_frame_t
subframe
,
uint8_t
gNB_index
,
uint8_t
gNB_index
,
uint8_t
*
ulsch_buffer
,
uint8_t
*
ulsch_buffer
,
uint32_t
buflen
);
uint32_t
buflen
,
int16_t
tx_power
,
int16_t
P_CMAX
);
void
set_harq_status
(
NR_UE_MAC_INST_t
*
mac
,
void
set_harq_status
(
NR_UE_MAC_INST_t
*
mac
,
uint8_t
pucch_id
,
uint8_t
pucch_id
,
...
...
openair2/LAYER2/NR_MAC_UE/main_ue_nr.c
View file @
c7c1cb2d
...
@@ -118,8 +118,10 @@ void nr_ue_mac_default_configs(NR_UE_MAC_INST_t *mac)
...
@@ -118,8 +118,10 @@ void nr_ue_mac_default_configs(NR_UE_MAC_INST_t *mac)
nr_timer_setup
(
&
mac
->
scheduling_info
.
retxBSR_Timer
,
80
*
subframes_per_slot
,
1
);
// 1 slot update rate
nr_timer_setup
(
&
mac
->
scheduling_info
.
retxBSR_Timer
,
80
*
subframes_per_slot
,
1
);
// 1 slot update rate
nr_timer_setup
(
&
mac
->
scheduling_info
.
periodicBSR_Timer
,
10
*
subframes_per_slot
,
1
);
// 1 slot update rate
nr_timer_setup
(
&
mac
->
scheduling_info
.
periodicBSR_Timer
,
10
*
subframes_per_slot
,
1
);
// 1 slot update rate
mac
->
scheduling_info
.
periodicPHR_Timer
=
NR_PHR_Config__phr_PeriodicTimer_sf10
;
mac
->
scheduling_info
.
phr_info
.
is_configured
=
true
;
mac
->
scheduling_info
.
prohibitPHR_Timer
=
NR_PHR_Config__phr_ProhibitTimer_sf10
;
mac
->
scheduling_info
.
phr_info
.
PathlossChange_db
=
1
;
nr_timer_setup
(
&
mac
->
scheduling_info
.
phr_info
.
periodicPHR_Timer
,
10
*
subframes_per_slot
,
1
);
nr_timer_setup
(
&
mac
->
scheduling_info
.
phr_info
.
prohibitPHR_Timer
,
10
*
subframes_per_slot
,
1
);
}
}
void
nr_ue_send_synch_request
(
NR_UE_MAC_INST_t
*
mac
,
module_id_t
module_id
,
int
cc_id
,
const
fapi_nr_synch_request_t
*
sync_req
)
void
nr_ue_send_synch_request
(
NR_UE_MAC_INST_t
*
mac
,
module_id_t
module_id
,
int
cc_id
,
const
fapi_nr_synch_request_t
*
sync_req
)
...
@@ -229,7 +231,8 @@ void reset_mac_inst(NR_UE_MAC_INST_t *nr_mac)
...
@@ -229,7 +231,8 @@ void reset_mac_inst(NR_UE_MAC_INST_t *nr_mac)
nr_mac
->
scheduling_info
.
BSR_reporting_active
=
NR_BSR_TRIGGER_NONE
;
nr_mac
->
scheduling_info
.
BSR_reporting_active
=
NR_BSR_TRIGGER_NONE
;
// cancel any triggered Power Headroom Reporting procedure
// cancel any triggered Power Headroom Reporting procedure
// TODO PHR not implemented yet
nr_mac
->
scheduling_info
.
phr_info
.
phr_reporting
=
0
;
nr_mac
->
scheduling_info
.
phr_info
.
was_mac_reset
=
true
;
// flush the soft buffers for all DL HARQ processes
// flush the soft buffers for all DL HARQ processes
for
(
int
k
=
0
;
k
<
NR_MAX_HARQ_PROCESSES
;
k
++
)
for
(
int
k
=
0
;
k
<
NR_MAX_HARQ_PROCESSES
;
k
++
)
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_procedures.c
View file @
c7c1cb2d
...
@@ -3668,30 +3668,28 @@ void nr_ue_process_mac_pdu(NR_UE_MAC_INST_t *mac, nr_downlink_indication_t *dl_i
...
@@ -3668,30 +3668,28 @@ void nr_ue_process_mac_pdu(NR_UE_MAC_INST_t *mac, nr_downlink_indication_t *dl_i
*/
*/
int
nr_write_ce_ulsch_pdu
(
uint8_t
*
mac_ce
,
int
nr_write_ce_ulsch_pdu
(
uint8_t
*
mac_ce
,
NR_UE_MAC_INST_t
*
mac
,
NR_UE_MAC_INST_t
*
mac
,
uint8_t
power_headroom
,
// todo: NR_POWER_HEADROOM_CMD
*power_headroom,
NR_SINGLE_ENTRY_PHR_MAC_CE
*
power_headroom
,
uint16_t
*
crnti
,
uint16_t
*
crnti
,
NR_BSR_SHORT
*
truncated_bsr
,
NR_BSR_SHORT
*
truncated_bsr
,
NR_BSR_SHORT
*
short_bsr
,
NR_BSR_SHORT
*
short_bsr
,
NR_BSR_LONG
*
long_bsr
)
NR_BSR_LONG
*
long_bsr
)
{
{
int
mac_ce_len
=
0
;
int
mac_ce_len
=
0
;
uint8_t
mac_ce_size
=
0
;
uint8_t
*
pdu
=
mac_ce
;
uint8_t
*
pdu
=
mac_ce
;
if
(
power_headroom
)
{
if
(
power_headroom
)
{
// MAC CE fixed subheader
// MAC CE fixed subheader
((
NR_MAC_SUBHEADER_FIXED
*
)
mac_ce
)
->
R
=
0
;
((
NR_MAC_SUBHEADER_FIXED
*
)
mac_ce
)
->
R
=
0
;
((
NR_MAC_SUBHEADER_FIXED
*
)
mac_ce
)
->
LCID
=
UL_SCH_LCID_SINGLE_ENTRY_PHR
;
((
NR_MAC_SUBHEADER_FIXED
*
)
mac_ce
)
->
LCID
=
UL_SCH_LCID_SINGLE_ENTRY_PHR
;
mac_ce
++
;
mac_ce
++
;
// PHR MAC CE (1 octet)
// PHR MAC CE (1 octet)
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
PH
=
power_headroom
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
PH
=
power_headroom
->
PH
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
R1
=
0
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
R1
=
0
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
PCMAX
=
0
;
// todo
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
PCMAX
=
power_headroom
->
PCMAX
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
R2
=
0
;
((
NR_SINGLE_ENTRY_PHR_MAC_CE
*
)
mac_ce
)
->
R2
=
0
;
// update pointer and length
// update pointer and length
mac_ce_size
=
sizeof
(
NR_SINGLE_ENTRY_PHR_MAC_CE
);
int
mac_ce_size
=
sizeof
(
NR_SINGLE_ENTRY_PHR_MAC_CE
);
mac_ce
+=
mac_ce_size
;
mac_ce
+=
mac_ce_size
;
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : power_headroom pdu %p mac_ce %p b
\n
"
,
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : power_headroom pdu %p mac_ce %p b
\n
"
,
...
@@ -3710,7 +3708,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
...
@@ -3710,7 +3708,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
memcpy
(
mac_ce
,
crnti
,
sizeof
(
*
crnti
));
memcpy
(
mac_ce
,
crnti
,
sizeof
(
*
crnti
));
// update pointer and length
// update pointer and length
mac_ce_size
=
sizeof
(
uint16_t
);
int
mac_ce_size
=
sizeof
(
uint16_t
);
mac_ce
+=
mac_ce_size
;
mac_ce
+=
mac_ce_size
;
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
}
}
...
@@ -3727,7 +3725,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
...
@@ -3727,7 +3725,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
((
NR_BSR_SHORT_TRUNCATED
*
)
mac_ce
)
->
LcgID
=
truncated_bsr
->
LcgID
;;
((
NR_BSR_SHORT_TRUNCATED
*
)
mac_ce
)
->
LcgID
=
truncated_bsr
->
LcgID
;;
// update pointer and length
// update pointer and length
mac_ce_size
=
sizeof
(
NR_BSR_SHORT_TRUNCATED
);
int
mac_ce_size
=
sizeof
(
NR_BSR_SHORT_TRUNCATED
);
mac_ce
+=
mac_ce_size
;
mac_ce
+=
mac_ce_size
;
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : truncated_bsr Buffer_size %d LcgID %d pdu %p mac_ce %p
\n
"
,
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : truncated_bsr Buffer_size %d LcgID %d pdu %p mac_ce %p
\n
"
,
...
@@ -3745,7 +3743,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
...
@@ -3745,7 +3743,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
((
NR_BSR_SHORT
*
)
mac_ce
)
->
LcgID
=
short_bsr
->
LcgID
;
((
NR_BSR_SHORT
*
)
mac_ce
)
->
LcgID
=
short_bsr
->
LcgID
;
// update pointer and length
// update pointer and length
mac_ce_size
=
sizeof
(
NR_BSR_SHORT
);
int
mac_ce_size
=
sizeof
(
NR_BSR_SHORT
);
mac_ce
+=
mac_ce_size
;
mac_ce
+=
mac_ce_size
;
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
mac_ce_len
+=
mac_ce_size
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : short_bsr Buffer_size %d LcgID %d pdu %p mac_ce %p
\n
"
,
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : short_bsr Buffer_size %d LcgID %d pdu %p mac_ce %p
\n
"
,
...
@@ -3812,7 +3810,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
...
@@ -3812,7 +3810,7 @@ int nr_write_ce_ulsch_pdu(uint8_t *mac_ce,
((
NR_BSR_LONG
*
)
mac_ce
)
->
LcgID7
=
1
;
((
NR_BSR_LONG
*
)
mac_ce
)
->
LcgID7
=
1
;
*
Buffer_size_ptr
++
=
long_bsr
->
Buffer_size7
;
*
Buffer_size_ptr
++
=
long_bsr
->
Buffer_size7
;
}
}
((
NR_MAC_SUBHEADER_SHORT
*
)
mac_pdu_subheader_ptr
)
->
L
=
mac_ce_size
=
(
uint8_t
*
)
Buffer_size_ptr
-
(
uint8_t
*
)
mac_ce
;
int
mac_ce_size
=
((
NR_MAC_SUBHEADER_SHORT
*
)
mac_pdu_subheader_ptr
)
->
L
=
(
uint8_t
*
)
Buffer_size_ptr
-
(
uint8_t
*
)
mac_ce
;
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : long_bsr size %d Lcgbit 0x%02x Buffer_size %d %d %d %d %d %d %d %d
\n
"
,
mac_ce_size
,
*
((
uint8_t
*
)
mac_ce
),
LOG_D
(
NR_MAC
,
"[UE] Generating ULSCH PDU : long_bsr size %d Lcgbit 0x%02x Buffer_size %d %d %d %d %d %d %d %d
\n
"
,
mac_ce_size
,
*
((
uint8_t
*
)
mac_ce
),
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size0
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size1
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size2
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size3
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size0
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size1
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size2
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size3
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size4
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size5
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size6
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size7
);
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size4
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size5
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size6
,
((
NR_BSR_LONG
*
)
mac_ce
)
->
Buffer_size7
);
...
...
openair2/LAYER2/NR_MAC_UE/nr_ue_scheduler.c
View file @
c7c1cb2d
...
@@ -64,6 +64,12 @@
...
@@ -64,6 +64,12 @@
static
void
nr_ue_prach_scheduler
(
NR_UE_MAC_INST_t
*
mac
,
frame_t
frameP
,
sub_frame_t
slotP
);
static
void
nr_ue_prach_scheduler
(
NR_UE_MAC_INST_t
*
mac
,
frame_t
frameP
,
sub_frame_t
slotP
);
static
void
schedule_ta_command
(
fapi_nr_dl_config_request_t
*
dl_config
,
NR_UL_TIME_ALIGNMENT_t
*
ul_time_alignment
);
static
void
schedule_ta_command
(
fapi_nr_dl_config_request_t
*
dl_config
,
NR_UL_TIME_ALIGNMENT_t
*
ul_time_alignment
);
static
void
nr_ue_fill_phr
(
NR_UE_MAC_INST_t
*
mac
,
NR_SINGLE_ENTRY_PHR_MAC_CE
*
phr
,
float
P_CMAX
,
float
tx_power
,
frame_t
frameP
,
sub_frame_t
subframe
);
void
clear_ul_config_request
(
NR_UE_MAC_INST_t
*
mac
,
int
scs
)
void
clear_ul_config_request
(
NR_UE_MAC_INST_t
*
mac
,
int
scs
)
{
{
...
@@ -176,6 +182,21 @@ void update_mac_timers(NR_UE_MAC_INST_t *mac)
...
@@ -176,6 +182,21 @@ void update_mac_timers(NR_UE_MAC_INST_t *mac)
AssertFatal
(
!
nr_timer_tick
(
&
mac
->
scheduling_info
.
lc_sched_info
[
i
].
Bj_timer
),
AssertFatal
(
!
nr_timer_tick
(
&
mac
->
scheduling_info
.
lc_sched_info
[
i
].
Bj_timer
),
"Bj timer for LCID %d expired! That should never happen
\n
"
,
"Bj timer for LCID %d expired! That should never happen
\n
"
,
i
);
i
);
nr_phr_info_t
*
phr_info
=
&
mac
->
scheduling_info
.
phr_info
;
if
(
phr_info
->
is_configured
)
{
bool
prohibit_expired
=
nr_timer_tick
(
&
phr_info
->
prohibitPHR_Timer
);
if
(
prohibit_expired
)
{
int16_t
pathloss
=
compute_nr_SSB_PL
(
mac
,
mac
->
ssb_measurements
.
ssb_rsrp_dBm
);
if
(
abs
(
pathloss
-
phr_info
->
PathlossLastValue
)
>
phr_info
->
PathlossChange_db
)
{
phr_info
->
phr_reporting
|=
(
1
<<
phr_cause_prohibit_timer
);
}
}
bool
periodic_expired
=
nr_timer_tick
(
&
phr_info
->
periodicPHR_Timer
);
if
(
periodic_expired
)
{
phr_info
->
phr_reporting
|=
(
1
<<
phr_cause_periodic_timer
);
}
}
}
}
void
remove_ul_config_last_item
(
fapi_nr_ul_config_request_pdu_t
*
pdu
)
void
remove_ul_config_last_item
(
fapi_nr_ul_config_request_pdu_t
*
pdu
)
...
@@ -942,6 +963,16 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac,
...
@@ -942,6 +963,16 @@ int nr_config_pusch_pdu(NR_UE_MAC_INST_t *mac,
return
-
1
;
return
-
1
;
}
}
// 38.321 5.4.6
// if it is the first UL resource allocated for a new transmission since the last MAC reset:
// 2> start phr-PeriodicTimer;
if
(
mac
->
scheduling_info
.
phr_info
.
is_configured
)
{
if
(
mac
->
scheduling_info
.
phr_info
.
was_mac_reset
&&
pusch_config_pdu
->
pusch_data
.
new_data_indicator
)
{
mac
->
scheduling_info
.
phr_info
.
was_mac_reset
=
false
;
nr_timer_start
(
&
mac
->
scheduling_info
.
phr_info
.
periodicPHR_Timer
);
}
}
return
0
;
return
0
;
}
}
...
@@ -1185,7 +1216,6 @@ static bool nr_ue_periodic_srs_scheduling(NR_UE_MAC_INST_t *mac, frame_t frame,
...
@@ -1185,7 +1216,6 @@ static bool nr_ue_periodic_srs_scheduling(NR_UE_MAC_INST_t *mac, frame_t frame,
// Performs :
// Performs :
// 1. TODO: Call RRC for link status return to PHY
// 1. TODO: Call RRC for link status return to PHY
// 2. TODO: Perform SR/BSR procedures for scheduling feedback
// 2. TODO: Perform SR/BSR procedures for scheduling feedback
// 3. TODO: Perform PHR procedures
void
nr_ue_dl_scheduler
(
NR_UE_MAC_INST_t
*
mac
,
nr_downlink_indication_t
*
dl_info
)
void
nr_ue_dl_scheduler
(
NR_UE_MAC_INST_t
*
mac
,
nr_downlink_indication_t
*
dl_info
)
{
{
frame_t
rx_frame
=
dl_info
->
frame
;
frame_t
rx_frame
=
dl_info
->
frame
;
...
@@ -1422,10 +1452,24 @@ void nr_ue_ul_scheduler(NR_UE_MAC_INST_t *mac, nr_uplink_indication_t *ul_info)
...
@@ -1422,10 +1452,24 @@ void nr_ue_ul_scheduler(NR_UE_MAC_INST_t *mac, nr_uplink_indication_t *ul_info)
if
(
ulcfg_pdu
->
pusch_config_pdu
.
pusch_data
.
new_data_indicator
if
(
ulcfg_pdu
->
pusch_config_pdu
.
pusch_data
.
new_data_indicator
&&
(
mac
->
state
==
UE_CONNECTED
||
(
ra
->
ra_state
==
nrRA_WAIT_RAR
&&
ra
->
cfra
)))
{
&&
(
mac
->
state
==
UE_CONNECTED
||
(
ra
->
ra_state
==
nrRA_WAIT_RAR
&&
ra
->
cfra
)))
{
// Getting IP traffic to be transmitted
// Getting IP traffic to be transmitted
nr_ue_get_sdu
(
mac
,
cc_id
,
frame_tx
,
slot_tx
,
gNB_index
,
ulsch_input_buffer
,
TBS_bytes
);
int
tx_power
=
ulcfg_pdu
->
pusch_config_pdu
.
tx_power
;
ulcfg_pdu
->
pusch_config_pdu
.
tx_request_body
.
fapiTxPdu
=
ulsch_input_buffer
;
int
P_CMAX
=
nr_get_Pcmax
(
mac
->
p_Max
,
ulcfg_pdu
->
pusch_config_pdu
.
tx_request_body
.
pdu_length
=
TBS_bytes
;
mac
->
nr_band
,
number_of_pdus
++
;
mac
->
frame_type
,
mac
->
frequency_range
,
mac
->
current_UL_BWP
->
channel_bandwidth
,
ulcfg_pdu
->
pusch_config_pdu
.
qam_mod_order
,
false
,
mac
->
current_UL_BWP
->
scs
,
mac
->
current_UL_BWP
->
BWPSize
,
ulcfg_pdu
->
pusch_config_pdu
.
transform_precoding
,
ulcfg_pdu
->
pusch_config_pdu
.
rb_size
,
ulcfg_pdu
->
pusch_config_pdu
.
rb_start
);
nr_ue_get_sdu
(
mac
,
cc_id
,
frame_tx
,
slot_tx
,
gNB_index
,
ulsch_input_buffer
,
TBS_bytes
,
tx_power
,
P_CMAX
);
ulcfg_pdu
->
pusch_config_pdu
.
tx_request_body
.
fapiTxPdu
=
ulsch_input_buffer
;
ulcfg_pdu
->
pusch_config_pdu
.
tx_request_body
.
pdu_length
=
TBS_bytes
;
number_of_pdus
++
;
}
}
}
}
...
@@ -2735,6 +2779,7 @@ typedef struct {
...
@@ -2735,6 +2779,7 @@ typedef struct {
NR_BSR_SHORT
*
bsr_s
;
NR_BSR_SHORT
*
bsr_s
;
NR_BSR_LONG
*
bsr_l
;
NR_BSR_LONG
*
bsr_l
;
NR_BSR_SHORT
*
bsr_t
;
NR_BSR_SHORT
*
bsr_t
;
NR_SINGLE_ENTRY_PHR_MAC_CE
*
phr
;
//NR_POWER_HEADROOM_CMD *phr_pr;
//NR_POWER_HEADROOM_CMD *phr_pr;
int
tot_mac_ce_len
;
int
tot_mac_ce_len
;
uint8_t
total_mac_pdu_header_len
;
uint8_t
total_mac_pdu_header_len
;
...
@@ -2758,12 +2803,13 @@ static int nr_ue_get_sdu_mac_ce_pre(NR_UE_MAC_INST_t *mac,
...
@@ -2758,12 +2803,13 @@ static int nr_ue_get_sdu_mac_ce_pre(NR_UE_MAC_INST_t *mac,
uint8_t
gNB_index
,
uint8_t
gNB_index
,
uint8_t
*
ulsch_buffer
,
uint8_t
*
ulsch_buffer
,
uint32_t
buflen
,
uint32_t
buflen
,
int16_t
tx_power
,
int16_t
P_CMAX
,
NR_UE_MAC_CE_INFO
*
mac_ce_p
)
NR_UE_MAC_CE_INFO
*
mac_ce_p
)
{
{
int
num_lcg_id_with_data
=
0
;
int
num_lcg_id_with_data
=
0
;
// Preparing the MAC CEs sub-PDUs and get the total size
// Preparing the MAC CEs sub-PDUs and get the total size
mac_ce_p
->
bsr_header_len
=
0
;
mac_ce_p
->
bsr_header_len
=
0
;
mac_ce_p
->
phr_header_len
=
0
;
//sizeof(SCH_SUBHEADER_FIXED);
int
lcg_id
=
0
;
int
lcg_id
=
0
;
while
(
lcg_id
!=
NR_INVALID_LCGID
)
{
while
(
lcg_id
!=
NR_INVALID_LCGID
)
{
if
(
mac
->
scheduling_info
.
lcg_sched_info
[
lcg_id
].
BSR_bytes
)
{
if
(
mac
->
scheduling_info
.
lcg_sched_info
[
lcg_id
].
BSR_bytes
)
{
...
@@ -2794,8 +2840,23 @@ static int nr_ue_get_sdu_mac_ce_pre(NR_UE_MAC_INST_t *mac,
...
@@ -2794,8 +2840,23 @@ static int nr_ue_get_sdu_mac_ce_pre(NR_UE_MAC_INST_t *mac,
}
}
}
}
}
}
mac_ce_p
->
bsr_len
=
mac_ce_p
->
bsr_ce_len
+
mac_ce_p
->
bsr_header_len
;
mac_ce_p
->
bsr_len
=
mac_ce_p
->
bsr_ce_len
+
mac_ce_p
->
bsr_header_len
;
nr_phr_info_t
*
phr_info
=
&
mac
->
scheduling_info
.
phr_info
;
mac_ce_p
->
phr_header_len
=
0
;
mac_ce_p
->
phr_ce_len
=
0
;
if
(
phr_info
->
is_configured
&&
phr_info
->
phr_reporting
>
0
)
{
if
(
buflen
>=
(
mac_ce_p
->
bsr_len
+
sizeof
(
NR_MAC_SUBHEADER_FIXED
)
+
sizeof
(
NR_SINGLE_ENTRY_PHR_MAC_CE
)))
{
if
(
mac
->
scheduling_info
.
phr_info
.
phr_reporting
)
{
mac_ce_p
->
phr_header_len
=
sizeof
(
NR_MAC_SUBHEADER_FIXED
);
mac_ce_p
->
phr_ce_len
=
sizeof
(
NR_SINGLE_ENTRY_PHR_MAC_CE
);
nr_ue_fill_phr
(
mac
,
mac_ce_p
->
phr
,
P_CMAX
,
tx_power
,
frameP
,
subframe
);
}
}
}
mac_ce_p
->
phr_len
=
mac_ce_p
->
phr_header_len
+
mac_ce_p
->
phr_ce_len
;
return
(
mac_ce_p
->
bsr_len
+
mac_ce_p
->
phr_len
);
return
(
mac_ce_p
->
bsr_len
+
mac_ce_p
->
phr_len
);
}
}
...
@@ -3234,7 +3295,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
...
@@ -3234,7 +3295,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
slot_t
slot
,
slot_t
slot
,
uint8_t
gNB_index
,
uint8_t
gNB_index
,
uint8_t
*
ulsch_buffer
,
uint8_t
*
ulsch_buffer
,
uint32_t
buflen
)
uint32_t
buflen
,
int16_t
tx_power
,
int16_t
P_CMAX
)
{
{
NR_UE_MAC_CE_INFO
mac_ce_info
;
NR_UE_MAC_CE_INFO
mac_ce_info
;
NR_UE_MAC_CE_INFO
*
mac_ce_p
=&
mac_ce_info
;
NR_UE_MAC_CE_INFO
*
mac_ce_p
=&
mac_ce_info
;
...
@@ -3253,8 +3316,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
...
@@ -3253,8 +3316,9 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
mac_ce_p
->
bsr_s
=
&
bsr_short
;
mac_ce_p
->
bsr_s
=
&
bsr_short
;
mac_ce_p
->
bsr_l
=
&
bsr_long
;
mac_ce_p
->
bsr_l
=
&
bsr_long
;
mac_ce_p
->
bsr_t
=
&
bsr_truncated
;
mac_ce_p
->
bsr_t
=
&
bsr_truncated
;
//NR_POWER_HEADROOM_CMD phr;
//mac_ce_p->phr_p = &phr;
NR_SINGLE_ENTRY_PHR_MAC_CE
phr
;
mac_ce_p
->
phr
=
&
phr
;
//int highest_priority = 16;
//int highest_priority = 16;
const
uint8_t
sh_size
=
sizeof
(
NR_MAC_SUBHEADER_LONG
);
const
uint8_t
sh_size
=
sizeof
(
NR_MAC_SUBHEADER_LONG
);
...
@@ -3273,7 +3337,7 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
...
@@ -3273,7 +3337,7 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
// because as per standard(TS38.321), all equal priority channels should be served equally
// because as per standard(TS38.321), all equal priority channels should be served equally
// nr_ue_get_sdu_mac_ce_pre updates all mac_ce related header field related to length
// nr_ue_get_sdu_mac_ce_pre updates all mac_ce related header field related to length
mac_ce_p
->
tot_mac_ce_len
=
nr_ue_get_sdu_mac_ce_pre
(
mac
,
CC_id
,
frame
,
slot
,
gNB_index
,
ulsch_buffer
,
buflen
,
mac_ce_p
);
mac_ce_p
->
tot_mac_ce_len
=
nr_ue_get_sdu_mac_ce_pre
(
mac
,
CC_id
,
frame
,
slot
,
gNB_index
,
ulsch_buffer
,
buflen
,
tx_power
,
P_CMAX
,
mac_ce_p
);
mac_ce_p
->
total_mac_pdu_header_len
=
mac_ce_p
->
tot_mac_ce_len
;
mac_ce_p
->
total_mac_pdu_header_len
=
mac_ce_p
->
tot_mac_ce_len
;
LOG_D
(
NR_MAC
,
"[UE %d] [%d.%d] process UL transport block at with size TBS = %d bytes
\n
"
,
mac
->
ue_id
,
frame
,
slot
,
buflen
);
LOG_D
(
NR_MAC
,
"[UE %d] [%d.%d] process UL transport block at with size TBS = %d bytes
\n
"
,
mac
->
ue_id
,
frame
,
slot
,
buflen
);
...
@@ -3373,9 +3437,8 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
...
@@ -3373,9 +3437,8 @@ uint8_t nr_ue_get_sdu(NR_UE_MAC_INST_t *mac,
nr_ue_get_sdu_mac_ce_post
(
mac
,
frame
,
slot
,
ulsch_buffer
,
buflen
,
mac_ce_p
);
nr_ue_get_sdu_mac_ce_post
(
mac
,
frame
,
slot
,
ulsch_buffer
,
buflen
,
mac_ce_p
);
if
(
mac_ce_p
->
tot_mac_ce_len
>
0
)
{
if
(
mac_ce_p
->
tot_mac_ce_len
>
0
)
{
LOG_D
(
NR_MAC
,
"In %s copying %d bytes of MAC CEs to the UL PDU
\n
"
,
__FUNCTION__
,
mac_ce_p
->
tot_mac_ce_len
);
LOG_D
(
NR_MAC
,
"In %s copying %d bytes of MAC CEs to the UL PDU
\n
"
,
__FUNCTION__
,
mac_ce_p
->
tot_mac_ce_len
);
int
size
=
nr_write_ce_ulsch_pdu
(
pdu
,
mac
,
0
,
NULL
,
mac_ce_p
->
bsr_t
,
mac_ce_p
->
bsr_s
,
mac_ce_p
->
bsr_l
);
int
size
=
nr_write_ce_ulsch_pdu
(
pdu
,
mac
,
mac_ce_p
->
phr_ce_len
?
mac_ce_p
->
phr
:
NULL
,
0
,
mac_ce_p
->
bsr_t
,
mac_ce_p
->
bsr_s
,
mac_ce_p
->
bsr_l
);
if
(
size
!=
mac_ce_p
->
tot_mac_ce_len
)
if
(
size
!=
mac_ce_p
->
tot_mac_ce_len
)
LOG_E
(
NR_MAC
,
"MAC CE size computed by nr_write_ce_ulsch_pdu is %d while the one assumed before is %d
\n
"
,
size
,
mac_ce_p
->
tot_mac_ce_len
);
LOG_E
(
NR_MAC
,
"MAC CE size computed by nr_write_ce_ulsch_pdu is %d while the one assumed before is %d
\n
"
,
size
,
mac_ce_p
->
tot_mac_ce_len
);
pdu
+=
(
unsigned
char
)
mac_ce_p
->
tot_mac_ce_len
;
pdu
+=
(
unsigned
char
)
mac_ce_p
->
tot_mac_ce_len
;
...
@@ -3436,3 +3499,42 @@ static void schedule_ta_command(fapi_nr_dl_config_request_t *dl_config, NR_UL_TI
...
@@ -3436,3 +3499,42 @@ static void schedule_ta_command(fapi_nr_dl_config_request_t *dl_config, NR_UL_TI
dl_config
->
number_pdus
+=
1
;
dl_config
->
number_pdus
+=
1
;
ul_time_alignment
->
ta_apply
=
no_ta
;
ul_time_alignment
->
ta_apply
=
no_ta
;
}
}
static
void
nr_ue_fill_phr
(
NR_UE_MAC_INST_t
*
mac
,
NR_SINGLE_ENTRY_PHR_MAC_CE
*
phr
,
float
P_CMAX
,
float
tx_power
,
frame_t
frameP
,
sub_frame_t
subframe
)
{
nr_phr_info_t
*
phr_info
=
&
mac
->
scheduling_info
.
phr_info
;
// Value mapping according to 38.133 10.1.18.1
const
int
PC_MAX_00
=
-
29
;
phr
->
PCMAX
=
max
(
0
,
(
int
)
P_CMAX
-
PC_MAX_00
)
&
0x3f
;
// Value mapping according to 38.133 10.1.17.1.1
const
int
POWER_HEADROOM_55
=
22
;
int
headroom
=
P_CMAX
-
tx_power
;
if
(
headroom
<
POWER_HEADROOM_55
)
{
const
int
POWER_HEADROOM_0
=
-
32
;
phr
->
PH
=
max
(
0
,
headroom
-
POWER_HEADROOM_0
);
}
else
{
phr
->
PH
=
min
(
0x3f
,
55
+
(
headroom
-
POWER_HEADROOM_55
)
/
2
);
}
LOG_D
(
NR_MAC
,
"PHR Reporting sfn.subframe %d.%d reason = %d, P_CMAX = %d (%5.2f dBm), headrom = %d (%d dB) tx_power = %5.2f dBm
\n
"
,
frameP
,
subframe
,
phr_info
->
phr_reporting
,
phr
->
PCMAX
,
P_CMAX
,
phr
->
PH
,
headroom
,
tx_power
);
phr_info
->
PathlossLastValue
=
compute_nr_SSB_PL
(
mac
,
mac
->
ssb_measurements
.
ssb_rsrp_dBm
);
// Restart both timers according to 38.321
nr_timer_start
(
&
phr_info
->
periodicPHR_Timer
);
nr_timer_start
(
&
phr_info
->
prohibitPHR_Timer
);
phr_info
->
phr_reporting
=
0
;
}
openair2/LAYER2/NR_MAC_gNB/gNB_scheduler_ulsch.c
View file @
c7c1cb2d
...
@@ -331,8 +331,16 @@ static int nr_process_mac_pdu(instance_t module_idP,
...
@@ -331,8 +331,16 @@ static int nr_process_mac_pdu(instance_t module_idP,
sched_ctrl
->
ph0
=
PH
;
sched_ctrl
->
ph0
=
PH
;
/* 38.133 Table10.1.18.1-1 */
/* 38.133 Table10.1.18.1-1 */
sched_ctrl
->
pcmax
=
PCMAX
-
29
;
sched_ctrl
->
pcmax
=
PCMAX
-
29
;
LOG_D
(
NR_MAC
,
"SINGLE ENTRY PHR R1 %d PH %d (%d dB) R2 %d PCMAX %d (%d dBm)
\n
"
,
LOG_D
(
NR_MAC
,
phr
->
R1
,
PH
,
sched_ctrl
->
ph
,
phr
->
R2
,
PCMAX
,
sched_ctrl
->
pcmax
);
"SINGLE ENTRY PHR %d.%d R1 %d PH %d (%d dB) R2 %d PCMAX %d (%d dBm)
\n
"
,
frameP
,
slot
,
phr
->
R1
,
PH
,
sched_ctrl
->
ph
,
phr
->
R2
,
PCMAX
,
sched_ctrl
->
pcmax
);
break
;
break
;
case
UL_SCH_LCID_MULTI_ENTRY_PHR_1_OCT
:
case
UL_SCH_LCID_MULTI_ENTRY_PHR_1_OCT
:
...
...
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