Commit 0b7452a6 authored by Michael Cook's avatar Michael Cook

Merge branch 'episys/Initial_ChannelModel' into 'episys/master'

Episys/initial channel model

See merge request aburger/openairinterface5g!21
parents 0b40edef b2f85f7a
...@@ -50,6 +50,8 @@ queue_t hi_dci0_req_queue; ...@@ -50,6 +50,8 @@ queue_t hi_dci0_req_queue;
int current_sfn_sf; int current_sfn_sf;
sem_t sfn_semaphore; sem_t sfn_semaphore;
static sf_rnti_mcs_s sf_rnti_mcs[10];
static int ue_tx_sock_descriptor = -1; static int ue_tx_sock_descriptor = -1;
static int ue_rx_sock_descriptor = -1; static int ue_rx_sock_descriptor = -1;
...@@ -293,7 +295,7 @@ void fill_ulsch_cqi_indication_UE_MAC(int Mod_id, ...@@ -293,7 +295,7 @@ void fill_ulsch_cqi_indication_UE_MAC(int Mod_id,
pdu->ul_cqi_information.channel = 1; pdu->ul_cqi_information.channel = 1;
// eNB_scheduler_primitives.c:4839: the upper four bits seem to be the CQI // eNB_scheduler_primitives.c:4839: the upper four bits seem to be the CQI
const int cqi = 15; const int cqi = 15; // Need to map EMANE SINR to CQI!
raw_pdu->pdu[0] = cqi << 4; raw_pdu->pdu[0] = cqi << 4;
UL_INFO->cqi_ind.cqi_indication_body.number_of_cqis++; UL_INFO->cqi_ind.cqi_indication_body.number_of_cqis++;
...@@ -373,7 +375,7 @@ void fill_uci_harq_indication_UE_MAC(int Mod_id, ...@@ -373,7 +375,7 @@ void fill_uci_harq_indication_UE_MAC(int Mod_id,
pdu->ul_cqi_information.tl.tag = NFAPI_UL_CQI_INFORMATION_TAG; pdu->ul_cqi_information.tl.tag = NFAPI_UL_CQI_INFORMATION_TAG;
int SNRtimes10 = 640; int SNRtimes10 = 640; // TODO: Replace with EpiSci SNR * 10
if (SNRtimes10 < -640) if (SNRtimes10 < -640)
pdu->ul_cqi_information.ul_cqi = 0; pdu->ul_cqi_information.ul_cqi = 0;
...@@ -402,6 +404,12 @@ void fill_uci_harq_indication_UE_MAC(int Mod_id, ...@@ -402,6 +404,12 @@ void fill_uci_harq_indication_UE_MAC(int Mod_id,
// go look to see if dl_config_req (with c-rnti) was received in subframe (n - 4) // go look to see if dl_config_req (with c-rnti) was received in subframe (n - 4)
// 3.) if the answer to #2 is yes then send ACK IF NOT send DTX // 3.) if the answer to #2 is yes then send ACK IF NOT send DTX
if (drop_tb((subframe+6) % 10, rnti)) // TODO: Handle DTX. Also discuss handling PDCCH
{
pdu->harq_indication_fdd_rel13.harq_tb_n[0] = 2;
LOG_I(PHY, "Setting HARQ No ACK - Channel Model\n");
}
} else if ((harq_information->harq_information_rel9_fdd.ack_nack_mode == 0) } else if ((harq_information->harq_information_rel9_fdd.ack_nack_mode == 0)
&& (harq_information->harq_information_rel9_fdd.harq_size && (harq_information->harq_information_rel9_fdd.harq_size
== 2)) { == 2)) {
...@@ -791,10 +799,18 @@ void dl_config_req_UE_MAC_dci(int sfn, ...@@ -791,10 +799,18 @@ void dl_config_req_UE_MAC_dci(int sfn,
sfn, sf, dci->pdu_size, sfn, sf, dci->pdu_size,
dlsch->dlsch_pdu.dlsch_pdu_rel8.pdu_index, dlsch->dlsch_pdu.dlsch_pdu_rel8.pdu_index,
tx_req_pdu_list->num_pdus); tx_req_pdu_list->num_pdus);
ue_send_sdu(ue_id, 0, sfn, sf,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data, if (!drop_tb(sf, dci->dci_dl_pdu.dci_dl_pdu_rel8.rnti))
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length, {
0); ue_send_sdu(ue_id, 0, sfn, sf,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length,
0);
}
else
{
LOG_I(MAC, "Transport Block discarded - ue_send_sdu not called. sf: %d", sf);
}
return; return;
} }
} }
...@@ -804,17 +820,33 @@ void dl_config_req_UE_MAC_dci(int sfn, ...@@ -804,17 +820,33 @@ void dl_config_req_UE_MAC_dci(int sfn,
if (UE_mac_inst[ue_id].UE_mode[0] == NOT_SYNCHED) if (UE_mac_inst[ue_id].UE_mode[0] == NOT_SYNCHED)
continue; continue;
ue_decode_si(ue_id, 0, sfn, 0, if (!drop_tb(sf, dci->dci_dl_pdu.dci_dl_pdu_rel8.rnti))
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data, {
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length); ue_decode_si(ue_id, 0, sfn, 0,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length);
}
else
{
LOG_I(MAC, "Transport Block discarded - ue_decode_si not called. sf: %d", sf);
}
} }
} else if (rnti == 0xFFFE) { /* PI-RNTI */ } else if (rnti == 0xFFFE) { /* PI-RNTI */
for (int ue_id = 0; ue_id < num_ue; ue_id++) { for (int ue_id = 0; ue_id < num_ue; ue_id++) {
LOG_I(MAC, "%s() Received paging message: sfn/sf:%d.%d\n", LOG_I(MAC, "%s() Received paging message: sfn/sf:%d.%d\n",
__func__, sfn, sf); __func__, sfn, sf);
ue_decode_p(ue_id, 0, sfn, 0,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length); if (!drop_tb(sf, dci->dci_dl_pdu.dci_dl_pdu_rel8.rnti))
{
ue_decode_p(ue_id, 0, sfn, 0,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_length);
}
else
{
LOG_I(MAC, "Transport Block discarded - ue_decode_p not called. sf: %d", sf);
}
} }
} else if (rnti == 0x0002) { /* RA-RNTI */ } else if (rnti == 0x0002) { /* RA-RNTI */
for (int ue_id = 0; ue_id < num_ue; ue_id++) { for (int ue_id = 0; ue_id < num_ue; ue_id++) {
...@@ -834,12 +866,21 @@ void dl_config_req_UE_MAC_dci(int sfn, ...@@ -834,12 +866,21 @@ void dl_config_req_UE_MAC_dci(int sfn,
LOG_E(MAC, LOG_E(MAC,
"%s(): Received RAR, PreambleIndex: %d\n", "%s(): Received RAR, PreambleIndex: %d\n",
__func__, UE_mac_inst[ue_id].RA_prach_resources.ra_PreambleIndex); __func__, UE_mac_inst[ue_id].RA_prach_resources.ra_PreambleIndex);
ue_process_rar(ue_id, 0, sfn,
ra_rnti, //RA-RNTI
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data, if (!drop_tb(sf, dci->dci_dl_pdu.dci_dl_pdu_rel8.rnti))
&UE_mac_inst[ue_id].crnti, //t-crnti {
UE_mac_inst[ue_id].RA_prach_resources.ra_PreambleIndex, ue_process_rar(ue_id, 0, sfn,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data); ra_rnti, //RA-RNTI
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data,
&UE_mac_inst[ue_id].crnti, //t-crnti
UE_mac_inst[ue_id].RA_prach_resources.ra_PreambleIndex,
tx_req_pdu_list->pdus[pdu_index].segments[0].segment_data);
}
else
{
LOG_I(MAC, "Transport Block discarded - RAR Not Processed. sf: %d, ra_rnti: %d", sf, ra_rnti);
}
// UE_mac_inst[ue_id].UE_mode[0] = RA_RESPONSE; // UE_mac_inst[ue_id].UE_mode[0] = RA_RESPONSE;
LOG_I(MAC, "setting UE_MODE now: %d\n", UE_mac_inst[ue_id].UE_mode[0]); LOG_I(MAC, "setting UE_MODE now: %d\n", UE_mac_inst[ue_id].UE_mode[0]);
// Expecting an UL_CONFIG_ULSCH_PDU to enable Msg3 Txon (first // Expecting an UL_CONFIG_ULSCH_PDU to enable Msg3 Txon (first
...@@ -1251,7 +1292,6 @@ void *ue_standalone_pnf_task(void *context) ...@@ -1251,7 +1292,6 @@ void *ue_standalone_pnf_task(void *context)
struct sockaddr_in server_address; struct sockaddr_in server_address;
socklen_t addr_len = sizeof(server_address); socklen_t addr_len = sizeof(server_address);
char buffer[1024]; char buffer[1024];
int sd = ue_rx_sock_descriptor; int sd = ue_rx_sock_descriptor;
assert(sd > 0); assert(sd > 0);
...@@ -1280,6 +1320,26 @@ void *ue_standalone_pnf_task(void *context) ...@@ -1280,6 +1320,26 @@ void *ue_standalone_pnf_task(void *context)
abort(); abort();
} }
} }
else if (len == sizeof(channel_info))
{
LOG_I(MAC, "Entered Channel Info Loop");
channel_info * ch_info = malloc(sizeof(channel_info));
memcpy(ch_info, buffer, sizeof(channel_info));
current_sfn_sf = ch_info->sfn_sf;
if (sem_post(&sfn_semaphore) != 0)
{
LOG_E(MAC, "sem_post() error\n");
abort();
}
uint16_t sf = ch_info->sfn_sf & 15;
if(sf > 10 && sf < 0)
{
LOG_E(MAC, "sf out of bounds, sfn: %d\n", sf);
abort();
}
sf_rnti_mcs[sf].sinr = ch_info->sinr;
}
else else
{ {
nfapi_p7_message_header_t header; nfapi_p7_message_header_t header;
...@@ -1318,6 +1378,7 @@ void *ue_standalone_pnf_task(void *context) ...@@ -1318,6 +1378,7 @@ void *ue_standalone_pnf_task(void *context)
tx_req_valid = false; tx_req_valid = false;
break; break;
} }
read_channel_param(&dl_config_req, (dl_config_req.sfn_sf & 15));
enqueue_dl_config_req_tx_req(&dl_config_req, &tx_req); enqueue_dl_config_req_tx_req(&dl_config_req, &tx_req);
dl_config_req_valid = false; dl_config_req_valid = false;
tx_req_valid = false; tx_req_valid = false;
...@@ -1865,3 +1926,112 @@ char *nfapi_ul_config_req_to_string(nfapi_ul_config_request_t *req) ...@@ -1865,3 +1926,112 @@ char *nfapi_ul_config_req_to_string(nfapi_ul_config_request_t *req)
void init_eNB_afterRU(void) void init_eNB_afterRU(void)
{ {
} }
void read_channel_param(nfapi_dl_config_request_t * dl_config, int sf)
{
if (dl_config == NULL)
{
LOG_E(MAC,"DL_CONFIG NULL\n");
abort();
}
// Store all rnti and mcs for all pdus
sf_rnti_mcs[sf].pdu_size = dl_config->dl_config_request_body.number_pdu;
for (int n = 0; n < sf_rnti_mcs[sf].pdu_size; n++)
{
sf_rnti_mcs[sf].rnti[n] = dl_config->dl_config_request_body.dl_config_pdu_list[n].dci_dl_pdu.dci_dl_pdu_rel8.rnti;
sf_rnti_mcs[sf].mcs[n] = dl_config->dl_config_request_body.dl_config_pdu_list[n].dci_dl_pdu.dci_dl_pdu_rel8.mcs_1;
}
}
int drop_tb(int sf, uint16_t rnti)
{
int sinr_index = 0;
bool lin_interp = false;
bool skip_search = false;
assert(sf < 10 && sf >= 0);
uint8_t mcs = 99;
for (int n = 0; n < sf_rnti_mcs[sf].pdu_size; n++)
{
if (sf_rnti_mcs[sf].rnti[n] == rnti)
{
mcs = sf_rnti_mcs[sf].mcs[n];
break;
}
}
if (mcs == 99)
{
LOG_E(MAC, "NO MCS Found\n");
abort();
}
// Loop through bler table to find sinr_index - What if EMANE SINR doesn't match any of the table SINR values??
//float epsilon = 0.0001;
int temp_bler = 0;
int temp_sinr = ((int)(sf_rnti_mcs[sf].sinr * 10));
int i;
float bler_val = 0.0;
if (temp_sinr < (int)(bler_data[mcs].bler_table[0][0] * 10))
{
skip_search = true;
bler_val = 0.0;
}
else if (temp_sinr > (int)(bler_data[mcs].bler_table[bler_data[mcs].length - 1][0] * 10))
{
skip_search = true;
bler_val = 1.0;
}
for (i = 0; i < bler_data[mcs].length; i++)
{
if(skip_search)
break;
temp_bler = (int)(bler_data[mcs].bler_table[i][0] * 10);
if (temp_bler == temp_sinr)
{
sinr_index = i;
break;
}
// Linear interpolation when SINR is between indices
else if (temp_bler > temp_sinr)
{
sinr_index = i;
lin_interp = true;
break;
}
}
if (i >= (bler_data[mcs].length - 1))
{
LOG_E(MAC, "NO SINR INDEX FOUND! - mcs: %d, temp_sinr: %d, temp_bler: %d, sinr_index: %d\n", mcs, temp_sinr, temp_bler, sinr_index);
abort();
}
if (lin_interp)
{
bler_val = ((bler_data[mcs].bler_table[sinr_index - 1][3] + bler_data[mcs].bler_table[sinr_index][3]) / 2);
}
else
{
if (skip_search == false)
bler_val = bler_data[mcs].bler_table[sinr_index][3]; // 3 is the rate, or bler rate column
}
double drop_cutoff = ((double) rand() / (RAND_MAX));
assert(drop_cutoff < 1);
if (bler_val <= drop_cutoff)
{
return 1;
}
else
{
return 0;
}
}
...@@ -21,6 +21,10 @@ ...@@ -21,6 +21,10 @@
//#include "openair1/PHY/LTE_TRANSPORT/defs.h" //#include "openair1/PHY/LTE_TRANSPORT/defs.h"
#include "queue.h" #include "queue.h"
#define NUM_MCS 28
#define NUM_SINR 100
#define NUM_BLER_COL 13
// this mutex is used to set multiple UE's UL value in L2 FAPI simulator. // this mutex is used to set multiple UE's UL value in L2 FAPI simulator.
FILL_UL_INFO_MUTEX_t fill_ul_mutex; FILL_UL_INFO_MUTEX_t fill_ul_mutex;
//below 2 difinitions move to phy_stub_UE.c to add initialization when difinition. //below 2 difinitions move to phy_stub_UE.c to add initialization when difinition.
...@@ -34,6 +38,30 @@ extern UL_IND_t *UL_INFO; ...@@ -34,6 +38,30 @@ extern UL_IND_t *UL_INFO;
//module_id_t next_Mod_id; //module_id_t next_Mod_id;
eth_params_t stub_eth_params; eth_params_t stub_eth_params;
typedef struct
{
uint16_t sfn_sf;
float sinr;
// Incomplete, need all channel parameters
} channel_info;
typedef struct
{
uint8_t sf;
uint16_t rnti[256];
uint8_t mcs[256];
float sinr;
uint16_t pdu_size;
} sf_rnti_mcs_s;
typedef struct
{
uint16_t length;
float bler_table[NUM_SINR][NUM_BLER_COL];
} bler_struct;
extern bler_struct bler_data[NUM_MCS];
...@@ -171,6 +199,9 @@ char *nfapi_ul_config_req_to_string(nfapi_ul_config_request_t *req); ...@@ -171,6 +199,9 @@ char *nfapi_ul_config_req_to_string(nfapi_ul_config_request_t *req);
const char *dl_pdu_type_to_string(uint8_t pdu_type); const char *dl_pdu_type_to_string(uint8_t pdu_type);
const char *ul_pdu_type_to_string(uint8_t pdu_type); const char *ul_pdu_type_to_string(uint8_t pdu_type);
void read_channel_param(nfapi_dl_config_request_t * dl_config, int sf);
int drop_tb(int sf, uint16_t rnti);
extern queue_t dl_config_req_tx_req_queue; extern queue_t dl_config_req_tx_req_queue;
extern queue_t ul_config_req_queue; extern queue_t ul_config_req_queue;
extern queue_t hi_dci0_req_queue; extern queue_t hi_dci0_req_queue;
......
...@@ -212,4 +212,6 @@ extern void init_UE_standalone_thread(int ue_idx); ...@@ -212,4 +212,6 @@ extern void init_UE_standalone_thread(int ue_idx);
extern PHY_VARS_UE *init_ue_vars(LTE_DL_FRAME_PARMS *frame_parms, uint8_t UE_id, uint8_t abstraction_flag); extern PHY_VARS_UE *init_ue_vars(LTE_DL_FRAME_PARMS *frame_parms, uint8_t UE_id, uint8_t abstraction_flag);
extern void init_bler_table(void);
#endif #endif
...@@ -194,6 +194,8 @@ int oaisim_flag=0; ...@@ -194,6 +194,8 @@ int oaisim_flag=0;
*/ */
uint8_t abstraction_flag=0; uint8_t abstraction_flag=0;
bler_struct bler_data[NUM_MCS];
/* forward declarations */ /* forward declarations */
void set_default_frame_parms(LTE_DL_FRAME_PARMS *frame_parms[MAX_NUM_CCs]); void set_default_frame_parms(LTE_DL_FRAME_PARMS *frame_parms[MAX_NUM_CCs]);
...@@ -749,6 +751,8 @@ int main( int argc, char **argv ) { ...@@ -749,6 +751,8 @@ int main( int argc, char **argv ) {
init_queue(&hi_dci0_req_queue); init_queue(&hi_dci0_req_queue);
init_queue(&ul_config_req_queue); init_queue(&ul_config_req_queue);
init_bler_table();
config_sync_var=0; config_sync_var=0;
if (sem_init(&sfn_semaphore, 0, 0) != 0) if (sem_init(&sfn_semaphore, 0, 0) != 0)
{ {
...@@ -837,3 +841,64 @@ int main( int argc, char **argv ) { ...@@ -837,3 +841,64 @@ int main( int argc, char **argv ) {
printf("Bye.\n"); printf("Bye.\n");
return 0; return 0;
} }
// Read in each MCS file and build BLER-SINR-TB table
void init_bler_table(void)
{
size_t bufSize = 128;
char fName[bufSize];
char * line = NULL;
char * token;
char * temp = NULL;
FILE *pFile;
char * home = getenv("HOME");
// Maybe not needed... and may not work.
memset(bler_data, 0, sizeof(bler_data));
for (unsigned int i = 0; i < NUM_MCS; i++)
{
// Filename needs to be changed to dynamic name
snprintf(fName, sizeof(fName), "%s/openairinterface5g/openair1/SIMULATION/LTE_PHY/BLER_SIMULATIONS/AWGN/AWGN_results/bler_tx1_chan18_nrx1_mcs%d.csv", home, i);
pFile = fopen(fName, "r");
if(!pFile)
{
LOG_E(MAC, "Bler File ERROR! - fopen(), file: %s\n", fName);
abort();
}
int nlines = 0;
while(getline(&line, &bufSize, pFile) > 0)
{
if (!strncmp(line,"SNR",3))
{
continue;
}
if (nlines > NUM_SINR)
{
LOG_E(MAC, "BLER FILE ERROR - num lines greater than expected - file: %s\n", fName);
abort();
}
token = strtok_r(line, ";", &temp);
int ncols = 0;
while (token != NULL)
{
if (ncols > NUM_BLER_COL)
{
LOG_E(MAC, "BLER FILE ERROR - num of cols greater than expected\n");
abort();
}
bler_data[i].bler_table[nlines][ncols] = strtof(token, NULL);
ncols++;
token = strtok_r(NULL, ";", &temp);
}
nlines++;
}
bler_data[i].length = nlines;
fclose(pFile);
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment