#include <thread>
#include <chrono>
+#include "viavi_connector.hpp"
+
using json = nlohmann::json;
using namespace std;
fprintf(stderr, "JSON Test\n");
+ uint8_t *nrcellid_buf = (uint8_t*)calloc(1,5);
+ nrcellid_buf[0] = 0x22;
+ nrcellid_buf[1] = 0x5B;
+ nrcellid_buf[2] = 0xD6;
+ nrcellid_buf[3] = 0x00;
+ nrcellid_buf[4] = 0x70;
+
+
asn_codec_ctx_t *opt_cod;
(E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
encode_kpm_function_description(ranfunc_desc);
- uint8_t e2smbuffer[8192];
+ uint8_t e2smbuffer[8192] = {0, };
size_t e2smbuffer_size = 8192;
asn_enc_rval_t er =
}
-void run_report_loop(long requestorId, long instanceId, long ranFunctionId, long actionId) {
+void get_cell_id(uint8_t *nrcellid_buf, char *cid_return_buf) {
+
+ uint8_t nr0 = nrcellid_buf[0] >> 4;
+ uint8_t nr1 = nrcellid_buf[0] << 4;
+ nr1 = nr1 >> 4;
- std::ifstream input("/playpen/src/reports.json");
- bool x = input.good();
+ uint8_t nr2 = nrcellid_buf[1] >> 4;
+ uint8_t nr3 = nrcellid_buf[1] << 4;
+ nr3 = nr3 >> 4;
- fprintf(stderr, "%s\n", x ? "true" : "false");
+ uint8_t nr4 = nrcellid_buf[2] >> 4;
+ uint8_t nr5 = nrcellid_buf[2] << 4;
+ nr5 = nr5 >> 4;
+
+ uint8_t nr6 = nrcellid_buf[3] >> 4;
+ uint8_t nr7 = nrcellid_buf[3] << 4;
+ nr7 = nr7 >> 4;
+
+ uint8_t nr8 = nrcellid_buf[4] >> 4;
+
+ sprintf(cid_return_buf, "373437%d%d%d%d%d%d%d%d%d", nr0,nr1,nr2,nr3,nr4,nr5,nr6,nr7,nr8);
+
+}
+
+void run_report_loop(long requestorId, long instanceId, long ranFunctionId, long actionId)
+{
+ std::filebuf reports_json;
+ std::streambuf *input_filebuf = &reports_json;
+
+ std::unique_ptr<viavi::RICTesterReceiver> viavi_connector;
+ if (!reports_json.open("/playpen/src/reports.json", std::ios::in)) {
+ std::cerr << "Can't open reports.json, enabling VIAVI connector instead..." << endl;
+ viavi_connector.reset(new viavi::RICTesterReceiver {3001, nullptr});
+ input_filebuf = viavi_connector->get_data_filebuf();
+ }
+
+ std::istream input {input_filebuf};
long seqNum = 1;
int nextRssinr;
float tput;
int prb_usage;
+ std::string ueId;
+
fprintf(stderr,"UE number %d\n", i);
+
+ json::json_pointer p001(std::string("/ueMeasReport/ueMeasReportList/") + std::to_string(i) +"/ue-id");
+ ueId = all_ues_json[p001].get<std::string>();
+ fprintf(stderr, "UEID %s\n", ueId.c_str());
json::json_pointer p0(std::string("/ueMeasReport/ueMeasReportList/") + std::to_string(i) +"/throughput");
tput = all_ues_json[p0].get<float>();
json::json_pointer p00(std::string("/ueMeasReport/ueMeasReportList/") + std::to_string(i) +"/prb_usage");
prb_usage = all_ues_json[p00].get<int>();
- fprintf(stderr, "Throughput %d\n", prb_usage);
+ fprintf(stderr, "Throughput %d\n", prb_usage);
json::json_pointer p1(std::string("/ueMeasReport/ueMeasReportList/") + std::to_string(i) +"/nrCellIdentity");
nextCellId = all_ues_json[p1].get<int>();
json::json_pointer p5(std::string("/ueMeasReport/ueMeasReportList/") + std::to_string(i) +"/neighbourCellList");
- uint8_t *crnti_buf = (uint8_t*)calloc(1,2);
-
- uint8_t *buf2 = (uint8_t*)"12";
- memcpy(crnti_buf, buf2, 2);
+ uint8_t crnti_buf[3] = {0, };
+
+ if (ueId.find("Pedestrian") != string::npos) {
+ std::string ind = ueId.substr(11);
+ fprintf(stderr, "ind is %s\n", ind.c_str());
+
+ int indval = std::stoi(ind);
+
+ if (indval < 10) {
+ crnti_buf[1] = indval;
+ crnti_buf[0] = 0;
+ } else {
+ crnti_buf[0] = indval/10;
+ crnti_buf[1] = indval % 10;
+ }
+
+ } else if (ueId.find("Car") != string::npos) {
+ crnti_buf[0] = 4;
+ crnti_buf[1] = 1;
+ }
+ // uint8_t *buf2 = (uint8_t*)"12";
std::string serving_str = "{\"rsrp\": " + std::to_string(nextRsrp) + ", \"rsrq\": " +
std::to_string(nextRsrq) + ", \"rssinr\": " + std::to_string(nextRssinr) + "}";
neighbor_str += ",";
}
+
+
+ uint8_t neighbor_cellid_buf[6] = {0, };
+ neighbor_cellid_buf[0] = 0x22;
+ neighbor_cellid_buf[1] = 0x5B;
+ neighbor_cellid_buf[2] = 0xD6;
+ neighbor_cellid_buf[3] = nextNbCell;
+ neighbor_cellid_buf[4] = 0x70;
+
+ char cid_buf[25] = {0, };
+ get_cell_id(neighbor_cellid_buf,cid_buf);
- neighbor_str += "{\"CID\" : \"" + std::to_string(nextNbCell) + "\", \"Cell-RF\" : \"{\"rsrp\": " + std::to_string(nextNbRsrp) +
+
+ neighbor_str += "{\"CID\" : \"" + std::string(cid_buf) + "\", \"Cell-RF\" : {\"rsrp\": " + std::to_string(nextNbRsrp) +
", \"rsrq\": " + std::to_string(nextNbRsrq) + ", \"rssinr\": " + std::to_string(nextNbRssinr) + "}}";
}
const uint8_t *neighbor_buf = reinterpret_cast<const uint8_t*>(neighbor_str.c_str());
- // uint8_t *nrcellid_buf = (uint8_t*)"12340";
- uint8_t *nrcellid_buf = (uint8_t*)calloc(1,5);
+
+ uint8_t nrcellid_buf[6] = {0, };
nrcellid_buf[0] = 0x22;
nrcellid_buf[1] = 0x5B;
nrcellid_buf[2] = 0xD6;
- nrcellid_buf[3] = 0x00;
+ nrcellid_buf[3] = nextCellId;
nrcellid_buf[4] = 0x70;
- uint8_t *gnbid_buf = (uint8_t*)calloc(1,3);
+ uint8_t gnbid_buf[4] = {0, };
gnbid_buf[0] = 0x22;
gnbid_buf[1] = 0x5B;
gnbid_buf[2] = 0xD6;
- uint8_t cuupid_buf[1];
+ uint8_t cuupid_buf[2] = {0, };
cuupid_buf[0] = 20000;
- uint8_t duid_buf[1];
+ uint8_t duid_buf[2] = {0, };
duid_buf[0] = 20000;
uint8_t *cuupname_buf = (uint8_t*)"GNBCUUP5";
encode_kpm_report_rancontainer_cucp_parameterized(ind_msg_cucp_ue, plmnid_buf, nrcellid_buf, crnti_buf, serving_buf, neighbor_buf);
- uint8_t e2sm_message_buf_cucp_ue[8192];
+ uint8_t e2sm_message_buf_cucp_ue[8192] = {0, };
size_t e2sm_message_buf_size_cucp_ue = 8192;
asn_codec_ctx_t *opt_cod;
ATS_ALIGNED_BASIC_PER,
&asn_DEF_E2SM_KPM_IndicationMessage,
ind_msg_cucp_ue, e2sm_message_buf_cucp_ue, e2sm_message_buf_size_cucp_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationMessage, ind_msg_cucp_ue);
fprintf(stderr, "er encded is %d\n", er_message_cucp_ue.encoded);
fprintf(stderr, "after encoding message\n");
fprintf(stderr, "Now printing xer outside of function call\n");
xer_fprint(stderr, &asn_DEF_E2SM_KPM_IndicationHeader, ind_header_cucp_ue);
- uint8_t e2sm_header_buf_cucp_ue[8192];
+ uint8_t e2sm_header_buf_cucp_ue[8192] = {0, };
size_t e2sm_header_buf_size_cucp_ue = 8192;
asn_enc_rval_t er_header_cucp_ue = asn_encode_to_buffer(opt_cod,
ATS_ALIGNED_BASIC_PER,
&asn_DEF_E2SM_KPM_IndicationHeader,
ind_header_cucp_ue, e2sm_header_buf_cucp_ue, e2sm_header_buf_size_cucp_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationHeader, ind_header_cucp_ue);
fprintf(stderr, "er encded is %d\n", er_header_cucp_ue.encoded);
fprintf(stderr, "error buf is %s\n", (char*)e2sm_header_buf_cucp_ue);
seqNum++;
- std::this_thread::sleep_for (std::chrono::seconds(2));
+ std::this_thread::sleep_for (std::chrono::milliseconds(50));
//Creating UE-level RAN-Container CUUP message
encode_kpm_report_rancontainer_cuup_parameterized(ind_msg_cuup_ue, plmnid_buf, nrcellid_buf, crnti_buf, bytes, 0);
- uint8_t e2sm_message_buf_cuup_ue[8192];
+ uint8_t e2sm_message_buf_cuup_ue[8192] = {0, };
size_t e2sm_message_buf_size_cuup_ue = 8192;
asn_codec_ctx_t *opt_cod2;
ATS_ALIGNED_BASIC_PER,
&asn_DEF_E2SM_KPM_IndicationMessage,
ind_msg_cuup_ue, e2sm_message_buf_cuup_ue, e2sm_message_buf_size_cuup_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationMessage, ind_msg_cuup_ue);
fprintf(stderr, "er encded is %d\n", er_message_cuup_ue.encoded);
fprintf(stderr, "after encoding message\n");
(E2SM_KPM_IndicationHeader_t*)calloc(1,sizeof(E2SM_KPM_IndicationHeader_t));
encode_e2sm_kpm_indication_header(ind_header_cuup_ue, plmnid_buf, sst_buf, sd_buf, fqival, qcival, nrcellid_buf, gnbid_buf, 0, cuupid_buf, duid_buf, cuupname_buf);
- uint8_t e2sm_header_buf_cuup_ue[8192];
+ uint8_t e2sm_header_buf_cuup_ue[8192] = {0, };
size_t e2sm_header_buf_size_cuup_ue = 8192;
asn_enc_rval_t er_header_cuup_ue = asn_encode_to_buffer(opt_cod,
ATS_ALIGNED_BASIC_PER,
&asn_DEF_E2SM_KPM_IndicationHeader,
ind_header_cuup_ue, e2sm_header_buf_cuup_ue, e2sm_header_buf_size_cuup_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationHeader, ind_header_cuup_ue);
E2AP_PDU *pdu_cuup_ue = (E2AP_PDU*)calloc(1,sizeof(E2AP_PDU));
seqNum++;
- std::this_thread::sleep_for (std::chrono::seconds(2));
+ std::this_thread::sleep_for (std::chrono::milliseconds(50));
//Creating UE-level RAN-Container DU message
encode_kpm_report_rancontainer_du_parameterized(ind_message_du_ue,
plmnid_buf, nrcellid_buf, crnti_buf, prb_usage, 0);
- uint8_t e2sm_message_buf_du_ue[8192];
+ uint8_t e2sm_message_buf_du_ue[8192] = {0, };
size_t e2sm_message_buf_size_du_ue = 8192;
asn_codec_ctx_t *opt_cod3;
ind_message_du_ue,
e2sm_message_buf_du_ue,
e2sm_message_buf_size_du_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationMessage, ind_message_du_ue);
fprintf(stderr, "er encded is %d\n", er_message_du_ue.encoded);
fprintf(stderr, "after encoding message\n");
(E2SM_KPM_IndicationHeader_t*)calloc(1,sizeof(E2SM_KPM_IndicationHeader_t));
encode_e2sm_kpm_indication_header(ind_header_du_ue, plmnid_buf, sst_buf, sd_buf, fqival, qcival, nrcellid_buf, gnbid_buf, 0, cuupid_buf, duid_buf, cuupname_buf);
- uint8_t e2sm_header_buf_du_ue[8192];
+ uint8_t e2sm_header_buf_du_ue[8192] = {0, };
size_t e2sm_header_buf_size_du_ue = 8192;
asn_enc_rval_t er_header_du_ue = asn_encode_to_buffer(opt_cod,
&asn_DEF_E2SM_KPM_IndicationHeader,
ind_header_du_ue, e2sm_header_buf_du_ue,
e2sm_header_buf_size_du_ue);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationHeader, ind_header_du_ue);
E2AP_PDU *pdu_du_ue = (E2AP_PDU*)calloc(1,sizeof(E2AP_PDU));
seqNum++;
- std::this_thread::sleep_for (std::chrono::seconds(2));
+ std::this_thread::sleep_for (std::chrono::milliseconds(50));
fprintf(stderr, "done with ue meas report\n");
}
float bytes_ul;
int prb_dl;
int prb_ul;
+ int cellid;
fprintf(stderr,"UE number %d\n", i);
+
+ json::json_pointer p00(std::string("/cellMeasReport/cellMeasReportList/") + std::to_string(i) +"/nrCellIdentity");
+ cellid = all_ues_json[p00].get<int>();
+ fprintf(stderr, "Cell ID %d\n", cellid);
json::json_pointer p0(std::string("/cellMeasReport/cellMeasReportList/") + std::to_string(i) +"/pdcpByteMeasReport/pdcpBytesDl");
bytes_dl = all_ues_json[p0].get<float>();
uint8_t *sd_buf = (uint8_t*)"100";
uint8_t *plmnid_buf = (uint8_t*)"747";
- uint8_t *nrcellid_buf = (uint8_t*)calloc(1,5);
+ uint8_t nrcellid_buf[6] = {0, };
nrcellid_buf[0] = 0x22;
nrcellid_buf[1] = 0x5B;
nrcellid_buf[2] = 0xD6;
- nrcellid_buf[3] = 0x00;
+ nrcellid_buf[3] = cellid;
nrcellid_buf[4] = 0x70;
- uint8_t *gnbid_buf = (uint8_t*)calloc(1,3);
+ uint8_t gnbid_buf[4] = {0, };
gnbid_buf[0] = 0x22;
gnbid_buf[1] = 0x5B;
gnbid_buf[2] = 0xD6;
- uint8_t cuupid_buf[1];
- cuupid_buf[0] = 200;
+ uint8_t cuupid_buf[2] = {0, };
+ cuupid_buf[0] = 20000;
- uint8_t duid_buf[1];
- duid_buf[0] = 300;
+ uint8_t duid_buf[2] = {0, };
+ duid_buf[0] = 20000;
uint8_t *cuupname_buf = (uint8_t*)"GNBCUUP5";
encode_kpm_report_style5_parameterized(ind_msg_style5 , cuupname_buf, bytes_dl, bytes_ul, sst_buf, sd_buf, plmnid_buf);
- uint8_t e2sm_message_buf_style5[8192];
+ uint8_t e2sm_message_buf_style5[8192] = {0, };
size_t e2sm_message_buf_size_style5 = 8192;
asn_enc_rval_t er_message_style5 = asn_encode_to_buffer(opt_cod,
ATS_ALIGNED_BASIC_PER,
&asn_DEF_E2SM_KPM_IndicationMessage,
ind_msg_style5, e2sm_message_buf_style5, e2sm_message_buf_size_style5);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationMessage, ind_msg_style5);
fprintf(stderr, "er encded is %d\n", er_message_style5.encoded);
fprintf(stderr, "after encoding message\n");
(E2SM_KPM_IndicationHeader_t*)calloc(1,sizeof(E2SM_KPM_IndicationHeader_t));
encode_e2sm_kpm_indication_header(ind_header_style5, plmnid_buf, sst_buf, sd_buf, fqival, qcival, nrcellid_buf, gnbid_buf, 0, cuupid_buf, duid_buf, cuupname_buf);
- uint8_t e2sm_header_buf_style5[8192];
+ uint8_t e2sm_header_buf_style5[8192] = {0, };
size_t e2sm_header_buf_size_style5 = 8192;
asn_enc_rval_t er_header_style5 = asn_encode_to_buffer(opt_cod,
&asn_DEF_E2SM_KPM_IndicationHeader,
ind_header_style5,
e2sm_header_buf_style5, e2sm_header_buf_size_style5);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationHeader, ind_header_style5);
encoding::generate_e2apv1_indication_request_parameterized(pdu_style5, requestorId,
seqNum++;
- std::this_thread::sleep_for (std::chrono::seconds(2));
+ std::this_thread::sleep_for (std::chrono::milliseconds(50));
//Encoding Style 1 Message Body
- long l_dl_prbs = prb_dl;
- long l_ul_prbs = prb_ul;
+ long *l_dl_prbs = (long*)calloc(1, sizeof(long));
+ long *l_ul_prbs = (long*)calloc(1, sizeof(long));
+ *l_dl_prbs = (long)prb_dl;
+ *l_ul_prbs = (long)prb_ul;
encode_kpm_report_style1_parameterized(ind_message_style1, fiveqi,
prb_dl, prb_ul, sst_buf, sd_buf,
- plmnid_buf, nrcellid_buf, &l_dl_prbs, &l_ul_prbs);
+ plmnid_buf, nrcellid_buf, l_dl_prbs, l_ul_prbs);
- uint8_t e2sm_message_buf_style1[8192];
+ uint8_t e2sm_message_buf_style1[8192] = {0, };
size_t e2sm_message_buf_size_style1 = 8192;
asn_enc_rval_t er_message_style1 = asn_encode_to_buffer(opt_cod2,
&asn_DEF_E2SM_KPM_IndicationMessage,
ind_message_style1,
e2sm_message_buf_style1, e2sm_message_buf_size_style1);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationMessage, ind_message_style1);
fprintf(stderr, "er encded is %d\n", er_message_style1.encoded);
fprintf(stderr, "after encoding message\n");
(E2SM_KPM_IndicationHeader_t*)calloc(1,sizeof(E2SM_KPM_IndicationHeader_t));
encode_e2sm_kpm_indication_header(ind_header_style1, plmnid_buf, sst_buf, sd_buf, fqival, qcival, nrcellid_buf, gnbid_buf, 0, cuupid_buf, duid_buf, cuupname_buf);
- uint8_t e2sm_header_buf_style1[8192];
+ uint8_t e2sm_header_buf_style1[8192] = {0, };
size_t e2sm_header_buf_size_style1 = 8192;
asn_enc_rval_t er_header_style1 = asn_encode_to_buffer(opt_cod,
&asn_DEF_E2SM_KPM_IndicationHeader,
ind_header_style1,
e2sm_header_buf_style1, e2sm_header_buf_size_style1);
+ ASN_STRUCT_FREE(asn_DEF_E2SM_KPM_IndicationHeader, ind_header_style1);
encoding::generate_e2apv1_indication_request_parameterized(pdu_style1, requestorId,
instanceId, ranFunctionId,
e2sim.encode_and_send_sctp_data(pdu_style1);
seqNum++;
- std::this_thread::sleep_for (std::chrono::seconds(2));
+ std::this_thread::sleep_for (std::chrono::milliseconds(50));
}
}