@ -295,11 +295,12 @@ void mac::rl_ok(uint16_t rnti)
}
}
}
}
int mac : : ack_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, uint32_t tb_idx , bool ack )
int mac : : ack_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, uint32_t tb_idx , bool ack )
{
{
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
uint32_t nof_bytes = scheduler . dl_ack_info ( tti , rnti , cc_idx , tb_idx , ack ) ;
if ( ue_db . count ( rnti ) ) {
uint32_t nof_bytes = scheduler . dl_ack_info ( tti , rnti , enb_cc_idx , tb_idx , ack ) ;
ue_db [ rnti ] - > metrics_tx ( ack , nof_bytes ) ;
ue_db [ rnti ] - > metrics_tx ( ack , nof_bytes ) ;
if ( ack ) {
if ( ack ) {
@ -308,93 +309,104 @@ int mac::ack_info(uint32_t tti, uint16_t rnti, uint32_t cc_idx, uint32_t tb_idx,
log_h - > debug ( " DL activity rnti=0x%x, n_bytes=%d \n " , rnti , nof_bytes ) ;
log_h - > debug ( " DL activity rnti=0x%x, n_bytes=%d \n " , rnti , nof_bytes ) ;
}
}
}
}
return 0 ;
}
return SRSLTE_SUCCESS ;
}
}
int mac : : crc_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, uint32_t nof_bytes , bool crc )
int mac : : crc_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, uint32_t nof_bytes , bool crc )
{
{
int ret = SRSLTE_ERROR ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
int ret = - 1 ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
ue_db [ rnti ] - > set_tti ( tti ) ;
ue_db [ rnti ] - > set_tti ( tti ) ;
ue_db [ rnti ] - > metrics_rx ( crc , nof_bytes ) ;
ue_db [ rnti ] - > metrics_rx ( crc , nof_bytes ) ;
uint32_t ue_cc_idx = 0 ; // FIXME: mapping between eNB->UE CC idx
// push the pdu through the queue if received correctly
// push the pdu through the queue if received correctly
if ( crc ) {
if ( crc ) {
Info ( " Pushing PDU rnti=%d, tti=%d, nof_bytes=%d \n " , rnti , tti , nof_bytes ) ;
Info ( " Pushing PDU rnti=%d, tti=%d, nof_bytes=%d \n " , rnti , tti , nof_bytes ) ;
ue_db [ rnti ] - > push_pdu ( tti, nof_bytes ) ;
ue_db [ rnti ] - > push_pdu ( ue_cc_idx, tti, nof_bytes ) ;
stack_task_queue . push ( [ this ] ( ) { process_pdus ( ) ; } ) ;
stack_task_queue . push ( [ this ] ( ) { process_pdus ( ) ; } ) ;
} else {
} else {
ue_db [ rnti ] - > deallocate_pdu ( tti) ;
ue_db [ rnti ] - > deallocate_pdu ( ue_cc_idx, tti) ;
}
}
ret = scheduler . ul_crc_info ( tti , rnti , cc_idx, crc ) ;
ret = scheduler . ul_crc_info ( tti , rnti , ue_ cc_idx, crc ) ;
} else {
} else {
Error ( " User rnti=0x%x not found \n " , rnti ) ;
Error ( " User rnti=0x%x not found \n " , rnti ) ;
}
}
return ret ;
return ret ;
}
}
int mac : : ri_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, uint32_t ri_value )
int mac : : ri_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, uint32_t ri_value )
{
{
int ret = SRSLTE_ERROR ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
int ret = - 1 ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
scheduler . dl_ri_info ( tti , rnti , cc_idx, ri_value ) ;
scheduler . dl_ri_info ( tti , rnti , enb_ cc_idx, ri_value ) ;
ue_db [ rnti ] - > metrics_dl_ri ( ri_value ) ;
ue_db [ rnti ] - > metrics_dl_ri ( ri_value ) ;
ret = 0 ;
ret = SRSLTE_SUCCESS ;
} else {
} else {
Error ( " User rnti=0x%x not found \n " , rnti ) ;
Error ( " User rnti=0x%x not found \n " , rnti ) ;
}
}
return ret ;
return ret ;
}
}
int mac : : pmi_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, uint32_t pmi_value )
int mac : : pmi_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, uint32_t pmi_value )
{
{
int ret = SRSLTE_ERROR ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
int ret = - 1 ;
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
scheduler . dl_pmi_info ( tti , rnti , cc_idx, pmi_value ) ;
scheduler . dl_pmi_info ( tti , rnti , enb_ cc_idx, pmi_value ) ;
ue_db [ rnti ] - > metrics_dl_pmi ( pmi_value ) ;
ue_db [ rnti ] - > metrics_dl_pmi ( pmi_value ) ;
ret = 0 ;
ret = SRSLTE_SUCCESS ;
} else {
} else {
Error ( " User rnti=0x%x not found \n " , rnti ) ;
Error ( " User rnti=0x%x not found \n " , rnti ) ;
}
}
return ret ;
return ret ;
}
}
int mac : : cqi_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, uint32_t cqi_value )
int mac : : cqi_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, uint32_t cqi_value )
{
{
int ret = SRSLTE_ERROR ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
int ret = - 1 ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
scheduler . dl_cqi_info ( tti , rnti , cc_idx, cqi_value ) ;
scheduler . dl_cqi_info ( tti , rnti , enb_ cc_idx, cqi_value ) ;
ue_db [ rnti ] - > metrics_dl_cqi ( cqi_value ) ;
ue_db [ rnti ] - > metrics_dl_cqi ( cqi_value ) ;
ret = 0 ;
ret = SRSLTE_SUCCESS ;
} else {
} else {
Error ( " User rnti=0x%x not found \n " , rnti ) ;
Error ( " User rnti=0x%x not found \n " , rnti ) ;
}
}
return ret ;
return ret ;
}
}
int mac : : snr_info ( uint32_t tti , uint16_t rnti , uint32_t cc_idx, float snr )
int mac : : snr_info ( uint32_t tti , uint16_t rnti , uint32_t enb_ cc_idx, float snr )
{
{
int ret = SRSLTE_ERROR ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
int ret = - 1 ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
uint32_t cqi = srslte_cqi_from_snr ( snr ) ;
uint32_t cqi = srslte_cqi_from_snr ( snr ) ;
scheduler . ul_cqi_info ( tti , rnti , cc_idx, cqi , 0 ) ;
scheduler . ul_cqi_info ( tti , rnti , enb_ cc_idx, cqi , 0 ) ;
ret = 0 ;
ret = SRSLTE_SUCCESS ;
} else {
} else {
Error ( " User rnti=0x%x not found \n " , rnti ) ;
Error ( " User rnti=0x%x not found \n " , rnti ) ;
}
}
return ret ;
return ret ;
}
}
@ -491,7 +503,7 @@ int mac::get_dl_sched(uint32_t tti, dl_sched_list_t& dl_sched_res_list)
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
for ( uint32_t enb_cc_idx = 0 ; enb_cc_idx < = cell_config . size ( ) ; enb_cc_idx + + ) {
for ( uint32_t enb_cc_idx = 0 ; enb_cc_idx < cell_config . size ( ) ; enb_cc_idx + + ) {
// Run scheduler with current info
// Run scheduler with current info
sched_interface : : dl_sched_res_t sched_result = { } ;
sched_interface : : dl_sched_res_t sched_result = { } ;
if ( scheduler . dl_sched ( tti , enb_cc_idx , sched_result ) < 0 ) {
if ( scheduler . dl_sched ( tti , enb_cc_idx , sched_result ) < 0 ) {
@ -516,7 +528,7 @@ int mac::get_dl_sched(uint32_t tti, dl_sched_list_t& dl_sched_res_list)
dl_sched_res - > pdsch [ n ] . dci = sched_result . data [ i ] . dci ;
dl_sched_res - > pdsch [ n ] . dci = sched_result . data [ i ] . dci ;
for ( uint32_t tb = 0 ; tb < SRSLTE_MAX_TB ; tb + + ) {
for ( uint32_t tb = 0 ; tb < SRSLTE_MAX_TB ; tb + + ) {
dl_sched_res - > pdsch [ n ] . softbuffer_tx [ tb ] = ue_db [ rnti ] - > get_tx_softbuffer ( sched_result . data [ i ] . dci . pid, tb ) ;
dl_sched_res - > pdsch [ n ] . softbuffer_tx [ tb ] = ue_db [ rnti ] - > get_tx_softbuffer ( sched_result . data [ i ] . dci . ue_cc_idx, sched_result . data [ i ] . dci . pid, tb ) ;
if ( sched_result . data [ i ] . nof_pdu_elems [ tb ] > 0 ) {
if ( sched_result . data [ i ] . nof_pdu_elems [ tb ] > 0 ) {
/* Get PDU if it's a new transmission */
/* Get PDU if it's a new transmission */
@ -739,9 +751,9 @@ uint8_t* mac::assemble_rar(sched_interface::dl_sched_rar_grant_t* grants,
}
}
}
}
uint8_t * mac : : assemble_si ( const uint8_t cc_idx, const uint32_t sib_index )
uint8_t * mac : : assemble_si ( const uint8_t enb_ cc_idx, const uint32_t sib_index )
{
{
uint8_t * sib_payload = rrc_h - > read_pdu_bcch_dlsch ( cc_idx, sib_index ) ;
uint8_t * sib_payload = rrc_h - > read_pdu_bcch_dlsch ( enb_ cc_idx, sib_index ) ;
if ( sib_payload = = nullptr ) {
if ( sib_payload = = nullptr ) {
// return MAC managed dummy buffer in this case
// return MAC managed dummy buffer in this case
sib_payload = bcch_dlsch_payload ;
sib_payload = bcch_dlsch_payload ;
@ -751,16 +763,18 @@ uint8_t* mac::assemble_si(const uint8_t cc_idx, const uint32_t sib_index)
int mac : : get_ul_sched ( uint32_t tti , ul_sched_list_t & ul_sched_res_list )
int mac : : get_ul_sched ( uint32_t tti , ul_sched_list_t & ul_sched_res_list )
{
{
ul_sched_t * ul_sched_res = & ul_sched_res_list [ 0 ] ;
log_h - > step ( tti ) ;
log_h - > step ( tti ) ;
if ( ! started ) {
if ( ! started ) {
return 0 ;
return SRSLTE_SUCCESS ;
}
}
for ( uint32_t enb_cc_idx = 0 ; enb_cc_idx < cell_config . size ( ) ; enb_cc_idx + + ) {
ul_sched_t * phy_ul_sched_res = & ul_sched_res_list [ enb_cc_idx ] ;
// Run scheduler with current info
// Run scheduler with current info
sched_interface : : ul_sched_res_t sched_result = { } ;
sched_interface : : ul_sched_res_t sched_result = { } ;
if ( scheduler . ul_sched ( tti , 0 , sched_result ) < 0 ) {
if ( scheduler . ul_sched ( tti , enb_cc_idx , sched_result ) < 0 ) {
Error ( " Running scheduler \n " ) ;
Error ( " Running scheduler \n " ) ;
return SRSLTE_ERROR ;
return SRSLTE_ERROR ;
}
}
@ -769,7 +783,7 @@ int mac::get_ul_sched(uint32_t tti, ul_sched_list_t& ul_sched_res_list)
srslte : : rwlock_read_guard lock ( rwlock ) ;
srslte : : rwlock_read_guard lock ( rwlock ) ;
// Copy DCI grants
// Copy DCI grants
ul_sched_res- > nof_grants = 0 ;
phy_ ul_sched_res- > nof_grants = 0 ;
int n = 0 ;
int n = 0 ;
for ( uint32_t i = 0 ; i < sched_result . nof_dci_elems ; i + + ) {
for ( uint32_t i = 0 ; i < sched_result . nof_dci_elems ; i + + ) {
@ -779,16 +793,17 @@ int mac::get_ul_sched(uint32_t tti, ul_sched_list_t& ul_sched_res_list)
if ( ue_db . count ( rnti ) ) {
if ( ue_db . count ( rnti ) ) {
// Copy grant info
// Copy grant info
ul_sched_res- > pusch [ n ] . current_tx_nb = sched_result . pusch [ i ] . current_tx_nb ;
phy_ ul_sched_res- > pusch [ n ] . current_tx_nb = sched_result . pusch [ i ] . current_tx_nb ;
ul_sched_res- > pusch [ n ] . needs_pdcch = sched_result . pusch [ i ] . needs_pdcch ;
phy_ ul_sched_res- > pusch [ n ] . needs_pdcch = sched_result . pusch [ i ] . needs_pdcch ;
ul_sched_res- > pusch [ n ] . dci = sched_result . pusch [ i ] . dci ;
phy_ ul_sched_res- > pusch [ n ] . dci = sched_result . pusch [ i ] . dci ;
ul_sched_res- > pusch [ n ] . softbuffer_rx = ue_db [ rnti ] - > get_rx_softbuffer ( tti ) ;
phy_ ul_sched_res- > pusch [ n ] . softbuffer_rx =
ue_db [ rnti ] - > get_rx_softbuffer ( sched_result . pusch [ i ] . dci . ue_cc_idx , tti ) ;
if ( sched_result . pusch [ n ] . current_tx_nb = = 0 ) {
if ( sched_result . pusch [ n ] . current_tx_nb = = 0 ) {
srslte_softbuffer_rx_reset_tbs ( ul_sched_res- > pusch [ n ] . softbuffer_rx , sched_result . pusch [ i ] . tbs * 8 ) ;
srslte_softbuffer_rx_reset_tbs ( phy_ ul_sched_res- > pusch [ n ] . softbuffer_rx , sched_result . pusch [ i ] . tbs * 8 ) ;
}
}
ul_sched_res - > pusch [ n ] . data = ue_db [ rnti ] - > request_buffer ( tti , sched_result . pusch [ i ] . tbs ) ;
phy_ul_sched_res - > pusch [ n ] . data =
ul_sched_res - > nof_grants + + ;
ue_db [ rnti ] - > request_buffer ( sched_result . pusch [ i ] . dci . ue_cc_idx , tti , sched_result . pusch [ i ] . tbs ) ;
phy_ul_sched_res - > nof_grants + + ;
n + + ;
n + + ;
} else {
} else {
Warning ( " Invalid UL scheduling result. User 0x%x does not exist \n " , rnti ) ;
Warning ( " Invalid UL scheduling result. User 0x%x does not exist \n " , rnti ) ;
@ -804,10 +819,11 @@ int mac::get_ul_sched(uint32_t tti, ul_sched_list_t& ul_sched_res_list)
// Copy PHICH actions
// Copy PHICH actions
for ( uint32_t i = 0 ; i < sched_result . nof_phich_elems ; i + + ) {
for ( uint32_t i = 0 ; i < sched_result . nof_phich_elems ; i + + ) {
ul_sched_res - > phich [ i ] . ack = sched_result . phich [ i ] . phich = = sched_interface : : ul_sched_phich_t : : ACK ;
phy_ul_sched_res - > phich [ i ] . ack = sched_result . phich [ i ] . phich = = sched_interface : : ul_sched_phich_t : : ACK ;
ul_sched_res - > phich [ i ] . rnti = sched_result . phich [ i ] . rnti ;
phy_ul_sched_res - > phich [ i ] . rnti = sched_result . phich [ i ] . rnti ;
}
phy_ul_sched_res - > nof_phich = sched_result . nof_phich_elems ;
}
}
ul_sched_res - > nof_phich = sched_result . nof_phich_elems ;
return SRSLTE_SUCCESS ;
return SRSLTE_SUCCESS ;
}
}