Standalone decoders for nas and rrc in asn1 test. Thanks Dirk

master
David Rupprecht 5 years ago committed by Andre Puschmann
parent 95bc7b48df
commit 4e283ec942

@ -59,3 +59,9 @@ if (ENABLE_5GNR)
target_link_libraries(ngap_asn1_test ngap_nr_asn1 srslte_common) target_link_libraries(ngap_asn1_test ngap_nr_asn1 srslte_common)
add_test(ngap_asn1_test ngap_asn1_test) add_test(ngap_asn1_test ngap_asn1_test)
endif(ENABLE_5GNR) endif(ENABLE_5GNR)
add_executable(rrc_asn1_decoder rrc_asn1_decoder.cc)
target_link_libraries(rrc_asn1_decoder rrc_asn1)
add_executable(nas_decoder nas_decoder.cc)
target_link_libraries(nas_decoder srslte_asn1)

@ -0,0 +1,286 @@
/*
Copyright 2013-2020 Software Radio Systems Limited
This file is part of srsLTE
srsLTE is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of
the License, or (at your option) any later version.
srsLTE is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
A copy of the GNU Affero General Public License can be found in
the LICENSE file in the top-level directory of this distribution
and at http://www.gnu.org/licenses/.
*/
#include "srslte/asn1/liblte_mme.h"
#include "srslte/common/common.h"
#include <fstream>
#include <iostream>
using namespace std;
int main(int argc, char** argv)
{
uint8 pd = 0;
uint8 msg_type = 0;
uint8 sec_hdr_type = 0;
ssize_t ret_in;
LIBLTE_BYTE_MSG_STRUCT msg;
LIBLTE_ERROR_ENUM err;
FILE* fd;
ZERO_OBJECT(msg);
if (argc < 2) {
printf("Please only call me with one parameter\n");
return 1;
}
fd = fopen(argv[1], "rb");
if (fd == NULL) {
printf("Error failed to open file %s\n", argv[1]);
return -1;
}
fseek(fd, 0, SEEK_END);
long fsize = ftell(fd);
fseek(fd, 0, SEEK_SET); /* same as rewind(f); */
if (fsize >= LIBLTE_MAX_MSG_SIZE_BYTES) {
printf("LIBLTE_MAX_MSG_SIZE_BYTES\n");
fclose(fd);
return -1;
}
size_t read_size = fread(msg.msg, 1, fsize, fd);
fclose(fd);
if (read_size != (size_t)fsize) {
printf("read_size != fsize\n");
return -1;
}
msg.N_bytes = fsize;
liblte_mme_parse_msg_header(&msg, &pd, &msg_type);
switch (msg_type) {
case LIBLTE_MME_MSG_TYPE_ATTACH_REQUEST:
LIBLTE_MME_ATTACH_REQUEST_MSG_STRUCT attach_req;
err = liblte_mme_unpack_attach_request_msg(&msg, &attach_req);
break;
case LIBLTE_MME_MSG_TYPE_ATTACH_ACCEPT:
LIBLTE_MME_ATTACH_ACCEPT_MSG_STRUCT attach_accept;
err = liblte_mme_unpack_attach_accept_msg(&msg, &attach_accept);
break;
case LIBLTE_MME_MSG_TYPE_ATTACH_COMPLETE:
LIBLTE_MME_ATTACH_COMPLETE_MSG_STRUCT attach_complete;
err = liblte_mme_unpack_attach_complete_msg(&msg, &attach_complete);
break;
case LIBLTE_MME_MSG_TYPE_ATTACH_REJECT:
LIBLTE_MME_ATTACH_REJECT_MSG_STRUCT attach_reject;
err = liblte_mme_unpack_attach_reject_msg(&msg, &attach_reject);
break;
case LIBLTE_MME_MSG_TYPE_DETACH_REQUEST:
LIBLTE_MME_DETACH_REQUEST_MSG_STRUCT detach_request;
err = liblte_mme_unpack_detach_request_msg(&msg, &detach_request);
break;
case LIBLTE_MME_MSG_TYPE_DETACH_ACCEPT:
LIBLTE_MME_DETACH_ACCEPT_MSG_STRUCT detach_accept;
err = liblte_mme_unpack_detach_accept_msg(&msg, &detach_accept);
break;
case LIBLTE_MME_MSG_TYPE_TRACKING_AREA_UPDATE_ACCEPT:
LIBLTE_MME_TRACKING_AREA_UPDATE_ACCEPT_MSG_STRUCT ta_update_accept;
err = liblte_mme_unpack_tracking_area_update_accept_msg(&msg, &ta_update_accept);
break;
case LIBLTE_MME_MSG_TYPE_TRACKING_AREA_UPDATE_REJECT:
LIBLTE_MME_TRACKING_AREA_UPDATE_REJECT_MSG_STRUCT ta_update_reject;
err = liblte_mme_unpack_tracking_area_update_reject_msg(&msg, &ta_update_reject);
break;
/* NOT IMPLEMENTED
case LIBLTE_MME_MSG_TYPE_TRACKING_AREA_UPDATE_REQUEST:
LIBLTE_MME_TRACKING_AREA_UPDATE_REQUEST_MSG_STRUCT ta_update_request;
err = liblte_mme_unpack_tracking_area_update_request_msg(&msg, &ta_update_request);
break;
*/
case LIBLTE_MME_MSG_TYPE_TRACKING_AREA_UPDATE_COMPLETE:
LIBLTE_MME_TRACKING_AREA_UPDATE_COMPLETE_MSG_STRUCT ta_update_complete;
err = liblte_mme_unpack_tracking_area_update_complete_msg(&msg, &ta_update_complete);
break;
case LIBLTE_MME_MSG_TYPE_EXTENDED_SERVICE_REQUEST:
LIBLTE_MME_EXTENDED_SERVICE_REQUEST_MSG_STRUCT ext_service;
err = liblte_mme_unpack_extended_service_request_msg(&msg, &ext_service);
break;
case LIBLTE_MME_MSG_TYPE_SERVICE_REJECT: // Service reject
LIBLTE_MME_SERVICE_REJECT_MSG_STRUCT service_reject;
err = liblte_mme_unpack_service_reject_msg(&msg, &service_reject);
break;
case LIBLTE_MME_MSG_TYPE_GUTI_REALLOCATION_COMMAND: // GUTI reallocation command
LIBLTE_MME_GUTI_REALLOCATION_COMMAND_MSG_STRUCT guti_realloc_cmd;
err = liblte_mme_unpack_guti_reallocation_command_msg(&msg, &guti_realloc_cmd);
break;
case LIBLTE_MME_MSG_TYPE_GUTI_REALLOCATION_COMPLETE:
LIBLTE_MME_GUTI_REALLOCATION_COMPLETE_MSG_STRUCT guti_realloc_cmplt;
err = liblte_mme_unpack_guti_reallocation_complete_msg(&msg, &guti_realloc_cmplt);
break;
case LIBLTE_MME_MSG_TYPE_AUTHENTICATION_REJECT:
LIBLTE_MME_AUTHENTICATION_REJECT_MSG_STRUCT auth_reject;
err = liblte_mme_unpack_authentication_reject_msg(&msg, &auth_reject);
break;
case LIBLTE_MME_MSG_TYPE_AUTHENTICATION_RESPONSE:
LIBLTE_MME_AUTHENTICATION_RESPONSE_MSG_STRUCT auth_response;
err = liblte_mme_unpack_authentication_response_msg(&msg, &auth_response);
break;
case LIBLTE_MME_MSG_TYPE_AUTHENTICATION_REQUEST:
LIBLTE_MME_AUTHENTICATION_REQUEST_MSG_STRUCT auth_req;
err = liblte_mme_unpack_authentication_request_msg(&msg, &auth_req);
break;
case LIBLTE_MME_MSG_TYPE_IDENTITY_REQUEST:
LIBLTE_MME_ID_REQUEST_MSG_STRUCT identity_request;
err = liblte_mme_unpack_identity_request_msg(&msg, &identity_request);
break;
case LIBLTE_MME_MSG_TYPE_IDENTITY_RESPONSE:
LIBLTE_MME_ID_RESPONSE_MSG_STRUCT identity_response;
err = liblte_mme_unpack_identity_response_msg(&msg, &identity_response);
break;
case LIBLTE_MME_MSG_TYPE_SECURITY_MODE_COMMAND:
LIBLTE_MME_SECURITY_MODE_COMMAND_MSG_STRUCT sec_mode_cmd;
err = liblte_mme_unpack_security_mode_command_msg(&msg, &sec_mode_cmd);
break;
case LIBLTE_MME_MSG_TYPE_SECURITY_MODE_COMPLETE:
LIBLTE_MME_SECURITY_MODE_COMPLETE_MSG_STRUCT sec_mode_cmplt;
err = liblte_mme_unpack_security_mode_complete_msg(&msg, &sec_mode_cmplt);
break;
case LIBLTE_MME_MSG_TYPE_SECURITY_MODE_REJECT:
LIBLTE_MME_SECURITY_MODE_REJECT_MSG_STRUCT sec_mode_reject;
err = liblte_mme_unpack_security_mode_reject_msg(&msg, &sec_mode_reject);
break;
case LIBLTE_MME_MSG_TYPE_EMM_INFORMATION:
LIBLTE_MME_EMM_INFORMATION_MSG_STRUCT emm_info;
err = liblte_mme_unpack_emm_information_msg(&msg, &emm_info);
break;
case LIBLTE_MME_MSG_TYPE_EMM_STATUS:
LIBLTE_MME_EMM_STATUS_MSG_STRUCT emm_status;
err = liblte_mme_unpack_emm_status_msg(&msg, &emm_status);
break;
case LIBLTE_MME_MSG_TYPE_DOWNLINK_NAS_TRANSPORT:
LIBLTE_MME_DOWNLINK_NAS_TRANSPORT_MSG_STRUCT dl_nas_transport;
err = liblte_mme_unpack_downlink_nas_transport_msg(&msg, &dl_nas_transport);
break;
/* NOT IMPLEMENTED
case LIBLTE_MME_MSG_TYPE_CS_SERVICE_NOTIFICATION: // CS Service notification
LIBLTE_MME_MSG_TYPE_CS_SERVICE_NOTIFICATION cs_service_notification;
err = liblte_mme_unpack_cs_servicie_notification_msg(&msg, cs_service_notification);
break;
*/
case LIBLTE_MME_MSG_TYPE_DOWNLINK_GENERIC_NAS_TRANSPORT:
LIBLTE_MME_DOWNLINK_GENERIC_NAS_TRANSPORT_MSG_STRUCT dl_generic_nas_transport;
err = liblte_mme_unpack_downlink_generic_nas_transport_msg(&msg, &dl_generic_nas_transport);
break;
case LIBLTE_MME_MSG_TYPE_UPLINK_GENERIC_NAS_TRANSPORT:
LIBLTE_MME_UPLINK_GENERIC_NAS_TRANSPORT_MSG_STRUCT ul_generic_nas_transport;
err = liblte_mme_unpack_uplink_generic_nas_transport_msg(&msg, &ul_generic_nas_transport);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_REQUEST:
LIBLTE_MME_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_REQUEST_MSG_STRUCT act_def_eps_bearer;
err = liblte_mme_unpack_activate_default_eps_bearer_context_request_msg(&msg, &act_def_eps_bearer);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_ACCEPT:
LIBLTE_MME_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_ACCEPT_MSG_STRUCT act_def_eps_bearer_accept;
err = liblte_mme_unpack_activate_default_eps_bearer_context_accept_msg(&msg, &act_def_eps_bearer_accept);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_REJECT:
LIBLTE_MME_ACTIVATE_DEFAULT_EPS_BEARER_CONTEXT_REJECT_MSG_STRUCT act_def_eps_bearer_reject;
err = liblte_mme_unpack_activate_default_eps_bearer_context_reject_msg(&msg, &act_def_eps_bearer_reject);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_REQUEST:
LIBLTE_MME_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_REQUEST_MSG_STRUCT act_ded_eps_bearer_request;
err = liblte_mme_unpack_activate_dedicated_eps_bearer_context_request_msg(&msg, &act_ded_eps_bearer_request);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_ACCEPT:
LIBLTE_MME_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_ACCEPT_MSG_STRUCT act_ded_eps_bearer_accept;
err = liblte_mme_unpack_activate_dedicated_eps_bearer_context_accept_msg(&msg, &act_ded_eps_bearer_accept);
break;
case LIBLTE_MME_MSG_TYPE_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_REJECT:
LIBLTE_MME_ACTIVATE_DEDICATED_EPS_BEARER_CONTEXT_REJECT_MSG_STRUCT act_ded_eps_bearer_reject;
err = liblte_mme_unpack_activate_dedicated_eps_bearer_context_reject_msg(&msg, &act_ded_eps_bearer_reject);
break;
case LIBLTE_MME_MSG_TYPE_MODIFY_EPS_BEARER_CONTEXT_REQUEST:
LIBLTE_MME_MODIFY_EPS_BEARER_CONTEXT_REQUEST_MSG_STRUCT mod_eps_bearer_request;
err = liblte_mme_unpack_modify_eps_bearer_context_request_msg(&msg, &mod_eps_bearer_request);
break;
case LIBLTE_MME_MSG_TYPE_MODIFY_EPS_BEARER_CONTEXT_ACCEPT:
LIBLTE_MME_MODIFY_EPS_BEARER_CONTEXT_ACCEPT_MSG_STRUCT mod_eps_bearer_accept;
err = liblte_mme_unpack_modify_eps_bearer_context_accept_msg(&msg, &mod_eps_bearer_accept);
break;
case LIBLTE_MME_MSG_TYPE_MODIFY_EPS_BEARER_CONTEXT_REJECT:
LIBLTE_MME_MODIFY_EPS_BEARER_CONTEXT_REJECT_MSG_STRUCT mod_eps_bearer_reject;
err = liblte_mme_unpack_modify_eps_bearer_context_reject_msg(&msg, &mod_eps_bearer_reject);
break;
case LIBLTE_MME_MSG_TYPE_DEACTIVATE_EPS_BEARER_CONTEXT_REQUEST:
LIBLTE_MME_DEACTIVATE_EPS_BEARER_CONTEXT_REQUEST_MSG_STRUCT deactivate_eps_bearer_request;
err = liblte_mme_unpack_deactivate_eps_bearer_context_request_msg(&msg, &deactivate_eps_bearer_request);
break;
case LIBLTE_MME_MSG_TYPE_DEACTIVATE_EPS_BEARER_CONTEXT_ACCEPT:
LIBLTE_MME_DEACTIVATE_EPS_BEARER_CONTEXT_ACCEPT_MSG_STRUCT deactivate_eps_bearer_accept;
err = liblte_mme_unpack_deactivate_eps_bearer_context_accept_msg(&msg, &deactivate_eps_bearer_accept);
break;
case LIBLTE_MME_MSG_TYPE_PDN_CONNECTIVITY_REQUEST:
LIBLTE_MME_PDN_CONNECTIVITY_REQUEST_MSG_STRUCT pdn_connectivity_request;
err = liblte_mme_unpack_pdn_connectivity_request_msg(&msg, &pdn_connectivity_request);
break;
case LIBLTE_MME_MSG_TYPE_PDN_CONNECTIVITY_REJECT:
LIBLTE_MME_PDN_CONNECTIVITY_REJECT_MSG_STRUCT pdn_connectivity_reject;
err = liblte_mme_unpack_pdn_connectivity_reject_msg(&msg, &pdn_connectivity_reject);
break;
case LIBLTE_MME_MSG_TYPE_PDN_DISCONNECT_REQUEST:
LIBLTE_MME_PDN_DISCONNECT_REQUEST_MSG_STRUCT pdn_disconnect_request;
err = liblte_mme_unpack_pdn_disconnect_request_msg(&msg, &pdn_disconnect_request);
break;
case LIBLTE_MME_MSG_TYPE_PDN_DISCONNECT_REJECT:
LIBLTE_MME_PDN_DISCONNECT_REJECT_MSG_STRUCT pdn_disconnect_reject;
err = liblte_mme_unpack_pdn_disconnect_reject_msg(&msg, &pdn_disconnect_reject);
break;
case LIBLTE_MME_MSG_TYPE_BEARER_RESOURCE_ALLOCATION_REQUEST:
LIBLTE_MME_BEARER_RESOURCE_ALLOCATION_REQUEST_MSG_STRUCT rsrc_alloc_request;
err = liblte_mme_unpack_bearer_resource_allocation_request_msg(&msg, &rsrc_alloc_request);
break;
case LIBLTE_MME_MSG_TYPE_BEARER_RESOURCE_ALLOCATION_REJECT:
LIBLTE_MME_BEARER_RESOURCE_ALLOCATION_REJECT_MSG_STRUCT rsrc_alloc_reject;
err = liblte_mme_unpack_bearer_resource_allocation_reject_msg(&msg, &rsrc_alloc_reject);
break;
case LIBLTE_MME_MSG_TYPE_BEARER_RESOURCE_MODIFICATION_REQUEST:
LIBLTE_MME_BEARER_RESOURCE_MODIFICATION_REQUEST_MSG_STRUCT rsrc_mod_request;
err = liblte_mme_unpack_bearer_resource_modification_request_msg(&msg, &rsrc_mod_request);
break;
case LIBLTE_MME_MSG_TYPE_BEARER_RESOURCE_MODIFICATION_REJECT:
LIBLTE_MME_BEARER_RESOURCE_MODIFICATION_REJECT_MSG_STRUCT rsrc_mod_reject;
err = liblte_mme_unpack_bearer_resource_modification_reject_msg(&msg, &rsrc_mod_reject);
break;
case LIBLTE_MME_MSG_TYPE_ESM_INFORMATION_REQUEST:
LIBLTE_MME_ESM_INFORMATION_REQUEST_MSG_STRUCT esm_information_request;
err = liblte_mme_unpack_esm_information_request_msg(&msg, &esm_information_request);
break;
case LIBLTE_MME_MSG_TYPE_ESM_INFORMATION_RESPONSE:
LIBLTE_MME_ESM_INFORMATION_RESPONSE_MSG_STRUCT esm_information_response;
err = liblte_mme_unpack_esm_information_response_msg(&msg, &esm_information_response);
break;
case LIBLTE_MME_MSG_TYPE_NOTIFICATION:
LIBLTE_MME_NOTIFICATION_MSG_STRUCT notification;
err = liblte_mme_unpack_notification_msg(&msg, &notification);
break;
case LIBLTE_MME_MSG_TYPE_ESM_STATUS:
LIBLTE_MME_ESM_STATUS_MSG_STRUCT esm_status;
err = liblte_mme_unpack_esm_status_msg(&msg, &esm_status);
break;
break;
default:
err = LIBLTE_SUCCESS;
break;
}
return (err == LIBLTE_SUCCESS);
}

