Added mutex to phch_common

master
Ismael Gomez 7 years ago
parent a75604eb0e
commit 9a5e29ccab

@ -155,6 +155,8 @@ private:
uint32_t nof_mutex; uint32_t nof_mutex;
uint32_t max_mutex; uint32_t max_mutex;
pthread_mutex_t user_mutex;
phy_interface_rrc::phy_cfg_mbsfn_t mbsfn; phy_interface_rrc::phy_cfg_mbsfn_t mbsfn;
bool sib13_configured; bool sib13_configured;
bool mcch_configured; bool mcch_configured;

@ -57,7 +57,7 @@ bool phch_common::init(srslte_cell_t *cell_, srslte::radio* radio_h_, mac_interf
mac = mac_; mac = mac_;
memcpy(&cell, cell_, sizeof(srslte_cell_t)); memcpy(&cell, cell_, sizeof(srslte_cell_t));
pthread_mutex_init(&user_mutex, NULL);
is_first_of_burst = true; is_first_of_burst = true;
is_first_tx = true; is_first_tx = true;
@ -107,80 +107,110 @@ void phch_common::ue_db_clear(uint32_t sf_idx)
void phch_common::ue_db_add_rnti(uint16_t rnti) void phch_common::ue_db_add_rnti(uint16_t rnti)
{ {
pthread_mutex_lock(&user_mutex);
for (int sf_idx=0;sf_idx<TTIMOD_SZ;sf_idx++) { for (int sf_idx=0;sf_idx<TTIMOD_SZ;sf_idx++) {
for (uint32_t tb_idx = 0; tb_idx < SRSLTE_MAX_TB; tb_idx++) { for (uint32_t tb_idx = 0; tb_idx < SRSLTE_MAX_TB; tb_idx++) {
common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = false; common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = false;
} }
} }
pthread_mutex_unlock(&user_mutex);
} }
void phch_common::ue_db_rem_rnti(uint16_t rnti) void phch_common::ue_db_rem_rnti(uint16_t rnti)
{ {
pthread_mutex_lock(&user_mutex);
common_ue_db.erase(rnti); common_ue_db.erase(rnti);
pthread_mutex_unlock(&user_mutex);
} }
void phch_common::ue_db_set_ack_pending(uint32_t sf_idx, uint16_t rnti, uint32_t tb_idx, uint32_t last_n_pdcch) void phch_common::ue_db_set_ack_pending(uint32_t sf_idx, uint16_t rnti, uint32_t tb_idx, uint32_t last_n_pdcch)
{ {
pthread_mutex_lock(&user_mutex);
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = true; common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = true;
common_ue_db[rnti].pending_ack.n_pdcch[sf_idx] = (uint16_t) last_n_pdcch; common_ue_db[rnti].pending_ack.n_pdcch[sf_idx] = (uint16_t) last_n_pdcch;
} }
pthread_mutex_unlock(&user_mutex);
} }
bool phch_common::ue_db_is_ack_pending(uint32_t sf_idx, uint16_t rnti, uint32_t tb_idx, uint32_t *last_n_pdcch) { bool phch_common::ue_db_is_ack_pending(uint32_t sf_idx, uint16_t rnti, uint32_t tb_idx, uint32_t *last_n_pdcch)
{
bool ret = false;
pthread_mutex_lock(&user_mutex);
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
bool ret = common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx]; ret = common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx];
common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = false; common_ue_db[rnti].pending_ack.is_pending[sf_idx][tb_idx] = false;
if (ret && last_n_pdcch) { if (ret && last_n_pdcch) {
*last_n_pdcch = common_ue_db[rnti].pending_ack.n_pdcch[sf_idx]; *last_n_pdcch = common_ue_db[rnti].pending_ack.n_pdcch[sf_idx];
} }
return ret;
} else {
return false;
} }
pthread_mutex_unlock(&user_mutex);
return ret;
} }
void phch_common::ue_db_set_ri(uint16_t rnti, uint8_t ri) { void phch_common::ue_db_set_ri(uint16_t rnti, uint8_t ri) {
pthread_mutex_lock(&user_mutex);
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
common_ue_db[rnti].ri = ri; common_ue_db[rnti].ri = ri;
} }
pthread_mutex_unlock(&user_mutex);
} }
uint8_t phch_common::ue_db_get_ri(uint16_t rnti) {
uint8_t phch_common::ue_db_get_ri(uint16_t rnti)
{
pthread_mutex_lock(&user_mutex);
uint8_t ret = 0; uint8_t ret = 0;
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
ret = common_ue_db[rnti].ri; ret = common_ue_db[rnti].ri;
} }
pthread_mutex_unlock(&user_mutex);
return ret; return ret;
} }
void phch_common::ue_db_set_last_ul_mod(uint16_t rnti, uint32_t tti, srslte_mod_t mcs) {
void phch_common::ue_db_set_last_ul_mod(uint16_t rnti, uint32_t tti, srslte_mod_t mcs)
{
pthread_mutex_lock(&user_mutex);
if (!common_ue_db.count(rnti)) { if (!common_ue_db.count(rnti)) {
ue_db_add_rnti(rnti); ue_db_add_rnti(rnti);
} }
common_ue_db[rnti].last_ul_mod[TTI_RX(tti)%(2*HARQ_DELAY_MS)] = mcs; common_ue_db[rnti].last_ul_mod[TTI_RX(tti)%(2*HARQ_DELAY_MS)] = mcs;
pthread_mutex_unlock(&user_mutex);
} }
srslte_mod_t phch_common::ue_db_get_last_ul_mod(uint16_t rnti, uint32_t tti) {
srslte_mod_t phch_common::ue_db_get_last_ul_mod(uint16_t rnti, uint32_t tti)
{
pthread_mutex_lock(&user_mutex);
srslte_mod_t ret = SRSLTE_MOD_BPSK; srslte_mod_t ret = SRSLTE_MOD_BPSK;
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
ret = common_ue_db[rnti].last_ul_mod[TTI_RX(tti)%(2*HARQ_DELAY_MS)]; ret = common_ue_db[rnti].last_ul_mod[TTI_RX(tti)%(2*HARQ_DELAY_MS)];
} }
return ret; return ret;
pthread_mutex_unlock(&user_mutex);
} }
void phch_common::ue_db_set_last_ul_tbs(uint16_t rnti, uint32_t tti, int tbs) {
void phch_common::ue_db_set_last_ul_tbs(uint16_t rnti, uint32_t tti, int tbs)
{
pthread_mutex_lock(&user_mutex);
if (!common_ue_db.count(rnti)) { if (!common_ue_db.count(rnti)) {
ue_db_add_rnti(rnti); ue_db_add_rnti(rnti);
} }
common_ue_db[rnti].last_ul_tbs[TTI_RX(tti)%(2*HARQ_DELAY_MS)] = tbs; common_ue_db[rnti].last_ul_tbs[TTI_RX(tti)%(2*HARQ_DELAY_MS)] = tbs;
pthread_mutex_unlock(&user_mutex);
} }
int phch_common::ue_db_get_last_ul_tbs(uint16_t rnti, uint32_t tti) { int phch_common::ue_db_get_last_ul_tbs(uint16_t rnti, uint32_t tti) {
int ret = -1; int ret = -1;
pthread_mutex_lock(&user_mutex);
if (common_ue_db.count(rnti)) { if (common_ue_db.count(rnti)) {
ret = common_ue_db[rnti].last_ul_tbs[TTI_RX(tti)%(2*HARQ_DELAY_MS)]; ret = common_ue_db[rnti].last_ul_tbs[TTI_RX(tti)%(2*HARQ_DELAY_MS)];
} }
pthread_mutex_unlock(&user_mutex);
return ret; return ret;
} }
void phch_common::configure_mbsfn(phy_interface_rrc::phy_cfg_mbsfn_t *cfg) {
void phch_common::configure_mbsfn(phy_interface_rrc::phy_cfg_mbsfn_t *cfg)
{
memcpy(&mbsfn, cfg, sizeof(phy_interface_rrc::phy_cfg_mbsfn_t)); memcpy(&mbsfn, cfg, sizeof(phy_interface_rrc::phy_cfg_mbsfn_t));
build_mch_table(); build_mch_table();
@ -189,8 +219,8 @@ void phch_common::configure_mbsfn(phy_interface_rrc::phy_cfg_mbsfn_t *cfg) {
mcch_configured = true; mcch_configured = true;
} }
void phch_common::build_mch_table()
void phch_common::build_mch_table() { {
// First reset tables // First reset tables
bzero(&mch_table[0], sizeof(uint8_t)*40); bzero(&mch_table[0], sizeof(uint8_t)*40);
// 40 element table represents 4 frames (40 subframes) // 40 element table represents 4 frames (40 subframes)
@ -203,7 +233,8 @@ void phch_common::build_mch_table() {
} }
} }
void phch_common::build_mcch_table() { void phch_common::build_mcch_table()
{
bzero(&mcch_table[0], sizeof(uint8_t)*10); bzero(&mcch_table[0], sizeof(uint8_t)*10);
generate_mcch_table(&mcch_table[0], mbsfn.mbsfn_area_info.sf_alloc_info_r9); generate_mcch_table(&mcch_table[0], mbsfn.mbsfn_area_info.sf_alloc_info_r9);
@ -215,8 +246,6 @@ void phch_common::build_mcch_table() {
} }
} }
bool phch_common::is_mcch_subframe(subframe_cfg_t *cfg, uint32_t phy_tti) bool phch_common::is_mcch_subframe(subframe_cfg_t *cfg, uint32_t phy_tti)
{ {
uint32_t sfn; // System Frame Number uint32_t sfn; // System Frame Number
@ -245,6 +274,7 @@ bool phch_common::is_mcch_subframe(subframe_cfg_t *cfg, uint32_t phy_tti)
} }
return false; return false;
} }
bool phch_common::is_mch_subframe(subframe_cfg_t *cfg, uint32_t phy_tti) bool phch_common::is_mch_subframe(subframe_cfg_t *cfg, uint32_t phy_tti)
{ {
uint32_t sfn; // System Frame Number uint32_t sfn; // System Frame Number

Loading…
Cancel
Save