@ -0,0 +1,265 @@
/*
Copyright 2013-2020 Software Radio Systems Limited
This file is part of srsLTE
srsLTE is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of
the License, or (at your option) any later version.
srsLTE is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
A copy of the GNU Affero General Public License can be found in
the LICENSE file in the top-level directory of this distribution
and at http://www.gnu.org/licenses/.
*/
#include <getopt.h>
#include <iostream>
#include "srslte/asn1/asn1_utils.h"
#include "srslte/asn1/rrc_asn1.h"
using namespace std;
using namespace asn1;
using namespace asn1::rrc;
typedef enum {
DL_CCCH = 0,
DL_DCCH,
UL_CCCH,
UL_DCCH,
BCCH_BCH,
BCCH_DL_SCH,
PCCH,
MCCH,
RRC_MSG_N_ITEMS,
} rrc_msg_types;
static const char rrc_msg_type_text[RRC_MSG_N_ITEMS][20] =
{"dl_ccch", "dl_dcch", "ul_ccch", "ul_dcch", "bcch_bch", "bcch_dl_sch", "mcch", "pcch"};
int check_msg_type(char* input_msg_type)
{
int i;
for (i = 0; i < RRC_MSG_N_ITEMS; i++) {
if (strcasecmp(input_msg_type, rrc_msg_type_text[i]) == 0)
return i;
}
return -1;
}
void usage(char* prog)
{
printf("Usage: %s [fph]\n", prog);
printf("\t-f file\n");
printf("\t-p json print\n");
printf("\t-h show this message\n");
printf("\t-t type: dl_ccch, dl_dcch, ul_ccch, ul_dcch, bcch_bch, bcch_dl_sch, mcch, pcch\n");
}
int main(int argc, char** argv)
{
FILE* fd;
SRSASN_CODE err_code = SRSASN_ERROR_DECODE_FAIL;
uint8_t* rrc_msg;
int verbose = 0;
char* file;
int type = -1;
if (argc < 2) {
printf("Please only call me with one parameter\n");
usage(argv[0]);
exit(-1);
}
int opt;
while ((opt = getopt(argc, argv, "f:pht:")) != -1) {
switch (opt) {
case 'f':
file = optarg;
break;
case 'p':
verbose++;
break;
case 't':
type = check_msg_type(optarg);
if (type == -1) {
printf("[Error] Invalid message type %s\n", optarg);
usage(argv[0]);
}
break;
case 'h':
default:
usage(argv[0]);
exit(-1);
}
}
fd = fopen(file, "rb");
if (fd == NULL) {
printf("Error failed to open file %s\n", file);
exit(-1);
}
fseek(fd, 0, SEEK_END);
long fsize = ftell(fd);
fseek(fd, 0, SEEK_SET); /* same as rewind(f); */
rrc_msg = new uint8_t[fsize];
size_t read_size = fread(rrc_msg, 1, fsize, fd);
fclose(fd);
if (read_size != (size_t)fsize) {
printf("read_size != fsize\n");
return -1;
}
asn1::cbit_ref bref(rrc_msg, fsize);
// TODO do other rrc messages and type
switch (type) {
case DL_CCCH: {
dl_ccch_msg_s dl_ccch_msg;
err_code = dl_ccch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
dl_ccch_msg.to_json(jw);
printf("RRC DL CCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case DL_DCCH: {
dl_dcch_msg_s dl_dcch_msg;
err_code = dl_dcch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
dl_dcch_msg.to_json(jw);
printf("RRC DL DCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case UL_CCCH: {
ul_ccch_msg_s ul_ccch_msg;
err_code = ul_ccch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
ul_ccch_msg.to_json(jw);
printf("RRC UL CCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case UL_DCCH: {
ul_dcch_msg_s ul_dcch_msg;
err_code = ul_dcch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
ul_dcch_msg.to_json(jw);
printf("RRC UL DCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case BCCH_BCH: {
bcch_bch_msg_s bcch_bch_msg;
err_code = bcch_bch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
bcch_bch_msg.to_json(jw);
printf("RRC BCCH BCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case BCCH_DL_SCH: {
bcch_dl_sch_msg_s bcch_dl_sch_msg;
err_code = bcch_dl_sch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
bcch_dl_sch_msg.to_json(jw);
printf("RRC SBCCH SL BCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case MCCH: {
mcch_msg_s mcch_msg;
err_code = mcch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
mcch_msg.to_json(jw);
printf("RRC MCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
case PCCH: {
pcch_msg_s pcch_msg;
err_code = pcch_msg.unpack(bref);
if (err_code == SRSASN_SUCCESS) {
printf("Decoding Success\n");
if (verbose > 0) {
json_writer jw;
pcch_msg.to_json(jw);
printf("RRC PCCH Message:\n");
printf("%s\n", jw.to_string().c_str());
}
} else {
printf("Decoding Error\n");
}
break;
}
default: {
printf("[Error] type not supported\n");
break;
}
}
delete[] rrc_msg;
return 0;
}
Loading…
Cancel
Save