/** * Copyright 2013-2021 Software Radio Systems Limited * * This file is part of srsRAN. * * srsRAN 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. * * srsRAN 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/. * */ /******************************************************************************* * * 3GPP TS ASN1 RRC NR v15.11.0 (2020-10) * ******************************************************************************/ #ifndef SRSASN1_RRC_NR_H #define SRSASN1_RRC_NR_H #include "asn1_utils.h" #include #include namespace asn1 { namespace rrc_nr { /******************************************************************************* * Constant Definitions ******************************************************************************/ #define ASN1_RRC_NR_MAX_BAND_COMB 65536 #define ASN1_RRC_NR_MAX_CELL_BLACK 16 #define ASN1_RRC_NR_MAX_CELL_INTER 16 #define ASN1_RRC_NR_MAX_CELL_INTRA 16 #define ASN1_RRC_NR_MAX_CELL_MEAS_EUTRA 32 #define ASN1_RRC_NR_MAX_EARFCN 262143 #define ASN1_RRC_NR_MAX_EUTRA_CELL_BLACK 16 #define ASN1_RRC_NR_MAX_EUTRA_NS_PMAX 8 #define ASN1_RRC_NR_MAX_MULTI_BANDS 8 #define ASN1_RRC_NR_MAX_NARFCN 3279165 #define ASN1_RRC_NR_MAX_NR_NS_PMAX 8 #define ASN1_RRC_NR_MAX_NROF_SERVING_CELLS 32 #define ASN1_RRC_NR_MAX_NROF_SERVING_CELLS_MINUS1 31 #define ASN1_RRC_NR_MAX_NROF_AGGREGATED_CELLS_PER_CELL_GROUP 16 #define ASN1_RRC_NR_MAX_NROF_SCELLS 31 #define ASN1_RRC_NR_MAX_NROF_CELL_MEAS 32 #define ASN1_RRC_NR_MAX_NROF_SS_BLOCKS_TO_AVERAGE 16 #define ASN1_RRC_NR_MAX_NROF_CSI_RS_RES_TO_AVERAGE 16 #define ASN1_RRC_NR_MAX_NROF_DL_ALLOCS 16 #define ASN1_RRC_NR_MAX_NROF_SR_CFG_PER_CELL_GROUP 8 #define ASN1_RRC_NR_MAX_LCG_ID 7 #define ASN1_RRC_NR_MAX_LC_ID 32 #define ASN1_RRC_NR_MAX_NROF_TAGS 4 #define ASN1_RRC_NR_MAX_NROF_TAGS_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_BWPS 4 #define ASN1_RRC_NR_MAX_NROF_COMB_IDC 128 #define ASN1_RRC_NR_MAX_NROF_SYMBOLS_MINUS1 13 #define ASN1_RRC_NR_MAX_NROF_SLOTS 320 #define ASN1_RRC_NR_MAX_NROF_SLOTS_MINUS1 319 #define ASN1_RRC_NR_MAX_NROF_PHYS_RES_BLOCKS 275 #define ASN1_RRC_NR_MAX_NROF_PHYS_RES_BLOCKS_MINUS1 274 #define ASN1_RRC_NR_MAX_NROF_PHYS_RES_BLOCKS_PLUS1 276 #define ASN1_RRC_NR_MAX_NROF_CTRL_RES_SETS_MINUS1 11 #define ASN1_RRC_NR_MAX_CO_RE_SET_DUR 3 #define ASN1_RRC_NR_MAX_NROF_SEARCH_SPACES_MINUS1 39 #define ASN1_RRC_NR_MAX_SFI_DCI_PAYLOAD_SIZE 128 #define ASN1_RRC_NR_MAX_SFI_DCI_PAYLOAD_SIZE_MINUS1 127 #define ASN1_RRC_NR_MAX_INT_DCI_PAYLOAD_SIZE 126 #define ASN1_RRC_NR_MAX_INT_DCI_PAYLOAD_SIZE_MINUS1 125 #define ASN1_RRC_NR_MAX_NROF_RATE_MATCH_PATTERNS 4 #define ASN1_RRC_NR_MAX_NROF_RATE_MATCH_PATTERNS_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_RATE_MATCH_PATTERNS_PER_GROUP 8 #define ASN1_RRC_NR_MAX_NROF_CSI_REPORT_CFGS 48 #define ASN1_RRC_NR_MAX_NROF_CSI_REPORT_CFGS_MINUS1 47 #define ASN1_RRC_NR_MAX_NROF_CSI_RES_CFGS 112 #define ASN1_RRC_NR_MAX_NROF_CSI_RES_CFGS_MINUS1 111 #define ASN1_RRC_NR_MAX_NROF_AP_CSI_RS_RES_PER_SET 16 #define ASN1_RRC_NR_MAX_NR_OF_CSI_APERIODIC_TRIGGERS 128 #define ASN1_RRC_NR_MAX_NROF_REPORT_CFG_PER_APERIODIC_TRIGGER 16 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES 192 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_MINUS1 191 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_PER_SET 64 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_SETS 64 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_SETS_MINUS1 63 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_SETS_PER_CFG 16 #define ASN1_RRC_NR_MAX_NROF_NZP_CSI_RS_RES_PER_CFG 128 #define ASN1_RRC_NR_MAX_NROF_ZP_CSI_RS_RES 32 #define ASN1_RRC_NR_MAX_NROF_ZP_CSI_RS_RES_MINUS1 31 #define ASN1_RRC_NR_MAX_NROF_ZP_CSI_RS_RES_SETS_MINUS1 15 #define ASN1_RRC_NR_MAX_NROF_ZP_CSI_RS_RES_PER_SET 16 #define ASN1_RRC_NR_MAX_NROF_ZP_CSI_RS_RES_SETS 16 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES 32 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES_MINUS1 31 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES_PER_SET 8 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES_SETS 64 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES_SETS_MINUS1 63 #define ASN1_RRC_NR_MAX_NROF_CSI_IM_RES_SETS_PER_CFG 16 #define ASN1_RRC_NR_MAX_NROF_CSI_SSB_RES_PER_SET 64 #define ASN1_RRC_NR_MAX_NROF_CSI_SSB_RES_SETS 64 #define ASN1_RRC_NR_MAX_NROF_CSI_SSB_RES_SETS_MINUS1 63 #define ASN1_RRC_NR_MAX_NROF_CSI_SSB_RES_SETS_PER_CFG 1 #define ASN1_RRC_NR_MAX_NROF_FAIL_DETECTION_RES 10 #define ASN1_RRC_NR_MAX_NROF_FAIL_DETECTION_RES_MINUS1 9 #define ASN1_RRC_NR_MAX_NROF_OBJ_ID 64 #define ASN1_RRC_NR_MAX_NROF_PAGE_REC 32 #define ASN1_RRC_NR_MAX_NROF_PCI_RANGES 8 #define ASN1_RRC_NR_MAX_PLMN 12 #define ASN1_RRC_NR_MAX_NROF_CSI_RS_RES_RRM 96 #define ASN1_RRC_NR_MAX_NROF_CSI_RS_RES_RRM_MINUS1 95 #define ASN1_RRC_NR_MAX_NROF_MEAS_ID 64 #define ASN1_RRC_NR_MAX_NROF_QUANT_CFG 2 #define ASN1_RRC_NR_MAX_NROF_CSI_RS_CELLS_RRM 96 #define ASN1_RRC_NR_MAX_NROF_SRS_RES_SETS 16 #define ASN1_RRC_NR_MAX_NROF_SRS_RES_SETS_MINUS1 15 #define ASN1_RRC_NR_MAX_NROF_SRS_RES 64 #define ASN1_RRC_NR_MAX_NROF_SRS_RES_MINUS1 63 #define ASN1_RRC_NR_MAX_NROF_SRS_RES_PER_SET 16 #define ASN1_RRC_NR_MAX_NROF_SRS_TRIGGER_STATES_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_SRS_TRIGGER_STATES_MINUS2 2 #define ASN1_RRC_NR_MAX_RAT_CAP_CONTAINERS 8 #define ASN1_RRC_NR_MAX_SIMUL_BANDS 32 #define ASN1_RRC_NR_MAX_NROF_SLOT_FORMAT_COMBINATIONS_PER_SET 512 #define ASN1_RRC_NR_MAX_NROF_SLOT_FORMAT_COMBINATIONS_PER_SET_MINUS1 511 #define ASN1_RRC_NR_MAX_NROF_PUCCH_RES 128 #define ASN1_RRC_NR_MAX_NROF_PUCCH_RES_MINUS1 127 #define ASN1_RRC_NR_MAX_NROF_PUCCH_RES_SETS 4 #define ASN1_RRC_NR_MAX_NROF_PUCCH_RES_SETS_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_PUCCH_RES_PER_SET 32 #define ASN1_RRC_NR_MAX_NROF_PUCCH_P0_PER_SET 8 #define ASN1_RRC_NR_MAX_NROF_PUCCH_PATHLOSS_REF_RSS 4 #define ASN1_RRC_NR_MAX_NROF_PUCCH_PATHLOSS_REF_RSS_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_P0_PUSCH_ALPHA_SETS 30 #define ASN1_RRC_NR_MAX_NROF_P0_PUSCH_ALPHA_SETS_MINUS1 29 #define ASN1_RRC_NR_MAX_NROF_PUSCH_PATHLOSS_REF_RSS 4 #define ASN1_RRC_NR_MAX_NROF_PUSCH_PATHLOSS_REF_RSS_MINUS1 3 #define ASN1_RRC_NR_MAX_NROF_NAICS_ENTRIES 8 #define ASN1_RRC_NR_MAX_BANDS 1024 #define ASN1_RRC_NR_MAX_BANDS_MRDC 1280 #define ASN1_RRC_NR_MAX_BANDS_EUTRA 256 #define ASN1_RRC_NR_MAX_CELL_REPORT 8 #define ASN1_RRC_NR_MAX_DRB 29 #define ASN1_RRC_NR_MAX_FREQ 8 #define ASN1_RRC_NR_MAX_FREQ_IDC_MRDC 32 #define ASN1_RRC_NR_MAX_NROF_CANDIDATE_BEAMS 16 #define ASN1_RRC_NR_MAX_NROF_PCIS_PER_SMTC 64 #define ASN1_RRC_NR_MAX_NROF_QFIS 64 #define ASN1_RRC_NR_MAX_NR_OF_SEMI_PERSISTENT_PUSCH_TRIGGERS 64 #define ASN1_RRC_NR_MAX_NROF_SR_RES 8 #define ASN1_RRC_NR_MAX_NROF_SLOT_FORMATS_PER_COMBINATION 256 #define ASN1_RRC_NR_MAX_NROF_SPATIAL_RELATION_INFOS 8 #define ASN1_RRC_NR_MAX_NROF_IDXES_TO_REPORT 32 #define ASN1_RRC_NR_MAX_NROF_IDXES_TO_REPORT2 64 #define ASN1_RRC_NR_MAX_NROF_SSBS_MINUS1 63 #define ASN1_RRC_NR_MAX_NROF_S_NSSAI 8 #define ASN1_RRC_NR_MAX_NROF_TCI_STATES_PDCCH 64 #define ASN1_RRC_NR_MAX_NROF_TCI_STATES 128 #define ASN1_RRC_NR_MAX_NROF_TCI_STATES_MINUS1 127 #define ASN1_RRC_NR_MAX_NROF_UL_ALLOCS 16 #define ASN1_RRC_NR_MAX_QFI 63 #define ASN1_RRC_NR_MAX_RA_CSIRS_RES 96 #define ASN1_RRC_NR_MAX_RA_OCCASIONS_PER_CSIRS 64 #define ASN1_RRC_NR_MAX_RA_OCCASIONS_MINUS1 511 #define ASN1_RRC_NR_MAX_RA_SSB_RES 64 #define ASN1_RRC_NR_MAX_SCSS 5 #define ASN1_RRC_NR_MAX_SECONDARY_CELL_GROUPS 3 #define ASN1_RRC_NR_MAX_NROF_SERVING_CELLS_EUTRA 32 #define ASN1_RRC_NR_MAX_MBSFN_ALLOCS 8 #define ASN1_RRC_NR_MAX_NROF_MULTI_BANDS 8 #define ASN1_RRC_NR_MAX_CELL_SFTD 3 #define ASN1_RRC_NR_MAX_REPORT_CFG_ID 64 #define ASN1_RRC_NR_MAX_NROF_CODEBOOKS 16 #define ASN1_RRC_NR_MAX_NROF_CSI_RS_RES 7 #define ASN1_RRC_NR_MAX_NROF_SRI_PUSCH_MAPS 16 #define ASN1_RRC_NR_MAX_NROF_SRI_PUSCH_MAPS_MINUS1 15 #define ASN1_RRC_NR_MAX_SIB 32 #define ASN1_RRC_NR_MAX_SI_MSG 32 #define ASN1_RRC_NR_MAX_PO_PER_PF 4 #define ASN1_RRC_NR_MAX_ACCESS_CAT_MINUS1 63 #define ASN1_RRC_NR_MAX_BARR_INFO_SET 8 #define ASN1_RRC_NR_MAX_CELL_EUTRA 8 #define ASN1_RRC_NR_MAX_EUTRA_CARRIER 8 #define ASN1_RRC_NR_MAX_PLMN_IDENTITIES 8 #define ASN1_RRC_NR_MAX_DL_FEATURE_SETS 1024 #define ASN1_RRC_NR_MAX_UL_FEATURE_SETS 1024 #define ASN1_RRC_NR_MAX_EUTRA_DL_FEATURE_SETS 256 #define ASN1_RRC_NR_MAX_EUTRA_UL_FEATURE_SETS 256 #define ASN1_RRC_NR_MAX_FEATURE_SETS_PER_BAND 128 #define ASN1_RRC_NR_MAX_PER_CC_FEATURE_SETS 1024 #define ASN1_RRC_NR_MAX_FEATURE_SET_COMBINATIONS 1024 #define ASN1_RRC_NR_MAX_INTER_RAT_RSTD_FREQ 3 #define ASN1_RRC_NR_MAX_MEAS_FREQS_MN 32 #define ASN1_RRC_NR_MAX_MEAS_FREQS_SN 32 #define ASN1_RRC_NR_MAX_MEAS_IDENTITIES_MN 62 #define ASN1_RRC_NR_MAX_CELL_PREP 32 /******************************************************************************* * Struct Definitions ******************************************************************************/ // PDCCH-ConfigSIB1 ::= SEQUENCE struct pdcch_cfg_sib1_s { uint8_t ctrl_res_set_zero = 0; uint8_t search_space_zero = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MIB ::= SEQUENCE struct mib_s { struct sub_carrier_spacing_common_opts { enum options { scs15or60, scs30or120, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sub_carrier_spacing_common_e_; struct dmrs_type_a_position_opts { enum options { pos2, pos3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dmrs_type_a_position_e_; struct cell_barred_opts { enum options { barred, not_barred, nulltype } value; const char* to_string() const; }; typedef enumerated cell_barred_e_; struct intra_freq_resel_opts { enum options { allowed, not_allowed, nulltype } value; const char* to_string() const; }; typedef enumerated intra_freq_resel_e_; // member variables fixed_bitstring<6> sys_frame_num; sub_carrier_spacing_common_e_ sub_carrier_spacing_common; uint8_t ssb_subcarrier_offset = 0; dmrs_type_a_position_e_ dmrs_type_a_position; pdcch_cfg_sib1_s pdcch_cfg_sib1; cell_barred_e_ cell_barred; intra_freq_resel_e_ intra_freq_resel; fixed_bitstring<1> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BCCH-BCH-MessageType ::= CHOICE struct bcch_bch_msg_type_c { struct types_opts { enum options { mib, msg_class_ext, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods bcch_bch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters mib_s& mib() { assert_choice_type(types::mib, type_, "BCCH-BCH-MessageType"); return c; } const mib_s& mib() const { assert_choice_type(types::mib, type_, "BCCH-BCH-MessageType"); return c; } mib_s& set_mib(); void set_msg_class_ext(); private: types type_; mib_s c; }; // BCCH-BCH-Message ::= SEQUENCE struct bcch_bch_msg_s { bcch_bch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-NS-PmaxValue ::= SEQUENCE struct eutra_ns_pmax_value_s { bool add_pmax_present = false; bool add_spec_emission_present = false; int8_t add_pmax = -30; uint16_t add_spec_emission = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NR-NS-PmaxValue ::= SEQUENCE struct nr_ns_pmax_value_s { bool add_pmax_present = false; int8_t add_pmax = -30; uint8_t add_spec_emission = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-NS-PmaxList ::= SEQUENCE (SIZE (1..8)) OF EUTRA-NS-PmaxValue using eutra_ns_pmax_list_l = dyn_array; // EUTRA-Q-OffsetRange ::= ENUMERATED struct eutra_q_offset_range_opts { enum options { db_minus24, db_minus22, db_minus20, db_minus18, db_minus16, db_minus14, db_minus12, db_minus10, db_minus8, db_minus6, db_minus5, db_minus4, db_minus3, db_minus2, db_minus1, db0, db1, db2, db3, db4, db5, db6, db8, db10, db12, db14, db16, db18, db20, db22, db24, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated eutra_q_offset_range_e; // NR-NS-PmaxList ::= SEQUENCE (SIZE (1..8)) OF NR-NS-PmaxValue using nr_ns_pmax_list_l = dyn_array; // Q-OffsetRange ::= ENUMERATED struct q_offset_range_opts { enum options { db_minus24, db_minus22, db_minus20, db_minus18, db_minus16, db_minus14, db_minus12, db_minus10, db_minus8, db_minus6, db_minus5, db_minus4, db_minus3, db_minus2, db_minus1, db0, db1, db2, db3, db4, db5, db6, db8, db10, db12, db14, db16, db18, db20, db22, db24, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated q_offset_range_e; // EUTRA-FreqNeighCellInfo ::= SEQUENCE struct eutra_freq_neigh_cell_info_s { bool q_rx_lev_min_offset_cell_present = false; bool q_qual_min_offset_cell_present = false; uint16_t pci = 0; eutra_q_offset_range_e dummy; uint8_t q_rx_lev_min_offset_cell = 1; uint8_t q_qual_min_offset_cell = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-MultiBandInfo ::= SEQUENCE struct eutra_multi_band_info_s { bool eutra_ns_pmax_list_present = false; uint16_t eutra_freq_band_ind = 1; eutra_ns_pmax_list_l eutra_ns_pmax_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-PhysCellIdRange ::= SEQUENCE struct eutra_pci_range_s { struct range_opts { enum options { n4, n8, n12, n16, n24, n32, n48, n64, n84, n96, n128, n168, n252, n504, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated range_e_; // member variables bool range_present = false; uint16_t start = 0; range_e_ range; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // InterFreqNeighCellInfo ::= SEQUENCE struct inter_freq_neigh_cell_info_s { bool ext = false; bool q_rx_lev_min_offset_cell_present = false; bool q_rx_lev_min_offset_cell_sul_present = false; bool q_qual_min_offset_cell_present = false; uint16_t pci = 0; q_offset_range_e q_offset_cell; uint8_t q_rx_lev_min_offset_cell = 1; uint8_t q_rx_lev_min_offset_cell_sul = 1; uint8_t q_qual_min_offset_cell = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NR-MultiBandInfo ::= SEQUENCE struct nr_multi_band_info_s { bool freq_band_ind_nr_present = false; bool nr_ns_pmax_list_present = false; uint16_t freq_band_ind_nr = 1; nr_ns_pmax_list_l nr_ns_pmax_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PCI-Range ::= SEQUENCE struct pci_range_s { struct range_opts { enum options { n4, n8, n12, n16, n24, n32, n48, n64, n84, n96, n128, n168, n252, n504, n1008, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated range_e_; // member variables bool range_present = false; uint16_t start = 0; range_e_ range; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDSCH-TimeDomainResourceAllocation ::= SEQUENCE struct pdsch_time_domain_res_alloc_s { struct map_type_opts { enum options { type_a, type_b, nulltype } value; const char* to_string() const; }; typedef enumerated map_type_e_; // member variables bool k0_present = false; uint8_t k0 = 0; map_type_e_ map_type; uint8_t start_symbol_and_len = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-TimeDomainResourceAllocation ::= SEQUENCE struct pusch_time_domain_res_alloc_s { struct map_type_opts { enum options { type_a, type_b, nulltype } value; const char* to_string() const; }; typedef enumerated map_type_e_; // member variables bool k2_present = false; uint8_t k2 = 0; map_type_e_ map_type; uint8_t start_symbol_and_len = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellReselectionSubPriority ::= ENUMERATED struct cell_resel_sub_prio_opts { enum options { odot2, odot4, odot6, odot8, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated cell_resel_sub_prio_e; // ControlResourceSet ::= SEQUENCE struct ctrl_res_set_s { struct cce_reg_map_type_c_ { struct interleaved_s_ { struct reg_bundle_size_opts { enum options { n2, n3, n6, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated reg_bundle_size_e_; struct interleaver_size_opts { enum options { n2, n3, n6, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated interleaver_size_e_; // member variables bool shift_idx_present = false; reg_bundle_size_e_ reg_bundle_size; interleaver_size_e_ interleaver_size; uint16_t shift_idx = 0; }; struct types_opts { enum options { interleaved, non_interleaved, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods cce_reg_map_type_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters interleaved_s_& interleaved() { assert_choice_type(types::interleaved, type_, "cce-REG-MappingType"); return c; } const interleaved_s_& interleaved() const { assert_choice_type(types::interleaved, type_, "cce-REG-MappingType"); return c; } interleaved_s_& set_interleaved(); void set_non_interleaved(); private: types type_; interleaved_s_ c; }; struct precoder_granularity_opts { enum options { same_as_reg_bundle, all_contiguous_rbs, nulltype } value; const char* to_string() const; }; typedef enumerated precoder_granularity_e_; using tci_states_pdcch_to_add_list_l_ = dyn_array; using tci_states_pdcch_to_release_list_l_ = dyn_array; // member variables bool ext = false; bool tci_states_pdcch_to_add_list_present = false; bool tci_states_pdcch_to_release_list_present = false; bool tci_present_in_dci_present = false; bool pdcch_dmrs_scrambling_id_present = false; uint8_t ctrl_res_set_id = 0; fixed_bitstring<45> freq_domain_res; uint8_t dur = 1; cce_reg_map_type_c_ cce_reg_map_type; precoder_granularity_e_ precoder_granularity; tci_states_pdcch_to_add_list_l_ tci_states_pdcch_to_add_list; tci_states_pdcch_to_release_list_l_ tci_states_pdcch_to_release_list; uint32_t pdcch_dmrs_scrambling_id = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-AllowedMeasBandwidth ::= ENUMERATED struct eutra_allowed_meas_bw_opts { enum options { mbw6, mbw15, mbw25, mbw50, mbw75, mbw100, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated eutra_allowed_meas_bw_e; // EUTRA-FreqBlackCellList ::= SEQUENCE (SIZE (1..16)) OF EUTRA-PhysCellIdRange using eutra_freq_black_cell_list_l = dyn_array; // EUTRA-FreqNeighCellList ::= SEQUENCE (SIZE (1..8)) OF EUTRA-FreqNeighCellInfo using eutra_freq_neigh_cell_list_l = dyn_array; // EUTRA-MultiBandInfoList ::= SEQUENCE (SIZE (1..8)) OF EUTRA-MultiBandInfo using eutra_multi_band_info_list_l = dyn_array; // InterFreqBlackCellList ::= SEQUENCE (SIZE (1..16)) OF PCI-Range using inter_freq_black_cell_list_l = dyn_array; // InterFreqNeighCellList ::= SEQUENCE (SIZE (1..16)) OF InterFreqNeighCellInfo using inter_freq_neigh_cell_list_l = dyn_array; // MCC ::= SEQUENCE (SIZE (3)) OF INTEGER (0..9) using mcc_l = std::array; // MNC ::= SEQUENCE (SIZE (2..3)) OF INTEGER (0..9) using mnc_l = bounded_array; // MultiFrequencyBandListNR-SIB ::= SEQUENCE (SIZE (1..8)) OF NR-MultiBandInfo using multi_freq_band_list_nr_sib_l = dyn_array; // PDSCH-TimeDomainResourceAllocationList ::= SEQUENCE (SIZE (1..16)) OF PDSCH-TimeDomainResourceAllocation using pdsch_time_domain_res_alloc_list_l = dyn_array; // PUSCH-TimeDomainResourceAllocationList ::= SEQUENCE (SIZE (1..16)) OF PUSCH-TimeDomainResourceAllocation using pusch_time_domain_res_alloc_list_l = dyn_array; // RACH-ConfigGeneric ::= SEQUENCE struct rach_cfg_generic_s { struct msg1_fdm_opts { enum options { one, two, four, eight, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated msg1_fdm_e_; struct preamb_trans_max_opts { enum options { n3, n4, n5, n6, n7, n8, n10, n20, n50, n100, n200, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated preamb_trans_max_e_; struct pwr_ramp_step_opts { enum options { db0, db2, db4, db6, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pwr_ramp_step_e_; struct ra_resp_win_opts { enum options { sl1, sl2, sl4, sl8, sl10, sl20, sl40, sl80, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ra_resp_win_e_; // member variables bool ext = false; uint16_t prach_cfg_idx = 0; msg1_fdm_e_ msg1_fdm; uint16_t msg1_freq_start = 0; uint8_t zero_correlation_zone_cfg = 0; int16_t preamb_rx_target_pwr = -202; preamb_trans_max_e_ preamb_trans_max; pwr_ramp_step_e_ pwr_ramp_step; ra_resp_win_e_ ra_resp_win; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SS-RSSI-Measurement ::= SEQUENCE struct ss_rssi_meas_s { bounded_bitstring<1, 80> meas_slots; uint8_t end_symbol = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SSB-MTC ::= SEQUENCE struct ssb_mtc_s { struct periodicity_and_offset_c_ { struct types_opts { enum options { sf5, sf10, sf20, sf40, sf80, sf160, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods periodicity_and_offset_c_() = default; periodicity_and_offset_c_(const periodicity_and_offset_c_& other); periodicity_and_offset_c_& operator=(const periodicity_and_offset_c_& other); ~periodicity_and_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& sf5() { assert_choice_type(types::sf5, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sf10() { assert_choice_type(types::sf10, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sf20() { assert_choice_type(types::sf20, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sf40() { assert_choice_type(types::sf40, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sf80() { assert_choice_type(types::sf80, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sf160() { assert_choice_type(types::sf160, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf5() const { assert_choice_type(types::sf5, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf10() const { assert_choice_type(types::sf10, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf20() const { assert_choice_type(types::sf20, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf40() const { assert_choice_type(types::sf40, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf80() const { assert_choice_type(types::sf80, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sf160() const { assert_choice_type(types::sf160, type_, "periodicityAndOffset"); return c.get(); } uint8_t& set_sf5(); uint8_t& set_sf10(); uint8_t& set_sf20(); uint8_t& set_sf40(); uint8_t& set_sf80(); uint8_t& set_sf160(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct dur_opts { enum options { sf1, sf2, sf3, sf4, sf5, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dur_e_; // member variables periodicity_and_offset_c_ periodicity_and_offset; dur_e_ dur; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SSB-ToMeasure ::= CHOICE struct ssb_to_measure_c { struct types_opts { enum options { short_bitmap, medium_bitmap, long_bitmap, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ssb_to_measure_c() = default; ssb_to_measure_c(const ssb_to_measure_c& other); ssb_to_measure_c& operator=(const ssb_to_measure_c& other); ~ssb_to_measure_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<4>& short_bitmap() { assert_choice_type(types::short_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } fixed_bitstring<8>& medium_bitmap() { assert_choice_type(types::medium_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } fixed_bitstring<64>& long_bitmap() { assert_choice_type(types::long_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } const fixed_bitstring<4>& short_bitmap() const { assert_choice_type(types::short_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } const fixed_bitstring<8>& medium_bitmap() const { assert_choice_type(types::medium_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } const fixed_bitstring<64>& long_bitmap() const { assert_choice_type(types::long_bitmap, type_, "SSB-ToMeasure"); return c.get >(); } fixed_bitstring<4>& set_short_bitmap(); fixed_bitstring<8>& set_medium_bitmap(); fixed_bitstring<64>& set_long_bitmap(); private: types type_; choice_buffer_t > c; void destroy_(); }; // SearchSpace ::= SEQUENCE struct search_space_s { struct monitoring_slot_periodicity_and_offset_c_ { struct types_opts { enum options { sl1, sl2, sl4, sl5, sl8, sl10, sl16, sl20, sl40, sl80, sl160, sl320, sl640, sl1280, sl2560, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods monitoring_slot_periodicity_and_offset_c_() = default; monitoring_slot_periodicity_and_offset_c_(const monitoring_slot_periodicity_and_offset_c_& other); monitoring_slot_periodicity_and_offset_c_& operator=(const monitoring_slot_periodicity_and_offset_c_& other); ~monitoring_slot_periodicity_and_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& sl2() { assert_choice_type(types::sl2, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl4() { assert_choice_type(types::sl4, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl5() { assert_choice_type(types::sl5, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl8() { assert_choice_type(types::sl8, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl10() { assert_choice_type(types::sl10, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl16() { assert_choice_type(types::sl16, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl20() { assert_choice_type(types::sl20, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl40() { assert_choice_type(types::sl40, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl80() { assert_choice_type(types::sl80, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint8_t& sl160() { assert_choice_type(types::sl160, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint16_t& sl320() { assert_choice_type(types::sl320, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint16_t& sl640() { assert_choice_type(types::sl640, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint16_t& sl1280() { assert_choice_type(types::sl1280, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } uint16_t& sl2560() { assert_choice_type(types::sl2560, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl2() const { assert_choice_type(types::sl2, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl4() const { assert_choice_type(types::sl4, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl5() const { assert_choice_type(types::sl5, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl8() const { assert_choice_type(types::sl8, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl10() const { assert_choice_type(types::sl10, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl16() const { assert_choice_type(types::sl16, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl20() const { assert_choice_type(types::sl20, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl40() const { assert_choice_type(types::sl40, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl80() const { assert_choice_type(types::sl80, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint8_t& sl160() const { assert_choice_type(types::sl160, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint16_t& sl320() const { assert_choice_type(types::sl320, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint16_t& sl640() const { assert_choice_type(types::sl640, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint16_t& sl1280() const { assert_choice_type(types::sl1280, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } const uint16_t& sl2560() const { assert_choice_type(types::sl2560, type_, "monitoringSlotPeriodicityAndOffset"); return c.get(); } void set_sl1(); uint8_t& set_sl2(); uint8_t& set_sl4(); uint8_t& set_sl5(); uint8_t& set_sl8(); uint8_t& set_sl10(); uint8_t& set_sl16(); uint8_t& set_sl20(); uint8_t& set_sl40(); uint8_t& set_sl80(); uint8_t& set_sl160(); uint16_t& set_sl320(); uint16_t& set_sl640(); uint16_t& set_sl1280(); uint16_t& set_sl2560(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct nrof_candidates_s_ { struct aggregation_level1_opts { enum options { n0, n1, n2, n3, n4, n5, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level1_e_; struct aggregation_level2_opts { enum options { n0, n1, n2, n3, n4, n5, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level2_e_; struct aggregation_level4_opts { enum options { n0, n1, n2, n3, n4, n5, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level4_e_; struct aggregation_level8_opts { enum options { n0, n1, n2, n3, n4, n5, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level8_e_; struct aggregation_level16_opts { enum options { n0, n1, n2, n3, n4, n5, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level16_e_; // member variables aggregation_level1_e_ aggregation_level1; aggregation_level2_e_ aggregation_level2; aggregation_level4_e_ aggregation_level4; aggregation_level8_e_ aggregation_level8; aggregation_level16_e_ aggregation_level16; }; struct search_space_type_c_ { struct common_s_ { struct dci_format0_minus0_and_format1_minus0_s_ { bool ext = false; // ... }; struct dci_format2_minus0_s_ { struct nrof_candidates_sfi_s_ { struct aggregation_level1_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level1_e_; struct aggregation_level2_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level2_e_; struct aggregation_level4_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level4_e_; struct aggregation_level8_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level8_e_; struct aggregation_level16_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated aggregation_level16_e_; // member variables bool aggregation_level1_present = false; bool aggregation_level2_present = false; bool aggregation_level4_present = false; bool aggregation_level8_present = false; bool aggregation_level16_present = false; aggregation_level1_e_ aggregation_level1; aggregation_level2_e_ aggregation_level2; aggregation_level4_e_ aggregation_level4; aggregation_level8_e_ aggregation_level8; aggregation_level16_e_ aggregation_level16; }; // member variables bool ext = false; nrof_candidates_sfi_s_ nrof_candidates_sfi; // ... }; struct dci_format2_minus1_s_ { bool ext = false; // ... }; struct dci_format2_minus2_s_ { bool ext = false; // ... }; struct dci_format2_minus3_s_ { struct dummy1_opts { enum options { sl1, sl2, sl4, sl5, sl8, sl10, sl16, sl20, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dummy1_e_; struct dummy2_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dummy2_e_; // member variables bool ext = false; bool dummy1_present = false; dummy1_e_ dummy1; dummy2_e_ dummy2; // ... }; // member variables bool dci_format0_minus0_and_format1_minus0_present = false; bool dci_format2_minus0_present = false; bool dci_format2_minus1_present = false; bool dci_format2_minus2_present = false; bool dci_format2_minus3_present = false; dci_format0_minus0_and_format1_minus0_s_ dci_format0_minus0_and_format1_minus0; dci_format2_minus0_s_ dci_format2_minus0; dci_format2_minus1_s_ dci_format2_minus1; dci_format2_minus2_s_ dci_format2_minus2; dci_format2_minus3_s_ dci_format2_minus3; }; struct ue_specific_s_ { struct dci_formats_opts { enum options { formats0_minus0_and_minus1_minus0, formats0_minus1_and_minus1_minus1, nulltype } value; const char* to_string() const; }; typedef enumerated dci_formats_e_; // member variables bool ext = false; dci_formats_e_ dci_formats; // ... }; struct types_opts { enum options { common, ue_specific, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods search_space_type_c_() = default; search_space_type_c_(const search_space_type_c_& other); search_space_type_c_& operator=(const search_space_type_c_& other); ~search_space_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters common_s_& common() { assert_choice_type(types::common, type_, "searchSpaceType"); return c.get(); } ue_specific_s_& ue_specific() { assert_choice_type(types::ue_specific, type_, "searchSpaceType"); return c.get(); } const common_s_& common() const { assert_choice_type(types::common, type_, "searchSpaceType"); return c.get(); } const ue_specific_s_& ue_specific() const { assert_choice_type(types::ue_specific, type_, "searchSpaceType"); return c.get(); } common_s_& set_common(); ue_specific_s_& set_ue_specific(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ctrl_res_set_id_present = false; bool monitoring_slot_periodicity_and_offset_present = false; bool dur_present = false; bool monitoring_symbols_within_slot_present = false; bool nrof_candidates_present = false; bool search_space_type_present = false; uint8_t search_space_id = 0; uint8_t ctrl_res_set_id = 0; monitoring_slot_periodicity_and_offset_c_ monitoring_slot_periodicity_and_offset; uint16_t dur = 2; fixed_bitstring<14> monitoring_symbols_within_slot; nrof_candidates_s_ nrof_candidates; search_space_type_c_ search_space_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SpeedStateScaleFactors ::= SEQUENCE struct speed_state_scale_factors_s { struct sf_medium_opts { enum options { odot25, odot5, odot75, ldot0, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated sf_medium_e_; struct sf_high_opts { enum options { odot25, odot5, odot75, ldot0, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated sf_high_e_; // member variables sf_medium_e_ sf_medium; sf_high_e_ sf_high; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SubcarrierSpacing ::= ENUMERATED struct subcarrier_spacing_opts { enum options { khz15, khz30, khz60, khz120, khz240, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated subcarrier_spacing_e; // ThresholdNR ::= SEQUENCE struct thres_nr_s { bool thres_rsrp_present = false; bool thres_rsrq_present = false; bool thres_sinr_present = false; uint8_t thres_rsrp = 0; uint8_t thres_rsrq = 0; uint8_t thres_sinr = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP ::= SEQUENCE struct bwp_s { bool cp_present = false; uint16_t location_and_bw = 0; subcarrier_spacing_e subcarrier_spacing; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CarrierFreqEUTRA ::= SEQUENCE struct carrier_freq_eutra_s { struct thresh_x_q_s_ { uint8_t thresh_x_high_q = 0; uint8_t thresh_x_low_q = 0; }; // member variables bool eutra_multi_band_info_list_present = false; bool eutra_freq_neigh_cell_list_present = false; bool eutra_black_cell_list_present = false; bool cell_resel_prio_present = false; bool cell_resel_sub_prio_present = false; bool thresh_x_q_present = false; uint32_t carrier_freq = 0; eutra_multi_band_info_list_l eutra_multi_band_info_list; eutra_freq_neigh_cell_list_l eutra_freq_neigh_cell_list; eutra_freq_black_cell_list_l eutra_black_cell_list; eutra_allowed_meas_bw_e allowed_meas_bw; bool presence_ant_port1 = false; uint8_t cell_resel_prio = 0; cell_resel_sub_prio_e cell_resel_sub_prio; uint8_t thresh_x_high = 0; uint8_t thresh_x_low = 0; int8_t q_rx_lev_min = -70; int8_t q_qual_min = -34; int8_t p_max_eutra = -30; thresh_x_q_s_ thresh_x_q; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // InterFreqCarrierFreqInfo ::= SEQUENCE struct inter_freq_carrier_freq_info_s { struct thresh_x_q_s_ { uint8_t thresh_x_high_q = 0; uint8_t thresh_x_low_q = 0; }; // member variables bool ext = false; bool freq_band_list_present = false; bool freq_band_list_sul_present = false; bool nrof_ss_blocks_to_average_present = false; bool abs_thresh_ss_blocks_consolidation_present = false; bool smtc_present = false; bool ssb_to_measure_present = false; bool ss_rssi_meas_present = false; bool q_rx_lev_min_sul_present = false; bool q_qual_min_present = false; bool p_max_present = false; bool t_resel_nr_sf_present = false; bool thresh_x_q_present = false; bool cell_resel_prio_present = false; bool cell_resel_sub_prio_present = false; bool q_offset_freq_present = false; bool inter_freq_neigh_cell_list_present = false; bool inter_freq_black_cell_list_present = false; uint32_t dl_carrier_freq = 0; multi_freq_band_list_nr_sib_l freq_band_list; multi_freq_band_list_nr_sib_l freq_band_list_sul; uint8_t nrof_ss_blocks_to_average = 2; thres_nr_s abs_thresh_ss_blocks_consolidation; ssb_mtc_s smtc; subcarrier_spacing_e ssb_subcarrier_spacing; ssb_to_measure_c ssb_to_measure; bool derive_ssb_idx_from_cell = false; ss_rssi_meas_s ss_rssi_meas; int8_t q_rx_lev_min = -70; int8_t q_rx_lev_min_sul = -70; int8_t q_qual_min = -43; int8_t p_max = -30; uint8_t t_resel_nr = 0; speed_state_scale_factors_s t_resel_nr_sf; uint8_t thresh_x_high_p = 0; uint8_t thresh_x_low_p = 0; thresh_x_q_s_ thresh_x_q; uint8_t cell_resel_prio = 0; cell_resel_sub_prio_e cell_resel_sub_prio; q_offset_range_e q_offset_freq; inter_freq_neigh_cell_list_l inter_freq_neigh_cell_list; inter_freq_black_cell_list_l inter_freq_black_cell_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // IntraFreqNeighCellInfo ::= SEQUENCE struct intra_freq_neigh_cell_info_s { bool ext = false; bool q_rx_lev_min_offset_cell_present = false; bool q_rx_lev_min_offset_cell_sul_present = false; bool q_qual_min_offset_cell_present = false; uint16_t pci = 0; q_offset_range_e q_offset_cell; uint8_t q_rx_lev_min_offset_cell = 1; uint8_t q_rx_lev_min_offset_cell_sul = 1; uint8_t q_qual_min_offset_cell = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDCCH-ConfigCommon ::= SEQUENCE struct pdcch_cfg_common_s { using common_search_space_list_l_ = dyn_array; struct first_pdcch_monitoring_occasion_of_po_c_ { using scs15_kh_zone_t_l_ = bounded_array; using scs30_kh_zone_t_scs15_kh_zhalf_t_l_ = bounded_array; using scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_ = bounded_array; using scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_ = bounded_array; using scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zone_sixteenth_t_l_ = bounded_array; struct types_opts { enum options { scs15_kh_zone_t, scs30_kh_zone_t_scs15_kh_zhalf_t, scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, scs120_kh_zone_sixteenth_t, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods first_pdcch_monitoring_occasion_of_po_c_() = default; first_pdcch_monitoring_occasion_of_po_c_(const first_pdcch_monitoring_occasion_of_po_c_& other); first_pdcch_monitoring_occasion_of_po_c_& operator=(const first_pdcch_monitoring_occasion_of_po_c_& other); ~first_pdcch_monitoring_occasion_of_po_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters scs15_kh_zone_t_l_& scs15_kh_zone_t() { assert_choice_type(types::scs15_kh_zone_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs30_kh_zone_t_scs15_kh_zhalf_t_l_& scs30_kh_zone_t_scs15_kh_zhalf_t() { assert_choice_type(types::scs30_kh_zone_t_scs15_kh_zhalf_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t() { assert_choice_type( types::scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t() { assert_choice_type(types::scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t() { assert_choice_type( types::scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_sixteenth_t_l_& scs120_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs15_kh_zone_t_l_& scs15_kh_zone_t() const { assert_choice_type(types::scs15_kh_zone_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs30_kh_zone_t_scs15_kh_zhalf_t_l_& scs30_kh_zone_t_scs15_kh_zhalf_t() const { assert_choice_type(types::scs30_kh_zone_t_scs15_kh_zhalf_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t() const { assert_choice_type( types::scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t() const { assert_choice_type(types::scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t() const { assert_choice_type( types::scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_sixteenth_t_l_& scs120_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs15_kh_zone_t_l_& set_scs15_kh_zone_t(); scs30_kh_zone_t_scs15_kh_zhalf_t_l_& set_scs30_kh_zone_t_scs15_kh_zhalf_t(); scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& set_scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t(); scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& set_scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t(); scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& set_scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t(); scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& set_scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t(); scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& set_scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t(); scs120_kh_zone_sixteenth_t_l_& set_scs120_kh_zone_sixteenth_t(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool ctrl_res_set_zero_present = false; bool common_ctrl_res_set_present = false; bool search_space_zero_present = false; bool common_search_space_list_present = false; bool search_space_sib1_present = false; bool search_space_other_sys_info_present = false; bool paging_search_space_present = false; bool ra_search_space_present = false; uint8_t ctrl_res_set_zero = 0; ctrl_res_set_s common_ctrl_res_set; uint8_t search_space_zero = 0; common_search_space_list_l_ common_search_space_list; uint8_t search_space_sib1 = 0; uint8_t search_space_other_sys_info = 0; uint8_t paging_search_space = 0; uint8_t ra_search_space = 0; // ... // group 0 copy_ptr first_pdcch_monitoring_occasion_of_po; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDSCH-ConfigCommon ::= SEQUENCE struct pdsch_cfg_common_s { bool ext = false; bool pdsch_time_domain_alloc_list_present = false; pdsch_time_domain_res_alloc_list_l pdsch_time_domain_alloc_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-Identity ::= SEQUENCE struct plmn_id_s { bool mcc_present = false; mcc_l mcc; mnc_l mnc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-ConfigCommon ::= SEQUENCE struct pucch_cfg_common_s { struct pucch_group_hop_opts { enum options { neither, enable, disable, nulltype } value; const char* to_string() const; }; typedef enumerated pucch_group_hop_e_; // member variables bool ext = false; bool pucch_res_common_present = false; bool hop_id_present = false; bool p0_nominal_present = false; uint8_t pucch_res_common = 0; pucch_group_hop_e_ pucch_group_hop; uint16_t hop_id = 0; int16_t p0_nominal = -202; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-ConfigCommon ::= SEQUENCE struct pusch_cfg_common_s { bool ext = false; bool group_hop_enabled_transform_precoding_present = false; bool pusch_time_domain_alloc_list_present = false; bool msg3_delta_preamb_present = false; bool p0_nominal_with_grant_present = false; pusch_time_domain_res_alloc_list_l pusch_time_domain_alloc_list; int8_t msg3_delta_preamb = -1; int16_t p0_nominal_with_grant = -202; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PagingCycle ::= ENUMERATED struct paging_cycle_opts { enum options { rf32, rf64, rf128, rf256, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated paging_cycle_e; // RACH-ConfigCommon ::= SEQUENCE struct rach_cfg_common_s { struct ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_ { struct one_eighth_opts { enum options { n4, n8, n12, n16, n20, n24, n28, n32, n36, n40, n44, n48, n52, n56, n60, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated one_eighth_e_; struct one_fourth_opts { enum options { n4, n8, n12, n16, n20, n24, n28, n32, n36, n40, n44, n48, n52, n56, n60, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated one_fourth_e_; struct one_half_opts { enum options { n4, n8, n12, n16, n20, n24, n28, n32, n36, n40, n44, n48, n52, n56, n60, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated one_half_e_; struct one_opts { enum options { n4, n8, n12, n16, n20, n24, n28, n32, n36, n40, n44, n48, n52, n56, n60, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated one_e_; struct two_opts { enum options { n4, n8, n12, n16, n20, n24, n28, n32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated two_e_; struct types_opts { enum options { one_eighth, one_fourth, one_half, one, two, four, eight, sixteen, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated types; // choice methods ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_() = default; ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_(const ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_& other); ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_& operator=(const ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_& other); ~ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters one_eighth_e_& one_eighth() { assert_choice_type(types::one_eighth, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } one_fourth_e_& one_fourth() { assert_choice_type(types::one_fourth, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } one_half_e_& one_half() { assert_choice_type(types::one_half, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } one_e_& one() { assert_choice_type(types::one, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } two_e_& two() { assert_choice_type(types::two, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } uint8_t& four() { assert_choice_type(types::four, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } uint8_t& eight() { assert_choice_type(types::eight, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } uint8_t& sixteen() { assert_choice_type(types::sixteen, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const one_eighth_e_& one_eighth() const { assert_choice_type(types::one_eighth, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const one_fourth_e_& one_fourth() const { assert_choice_type(types::one_fourth, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const one_half_e_& one_half() const { assert_choice_type(types::one_half, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const one_e_& one() const { assert_choice_type(types::one, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const two_e_& two() const { assert_choice_type(types::two, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const uint8_t& four() const { assert_choice_type(types::four, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const uint8_t& eight() const { assert_choice_type(types::eight, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } const uint8_t& sixteen() const { assert_choice_type(types::sixteen, type_, "ssb-perRACH-OccasionAndCB-PreamblesPerSSB"); return c.get(); } one_eighth_e_& set_one_eighth(); one_fourth_e_& set_one_fourth(); one_half_e_& set_one_half(); one_e_& set_one(); two_e_& set_two(); uint8_t& set_four(); uint8_t& set_eight(); uint8_t& set_sixteen(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct group_bcfgured_s_ { struct ra_msg3_size_group_a_opts { enum options { b56, b144, b208, b256, b282, b480, b640, b800, b1000, b72, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated ra_msg3_size_group_a_e_; struct msg_pwr_offset_group_b_opts { enum options { minusinfinity, db0, db5, db8, db10, db12, db15, db18, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated msg_pwr_offset_group_b_e_; // member variables ra_msg3_size_group_a_e_ ra_msg3_size_group_a; msg_pwr_offset_group_b_e_ msg_pwr_offset_group_b; uint8_t nof_ra_preambs_group_a = 1; }; struct ra_contention_resolution_timer_opts { enum options { sf8, sf16, sf24, sf32, sf40, sf48, sf56, sf64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ra_contention_resolution_timer_e_; struct prach_root_seq_idx_c_ { struct types_opts { enum options { l839, l139, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods prach_root_seq_idx_c_() = default; prach_root_seq_idx_c_(const prach_root_seq_idx_c_& other); prach_root_seq_idx_c_& operator=(const prach_root_seq_idx_c_& other); ~prach_root_seq_idx_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint16_t& l839() { assert_choice_type(types::l839, type_, "prach-RootSequenceIndex"); return c.get(); } uint8_t& l139() { assert_choice_type(types::l139, type_, "prach-RootSequenceIndex"); return c.get(); } const uint16_t& l839() const { assert_choice_type(types::l839, type_, "prach-RootSequenceIndex"); return c.get(); } const uint8_t& l139() const { assert_choice_type(types::l139, type_, "prach-RootSequenceIndex"); return c.get(); } uint16_t& set_l839(); uint8_t& set_l139(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct restricted_set_cfg_opts { enum options { unrestricted_set, restricted_set_type_a, restricted_set_type_b, nulltype } value; const char* to_string() const; }; typedef enumerated restricted_set_cfg_e_; // member variables bool ext = false; bool total_nof_ra_preambs_present = false; bool ssb_per_rach_occasion_and_cb_preambs_per_ssb_present = false; bool group_bcfgured_present = false; bool rsrp_thres_ssb_present = false; bool rsrp_thres_ssb_sul_present = false; bool msg1_subcarrier_spacing_present = false; bool msg3_transform_precoder_present = false; rach_cfg_generic_s rach_cfg_generic; uint8_t total_nof_ra_preambs = 1; ssb_per_rach_occasion_and_cb_preambs_per_ssb_c_ ssb_per_rach_occasion_and_cb_preambs_per_ssb; group_bcfgured_s_ group_bcfgured; ra_contention_resolution_timer_e_ ra_contention_resolution_timer; uint8_t rsrp_thres_ssb = 0; uint8_t rsrp_thres_ssb_sul = 0; prach_root_seq_idx_c_ prach_root_seq_idx; subcarrier_spacing_e msg1_subcarrier_spacing; restricted_set_cfg_e_ restricted_set_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCS-SpecificCarrier ::= SEQUENCE struct scs_specific_carrier_s { bool ext = false; uint16_t offset_to_carrier = 0; subcarrier_spacing_e subcarrier_spacing; uint16_t carrier_bw = 1; // ... // group 0 bool tx_direct_current_location_present = false; uint16_t tx_direct_current_location = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB-TypeInfo ::= SEQUENCE struct sib_type_info_s { struct type_opts { enum options { sib_type2, sib_type3, sib_type4, sib_type5, sib_type6, sib_type7, sib_type8, sib_type9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, // ... nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated type_e_; // member variables bool value_tag_present = false; bool area_scope_present = false; type_e_ type; uint8_t value_tag = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SetupRelease{ElementTypeParam} ::= CHOICE template struct setup_release_c { struct types_opts { enum options { release, setup, nulltype } value; const char* to_string() const { static const char* options[] = {"release", "setup"}; return convert_enum_idx(options, 2, value, "setup_release_c::types"); } }; typedef enumerated types; // choice methods setup_release_c() = default; types type() const { return type_; } // getters elem_type_paramT_& setup() { assert_choice_type(types::setup, type_, "SetupRelease"); return c; } const elem_type_paramT_& setup() const { assert_choice_type(types::setup, type_, "SetupRelease"); return c; } void set_release() { set(types::release); } void set(typename types::options e) { type_ = e; } void to_json(json_writer& j) const { j.start_obj(); switch (type_) { case types::release: j.write_null("release"); break; case types::setup: j.write_fieldname("setup"); asn1::to_json(j, setup()); break; default: log_invalid_choice_id(type_, "setup_release_c"); } j.end_obj(); } SRSASN_CODE pack(bit_ref& bref) const { type_.pack(bref); switch (type_) { case types::release: break; case types::setup: HANDLE_CODE(c.pack(bref)); break; default: log_invalid_choice_id(type_, "setup_release_c"); return SRSASN_ERROR_ENCODE_FAIL; } return SRSASN_SUCCESS; } SRSASN_CODE unpack(cbit_ref& bref) { types e; e.unpack(bref); set(e); switch (type_) { case types::release: break; case types::setup: HANDLE_CODE(c.unpack(bref)); break; default: log_invalid_choice_id(type_, "setup_release_c"); return SRSASN_ERROR_DECODE_FAIL; } return SRSASN_SUCCESS; } elem_type_paramT_& set_setup() { set(types::setup); return c; } private: types type_; elem_type_paramT_ c; }; // UAC-BarringPerCat ::= SEQUENCE struct uac_barr_per_cat_s { uint8_t access_category = 1; uint8_t uac_barr_info_set_idx = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BCCH-Config ::= SEQUENCE struct bcch_cfg_s { struct mod_period_coeff_opts { enum options { n2, n4, n8, n16, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated mod_period_coeff_e_; // member variables bool ext = false; mod_period_coeff_e_ mod_period_coeff; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-DownlinkCommon ::= SEQUENCE struct bwp_dl_common_s { bool ext = false; bool pdcch_cfg_common_present = false; bool pdsch_cfg_common_present = false; bwp_s generic_params; setup_release_c pdcch_cfg_common; setup_release_c pdsch_cfg_common; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-UplinkCommon ::= SEQUENCE struct bwp_ul_common_s { bool ext = false; bool rach_cfg_common_present = false; bool pusch_cfg_common_present = false; bool pucch_cfg_common_present = false; bwp_s generic_params; setup_release_c rach_cfg_common; setup_release_c pusch_cfg_common; setup_release_c pucch_cfg_common; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CarrierFreqListEUTRA ::= SEQUENCE (SIZE (1..8)) OF CarrierFreqEUTRA using carrier_freq_list_eutra_l = dyn_array; // FrequencyInfoDL-SIB ::= SEQUENCE struct freq_info_dl_sib_s { using scs_specific_carrier_list_l_ = dyn_array; // member variables multi_freq_band_list_nr_sib_l freq_band_list; uint16_t offset_to_point_a = 0; scs_specific_carrier_list_l_ scs_specific_carrier_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FrequencyInfoUL-SIB ::= SEQUENCE struct freq_info_ul_sib_s { using scs_specific_carrier_list_l_ = dyn_array; // member variables bool ext = false; bool freq_band_list_present = false; bool absolute_freq_point_a_present = false; bool p_max_present = false; bool freq_shift7p5khz_present = false; multi_freq_band_list_nr_sib_l freq_band_list; uint32_t absolute_freq_point_a = 0; scs_specific_carrier_list_l_ scs_specific_carrier_list; int8_t p_max = -30; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // InterFreqCarrierFreqList ::= SEQUENCE (SIZE (1..8)) OF InterFreqCarrierFreqInfo using inter_freq_carrier_freq_list_l = dyn_array; // IntraFreqBlackCellList ::= SEQUENCE (SIZE (1..16)) OF PCI-Range using intra_freq_black_cell_list_l = dyn_array; // IntraFreqNeighCellList ::= SEQUENCE (SIZE (1..16)) OF IntraFreqNeighCellInfo using intra_freq_neigh_cell_list_l = dyn_array; // MobilityStateParameters ::= SEQUENCE struct mob_state_params_s { struct t_eval_opts { enum options { s30, s60, s120, s180, s240, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated t_eval_e_; struct t_hyst_normal_opts { enum options { s30, s60, s120, s180, s240, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated t_hyst_normal_e_; // member variables t_eval_e_ t_eval; t_hyst_normal_e_ t_hyst_normal; uint8_t n_cell_change_medium = 1; uint8_t n_cell_change_high = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PCCH-Config ::= SEQUENCE struct pcch_cfg_s { struct nand_paging_frame_offset_c_ { struct types_opts { enum options { one_t, half_t, quarter_t, one_eighth_t, one_sixteenth_t, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated types; // choice methods nand_paging_frame_offset_c_() = default; nand_paging_frame_offset_c_(const nand_paging_frame_offset_c_& other); nand_paging_frame_offset_c_& operator=(const nand_paging_frame_offset_c_& other); ~nand_paging_frame_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& half_t() { assert_choice_type(types::half_t, type_, "nAndPagingFrameOffset"); return c.get(); } uint8_t& quarter_t() { assert_choice_type(types::quarter_t, type_, "nAndPagingFrameOffset"); return c.get(); } uint8_t& one_eighth_t() { assert_choice_type(types::one_eighth_t, type_, "nAndPagingFrameOffset"); return c.get(); } uint8_t& one_sixteenth_t() { assert_choice_type(types::one_sixteenth_t, type_, "nAndPagingFrameOffset"); return c.get(); } const uint8_t& half_t() const { assert_choice_type(types::half_t, type_, "nAndPagingFrameOffset"); return c.get(); } const uint8_t& quarter_t() const { assert_choice_type(types::quarter_t, type_, "nAndPagingFrameOffset"); return c.get(); } const uint8_t& one_eighth_t() const { assert_choice_type(types::one_eighth_t, type_, "nAndPagingFrameOffset"); return c.get(); } const uint8_t& one_sixteenth_t() const { assert_choice_type(types::one_sixteenth_t, type_, "nAndPagingFrameOffset"); return c.get(); } void set_one_t(); uint8_t& set_half_t(); uint8_t& set_quarter_t(); uint8_t& set_one_eighth_t(); uint8_t& set_one_sixteenth_t(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct ns_opts { enum options { four, two, one, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ns_e_; struct first_pdcch_monitoring_occasion_of_po_c_ { using scs15_kh_zone_t_l_ = bounded_array; using scs30_kh_zone_t_scs15_kh_zhalf_t_l_ = bounded_array; using scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_ = bounded_array; using scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_ = bounded_array; using scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_ = bounded_array; using scs120_kh_zone_sixteenth_t_l_ = bounded_array; struct types_opts { enum options { scs15_kh_zone_t, scs30_kh_zone_t_scs15_kh_zhalf_t, scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, scs120_kh_zone_sixteenth_t, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods first_pdcch_monitoring_occasion_of_po_c_() = default; first_pdcch_monitoring_occasion_of_po_c_(const first_pdcch_monitoring_occasion_of_po_c_& other); first_pdcch_monitoring_occasion_of_po_c_& operator=(const first_pdcch_monitoring_occasion_of_po_c_& other); ~first_pdcch_monitoring_occasion_of_po_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters scs15_kh_zone_t_l_& scs15_kh_zone_t() { assert_choice_type(types::scs15_kh_zone_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs30_kh_zone_t_scs15_kh_zhalf_t_l_& scs30_kh_zone_t_scs15_kh_zhalf_t() { assert_choice_type(types::scs30_kh_zone_t_scs15_kh_zhalf_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t() { assert_choice_type( types::scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t() { assert_choice_type(types::scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t() { assert_choice_type( types::scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs120_kh_zone_sixteenth_t_l_& scs120_kh_zone_sixteenth_t() { assert_choice_type(types::scs120_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs15_kh_zone_t_l_& scs15_kh_zone_t() const { assert_choice_type(types::scs15_kh_zone_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs30_kh_zone_t_scs15_kh_zhalf_t_l_& scs30_kh_zone_t_scs15_kh_zhalf_t() const { assert_choice_type(types::scs30_kh_zone_t_scs15_kh_zhalf_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t() const { assert_choice_type( types::scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t() const { assert_choice_type(types::scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t() const { assert_choice_type( types::scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } const scs120_kh_zone_sixteenth_t_l_& scs120_kh_zone_sixteenth_t() const { assert_choice_type(types::scs120_kh_zone_sixteenth_t, type_, "firstPDCCH-MonitoringOccasionOfPO"); return c.get(); } scs15_kh_zone_t_l_& set_scs15_kh_zone_t(); scs30_kh_zone_t_scs15_kh_zhalf_t_l_& set_scs30_kh_zone_t_scs15_kh_zhalf_t(); scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t_l_& set_scs60_kh_zone_t_scs30_kh_zhalf_t_scs15_kh_zquarter_t(); scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t_l_& set_scs120_kh_zone_t_scs60_kh_zhalf_t_scs30_kh_zquarter_t_scs15_kh_zone_eighth_t(); scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t_l_& set_scs120_kh_zhalf_t_scs60_kh_zquarter_t_scs30_kh_zone_eighth_t_scs15_kh_zone_sixteenth_t(); scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t_l_& set_scs120_kh_zquarter_t_scs60_kh_zone_eighth_t_scs30_kh_zone_sixteenth_t(); scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t_l_& set_scs120_kh_zone_eighth_t_scs60_kh_zone_sixteenth_t(); scs120_kh_zone_sixteenth_t_l_& set_scs120_kh_zone_sixteenth_t(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool first_pdcch_monitoring_occasion_of_po_present = false; paging_cycle_e default_paging_cycle; nand_paging_frame_offset_c_ nand_paging_frame_offset; ns_e_ ns; first_pdcch_monitoring_occasion_of_po_c_ first_pdcch_monitoring_occasion_of_po; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-IdentityInfo ::= SEQUENCE struct plmn_id_info_s { using plmn_id_list_l_ = dyn_array; struct cell_reserved_for_oper_opts { enum options { reserved, not_reserved, nulltype } value; const char* to_string() const; }; typedef enumerated cell_reserved_for_oper_e_; // member variables bool ext = false; bool tac_present = false; bool ranac_present = false; plmn_id_list_l_ plmn_id_list; fixed_bitstring<24> tac; uint16_t ranac = 0; fixed_bitstring<36> cell_id; cell_reserved_for_oper_e_ cell_reserved_for_oper; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RangeToBestCell ::= Q-OffsetRange using range_to_best_cell_e = q_offset_range_e; // SI-RequestResources ::= SEQUENCE struct si_request_res_s { bool ra_assoc_period_idx_present = false; bool ra_ssb_occasion_mask_idx_present = false; uint8_t ra_preamb_start_idx = 0; uint8_t ra_assoc_period_idx = 0; uint8_t ra_ssb_occasion_mask_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB-Mapping ::= SEQUENCE (SIZE (1..32)) OF SIB-TypeInfo using sib_map_l = dyn_array; // TDD-UL-DL-Pattern ::= SEQUENCE struct tdd_ul_dl_pattern_s { struct dl_ul_tx_periodicity_opts { enum options { ms0p5, ms0p625, ms1, ms1p25, ms2, ms2p5, ms5, ms10, nulltype } value; const char* to_string() const; }; typedef enumerated dl_ul_tx_periodicity_e_; struct dl_ul_tx_periodicity_v1530_opts { enum options { ms3, ms4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dl_ul_tx_periodicity_v1530_e_; // member variables bool ext = false; dl_ul_tx_periodicity_e_ dl_ul_tx_periodicity; uint16_t nrof_dl_slots = 0; uint8_t nrof_dl_symbols = 0; uint16_t nrof_ul_slots = 0; uint8_t nrof_ul_symbols = 0; // ... // group 0 bool dl_ul_tx_periodicity_v1530_present = false; dl_ul_tx_periodicity_v1530_e_ dl_ul_tx_periodicity_v1530; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TimeAlignmentTimer ::= ENUMERATED struct time_align_timer_opts { enum options { ms500, ms750, ms1280, ms1920, ms2560, ms5120, ms10240, infinity, nulltype } value; typedef int16_t number_type; const char* to_string() const; int16_t to_number() const; }; typedef enumerated time_align_timer_e; // UAC-BarringPerCatList ::= SEQUENCE (SIZE (1..63)) OF UAC-BarringPerCat using uac_barr_per_cat_list_l = dyn_array; // DownlinkConfigCommonSIB ::= SEQUENCE struct dl_cfg_common_sib_s { bool ext = false; freq_info_dl_sib_s freq_info_dl; bwp_dl_common_s init_dl_bwp; bcch_cfg_s bcch_cfg; pcch_cfg_s pcch_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-IdentityInfoList ::= SEQUENCE (SIZE (1..12)) OF PLMN-IdentityInfo using plmn_id_info_list_l = dyn_array; // SI-RequestConfig ::= SEQUENCE struct si_request_cfg_s { struct rach_occasions_si_s_ { struct ssb_per_rach_occasion_opts { enum options { one_eighth, one_fourth, one_half, one, two, four, eight, sixteen, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated ssb_per_rach_occasion_e_; // member variables rach_cfg_generic_s rach_cfg_si; ssb_per_rach_occasion_e_ ssb_per_rach_occasion; }; struct si_request_period_opts { enum options { one, two, four, six, eight, ten, twelve, sixteen, nulltype } value; const char* to_string() const; }; typedef enumerated si_request_period_e_; using si_request_res_l_ = dyn_array; // member variables bool rach_occasions_si_present = false; bool si_request_period_present = false; rach_occasions_si_s_ rach_occasions_si; si_request_period_e_ si_request_period; si_request_res_l_ si_request_res; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB2 ::= SEQUENCE struct sib2_s { struct cell_resel_info_common_s_ { struct q_hyst_opts { enum options { db0, db1, db2, db3, db4, db5, db6, db8, db10, db12, db14, db16, db18, db20, db22, db24, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated q_hyst_e_; struct speed_state_resel_pars_s_ { struct q_hyst_sf_s_ { struct sf_medium_opts { enum options { db_minus6, db_minus4, db_minus2, db0, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated sf_medium_e_; struct sf_high_opts { enum options { db_minus6, db_minus4, db_minus2, db0, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated sf_high_e_; // member variables sf_medium_e_ sf_medium; sf_high_e_ sf_high; }; // member variables mob_state_params_s mob_state_params; q_hyst_sf_s_ q_hyst_sf; }; // member variables bool ext = false; bool nrof_ss_blocks_to_average_present = false; bool abs_thresh_ss_blocks_consolidation_present = false; bool range_to_best_cell_present = false; bool speed_state_resel_pars_present = false; uint8_t nrof_ss_blocks_to_average = 2; thres_nr_s abs_thresh_ss_blocks_consolidation; range_to_best_cell_e range_to_best_cell; q_hyst_e_ q_hyst; speed_state_resel_pars_s_ speed_state_resel_pars; // ... }; struct cell_resel_serving_freq_info_s_ { bool ext = false; bool s_non_intra_search_p_present = false; bool s_non_intra_search_q_present = false; bool thresh_serving_low_q_present = false; bool cell_resel_sub_prio_present = false; uint8_t s_non_intra_search_p = 0; uint8_t s_non_intra_search_q = 0; uint8_t thresh_serving_low_p = 0; uint8_t thresh_serving_low_q = 0; uint8_t cell_resel_prio = 0; cell_resel_sub_prio_e cell_resel_sub_prio; // ... }; struct intra_freq_cell_resel_info_s_ { bool ext = false; bool q_rx_lev_min_sul_present = false; bool q_qual_min_present = false; bool s_intra_search_q_present = false; bool freq_band_list_present = false; bool freq_band_list_sul_present = false; bool p_max_present = false; bool smtc_present = false; bool ss_rssi_meas_present = false; bool ssb_to_measure_present = false; int8_t q_rx_lev_min = -70; int8_t q_rx_lev_min_sul = -70; int8_t q_qual_min = -43; uint8_t s_intra_search_p = 0; uint8_t s_intra_search_q = 0; uint8_t t_resel_nr = 0; multi_freq_band_list_nr_sib_l freq_band_list; multi_freq_band_list_nr_sib_l freq_band_list_sul; int8_t p_max = -30; ssb_mtc_s smtc; ss_rssi_meas_s ss_rssi_meas; ssb_to_measure_c ssb_to_measure; bool derive_ssb_idx_from_cell = false; // ... // group 0 copy_ptr t_resel_nr_sf; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // member variables bool ext = false; cell_resel_info_common_s_ cell_resel_info_common; cell_resel_serving_freq_info_s_ cell_resel_serving_freq_info; intra_freq_cell_resel_info_s_ intra_freq_cell_resel_info; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB3 ::= SEQUENCE struct sib3_s { bool ext = false; bool intra_freq_neigh_cell_list_present = false; bool intra_freq_black_cell_list_present = false; bool late_non_crit_ext_present = false; intra_freq_neigh_cell_list_l intra_freq_neigh_cell_list; intra_freq_black_cell_list_l intra_freq_black_cell_list; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB4 ::= SEQUENCE struct sib4_s { bool ext = false; bool late_non_crit_ext_present = false; inter_freq_carrier_freq_list_l inter_freq_carrier_freq_list; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB5 ::= SEQUENCE struct sib5_s { bool ext = false; bool carrier_freq_list_eutra_present = false; bool t_resel_eutra_sf_present = false; bool late_non_crit_ext_present = false; carrier_freq_list_eutra_l carrier_freq_list_eutra; uint8_t t_resel_eutra = 0; speed_state_scale_factors_s t_resel_eutra_sf; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB6 ::= SEQUENCE struct sib6_s { bool ext = false; bool late_non_crit_ext_present = false; fixed_bitstring<16> msg_id; fixed_bitstring<16> serial_num; fixed_octstring<2> warning_type; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB7 ::= SEQUENCE struct sib7_s { struct warning_msg_segment_type_opts { enum options { not_last_segment, last_segment, nulltype } value; const char* to_string() const; }; typedef enumerated warning_msg_segment_type_e_; // member variables bool ext = false; bool data_coding_scheme_present = false; bool late_non_crit_ext_present = false; fixed_bitstring<16> msg_id; fixed_bitstring<16> serial_num; warning_msg_segment_type_e_ warning_msg_segment_type; uint8_t warning_msg_segment_num = 0; dyn_octstring warning_msg_segment; fixed_octstring<1> data_coding_scheme; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB8 ::= SEQUENCE struct sib8_s { struct warning_msg_segment_type_opts { enum options { not_last_segment, last_segment, nulltype } value; const char* to_string() const; }; typedef enumerated warning_msg_segment_type_e_; // member variables bool ext = false; bool data_coding_scheme_present = false; bool warning_area_coordinates_segment_present = false; bool late_non_crit_ext_present = false; fixed_bitstring<16> msg_id; fixed_bitstring<16> serial_num; warning_msg_segment_type_e_ warning_msg_segment_type; uint8_t warning_msg_segment_num = 0; dyn_octstring warning_msg_segment; fixed_octstring<1> data_coding_scheme; dyn_octstring warning_area_coordinates_segment; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB9 ::= SEQUENCE struct sib9_s { struct time_info_s_ { bool day_light_saving_time_present = false; bool leap_seconds_present = false; bool local_time_offset_present = false; uint64_t time_info_utc = 0; fixed_bitstring<2> day_light_saving_time; int16_t leap_seconds = -127; int8_t local_time_offset = -63; }; // member variables bool ext = false; bool time_info_present = false; bool late_non_crit_ext_present = false; time_info_s_ time_info; dyn_octstring late_non_crit_ext; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SchedulingInfo ::= SEQUENCE struct sched_info_s { struct si_broadcast_status_opts { enum options { broadcasting, not_broadcasting, nulltype } value; const char* to_string() const; }; typedef enumerated si_broadcast_status_e_; struct si_periodicity_opts { enum options { rf8, rf16, rf32, rf64, rf128, rf256, rf512, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated si_periodicity_e_; // member variables si_broadcast_status_e_ si_broadcast_status; si_periodicity_e_ si_periodicity; sib_map_l sib_map_info; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TDD-UL-DL-ConfigCommon ::= SEQUENCE struct tdd_ul_dl_cfg_common_s { bool ext = false; bool pattern2_present = false; subcarrier_spacing_e ref_subcarrier_spacing; tdd_ul_dl_pattern_s pattern1; tdd_ul_dl_pattern_s pattern2; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UAC-BarringInfoSet ::= SEQUENCE struct uac_barr_info_set_s { struct uac_barr_factor_opts { enum options { p00, p05, p10, p15, p20, p25, p30, p40, p50, p60, p70, p75, p80, p85, p90, p95, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated uac_barr_factor_e_; struct uac_barr_time_opts { enum options { s4, s8, s16, s32, s64, s128, s256, s512, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated uac_barr_time_e_; // member variables uac_barr_factor_e_ uac_barr_factor; uac_barr_time_e_ uac_barr_time; fixed_bitstring<7> uac_barr_for_access_id; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UAC-BarringPerPLMN ::= SEQUENCE struct uac_barr_per_plmn_s { struct uac_ac_barr_list_type_c_ { using uac_implicit_ac_barr_list_l_ = std::array; struct types_opts { enum options { uac_implicit_ac_barr_list, uac_explicit_ac_barr_list, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods uac_ac_barr_list_type_c_() = default; uac_ac_barr_list_type_c_(const uac_ac_barr_list_type_c_& other); uac_ac_barr_list_type_c_& operator=(const uac_ac_barr_list_type_c_& other); ~uac_ac_barr_list_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uac_implicit_ac_barr_list_l_& uac_implicit_ac_barr_list() { assert_choice_type(types::uac_implicit_ac_barr_list, type_, "uac-ACBarringListType"); return c.get(); } uac_barr_per_cat_list_l& uac_explicit_ac_barr_list() { assert_choice_type(types::uac_explicit_ac_barr_list, type_, "uac-ACBarringListType"); return c.get(); } const uac_implicit_ac_barr_list_l_& uac_implicit_ac_barr_list() const { assert_choice_type(types::uac_implicit_ac_barr_list, type_, "uac-ACBarringListType"); return c.get(); } const uac_barr_per_cat_list_l& uac_explicit_ac_barr_list() const { assert_choice_type(types::uac_explicit_ac_barr_list, type_, "uac-ACBarringListType"); return c.get(); } uac_implicit_ac_barr_list_l_& set_uac_implicit_ac_barr_list(); uac_barr_per_cat_list_l& set_uac_explicit_ac_barr_list(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool uac_ac_barr_list_type_present = false; uint8_t plmn_id_idx = 1; uac_ac_barr_list_type_c_ uac_ac_barr_list_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UplinkConfigCommonSIB ::= SEQUENCE struct ul_cfg_common_sib_s { freq_info_ul_sib_s freq_info_ul; bwp_ul_common_s init_ul_bwp; time_align_timer_e time_align_timer_common; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellAccessRelatedInfo ::= SEQUENCE struct cell_access_related_info_s { bool ext = false; bool cell_reserved_for_other_use_present = false; plmn_id_info_list_l plmn_id_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ConnEstFailureControl ::= SEQUENCE struct conn_est_fail_ctrl_s { struct conn_est_fail_count_opts { enum options { n1, n2, n3, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated conn_est_fail_count_e_; struct conn_est_fail_offset_validity_opts { enum options { s30, s60, s120, s240, s300, s420, s600, s900, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated conn_est_fail_offset_validity_e_; // member variables bool conn_est_fail_offset_present = false; conn_est_fail_count_e_ conn_est_fail_count; conn_est_fail_offset_validity_e_ conn_est_fail_offset_validity; uint8_t conn_est_fail_offset = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SI-SchedulingInfo ::= SEQUENCE struct si_sched_info_s { using sched_info_list_l_ = dyn_array; struct si_win_len_opts { enum options { s5, s10, s20, s40, s80, s160, s320, s640, s1280, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated si_win_len_e_; // member variables bool ext = false; bool si_request_cfg_present = false; bool si_request_cfg_sul_present = false; bool sys_info_area_id_present = false; sched_info_list_l_ sched_info_list; si_win_len_e_ si_win_len; si_request_cfg_s si_request_cfg; si_request_cfg_s si_request_cfg_sul; fixed_bitstring<24> sys_info_area_id; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ServingCellConfigCommonSIB ::= SEQUENCE struct serving_cell_cfg_common_sib_s { struct n_timing_advance_offset_opts { enum options { n0, n25600, n39936, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated n_timing_advance_offset_e_; struct ssb_positions_in_burst_s_ { bool group_presence_present = false; fixed_bitstring<8> in_one_group; fixed_bitstring<8> group_presence; }; struct ssb_periodicity_serving_cell_opts { enum options { ms5, ms10, ms20, ms40, ms80, ms160, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ssb_periodicity_serving_cell_e_; // member variables bool ext = false; bool ul_cfg_common_present = false; bool supplementary_ul_present = false; bool n_timing_advance_offset_present = false; bool tdd_ul_dl_cfg_common_present = false; dl_cfg_common_sib_s dl_cfg_common; ul_cfg_common_sib_s ul_cfg_common; ul_cfg_common_sib_s supplementary_ul; n_timing_advance_offset_e_ n_timing_advance_offset; ssb_positions_in_burst_s_ ssb_positions_in_burst; ssb_periodicity_serving_cell_e_ ssb_periodicity_serving_cell; tdd_ul_dl_cfg_common_s tdd_ul_dl_cfg_common; int8_t ss_pbch_block_pwr = -60; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SystemInformation-IEs ::= SEQUENCE struct sys_info_ies_s { struct sib_type_and_info_item_c_ { struct types_opts { enum options { sib2, sib3, sib4, sib5, sib6, sib7, sib8, sib9, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods sib_type_and_info_item_c_() = default; sib_type_and_info_item_c_(const sib_type_and_info_item_c_& other); sib_type_and_info_item_c_& operator=(const sib_type_and_info_item_c_& other); ~sib_type_and_info_item_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters sib2_s& sib2() { assert_choice_type(types::sib2, type_, "sib-TypeAndInfo-item"); return c.get(); } sib3_s& sib3() { assert_choice_type(types::sib3, type_, "sib-TypeAndInfo-item"); return c.get(); } sib4_s& sib4() { assert_choice_type(types::sib4, type_, "sib-TypeAndInfo-item"); return c.get(); } sib5_s& sib5() { assert_choice_type(types::sib5, type_, "sib-TypeAndInfo-item"); return c.get(); } sib6_s& sib6() { assert_choice_type(types::sib6, type_, "sib-TypeAndInfo-item"); return c.get(); } sib7_s& sib7() { assert_choice_type(types::sib7, type_, "sib-TypeAndInfo-item"); return c.get(); } sib8_s& sib8() { assert_choice_type(types::sib8, type_, "sib-TypeAndInfo-item"); return c.get(); } sib9_s& sib9() { assert_choice_type(types::sib9, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib2_s& sib2() const { assert_choice_type(types::sib2, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib3_s& sib3() const { assert_choice_type(types::sib3, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib4_s& sib4() const { assert_choice_type(types::sib4, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib5_s& sib5() const { assert_choice_type(types::sib5, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib6_s& sib6() const { assert_choice_type(types::sib6, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib7_s& sib7() const { assert_choice_type(types::sib7, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib8_s& sib8() const { assert_choice_type(types::sib8, type_, "sib-TypeAndInfo-item"); return c.get(); } const sib9_s& sib9() const { assert_choice_type(types::sib9, type_, "sib-TypeAndInfo-item"); return c.get(); } sib2_s& set_sib2(); sib3_s& set_sib3(); sib4_s& set_sib4(); sib5_s& set_sib5(); sib6_s& set_sib6(); sib7_s& set_sib7(); sib8_s& set_sib8(); sib9_s& set_sib9(); private: types type_; choice_buffer_t c; void destroy_(); }; using sib_type_and_info_l_ = dyn_array; // member variables bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; sib_type_and_info_l_ sib_type_and_info; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UAC-AccessCategory1-SelectionAssistanceInfo ::= ENUMERATED struct uac_access_category1_sel_assist_info_opts { enum options { a, b, c, nulltype } value; const char* to_string() const; }; typedef enumerated uac_access_category1_sel_assist_info_e; // UAC-BarringInfoSetList ::= SEQUENCE (SIZE (1..8)) OF UAC-BarringInfoSet using uac_barr_info_set_list_l = dyn_array; // UAC-BarringPerPLMN-List ::= SEQUENCE (SIZE (1..12)) OF UAC-BarringPerPLMN using uac_barr_per_plmn_list_l = dyn_array; // UE-TimersAndConstants ::= SEQUENCE struct ue_timers_and_consts_s { struct t300_opts { enum options { ms100, ms200, ms300, ms400, ms600, ms1000, ms1500, ms2000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t300_e_; struct t301_opts { enum options { ms100, ms200, ms300, ms400, ms600, ms1000, ms1500, ms2000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t301_e_; struct t310_opts { enum options { ms0, ms50, ms100, ms200, ms500, ms1000, ms2000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t310_e_; struct n310_opts { enum options { n1, n2, n3, n4, n6, n8, n10, n20, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated n310_e_; struct t311_opts { enum options { ms1000, ms3000, ms5000, ms10000, ms15000, ms20000, ms30000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t311_e_; struct n311_opts { enum options { n1, n2, n3, n4, n5, n6, n8, n10, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated n311_e_; struct t319_opts { enum options { ms100, ms200, ms300, ms400, ms600, ms1000, ms1500, ms2000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t319_e_; // member variables bool ext = false; t300_e_ t300; t301_e_ t301; t310_e_ t310; n310_e_ n310; t311_e_ t311; n311_e_ n311; t319_e_ t319; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SIB1 ::= SEQUENCE struct sib1_s { struct cell_sel_info_s_ { bool q_rx_lev_min_offset_present = false; bool q_rx_lev_min_sul_present = false; bool q_qual_min_present = false; bool q_qual_min_offset_present = false; int8_t q_rx_lev_min = -70; uint8_t q_rx_lev_min_offset = 1; int8_t q_rx_lev_min_sul = -70; int8_t q_qual_min = -43; uint8_t q_qual_min_offset = 1; }; struct uac_barr_info_s_ { struct uac_access_category1_sel_assist_info_c_ { using individual_plmn_list_l_ = bounded_array; struct types_opts { enum options { plmn_common, individual_plmn_list, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods uac_access_category1_sel_assist_info_c_() = default; uac_access_category1_sel_assist_info_c_(const uac_access_category1_sel_assist_info_c_& other); uac_access_category1_sel_assist_info_c_& operator=(const uac_access_category1_sel_assist_info_c_& other); ~uac_access_category1_sel_assist_info_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uac_access_category1_sel_assist_info_e& plmn_common() { assert_choice_type(types::plmn_common, type_, "uac-AccessCategory1-SelectionAssistanceInfo"); return c.get(); } individual_plmn_list_l_& individual_plmn_list() { assert_choice_type(types::individual_plmn_list, type_, "uac-AccessCategory1-SelectionAssistanceInfo"); return c.get(); } const uac_access_category1_sel_assist_info_e& plmn_common() const { assert_choice_type(types::plmn_common, type_, "uac-AccessCategory1-SelectionAssistanceInfo"); return c.get(); } const individual_plmn_list_l_& individual_plmn_list() const { assert_choice_type(types::individual_plmn_list, type_, "uac-AccessCategory1-SelectionAssistanceInfo"); return c.get(); } uac_access_category1_sel_assist_info_e& set_plmn_common(); individual_plmn_list_l_& set_individual_plmn_list(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool uac_barr_for_common_present = false; bool uac_barr_per_plmn_list_present = false; bool uac_access_category1_sel_assist_info_present = false; uac_barr_per_cat_list_l uac_barr_for_common; uac_barr_per_plmn_list_l uac_barr_per_plmn_list; uac_barr_info_set_list_l uac_barr_info_set_list; uac_access_category1_sel_assist_info_c_ uac_access_category1_sel_assist_info; }; // member variables bool cell_sel_info_present = false; bool conn_est_fail_ctrl_present = false; bool si_sched_info_present = false; bool serving_cell_cfg_common_present = false; bool ims_emergency_support_present = false; bool ecall_over_ims_support_present = false; bool ue_timers_and_consts_present = false; bool uac_barr_info_present = false; bool use_full_resume_id_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; cell_sel_info_s_ cell_sel_info; cell_access_related_info_s cell_access_related_info; conn_est_fail_ctrl_s conn_est_fail_ctrl; si_sched_info_s si_sched_info; serving_cell_cfg_common_sib_s serving_cell_cfg_common; ue_timers_and_consts_s ue_timers_and_consts; uac_barr_info_s_ uac_barr_info; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SystemInformation ::= SEQUENCE struct sys_info_s { struct crit_exts_c_ { struct types_opts { enum options { sys_info, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters sys_info_ies_s& sys_info() { assert_choice_type(types::sys_info, type_, "criticalExtensions"); return c; } const sys_info_ies_s& sys_info() const { assert_choice_type(types::sys_info, type_, "criticalExtensions"); return c; } sys_info_ies_s& set_sys_info(); void set_crit_exts_future(); private: types type_; sys_info_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BCCH-DL-SCH-MessageType ::= CHOICE struct bcch_dl_sch_msg_type_c { struct c1_c_ { struct types_opts { enum options { sys_info, sib_type1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods c1_c_() = default; c1_c_(const c1_c_& other); c1_c_& operator=(const c1_c_& other); ~c1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters sys_info_s& sys_info() { assert_choice_type(types::sys_info, type_, "c1"); return c.get(); } sib1_s& sib_type1() { assert_choice_type(types::sib_type1, type_, "c1"); return c.get(); } const sys_info_s& sys_info() const { assert_choice_type(types::sys_info, type_, "c1"); return c.get(); } const sib1_s& sib_type1() const { assert_choice_type(types::sib_type1, type_, "c1"); return c.get(); } sys_info_s& set_sys_info(); sib1_s& set_sib_type1(); private: types type_; choice_buffer_t c; void destroy_(); }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods bcch_dl_sch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "BCCH-DL-SCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "BCCH-DL-SCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // BCCH-DL-SCH-Message ::= SEQUENCE struct bcch_dl_sch_msg_s { bcch_dl_sch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-DataSplitThreshold ::= ENUMERATED struct ul_data_split_thres_opts { enum options { b0, b100, b200, b400, b800, b1600, b3200, b6400, b12800, b25600, b51200, b102400, b204800, b409600, b819200, b1228800, b1638400, b2457600, b3276800, b4096000, b4915200, b5734400, b6553600, infinity, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef int32_t number_type; const char* to_string() const; int32_t to_number() const; }; typedef enumerated ul_data_split_thres_e; // CipheringAlgorithm ::= ENUMERATED struct ciphering_algorithm_opts { enum options { nea0, nea1, nea2, nea3, spare4, spare3, spare2, spare1, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ciphering_algorithm_e; // IntegrityProtAlgorithm ::= ENUMERATED struct integrity_prot_algorithm_opts { enum options { nia0, nia1, nia2, nia3, spare4, spare3, spare2, spare1, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated integrity_prot_algorithm_e; // PDCP-Config ::= SEQUENCE struct pdcp_cfg_s { struct drb_s_ { struct discard_timer_opts { enum options { ms10, ms20, ms30, ms40, ms50, ms60, ms75, ms100, ms150, ms200, ms250, ms300, ms500, ms750, ms1500, infinity, nulltype } value; typedef int16_t number_type; const char* to_string() const; int16_t to_number() const; }; typedef enumerated discard_timer_e_; struct pdcp_sn_size_ul_opts { enum options { len12bits, len18bits, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdcp_sn_size_ul_e_; struct pdcp_sn_size_dl_opts { enum options { len12bits, len18bits, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdcp_sn_size_dl_e_; struct hdr_compress_c_ { struct rohc_s_ { struct profiles_s_ { bool profile0x0001 = false; bool profile0x0002 = false; bool profile0x0003 = false; bool profile0x0004 = false; bool profile0x0006 = false; bool profile0x0101 = false; bool profile0x0102 = false; bool profile0x0103 = false; bool profile0x0104 = false; }; // member variables bool max_cid_present = false; bool drb_continue_rohc_present = false; uint16_t max_cid = 1; profiles_s_ profiles; }; struct ul_only_rohc_s_ { struct profiles_s_ { bool profile0x0006 = false; }; // member variables bool max_cid_present = false; bool drb_continue_rohc_present = false; uint16_t max_cid = 1; profiles_s_ profiles; }; struct types_opts { enum options { not_used, rohc, ul_only_rohc, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods hdr_compress_c_() = default; hdr_compress_c_(const hdr_compress_c_& other); hdr_compress_c_& operator=(const hdr_compress_c_& other); ~hdr_compress_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rohc_s_& rohc() { assert_choice_type(types::rohc, type_, "headerCompression"); return c.get(); } ul_only_rohc_s_& ul_only_rohc() { assert_choice_type(types::ul_only_rohc, type_, "headerCompression"); return c.get(); } const rohc_s_& rohc() const { assert_choice_type(types::rohc, type_, "headerCompression"); return c.get(); } const ul_only_rohc_s_& ul_only_rohc() const { assert_choice_type(types::ul_only_rohc, type_, "headerCompression"); return c.get(); } void set_not_used(); rohc_s_& set_rohc(); ul_only_rohc_s_& set_ul_only_rohc(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool discard_timer_present = false; bool pdcp_sn_size_ul_present = false; bool pdcp_sn_size_dl_present = false; bool integrity_protection_present = false; bool status_report_required_present = false; bool out_of_order_delivery_present = false; discard_timer_e_ discard_timer; pdcp_sn_size_ul_e_ pdcp_sn_size_ul; pdcp_sn_size_dl_e_ pdcp_sn_size_dl; hdr_compress_c_ hdr_compress; }; struct more_than_one_rlc_s_ { struct primary_path_s_ { bool cell_group_present = false; bool lc_ch_present = false; uint8_t cell_group = 0; uint8_t lc_ch = 1; }; // member variables bool ul_data_split_thres_present = false; bool pdcp_dupl_present = false; primary_path_s_ primary_path; ul_data_split_thres_e ul_data_split_thres; bool pdcp_dupl = false; }; struct t_reordering_opts { enum options { ms0, ms1, ms2, ms4, ms5, ms8, ms10, ms15, ms20, ms30, ms40, ms50, ms60, ms80, ms100, ms120, ms140, ms160, ms180, ms200, ms220, ms240, ms260, ms280, ms300, ms500, ms750, ms1000, ms1250, ms1500, ms1750, ms2000, ms2250, ms2500, ms2750, ms3000, spare28, spare27, spare26, spare25, spare24, spare23, spare22, spare21, spare20, spare19, spare18, spare17, spare16, spare15, spare14, spare13, spare12, spare11, spare10, spare09, spare08, spare07, spare06, spare05, spare04, spare03, spare02, spare01, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t_reordering_e_; // member variables bool ext = false; bool drb_present = false; bool more_than_one_rlc_present = false; bool t_reordering_present = false; drb_s_ drb; more_than_one_rlc_s_ more_than_one_rlc; t_reordering_e_ t_reordering; // ... // group 0 bool ciphering_disabled_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SDAP-Config ::= SEQUENCE struct sdap_cfg_s { struct sdap_hdr_dl_opts { enum options { present, absent, nulltype } value; const char* to_string() const; }; typedef enumerated sdap_hdr_dl_e_; struct sdap_hdr_ul_opts { enum options { present, absent, nulltype } value; const char* to_string() const; }; typedef enumerated sdap_hdr_ul_e_; using mapped_qos_flows_to_add_l_ = dyn_array; using mapped_qos_flows_to_release_l_ = dyn_array; // member variables bool ext = false; bool mapped_qos_flows_to_add_present = false; bool mapped_qos_flows_to_release_present = false; uint16_t pdu_session = 0; sdap_hdr_dl_e_ sdap_hdr_dl; sdap_hdr_ul_e_ sdap_hdr_ul; bool default_drb = false; mapped_qos_flows_to_add_l_ mapped_qos_flows_to_add; mapped_qos_flows_to_release_l_ mapped_qos_flows_to_release; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRB-ToAddMod ::= SEQUENCE struct drb_to_add_mod_s { struct cn_assoc_c_ { struct types_opts { enum options { eps_bearer_id, sdap_cfg, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods cn_assoc_c_() = default; cn_assoc_c_(const cn_assoc_c_& other); cn_assoc_c_& operator=(const cn_assoc_c_& other); ~cn_assoc_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& eps_bearer_id() { assert_choice_type(types::eps_bearer_id, type_, "cnAssociation"); return c.get(); } sdap_cfg_s& sdap_cfg() { assert_choice_type(types::sdap_cfg, type_, "cnAssociation"); return c.get(); } const uint8_t& eps_bearer_id() const { assert_choice_type(types::eps_bearer_id, type_, "cnAssociation"); return c.get(); } const sdap_cfg_s& sdap_cfg() const { assert_choice_type(types::sdap_cfg, type_, "cnAssociation"); return c.get(); } uint8_t& set_eps_bearer_id(); sdap_cfg_s& set_sdap_cfg(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool cn_assoc_present = false; bool reestablish_pdcp_present = false; bool recover_pdcp_present = false; bool pdcp_cfg_present = false; cn_assoc_c_ cn_assoc; uint8_t drb_id = 1; pdcp_cfg_s pdcp_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRB-ToAddMod ::= SEQUENCE struct srb_to_add_mod_s { bool ext = false; bool reestablish_pdcp_present = false; bool discard_on_pdcp_present = false; bool pdcp_cfg_present = false; uint8_t srb_id = 1; pdcp_cfg_s pdcp_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityAlgorithmConfig ::= SEQUENCE struct security_algorithm_cfg_s { bool ext = false; bool integrity_prot_algorithm_present = false; ciphering_algorithm_e ciphering_algorithm; integrity_prot_algorithm_e integrity_prot_algorithm; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRB-ToAddModList ::= SEQUENCE (SIZE (1..29)) OF DRB-ToAddMod using drb_to_add_mod_list_l = dyn_array; // DRB-ToReleaseList ::= SEQUENCE (SIZE (1..29)) OF INTEGER (1..32) using drb_to_release_list_l = bounded_array; // SRB-ToAddModList ::= SEQUENCE (SIZE (1..2)) OF SRB-ToAddMod using srb_to_add_mod_list_l = dyn_array; // SecurityConfig ::= SEQUENCE struct security_cfg_s { struct key_to_use_opts { enum options { master, secondary, nulltype } value; const char* to_string() const; }; typedef enumerated key_to_use_e_; // member variables bool ext = false; bool security_algorithm_cfg_present = false; bool key_to_use_present = false; security_algorithm_cfg_s security_algorithm_cfg; key_to_use_e_ key_to_use; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RadioBearerConfig ::= SEQUENCE struct radio_bearer_cfg_s { bool ext = false; bool srb_to_add_mod_list_present = false; bool srb3_to_release_present = false; bool drb_to_add_mod_list_present = false; bool drb_to_release_list_present = false; bool security_cfg_present = false; srb_to_add_mod_list_l srb_to_add_mod_list; drb_to_add_mod_list_l drb_to_add_mod_list; drb_to_release_list_l drb_to_release_list; security_cfg_s security_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReject-IEs ::= SEQUENCE struct rrc_reject_ies_s { bool wait_time_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; uint8_t wait_time = 1; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetup-IEs ::= SEQUENCE struct rrc_setup_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; radio_bearer_cfg_s radio_bearer_cfg; dyn_octstring master_cell_group; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReject ::= SEQUENCE struct rrc_reject_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_reject, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_reject_ies_s& rrc_reject() { assert_choice_type(types::rrc_reject, type_, "criticalExtensions"); return c; } const rrc_reject_ies_s& rrc_reject() const { assert_choice_type(types::rrc_reject, type_, "criticalExtensions"); return c; } rrc_reject_ies_s& set_rrc_reject(); void set_crit_exts_future(); private: types type_; rrc_reject_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetup ::= SEQUENCE struct rrc_setup_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_setup, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_setup_ies_s& rrc_setup() { assert_choice_type(types::rrc_setup, type_, "criticalExtensions"); return c; } const rrc_setup_ies_s& rrc_setup() const { assert_choice_type(types::rrc_setup, type_, "criticalExtensions"); return c; } rrc_setup_ies_s& set_rrc_setup(); void set_crit_exts_future(); private: types type_; rrc_setup_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DL-CCCH-MessageType ::= CHOICE struct dl_ccch_msg_type_c { struct c1_c_ { struct types_opts { enum options { rrc_reject, rrc_setup, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; c1_c_(const c1_c_& other); c1_c_& operator=(const c1_c_& other); ~c1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_reject_s& rrc_reject() { assert_choice_type(types::rrc_reject, type_, "c1"); return c.get(); } rrc_setup_s& rrc_setup() { assert_choice_type(types::rrc_setup, type_, "c1"); return c.get(); } const rrc_reject_s& rrc_reject() const { assert_choice_type(types::rrc_reject, type_, "c1"); return c.get(); } const rrc_setup_s& rrc_setup() const { assert_choice_type(types::rrc_setup, type_, "c1"); return c.get(); } rrc_reject_s& set_rrc_reject(); rrc_setup_s& set_rrc_setup(); void set_spare2(); void set_spare1(); private: types type_; choice_buffer_t c; void destroy_(); }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods dl_ccch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "DL-CCCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "DL-CCCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // DL-CCCH-Message ::= SEQUENCE struct dl_ccch_msg_s { dl_ccch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-Resource-Mobility ::= SEQUENCE struct csi_rs_res_mob_s { struct slot_cfg_c_ { struct types_opts { enum options { ms4, ms5, ms10, ms20, ms40, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods slot_cfg_c_() = default; slot_cfg_c_(const slot_cfg_c_& other); slot_cfg_c_& operator=(const slot_cfg_c_& other); ~slot_cfg_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ms4() { assert_choice_type(types::ms4, type_, "slotConfig"); return c.get(); } uint8_t& ms5() { assert_choice_type(types::ms5, type_, "slotConfig"); return c.get(); } uint8_t& ms10() { assert_choice_type(types::ms10, type_, "slotConfig"); return c.get(); } uint8_t& ms20() { assert_choice_type(types::ms20, type_, "slotConfig"); return c.get(); } uint16_t& ms40() { assert_choice_type(types::ms40, type_, "slotConfig"); return c.get(); } const uint8_t& ms4() const { assert_choice_type(types::ms4, type_, "slotConfig"); return c.get(); } const uint8_t& ms5() const { assert_choice_type(types::ms5, type_, "slotConfig"); return c.get(); } const uint8_t& ms10() const { assert_choice_type(types::ms10, type_, "slotConfig"); return c.get(); } const uint8_t& ms20() const { assert_choice_type(types::ms20, type_, "slotConfig"); return c.get(); } const uint16_t& ms40() const { assert_choice_type(types::ms40, type_, "slotConfig"); return c.get(); } uint8_t& set_ms4(); uint8_t& set_ms5(); uint8_t& set_ms10(); uint8_t& set_ms20(); uint16_t& set_ms40(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct associated_ssb_s_ { uint8_t ssb_idx = 0; bool is_quasi_colocated = false; }; struct freq_domain_alloc_c_ { struct types_opts { enum options { row1, row2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods freq_domain_alloc_c_() = default; freq_domain_alloc_c_(const freq_domain_alloc_c_& other); freq_domain_alloc_c_& operator=(const freq_domain_alloc_c_& other); ~freq_domain_alloc_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<4>& row1() { assert_choice_type(types::row1, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<12>& row2() { assert_choice_type(types::row2, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<4>& row1() const { assert_choice_type(types::row1, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<12>& row2() const { assert_choice_type(types::row2, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<4>& set_row1(); fixed_bitstring<12>& set_row2(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool ext = false; bool associated_ssb_present = false; uint8_t csi_rs_idx = 0; slot_cfg_c_ slot_cfg; associated_ssb_s_ associated_ssb; freq_domain_alloc_c_ freq_domain_alloc; uint8_t first_ofdm_symbol_in_time_domain = 0; uint16_t seq_generation_cfg = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-CellMobility ::= SEQUENCE struct csi_rs_cell_mob_s { struct csi_rs_meas_bw_s_ { struct nrof_prbs_opts { enum options { size24, size48, size96, size192, size264, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated nrof_prbs_e_; // member variables nrof_prbs_e_ nrof_prbs; uint16_t start_prb = 0; }; struct density_opts { enum options { d1, d3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated density_e_; using csi_rs_res_list_mob_l_ = dyn_array; // member variables bool density_present = false; uint16_t cell_id = 0; csi_rs_meas_bw_s_ csi_rs_meas_bw; density_e_ density; csi_rs_res_list_mob_l_ csi_rs_res_list_mob; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Q-OffsetRangeList ::= SEQUENCE struct q_offset_range_list_s { bool rsrp_offset_ssb_present = false; bool rsrq_offset_ssb_present = false; bool sinr_offset_ssb_present = false; bool rsrp_offset_csi_rs_present = false; bool rsrq_offset_csi_rs_present = false; bool sinr_offset_csi_rs_present = false; q_offset_range_e rsrp_offset_ssb; q_offset_range_e rsrq_offset_ssb; q_offset_range_e sinr_offset_ssb; q_offset_range_e rsrp_offset_csi_rs; q_offset_range_e rsrq_offset_csi_rs; q_offset_range_e sinr_offset_csi_rs; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-ResourceConfigMobility ::= SEQUENCE struct csi_rs_res_cfg_mob_s { using csi_rs_cell_list_mob_l_ = dyn_array; // member variables bool ext = false; subcarrier_spacing_e subcarrier_spacing; csi_rs_cell_list_mob_l_ csi_rs_cell_list_mob; // ... // group 0 bool ref_serv_cell_idx_present = false; uint8_t ref_serv_cell_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellsToAddMod ::= SEQUENCE struct cells_to_add_mod_s { uint16_t pci = 0; q_offset_range_list_s cell_individual_offset; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FilterCoefficient ::= ENUMERATED struct filt_coef_opts { enum options { fc0, fc1, fc2, fc3, fc4, fc5, fc6, fc7, fc8, fc9, fc11, fc13, fc15, fc17, fc19, spare1, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated filt_coef_e; // MeasReportQuantity ::= SEQUENCE struct meas_report_quant_s { bool rsrp = false; bool rsrq = false; bool sinr = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasTriggerQuantity ::= CHOICE struct meas_trigger_quant_c { struct types_opts { enum options { rsrp, rsrq, sinr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods meas_trigger_quant_c() = default; meas_trigger_quant_c(const meas_trigger_quant_c& other); meas_trigger_quant_c& operator=(const meas_trigger_quant_c& other); ~meas_trigger_quant_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& rsrp() { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantity"); return c.get(); } uint8_t& rsrq() { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantity"); return c.get(); } uint8_t& sinr() { assert_choice_type(types::sinr, type_, "MeasTriggerQuantity"); return c.get(); } const uint8_t& rsrp() const { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantity"); return c.get(); } const uint8_t& rsrq() const { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantity"); return c.get(); } const uint8_t& sinr() const { assert_choice_type(types::sinr, type_, "MeasTriggerQuantity"); return c.get(); } uint8_t& set_rsrp(); uint8_t& set_rsrq(); uint8_t& set_sinr(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // MeasTriggerQuantityEUTRA ::= CHOICE struct meas_trigger_quant_eutra_c { struct types_opts { enum options { rsrp, rsrq, sinr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods meas_trigger_quant_eutra_c() = default; meas_trigger_quant_eutra_c(const meas_trigger_quant_eutra_c& other); meas_trigger_quant_eutra_c& operator=(const meas_trigger_quant_eutra_c& other); ~meas_trigger_quant_eutra_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& rsrp() { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } uint8_t& rsrq() { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } uint8_t& sinr() { assert_choice_type(types::sinr, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } const uint8_t& rsrp() const { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } const uint8_t& rsrq() const { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } const uint8_t& sinr() const { assert_choice_type(types::sinr, type_, "MeasTriggerQuantityEUTRA"); return c.get(); } uint8_t& set_rsrp(); uint8_t& set_rsrq(); uint8_t& set_sinr(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // MeasTriggerQuantityOffset ::= CHOICE struct meas_trigger_quant_offset_c { struct types_opts { enum options { rsrp, rsrq, sinr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods meas_trigger_quant_offset_c() = default; meas_trigger_quant_offset_c(const meas_trigger_quant_offset_c& other); meas_trigger_quant_offset_c& operator=(const meas_trigger_quant_offset_c& other); ~meas_trigger_quant_offset_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters int8_t& rsrp() { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantityOffset"); return c.get(); } int8_t& rsrq() { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantityOffset"); return c.get(); } int8_t& sinr() { assert_choice_type(types::sinr, type_, "MeasTriggerQuantityOffset"); return c.get(); } const int8_t& rsrp() const { assert_choice_type(types::rsrp, type_, "MeasTriggerQuantityOffset"); return c.get(); } const int8_t& rsrq() const { assert_choice_type(types::rsrq, type_, "MeasTriggerQuantityOffset"); return c.get(); } const int8_t& sinr() const { assert_choice_type(types::sinr, type_, "MeasTriggerQuantityOffset"); return c.get(); } int8_t& set_rsrp(); int8_t& set_rsrq(); int8_t& set_sinr(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // NR-RS-Type ::= ENUMERATED struct nr_rs_type_opts { enum options { ssb, csi_rs, nulltype } value; const char* to_string() const; }; typedef enumerated nr_rs_type_e; // ReportInterval ::= ENUMERATED struct report_interv_opts { enum options { ms120, ms240, ms480, ms640, ms1024, ms2048, ms5120, ms10240, ms20480, ms40960, min1, min6, min12, min30, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated report_interv_e; // SSB-ConfigMobility ::= SEQUENCE struct ssb_cfg_mob_s { bool ext = false; bool ssb_to_measure_present = false; bool ss_rssi_meas_present = false; setup_release_c ssb_to_measure; bool derive_ssb_idx_from_cell = false; ss_rssi_meas_s ss_rssi_meas; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TimeToTrigger ::= ENUMERATED struct time_to_trigger_opts { enum options { ms0, ms40, ms64, ms80, ms100, ms128, ms160, ms256, ms320, ms480, ms512, ms640, ms1024, ms1280, ms2560, ms5120, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated time_to_trigger_e; // CellsToAddModList ::= SEQUENCE (SIZE (1..32)) OF CellsToAddMod using cells_to_add_mod_list_l = dyn_array; // EUTRA-BlackCell ::= SEQUENCE struct eutra_black_cell_s { uint8_t cell_idx_eutra = 1; eutra_pci_range_s pci_range; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-Cell ::= SEQUENCE struct eutra_cell_s { uint8_t cell_idx_eutra = 1; uint16_t pci = 0; eutra_q_offset_range_e cell_individual_offset; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-CellIndexList ::= SEQUENCE (SIZE (1..32)) OF INTEGER (1..32) using eutra_cell_idx_list_l = bounded_array; // EventTriggerConfig ::= SEQUENCE struct event_trigger_cfg_s { struct event_id_c_ { struct event_a1_s_ { meas_trigger_quant_c a1_thres; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; }; struct event_a2_s_ { meas_trigger_quant_c a2_thres; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; }; struct event_a3_s_ { meas_trigger_quant_offset_c a3_offset; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; bool use_white_cell_list = false; }; struct event_a4_s_ { meas_trigger_quant_c a4_thres; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; bool use_white_cell_list = false; }; struct event_a5_s_ { meas_trigger_quant_c a5_thres1; meas_trigger_quant_c a5_thres2; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; bool use_white_cell_list = false; }; struct event_a6_s_ { meas_trigger_quant_offset_c a6_offset; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; bool use_white_cell_list = false; }; struct types_opts { enum options { event_a1, event_a2, event_a3, event_a4, event_a5, event_a6, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods event_id_c_() = default; event_id_c_(const event_id_c_& other); event_id_c_& operator=(const event_id_c_& other); ~event_id_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters event_a1_s_& event_a1() { assert_choice_type(types::event_a1, type_, "eventId"); return c.get(); } event_a2_s_& event_a2() { assert_choice_type(types::event_a2, type_, "eventId"); return c.get(); } event_a3_s_& event_a3() { assert_choice_type(types::event_a3, type_, "eventId"); return c.get(); } event_a4_s_& event_a4() { assert_choice_type(types::event_a4, type_, "eventId"); return c.get(); } event_a5_s_& event_a5() { assert_choice_type(types::event_a5, type_, "eventId"); return c.get(); } event_a6_s_& event_a6() { assert_choice_type(types::event_a6, type_, "eventId"); return c.get(); } const event_a1_s_& event_a1() const { assert_choice_type(types::event_a1, type_, "eventId"); return c.get(); } const event_a2_s_& event_a2() const { assert_choice_type(types::event_a2, type_, "eventId"); return c.get(); } const event_a3_s_& event_a3() const { assert_choice_type(types::event_a3, type_, "eventId"); return c.get(); } const event_a4_s_& event_a4() const { assert_choice_type(types::event_a4, type_, "eventId"); return c.get(); } const event_a5_s_& event_a5() const { assert_choice_type(types::event_a5, type_, "eventId"); return c.get(); } const event_a6_s_& event_a6() const { assert_choice_type(types::event_a6, type_, "eventId"); return c.get(); } event_a1_s_& set_event_a1(); event_a2_s_& set_event_a2(); event_a3_s_& set_event_a3(); event_a4_s_& set_event_a4(); event_a5_s_& set_event_a5(); event_a6_s_& set_event_a6(); private: types type_; choice_buffer_t c; void destroy_(); }; struct report_amount_opts { enum options { r1, r2, r4, r8, r16, r32, r64, infinity, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated report_amount_e_; // member variables bool ext = false; bool report_quant_rs_idxes_present = false; bool max_nrof_rs_idxes_to_report_present = false; bool report_add_neigh_meas_present = false; event_id_c_ event_id; nr_rs_type_e rs_type; report_interv_e report_interv; report_amount_e_ report_amount; meas_report_quant_s report_quant_cell; uint8_t max_report_cells = 1; meas_report_quant_s report_quant_rs_idxes; uint8_t max_nrof_rs_idxes_to_report = 1; bool include_beam_meass = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EventTriggerConfigInterRAT ::= SEQUENCE struct event_trigger_cfg_inter_rat_s { struct event_id_c_ { struct event_b1_s_ { bool ext = false; meas_trigger_quant_eutra_c b1_thres_eutra; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; // ... }; struct event_b2_s_ { bool ext = false; meas_trigger_quant_c b2_thres1; meas_trigger_quant_eutra_c b2_thres2_eutra; bool report_on_leave = false; uint8_t hysteresis = 0; time_to_trigger_e time_to_trigger; // ... }; struct types_opts { enum options { event_b1, event_b2, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods event_id_c_() = default; event_id_c_(const event_id_c_& other); event_id_c_& operator=(const event_id_c_& other); ~event_id_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters event_b1_s_& event_b1() { assert_choice_type(types::event_b1, type_, "eventId"); return c.get(); } event_b2_s_& event_b2() { assert_choice_type(types::event_b2, type_, "eventId"); return c.get(); } const event_b1_s_& event_b1() const { assert_choice_type(types::event_b1, type_, "eventId"); return c.get(); } const event_b2_s_& event_b2() const { assert_choice_type(types::event_b2, type_, "eventId"); return c.get(); } event_b1_s_& set_event_b1(); event_b2_s_& set_event_b2(); private: types type_; choice_buffer_t c; void destroy_(); }; struct report_amount_opts { enum options { r1, r2, r4, r8, r16, r32, r64, infinity, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated report_amount_e_; // member variables bool ext = false; event_id_c_ event_id; nr_rs_type_e rs_type; report_interv_e report_interv; report_amount_e_ report_amount; meas_report_quant_s report_quant; uint8_t max_report_cells = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FilterConfig ::= SEQUENCE struct filt_cfg_s { bool filt_coef_rsrp_present = false; bool filt_coef_rsrq_present = false; bool filt_coef_rs_sinr_present = false; filt_coef_e filt_coef_rsrp; filt_coef_e filt_coef_rsrq; filt_coef_e filt_coef_rs_sinr; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PCI-List ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..1007) using pci_list_l = bounded_array; // PCI-RangeElement ::= SEQUENCE struct pci_range_elem_s { uint8_t pci_range_idx = 1; pci_range_s pci_range; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PCI-RangeIndexList ::= SEQUENCE (SIZE (1..8)) OF INTEGER (1..8) using pci_range_idx_list_l = bounded_array; // PeriodicalReportConfig ::= SEQUENCE struct periodical_report_cfg_s { struct report_amount_opts { enum options { r1, r2, r4, r8, r16, r32, r64, infinity, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated report_amount_e_; // member variables bool ext = false; bool report_quant_rs_idxes_present = false; bool max_nrof_rs_idxes_to_report_present = false; nr_rs_type_e rs_type; report_interv_e report_interv; report_amount_e_ report_amount; meas_report_quant_s report_quant_cell; uint8_t max_report_cells = 1; meas_report_quant_s report_quant_rs_idxes; uint8_t max_nrof_rs_idxes_to_report = 1; bool include_beam_meass = false; bool use_white_cell_list = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PeriodicalReportConfigInterRAT ::= SEQUENCE struct periodical_report_cfg_inter_rat_s { struct report_amount_opts { enum options { r1, r2, r4, r8, r16, r32, r64, infinity, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated report_amount_e_; // member variables bool ext = false; report_interv_e report_interv; report_amount_e_ report_amount; meas_report_quant_s report_quant; uint8_t max_report_cells = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RAN-AreaConfig ::= SEQUENCE struct ran_area_cfg_s { using ran_area_code_list_l_ = bounded_array; // member variables bool ran_area_code_list_present = false; fixed_bitstring<24> tac; ran_area_code_list_l_ ran_area_code_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReferenceSignalConfig ::= SEQUENCE struct ref_sig_cfg_s { bool ssb_cfg_mob_present = false; bool csi_rs_res_cfg_mob_present = false; ssb_cfg_mob_s ssb_cfg_mob; setup_release_c csi_rs_res_cfg_mob; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportCGI ::= SEQUENCE struct report_cgi_s { bool ext = false; uint16_t cell_for_which_to_report_cgi = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportCGI-EUTRA ::= SEQUENCE struct report_cgi_eutra_s { bool ext = false; uint16_t cell_for_which_to_report_cgi = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportSFTD-EUTRA ::= SEQUENCE struct report_sftd_eutra_s { bool ext = false; bool report_sftd_meas = false; bool report_rsrp = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportSFTD-NR ::= SEQUENCE struct report_sftd_nr_s { using cells_for_which_to_report_sftd_l_ = bounded_array; // member variables bool ext = false; bool report_sftd_meas = false; bool report_rsrp = false; // ... // group 0 bool report_sftd_neigh_meas_present = false; bool drx_sftd_neigh_meas_present = false; copy_ptr cells_for_which_to_report_sftd; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SSB-MTC2 ::= SEQUENCE struct ssb_mtc2_s { using pci_list_l_ = dyn_array; struct periodicity_opts { enum options { sf5, sf10, sf20, sf40, sf80, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated periodicity_e_; // member variables bool pci_list_present = false; pci_list_l_ pci_list; periodicity_e_ periodicity; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MRDC-SecondaryCellGroupConfig ::= SEQUENCE struct mrdc_secondary_cell_group_cfg_s { struct mrdc_secondary_cell_group_c_ { struct types_opts { enum options { nr_scg, eutra_scg, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods mrdc_secondary_cell_group_c_() = default; mrdc_secondary_cell_group_c_(const mrdc_secondary_cell_group_c_& other); mrdc_secondary_cell_group_c_& operator=(const mrdc_secondary_cell_group_c_& other); ~mrdc_secondary_cell_group_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dyn_octstring& nr_scg() { assert_choice_type(types::nr_scg, type_, "mrdc-SecondaryCellGroup"); return c.get(); } dyn_octstring& eutra_scg() { assert_choice_type(types::eutra_scg, type_, "mrdc-SecondaryCellGroup"); return c.get(); } const dyn_octstring& nr_scg() const { assert_choice_type(types::nr_scg, type_, "mrdc-SecondaryCellGroup"); return c.get(); } const dyn_octstring& eutra_scg() const { assert_choice_type(types::eutra_scg, type_, "mrdc-SecondaryCellGroup"); return c.get(); } dyn_octstring& set_nr_scg(); dyn_octstring& set_eutra_scg(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool mrdc_release_and_add_present = false; mrdc_secondary_cell_group_c_ mrdc_secondary_cell_group; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasObjectEUTRA ::= SEQUENCE struct meas_obj_eutra_s { using cells_to_add_mod_list_eutran_l_ = dyn_array; using black_cells_to_add_mod_list_eutran_l_ = dyn_array; // member variables bool ext = false; bool cells_to_rem_list_eutran_present = false; bool cells_to_add_mod_list_eutran_present = false; bool black_cells_to_rem_list_eutran_present = false; bool black_cells_to_add_mod_list_eutran_present = false; bool eutra_q_offset_range_present = false; uint32_t carrier_freq = 0; eutra_allowed_meas_bw_e allowed_meas_bw; eutra_cell_idx_list_l cells_to_rem_list_eutran; cells_to_add_mod_list_eutran_l_ cells_to_add_mod_list_eutran; eutra_cell_idx_list_l black_cells_to_rem_list_eutran; black_cells_to_add_mod_list_eutran_l_ black_cells_to_add_mod_list_eutran; bool eutra_presence_ant_port1 = false; eutra_q_offset_range_e eutra_q_offset_range; bool wideband_rsrq_meas = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasObjectNR ::= SEQUENCE struct meas_obj_nr_s { using black_cells_to_add_mod_list_l_ = dyn_array; using white_cells_to_add_mod_list_l_ = dyn_array; struct meas_cycle_scell_opts { enum options { sf160, sf256, sf320, sf512, sf640, sf1024, sf1280, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated meas_cycle_scell_e_; // member variables bool ext = false; bool ssb_freq_present = false; bool ssb_subcarrier_spacing_present = false; bool smtc1_present = false; bool smtc2_present = false; bool ref_freq_csi_rs_present = false; bool abs_thresh_ss_blocks_consolidation_present = false; bool abs_thresh_csi_rs_consolidation_present = false; bool nrof_ss_blocks_to_average_present = false; bool nrof_csi_rs_res_to_average_present = false; bool cells_to_rem_list_present = false; bool cells_to_add_mod_list_present = false; bool black_cells_to_rem_list_present = false; bool black_cells_to_add_mod_list_present = false; bool white_cells_to_rem_list_present = false; bool white_cells_to_add_mod_list_present = false; uint32_t ssb_freq = 0; subcarrier_spacing_e ssb_subcarrier_spacing; ssb_mtc_s smtc1; ssb_mtc2_s smtc2; uint32_t ref_freq_csi_rs = 0; ref_sig_cfg_s ref_sig_cfg; thres_nr_s abs_thresh_ss_blocks_consolidation; thres_nr_s abs_thresh_csi_rs_consolidation; uint8_t nrof_ss_blocks_to_average = 2; uint8_t nrof_csi_rs_res_to_average = 2; uint8_t quant_cfg_idx = 1; q_offset_range_list_s offset_mo; pci_list_l cells_to_rem_list; cells_to_add_mod_list_l cells_to_add_mod_list; pci_range_idx_list_l black_cells_to_rem_list; black_cells_to_add_mod_list_l_ black_cells_to_add_mod_list; pci_range_idx_list_l white_cells_to_rem_list; white_cells_to_add_mod_list_l_ white_cells_to_add_mod_list; // ... // group 0 bool freq_band_ind_nr_present = false; bool meas_cycle_scell_present = false; uint16_t freq_band_ind_nr = 1; meas_cycle_scell_e_ meas_cycle_scell; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // OverheatingAssistanceConfig ::= SEQUENCE struct overheat_assist_cfg_s { struct overheat_ind_prohibit_timer_opts { enum options { s0, s0dot5, s1, s2, s5, s10, s20, s30, s60, s90, s120, s300, s600, spare3, spare2, spare1, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated overheat_ind_prohibit_timer_e_; // member variables overheat_ind_prohibit_timer_e_ overheat_ind_prohibit_timer; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-RAN-AreaCell ::= SEQUENCE struct plmn_ran_area_cell_s { using ran_area_cells_l_ = bounded_array, 32>; // member variables bool plmn_id_present = false; plmn_id_s plmn_id; ran_area_cells_l_ ran_area_cells; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-RAN-AreaConfig ::= SEQUENCE struct plmn_ran_area_cfg_s { using ran_area_l_ = dyn_array; // member variables bool plmn_id_present = false; plmn_id_s plmn_id; ran_area_l_ ran_area; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // QuantityConfigRS ::= SEQUENCE struct quant_cfg_rs_s { filt_cfg_s ssb_filt_cfg; filt_cfg_s csi_rs_filt_cfg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportConfigInterRAT ::= SEQUENCE struct report_cfg_inter_rat_s { struct report_type_c_ { struct types_opts { enum options { periodical, event_triggered, report_cgi, /*...*/ report_sftd, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods report_type_c_() = default; report_type_c_(const report_type_c_& other); report_type_c_& operator=(const report_type_c_& other); ~report_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters periodical_report_cfg_inter_rat_s& periodical() { assert_choice_type(types::periodical, type_, "reportType"); return c.get(); } event_trigger_cfg_inter_rat_s& event_triggered() { assert_choice_type(types::event_triggered, type_, "reportType"); return c.get(); } report_cgi_eutra_s& report_cgi() { assert_choice_type(types::report_cgi, type_, "reportType"); return c.get(); } report_sftd_eutra_s& report_sftd() { assert_choice_type(types::report_sftd, type_, "reportType"); return c.get(); } const periodical_report_cfg_inter_rat_s& periodical() const { assert_choice_type(types::periodical, type_, "reportType"); return c.get(); } const event_trigger_cfg_inter_rat_s& event_triggered() const { assert_choice_type(types::event_triggered, type_, "reportType"); return c.get(); } const report_cgi_eutra_s& report_cgi() const { assert_choice_type(types::report_cgi, type_, "reportType"); return c.get(); } const report_sftd_eutra_s& report_sftd() const { assert_choice_type(types::report_sftd, type_, "reportType"); return c.get(); } periodical_report_cfg_inter_rat_s& set_periodical(); event_trigger_cfg_inter_rat_s& set_event_triggered(); report_cgi_eutra_s& set_report_cgi(); report_sftd_eutra_s& set_report_sftd(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables report_type_c_ report_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportConfigNR ::= SEQUENCE struct report_cfg_nr_s { struct report_type_c_ { struct types_opts { enum options { periodical, event_triggered, /*...*/ report_cgi, report_sftd, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods report_type_c_() = default; report_type_c_(const report_type_c_& other); report_type_c_& operator=(const report_type_c_& other); ~report_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters periodical_report_cfg_s& periodical() { assert_choice_type(types::periodical, type_, "reportType"); return c.get(); } event_trigger_cfg_s& event_triggered() { assert_choice_type(types::event_triggered, type_, "reportType"); return c.get(); } report_cgi_s& report_cgi() { assert_choice_type(types::report_cgi, type_, "reportType"); return c.get(); } report_sftd_nr_s& report_sftd() { assert_choice_type(types::report_sftd, type_, "reportType"); return c.get(); } const periodical_report_cfg_s& periodical() const { assert_choice_type(types::periodical, type_, "reportType"); return c.get(); } const event_trigger_cfg_s& event_triggered() const { assert_choice_type(types::event_triggered, type_, "reportType"); return c.get(); } const report_cgi_s& report_cgi() const { assert_choice_type(types::report_cgi, type_, "reportType"); return c.get(); } const report_sftd_nr_s& report_sftd() const { assert_choice_type(types::report_sftd, type_, "reportType"); return c.get(); } periodical_report_cfg_s& set_periodical(); event_trigger_cfg_s& set_event_triggered(); report_cgi_s& set_report_cgi(); report_sftd_nr_s& set_report_sftd(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables report_type_c_ report_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqPriorityEUTRA ::= SEQUENCE struct freq_prio_eutra_s { bool cell_resel_sub_prio_present = false; uint32_t carrier_freq = 0; uint8_t cell_resel_prio = 0; cell_resel_sub_prio_e cell_resel_sub_prio; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqPriorityNR ::= SEQUENCE struct freq_prio_nr_s { bool cell_resel_sub_prio_present = false; uint32_t carrier_freq = 0; uint8_t cell_resel_prio = 0; cell_resel_sub_prio_e cell_resel_sub_prio; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // GapConfig ::= SEQUENCE struct gap_cfg_s { struct mgl_opts { enum options { ms1dot5, ms3, ms3dot5, ms4, ms5dot5, ms6, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated mgl_e_; struct mgrp_opts { enum options { ms20, ms40, ms80, ms160, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated mgrp_e_; struct mgta_opts { enum options { ms0, ms0dot25, ms0dot5, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated mgta_e_; struct ref_serv_cell_ind_opts { enum options { pcell, pscell, mcg_fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ref_serv_cell_ind_e_; // member variables bool ext = false; uint8_t gap_offset = 0; mgl_e_ mgl; mgrp_e_ mgrp; mgta_e_ mgta; // ... // group 0 bool ref_serv_cell_ind_present = false; ref_serv_cell_ind_e_ ref_serv_cell_ind; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasGapSharingScheme ::= ENUMERATED struct meas_gap_sharing_scheme_opts { enum options { scheme00, scheme01, scheme10, scheme11, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated meas_gap_sharing_scheme_e; // MeasIdToAddMod ::= SEQUENCE struct meas_id_to_add_mod_s { uint8_t meas_id = 1; uint8_t meas_obj_id = 1; uint8_t report_cfg_id = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasObjectToAddMod ::= SEQUENCE struct meas_obj_to_add_mod_s { struct meas_obj_c_ { struct types_opts { enum options { meas_obj_nr, /*...*/ meas_obj_eutra, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods meas_obj_c_() = default; meas_obj_c_(const meas_obj_c_& other); meas_obj_c_& operator=(const meas_obj_c_& other); ~meas_obj_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters meas_obj_nr_s& meas_obj_nr() { assert_choice_type(types::meas_obj_nr, type_, "measObject"); return c.get(); } meas_obj_eutra_s& meas_obj_eutra() { assert_choice_type(types::meas_obj_eutra, type_, "measObject"); return c.get(); } const meas_obj_nr_s& meas_obj_nr() const { assert_choice_type(types::meas_obj_nr, type_, "measObject"); return c.get(); } const meas_obj_eutra_s& meas_obj_eutra() const { assert_choice_type(types::meas_obj_eutra, type_, "measObject"); return c.get(); } meas_obj_nr_s& set_meas_obj_nr(); meas_obj_eutra_s& set_meas_obj_eutra(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables uint8_t meas_obj_id = 1; meas_obj_c_ meas_obj; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // OtherConfig-v1540 ::= SEQUENCE struct other_cfg_v1540_s { bool ext = false; bool overheat_assist_cfg_present = false; setup_release_c overheat_assist_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-RAN-AreaCellList ::= SEQUENCE (SIZE (1..8)) OF PLMN-RAN-AreaCell using plmn_ran_area_cell_list_l = dyn_array; // PLMN-RAN-AreaConfigList ::= SEQUENCE (SIZE (1..8)) OF PLMN-RAN-AreaConfig using plmn_ran_area_cfg_list_l = dyn_array; // QuantityConfigNR ::= SEQUENCE struct quant_cfg_nr_s { bool quant_cfg_rs_idx_present = false; quant_cfg_rs_s quant_cfg_cell; quant_cfg_rs_s quant_cfg_rs_idx; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RAT-Type ::= ENUMERATED struct rat_type_opts { enum options { nr, eutra_nr, eutra, spare1, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated rat_type_e; // RRCReconfiguration-v1560-IEs ::= SEQUENCE struct rrc_recfg_v1560_ies_s { bool mrdc_secondary_cell_group_cfg_present = false; bool radio_bearer_cfg2_present = false; bool sk_counter_present = false; bool non_crit_ext_present = false; setup_release_c mrdc_secondary_cell_group_cfg; dyn_octstring radio_bearer_cfg2; uint32_t sk_counter = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportConfigToAddMod ::= SEQUENCE struct report_cfg_to_add_mod_s { struct report_cfg_c_ { struct types_opts { enum options { report_cfg_nr, /*...*/ report_cfg_inter_rat, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods report_cfg_c_() = default; report_cfg_c_(const report_cfg_c_& other); report_cfg_c_& operator=(const report_cfg_c_& other); ~report_cfg_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters report_cfg_nr_s& report_cfg_nr() { assert_choice_type(types::report_cfg_nr, type_, "reportConfig"); return c.get(); } report_cfg_inter_rat_s& report_cfg_inter_rat() { assert_choice_type(types::report_cfg_inter_rat, type_, "reportConfig"); return c.get(); } const report_cfg_nr_s& report_cfg_nr() const { assert_choice_type(types::report_cfg_nr, type_, "reportConfig"); return c.get(); } const report_cfg_inter_rat_s& report_cfg_inter_rat() const { assert_choice_type(types::report_cfg_inter_rat, type_, "reportConfig"); return c.get(); } report_cfg_nr_s& set_report_cfg_nr(); report_cfg_inter_rat_s& set_report_cfg_inter_rat(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables uint8_t report_cfg_id = 1; report_cfg_c_ report_cfg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CarrierInfoNR ::= SEQUENCE struct carrier_info_nr_s { bool ext = false; bool smtc_present = false; uint32_t carrier_freq = 0; subcarrier_spacing_e ssb_subcarrier_spacing; ssb_mtc_s smtc; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRB-CountMSB-Info ::= SEQUENCE struct drb_count_msb_info_s { uint8_t drb_id = 1; uint32_t count_msb_ul = 0; uint32_t count_msb_dl = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqPriorityListEUTRA ::= SEQUENCE (SIZE (1..8)) OF FreqPriorityEUTRA using freq_prio_list_eutra_l = dyn_array; // FreqPriorityListNR ::= SEQUENCE (SIZE (1..8)) OF FreqPriorityNR using freq_prio_list_nr_l = dyn_array; // MasterKeyUpdate ::= SEQUENCE struct master_key_upd_s { bool ext = false; bool nas_container_present = false; bool key_set_change_ind = false; uint8_t next_hop_chaining_count = 0; dyn_octstring nas_container; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasGapConfig ::= SEQUENCE struct meas_gap_cfg_s { bool ext = false; bool gap_fr2_present = false; setup_release_c gap_fr2; // ... // group 0 copy_ptr > gap_fr1; copy_ptr > gap_ue; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasGapSharingConfig ::= SEQUENCE struct meas_gap_sharing_cfg_s { bool ext = false; bool gap_sharing_fr2_present = false; setup_release_c gap_sharing_fr2; // ... // group 0 copy_ptr > gap_sharing_fr1; copy_ptr > gap_sharing_ue; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasIdToAddModList ::= SEQUENCE (SIZE (1..64)) OF MeasIdToAddMod using meas_id_to_add_mod_list_l = dyn_array; // MeasIdToRemoveList ::= SEQUENCE (SIZE (1..64)) OF INTEGER (1..64) using meas_id_to_rem_list_l = dyn_array; // MeasObjectToAddModList ::= SEQUENCE (SIZE (1..64)) OF MeasObjectToAddMod using meas_obj_to_add_mod_list_l = dyn_array; // MeasObjectToRemoveList ::= SEQUENCE (SIZE (1..64)) OF INTEGER (1..64) using meas_obj_to_rem_list_l = dyn_array; // OtherConfig ::= SEQUENCE struct other_cfg_s { struct delay_budget_report_cfg_c_ { struct setup_s_ { struct delay_budget_report_prohibit_timer_opts { enum options { s0, s0dot4, s0dot8, s1dot6, s3, s6, s12, s30, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated delay_budget_report_prohibit_timer_e_; // member variables delay_budget_report_prohibit_timer_e_ delay_budget_report_prohibit_timer; }; struct types_opts { enum options { release, setup, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods delay_budget_report_cfg_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters setup_s_& setup() { assert_choice_type(types::setup, type_, "delayBudgetReportingConfig"); return c; } const setup_s_& setup() const { assert_choice_type(types::setup, type_, "delayBudgetReportingConfig"); return c; } void set_release(); setup_s_& set_setup(); private: types type_; setup_s_ c; }; // member variables bool delay_budget_report_cfg_present = false; delay_budget_report_cfg_c_ delay_budget_report_cfg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PeriodicRNAU-TimerValue ::= ENUMERATED struct periodic_rnau_timer_value_opts { enum options { min5, min10, min20, min30, min60, min120, min360, min720, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated periodic_rnau_timer_value_e; // QuantityConfig ::= SEQUENCE struct quant_cfg_s { using quant_cfg_nr_list_l_ = dyn_array; // member variables bool ext = false; bool quant_cfg_nr_list_present = false; quant_cfg_nr_list_l_ quant_cfg_nr_list; // ... // group 0 copy_ptr quant_cfg_eutra; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RAN-NotificationAreaInfo ::= CHOICE struct ran_notif_area_info_c { struct types_opts { enum options { cell_list, ran_area_cfg_list, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ran_notif_area_info_c() = default; ran_notif_area_info_c(const ran_notif_area_info_c& other); ran_notif_area_info_c& operator=(const ran_notif_area_info_c& other); ~ran_notif_area_info_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters plmn_ran_area_cell_list_l& cell_list() { assert_choice_type(types::cell_list, type_, "RAN-NotificationAreaInfo"); return c.get(); } plmn_ran_area_cfg_list_l& ran_area_cfg_list() { assert_choice_type(types::ran_area_cfg_list, type_, "RAN-NotificationAreaInfo"); return c.get(); } const plmn_ran_area_cell_list_l& cell_list() const { assert_choice_type(types::cell_list, type_, "RAN-NotificationAreaInfo"); return c.get(); } const plmn_ran_area_cfg_list_l& ran_area_cfg_list() const { assert_choice_type(types::ran_area_cfg_list, type_, "RAN-NotificationAreaInfo"); return c.get(); } plmn_ran_area_cell_list_l& set_cell_list(); plmn_ran_area_cfg_list_l& set_ran_area_cfg_list(); private: types type_; choice_buffer_t c; void destroy_(); }; // RRCReconfiguration-v1540-IEs ::= SEQUENCE struct rrc_recfg_v1540_ies_s { bool other_cfg_v1540_present = false; bool non_crit_ext_present = false; other_cfg_v1540_s other_cfg_v1540; rrc_recfg_v1560_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RedirectedCarrierInfo-EUTRA ::= SEQUENCE struct redirected_carrier_info_eutra_s { struct cn_type_opts { enum options { epc, five_gc, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated cn_type_e_; // member variables bool cn_type_present = false; uint32_t eutra_freq = 0; cn_type_e_ cn_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReportConfigToAddModList ::= SEQUENCE (SIZE (1..64)) OF ReportConfigToAddMod using report_cfg_to_add_mod_list_l = dyn_array; // ReportConfigToRemoveList ::= SEQUENCE (SIZE (1..64)) OF INTEGER (1..64) using report_cfg_to_rem_list_l = dyn_array; // UE-CapabilityRAT-Request ::= SEQUENCE struct ue_cap_rat_request_s { bool ext = false; bool cap_request_filt_present = false; rat_type_e rat_type; dyn_octstring cap_request_filt; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellReselectionPriorities ::= SEQUENCE struct cell_resel_priorities_s { struct t320_opts { enum options { min5, min10, min20, min30, min60, min120, min180, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated t320_e_; // member variables bool ext = false; bool freq_prio_list_eutra_present = false; bool freq_prio_list_nr_present = false; bool t320_present = false; freq_prio_list_eutra_l freq_prio_list_eutra; freq_prio_list_nr_l freq_prio_list_nr; t320_e_ t320; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRB-CountMSB-InfoList ::= SEQUENCE (SIZE (1..29)) OF DRB-CountMSB-Info using drb_count_msb_info_list_l = dyn_array; // MeasConfig ::= SEQUENCE struct meas_cfg_s { struct s_measure_cfg_c_ { struct types_opts { enum options { ssb_rsrp, csi_rsrp, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods s_measure_cfg_c_() = default; s_measure_cfg_c_(const s_measure_cfg_c_& other); s_measure_cfg_c_& operator=(const s_measure_cfg_c_& other); ~s_measure_cfg_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_rsrp() { assert_choice_type(types::ssb_rsrp, type_, "s-MeasureConfig"); return c.get(); } uint8_t& csi_rsrp() { assert_choice_type(types::csi_rsrp, type_, "s-MeasureConfig"); return c.get(); } const uint8_t& ssb_rsrp() const { assert_choice_type(types::ssb_rsrp, type_, "s-MeasureConfig"); return c.get(); } const uint8_t& csi_rsrp() const { assert_choice_type(types::csi_rsrp, type_, "s-MeasureConfig"); return c.get(); } uint8_t& set_ssb_rsrp(); uint8_t& set_csi_rsrp(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool meas_obj_to_rem_list_present = false; bool meas_obj_to_add_mod_list_present = false; bool report_cfg_to_rem_list_present = false; bool report_cfg_to_add_mod_list_present = false; bool meas_id_to_rem_list_present = false; bool meas_id_to_add_mod_list_present = false; bool s_measure_cfg_present = false; bool quant_cfg_present = false; bool meas_gap_cfg_present = false; bool meas_gap_sharing_cfg_present = false; meas_obj_to_rem_list_l meas_obj_to_rem_list; meas_obj_to_add_mod_list_l meas_obj_to_add_mod_list; report_cfg_to_rem_list_l report_cfg_to_rem_list; report_cfg_to_add_mod_list_l report_cfg_to_add_mod_list; meas_id_to_rem_list_l meas_id_to_rem_list; meas_id_to_add_mod_list_l meas_id_to_add_mod_list; s_measure_cfg_c_ s_measure_cfg; quant_cfg_s quant_cfg; meas_gap_cfg_s meas_gap_cfg; meas_gap_sharing_cfg_s meas_gap_sharing_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfiguration-v1530-IEs ::= SEQUENCE struct rrc_recfg_v1530_ies_s { using ded_nas_msg_list_l_ = bounded_array; // member variables bool master_cell_group_present = false; bool full_cfg_present = false; bool ded_nas_msg_list_present = false; bool master_key_upd_present = false; bool ded_sib1_delivery_present = false; bool ded_sys_info_delivery_present = false; bool other_cfg_present = false; bool non_crit_ext_present = false; dyn_octstring master_cell_group; ded_nas_msg_list_l_ ded_nas_msg_list; master_key_upd_s master_key_upd; dyn_octstring ded_sib1_delivery; dyn_octstring ded_sys_info_delivery; other_cfg_s other_cfg; rrc_recfg_v1540_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCRelease-v1540-IEs ::= SEQUENCE struct rrc_release_v1540_ies_s { bool wait_time_present = false; bool non_crit_ext_present = false; uint8_t wait_time = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResume-v1560-IEs ::= SEQUENCE struct rrc_resume_v1560_ies_s { bool radio_bearer_cfg2_present = false; bool sk_counter_present = false; bool non_crit_ext_present = false; dyn_octstring radio_bearer_cfg2; uint32_t sk_counter = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RedirectedCarrierInfo ::= CHOICE struct redirected_carrier_info_c { struct types_opts { enum options { nr, eutra, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods redirected_carrier_info_c() = default; redirected_carrier_info_c(const redirected_carrier_info_c& other); redirected_carrier_info_c& operator=(const redirected_carrier_info_c& other); ~redirected_carrier_info_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters carrier_info_nr_s& nr() { assert_choice_type(types::nr, type_, "RedirectedCarrierInfo"); return c.get(); } redirected_carrier_info_eutra_s& eutra() { assert_choice_type(types::eutra, type_, "RedirectedCarrierInfo"); return c.get(); } const carrier_info_nr_s& nr() const { assert_choice_type(types::nr, type_, "RedirectedCarrierInfo"); return c.get(); } const redirected_carrier_info_eutra_s& eutra() const { assert_choice_type(types::eutra, type_, "RedirectedCarrierInfo"); return c.get(); } carrier_info_nr_s& set_nr(); redirected_carrier_info_eutra_s& set_eutra(); private: types type_; choice_buffer_t c; void destroy_(); }; // SecurityConfigSMC ::= SEQUENCE struct security_cfg_smc_s { bool ext = false; security_algorithm_cfg_s security_algorithm_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SuspendConfig ::= SEQUENCE struct suspend_cfg_s { bool ext = false; bool ran_notif_area_info_present = false; bool t380_present = false; fixed_bitstring<40> full_i_rnti; fixed_bitstring<24> short_i_rnti; paging_cycle_e ran_paging_cycle; ran_notif_area_info_c ran_notif_area_info; periodic_rnau_timer_value_e t380; uint8_t next_hop_chaining_count = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRAT-RequestList ::= SEQUENCE (SIZE (1..8)) OF UE-CapabilityRAT-Request using ue_cap_rat_request_list_l = dyn_array; // CounterCheck-IEs ::= SEQUENCE struct counter_check_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; drb_count_msb_info_list_l drb_count_msb_info_list; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DLInformationTransfer-IEs ::= SEQUENCE struct dl_info_transfer_ies_s { bool ded_nas_msg_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring ded_nas_msg; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MobilityFromNRCommand-IEs ::= SEQUENCE struct mob_from_nr_cmd_ies_s { struct target_rat_type_opts { enum options { eutra, spare3, spare2, spare1, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated target_rat_type_e_; // member variables bool nas_security_param_from_nr_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; target_rat_type_e_ target_rat_type; dyn_octstring target_rat_msg_container; dyn_octstring nas_security_param_from_nr; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfiguration-IEs ::= SEQUENCE struct rrc_recfg_ies_s { bool radio_bearer_cfg_present = false; bool secondary_cell_group_present = false; bool meas_cfg_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; radio_bearer_cfg_s radio_bearer_cfg; dyn_octstring secondary_cell_group; meas_cfg_s meas_cfg; dyn_octstring late_non_crit_ext; rrc_recfg_v1530_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReestablishment-IEs ::= SEQUENCE struct rrc_reest_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; uint8_t next_hop_chaining_count = 0; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCRelease-IEs ::= SEQUENCE struct rrc_release_ies_s { struct depriorit_req_s_ { struct depriorit_type_opts { enum options { freq, nr, nulltype } value; const char* to_string() const; }; typedef enumerated depriorit_type_e_; struct depriorit_timer_opts { enum options { min5, min10, min15, min30, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated depriorit_timer_e_; // member variables depriorit_type_e_ depriorit_type; depriorit_timer_e_ depriorit_timer; }; // member variables bool redirected_carrier_info_present = false; bool cell_resel_priorities_present = false; bool suspend_cfg_present = false; bool depriorit_req_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; redirected_carrier_info_c redirected_carrier_info; cell_resel_priorities_s cell_resel_priorities; suspend_cfg_s suspend_cfg; depriorit_req_s_ depriorit_req; dyn_octstring late_non_crit_ext; rrc_release_v1540_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResume-IEs ::= SEQUENCE struct rrc_resume_ies_s { bool radio_bearer_cfg_present = false; bool master_cell_group_present = false; bool meas_cfg_present = false; bool full_cfg_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; radio_bearer_cfg_s radio_bearer_cfg; dyn_octstring master_cell_group; meas_cfg_s meas_cfg; dyn_octstring late_non_crit_ext; rrc_resume_v1560_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeCommand-IEs ::= SEQUENCE struct security_mode_cmd_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; security_cfg_smc_s security_cfg_smc; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UECapabilityEnquiry-IEs ::= SEQUENCE struct ue_cap_enquiry_ies_s { bool late_non_crit_ext_present = false; bool ue_cap_enquiry_ext_present = false; ue_cap_rat_request_list_l ue_cap_rat_request_list; dyn_octstring late_non_crit_ext; dyn_octstring ue_cap_enquiry_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CounterCheck ::= SEQUENCE struct counter_check_s { struct crit_exts_c_ { struct types_opts { enum options { counter_check, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters counter_check_ies_s& counter_check() { assert_choice_type(types::counter_check, type_, "criticalExtensions"); return c; } const counter_check_ies_s& counter_check() const { assert_choice_type(types::counter_check, type_, "criticalExtensions"); return c; } counter_check_ies_s& set_counter_check(); void set_crit_exts_future(); private: types type_; counter_check_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DLInformationTransfer ::= SEQUENCE struct dl_info_transfer_s { struct crit_exts_c_ { struct types_opts { enum options { dl_info_transfer, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dl_info_transfer_ies_s& dl_info_transfer() { assert_choice_type(types::dl_info_transfer, type_, "criticalExtensions"); return c; } const dl_info_transfer_ies_s& dl_info_transfer() const { assert_choice_type(types::dl_info_transfer, type_, "criticalExtensions"); return c; } dl_info_transfer_ies_s& set_dl_info_transfer(); void set_crit_exts_future(); private: types type_; dl_info_transfer_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MobilityFromNRCommand ::= SEQUENCE struct mob_from_nr_cmd_s { struct crit_exts_c_ { struct types_opts { enum options { mob_from_nr_cmd, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters mob_from_nr_cmd_ies_s& mob_from_nr_cmd() { assert_choice_type(types::mob_from_nr_cmd, type_, "criticalExtensions"); return c; } const mob_from_nr_cmd_ies_s& mob_from_nr_cmd() const { assert_choice_type(types::mob_from_nr_cmd, type_, "criticalExtensions"); return c; } mob_from_nr_cmd_ies_s& set_mob_from_nr_cmd(); void set_crit_exts_future(); private: types type_; mob_from_nr_cmd_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfiguration ::= SEQUENCE struct rrc_recfg_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_recfg, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_recfg_ies_s& rrc_recfg() { assert_choice_type(types::rrc_recfg, type_, "criticalExtensions"); return c; } const rrc_recfg_ies_s& rrc_recfg() const { assert_choice_type(types::rrc_recfg, type_, "criticalExtensions"); return c; } rrc_recfg_ies_s& set_rrc_recfg(); void set_crit_exts_future(); private: types type_; rrc_recfg_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReestablishment ::= SEQUENCE struct rrc_reest_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_reest, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_reest_ies_s& rrc_reest() { assert_choice_type(types::rrc_reest, type_, "criticalExtensions"); return c; } const rrc_reest_ies_s& rrc_reest() const { assert_choice_type(types::rrc_reest, type_, "criticalExtensions"); return c; } rrc_reest_ies_s& set_rrc_reest(); void set_crit_exts_future(); private: types type_; rrc_reest_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCRelease ::= SEQUENCE struct rrc_release_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_release, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_release_ies_s& rrc_release() { assert_choice_type(types::rrc_release, type_, "criticalExtensions"); return c; } const rrc_release_ies_s& rrc_release() const { assert_choice_type(types::rrc_release, type_, "criticalExtensions"); return c; } rrc_release_ies_s& set_rrc_release(); void set_crit_exts_future(); private: types type_; rrc_release_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResume ::= SEQUENCE struct rrc_resume_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_resume, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_resume_ies_s& rrc_resume() { assert_choice_type(types::rrc_resume, type_, "criticalExtensions"); return c; } const rrc_resume_ies_s& rrc_resume() const { assert_choice_type(types::rrc_resume, type_, "criticalExtensions"); return c; } rrc_resume_ies_s& set_rrc_resume(); void set_crit_exts_future(); private: types type_; rrc_resume_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeCommand ::= SEQUENCE struct security_mode_cmd_s { struct crit_exts_c_ { struct types_opts { enum options { security_mode_cmd, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters security_mode_cmd_ies_s& security_mode_cmd() { assert_choice_type(types::security_mode_cmd, type_, "criticalExtensions"); return c; } const security_mode_cmd_ies_s& security_mode_cmd() const { assert_choice_type(types::security_mode_cmd, type_, "criticalExtensions"); return c; } security_mode_cmd_ies_s& set_security_mode_cmd(); void set_crit_exts_future(); private: types type_; security_mode_cmd_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UECapabilityEnquiry ::= SEQUENCE struct ue_cap_enquiry_s { struct crit_exts_c_ { struct types_opts { enum options { ue_cap_enquiry, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ue_cap_enquiry_ies_s& ue_cap_enquiry() { assert_choice_type(types::ue_cap_enquiry, type_, "criticalExtensions"); return c; } const ue_cap_enquiry_ies_s& ue_cap_enquiry() const { assert_choice_type(types::ue_cap_enquiry, type_, "criticalExtensions"); return c; } ue_cap_enquiry_ies_s& set_ue_cap_enquiry(); void set_crit_exts_future(); private: types type_; ue_cap_enquiry_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DL-DCCH-MessageType ::= CHOICE struct dl_dcch_msg_type_c { struct c1_c_ { struct types_opts { enum options { rrc_recfg, rrc_resume, rrc_release, rrc_reest, security_mode_cmd, dl_info_transfer, ue_cap_enquiry, counter_check, mob_from_nr_cmd, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; c1_c_(const c1_c_& other); c1_c_& operator=(const c1_c_& other); ~c1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_recfg_s& rrc_recfg() { assert_choice_type(types::rrc_recfg, type_, "c1"); return c.get(); } rrc_resume_s& rrc_resume() { assert_choice_type(types::rrc_resume, type_, "c1"); return c.get(); } rrc_release_s& rrc_release() { assert_choice_type(types::rrc_release, type_, "c1"); return c.get(); } rrc_reest_s& rrc_reest() { assert_choice_type(types::rrc_reest, type_, "c1"); return c.get(); } security_mode_cmd_s& security_mode_cmd() { assert_choice_type(types::security_mode_cmd, type_, "c1"); return c.get(); } dl_info_transfer_s& dl_info_transfer() { assert_choice_type(types::dl_info_transfer, type_, "c1"); return c.get(); } ue_cap_enquiry_s& ue_cap_enquiry() { assert_choice_type(types::ue_cap_enquiry, type_, "c1"); return c.get(); } counter_check_s& counter_check() { assert_choice_type(types::counter_check, type_, "c1"); return c.get(); } mob_from_nr_cmd_s& mob_from_nr_cmd() { assert_choice_type(types::mob_from_nr_cmd, type_, "c1"); return c.get(); } const rrc_recfg_s& rrc_recfg() const { assert_choice_type(types::rrc_recfg, type_, "c1"); return c.get(); } const rrc_resume_s& rrc_resume() const { assert_choice_type(types::rrc_resume, type_, "c1"); return c.get(); } const rrc_release_s& rrc_release() const { assert_choice_type(types::rrc_release, type_, "c1"); return c.get(); } const rrc_reest_s& rrc_reest() const { assert_choice_type(types::rrc_reest, type_, "c1"); return c.get(); } const security_mode_cmd_s& security_mode_cmd() const { assert_choice_type(types::security_mode_cmd, type_, "c1"); return c.get(); } const dl_info_transfer_s& dl_info_transfer() const { assert_choice_type(types::dl_info_transfer, type_, "c1"); return c.get(); } const ue_cap_enquiry_s& ue_cap_enquiry() const { assert_choice_type(types::ue_cap_enquiry, type_, "c1"); return c.get(); } const counter_check_s& counter_check() const { assert_choice_type(types::counter_check, type_, "c1"); return c.get(); } const mob_from_nr_cmd_s& mob_from_nr_cmd() const { assert_choice_type(types::mob_from_nr_cmd, type_, "c1"); return c.get(); } rrc_recfg_s& set_rrc_recfg(); rrc_resume_s& set_rrc_resume(); rrc_release_s& set_rrc_release(); rrc_reest_s& set_rrc_reest(); security_mode_cmd_s& set_security_mode_cmd(); dl_info_transfer_s& set_dl_info_transfer(); ue_cap_enquiry_s& set_ue_cap_enquiry(); counter_check_s& set_counter_check(); mob_from_nr_cmd_s& set_mob_from_nr_cmd(); void set_spare7(); void set_spare6(); void set_spare5(); void set_spare4(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; choice_buffer_t c; void destroy_(); }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods dl_dcch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "DL-DCCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "DL-DCCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // DL-DCCH-Message ::= SEQUENCE struct dl_dcch_msg_s { dl_dcch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PagingUE-Identity ::= CHOICE struct paging_ue_id_c { struct types_opts { enum options { ng_minus5_g_s_tmsi, full_i_rnti, /*...*/ nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated types; // choice methods paging_ue_id_c() = default; paging_ue_id_c(const paging_ue_id_c& other); paging_ue_id_c& operator=(const paging_ue_id_c& other); ~paging_ue_id_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<48>& ng_minus5_g_s_tmsi() { assert_choice_type(types::ng_minus5_g_s_tmsi, type_, "PagingUE-Identity"); return c.get >(); } fixed_bitstring<40>& full_i_rnti() { assert_choice_type(types::full_i_rnti, type_, "PagingUE-Identity"); return c.get >(); } const fixed_bitstring<48>& ng_minus5_g_s_tmsi() const { assert_choice_type(types::ng_minus5_g_s_tmsi, type_, "PagingUE-Identity"); return c.get >(); } const fixed_bitstring<40>& full_i_rnti() const { assert_choice_type(types::full_i_rnti, type_, "PagingUE-Identity"); return c.get >(); } fixed_bitstring<48>& set_ng_minus5_g_s_tmsi(); fixed_bitstring<40>& set_full_i_rnti(); private: types type_; choice_buffer_t > c; void destroy_(); }; // PagingRecord ::= SEQUENCE struct paging_record_s { bool ext = false; bool access_type_present = false; paging_ue_id_c ue_id; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PagingRecordList ::= SEQUENCE (SIZE (1..32)) OF PagingRecord using paging_record_list_l = dyn_array; // Paging ::= SEQUENCE struct paging_s { bool paging_record_list_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; paging_record_list_l paging_record_list; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PCCH-MessageType ::= CHOICE struct pcch_msg_type_c { struct c1_c_ { struct types_opts { enum options { paging, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters paging_s& paging() { assert_choice_type(types::paging, type_, "c1"); return c; } const paging_s& paging() const { assert_choice_type(types::paging, type_, "c1"); return c; } paging_s& set_paging(); void set_spare1(); private: types type_; paging_s c; }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods pcch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "PCCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "PCCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // PCCH-Message ::= SEQUENCE struct pcch_msg_s { pcch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EstablishmentCause ::= ENUMERATED struct establishment_cause_opts { enum options { emergency, high_prio_access, mt_access, mo_sig, mo_data, mo_voice_call, mo_video_call, mo_sms, mps_prio_access, mcs_prio_access, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated establishment_cause_e; // InitialUE-Identity ::= CHOICE struct init_ue_id_c { struct types_opts { enum options { ng_minus5_g_s_tmsi_part1, random_value, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated types; // choice methods init_ue_id_c() = default; init_ue_id_c(const init_ue_id_c& other); init_ue_id_c& operator=(const init_ue_id_c& other); ~init_ue_id_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<39>& ng_minus5_g_s_tmsi_part1() { assert_choice_type(types::ng_minus5_g_s_tmsi_part1, type_, "InitialUE-Identity"); return c.get >(); } fixed_bitstring<39>& random_value() { assert_choice_type(types::random_value, type_, "InitialUE-Identity"); return c.get >(); } const fixed_bitstring<39>& ng_minus5_g_s_tmsi_part1() const { assert_choice_type(types::ng_minus5_g_s_tmsi_part1, type_, "InitialUE-Identity"); return c.get >(); } const fixed_bitstring<39>& random_value() const { assert_choice_type(types::random_value, type_, "InitialUE-Identity"); return c.get >(); } fixed_bitstring<39>& set_ng_minus5_g_s_tmsi_part1(); fixed_bitstring<39>& set_random_value(); private: types type_; choice_buffer_t > c; void destroy_(); }; // ReestabUE-Identity ::= SEQUENCE struct reestab_ue_id_s { uint32_t c_rnti = 0; uint16_t pci = 0; fixed_bitstring<16> short_mac_i; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReestablishmentCause ::= ENUMERATED struct reest_cause_opts { enum options { recfg_fail, ho_fail, other_fail, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated reest_cause_e; // ResumeCause ::= ENUMERATED struct resume_cause_opts { enum options { emergency, high_prio_access, mt_access, mo_sig, mo_data, mo_voice_call, mo_video_call, mo_sms, rna_upd, mps_prio_access, mcs_prio_access, spare1, spare2, spare3, spare4, spare5, nulltype } value; const char* to_string() const; }; typedef enumerated resume_cause_e; // RRCReestablishmentRequest-IEs ::= SEQUENCE struct rrc_reest_request_ies_s { reestab_ue_id_s ue_id; reest_cause_e reest_cause; fixed_bitstring<1> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeRequest-IEs ::= SEQUENCE struct rrc_resume_request_ies_s { fixed_bitstring<24> resume_id; fixed_bitstring<16> resume_mac_i; resume_cause_e resume_cause; fixed_bitstring<1> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetupRequest-IEs ::= SEQUENCE struct rrc_setup_request_ies_s { init_ue_id_c ue_id; establishment_cause_e establishment_cause; fixed_bitstring<1> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSystemInfoRequest-IEs ::= SEQUENCE struct rrc_sys_info_request_ies_s { fixed_bitstring<32> requested_si_list; fixed_bitstring<12> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReestablishmentRequest ::= SEQUENCE struct rrc_reest_request_s { rrc_reest_request_ies_s rrc_reest_request; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeRequest ::= SEQUENCE struct rrc_resume_request_s { rrc_resume_request_ies_s rrc_resume_request; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetupRequest ::= SEQUENCE struct rrc_setup_request_s { rrc_setup_request_ies_s rrc_setup_request; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSystemInfoRequest ::= SEQUENCE struct rrc_sys_info_request_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_sys_info_request, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_sys_info_request_ies_s& rrc_sys_info_request() { assert_choice_type(types::rrc_sys_info_request, type_, "criticalExtensions"); return c; } const rrc_sys_info_request_ies_s& rrc_sys_info_request() const { assert_choice_type(types::rrc_sys_info_request, type_, "criticalExtensions"); return c; } rrc_sys_info_request_ies_s& set_rrc_sys_info_request(); void set_crit_exts_future(); private: types type_; rrc_sys_info_request_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-CCCH-MessageType ::= CHOICE struct ul_ccch_msg_type_c { struct c1_c_ { struct types_opts { enum options { rrc_setup_request, rrc_resume_request, rrc_reest_request, rrc_sys_info_request, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; c1_c_(const c1_c_& other); c1_c_& operator=(const c1_c_& other); ~c1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_setup_request_s& rrc_setup_request() { assert_choice_type(types::rrc_setup_request, type_, "c1"); return c.get(); } rrc_resume_request_s& rrc_resume_request() { assert_choice_type(types::rrc_resume_request, type_, "c1"); return c.get(); } rrc_reest_request_s& rrc_reest_request() { assert_choice_type(types::rrc_reest_request, type_, "c1"); return c.get(); } rrc_sys_info_request_s& rrc_sys_info_request() { assert_choice_type(types::rrc_sys_info_request, type_, "c1"); return c.get(); } const rrc_setup_request_s& rrc_setup_request() const { assert_choice_type(types::rrc_setup_request, type_, "c1"); return c.get(); } const rrc_resume_request_s& rrc_resume_request() const { assert_choice_type(types::rrc_resume_request, type_, "c1"); return c.get(); } const rrc_reest_request_s& rrc_reest_request() const { assert_choice_type(types::rrc_reest_request, type_, "c1"); return c.get(); } const rrc_sys_info_request_s& rrc_sys_info_request() const { assert_choice_type(types::rrc_sys_info_request, type_, "c1"); return c.get(); } rrc_setup_request_s& set_rrc_setup_request(); rrc_resume_request_s& set_rrc_resume_request(); rrc_reest_request_s& set_rrc_reest_request(); rrc_sys_info_request_s& set_rrc_sys_info_request(); private: types type_; choice_buffer_t c; void destroy_(); }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ul_ccch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "UL-CCCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "UL-CCCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // UL-CCCH-Message ::= SEQUENCE struct ul_ccch_msg_s { ul_ccch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeRequest1-IEs ::= SEQUENCE struct rrc_resume_request1_ies_s { fixed_bitstring<40> resume_id; fixed_bitstring<16> resume_mac_i; resume_cause_e resume_cause; fixed_bitstring<1> spare; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeRequest1 ::= SEQUENCE struct rrc_resume_request1_s { rrc_resume_request1_ies_s rrc_resume_request1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-CCCH1-MessageType ::= CHOICE struct ul_ccch1_msg_type_c { struct c1_c_ { struct types_opts { enum options { rrc_resume_request1, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_resume_request1_s& rrc_resume_request1() { assert_choice_type(types::rrc_resume_request1, type_, "c1"); return c; } const rrc_resume_request1_s& rrc_resume_request1() const { assert_choice_type(types::rrc_resume_request1, type_, "c1"); return c; } rrc_resume_request1_s& set_rrc_resume_request1(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; rrc_resume_request1_s c; }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ul_ccch1_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "UL-CCCH1-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "UL-CCCH1-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // UL-CCCH1-Message ::= SEQUENCE struct ul_ccch1_msg_s { ul_ccch1_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasQuantityResults ::= SEQUENCE struct meas_quant_results_s { bool rsrp_present = false; bool rsrq_present = false; bool sinr_present = false; uint8_t rsrp = 0; uint8_t rsrq = 0; uint8_t sinr = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PLMN-Identity-EUTRA-5GC ::= CHOICE struct plmn_id_eutra_minus5_gc_c { struct types_opts { enum options { plmn_id_eutra_minus5_gc, plmn_idx, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated types; // choice methods plmn_id_eutra_minus5_gc_c() = default; plmn_id_eutra_minus5_gc_c(const plmn_id_eutra_minus5_gc_c& other); plmn_id_eutra_minus5_gc_c& operator=(const plmn_id_eutra_minus5_gc_c& other); ~plmn_id_eutra_minus5_gc_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters plmn_id_s& plmn_id_eutra_minus5_gc() { assert_choice_type(types::plmn_id_eutra_minus5_gc, type_, "PLMN-Identity-EUTRA-5GC"); return c.get(); } uint8_t& plmn_idx() { assert_choice_type(types::plmn_idx, type_, "PLMN-Identity-EUTRA-5GC"); return c.get(); } const plmn_id_s& plmn_id_eutra_minus5_gc() const { assert_choice_type(types::plmn_id_eutra_minus5_gc, type_, "PLMN-Identity-EUTRA-5GC"); return c.get(); } const uint8_t& plmn_idx() const { assert_choice_type(types::plmn_idx, type_, "PLMN-Identity-EUTRA-5GC"); return c.get(); } plmn_id_s& set_plmn_id_eutra_minus5_gc(); uint8_t& set_plmn_idx(); private: types type_; choice_buffer_t c; void destroy_(); }; // CellIdentity-EUTRA-5GC ::= CHOICE struct cell_id_eutra_minus5_gc_c { struct types_opts { enum options { cell_id_eutra, cell_id_idx, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods cell_id_eutra_minus5_gc_c() = default; cell_id_eutra_minus5_gc_c(const cell_id_eutra_minus5_gc_c& other); cell_id_eutra_minus5_gc_c& operator=(const cell_id_eutra_minus5_gc_c& other); ~cell_id_eutra_minus5_gc_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<28>& cell_id_eutra() { assert_choice_type(types::cell_id_eutra, type_, "CellIdentity-EUTRA-5GC"); return c.get >(); } uint8_t& cell_id_idx() { assert_choice_type(types::cell_id_idx, type_, "CellIdentity-EUTRA-5GC"); return c.get(); } const fixed_bitstring<28>& cell_id_eutra() const { assert_choice_type(types::cell_id_eutra, type_, "CellIdentity-EUTRA-5GC"); return c.get >(); } const uint8_t& cell_id_idx() const { assert_choice_type(types::cell_id_idx, type_, "CellIdentity-EUTRA-5GC"); return c.get(); } fixed_bitstring<28>& set_cell_id_eutra(); uint8_t& set_cell_id_idx(); private: types type_; choice_buffer_t > c; void destroy_(); }; // MultiFrequencyBandListNR ::= SEQUENCE (SIZE (1..8)) OF INTEGER (1..1024) using multi_freq_band_list_nr_l = bounded_array; // PLMN-IdentityList-EUTRA-5GC ::= SEQUENCE (SIZE (1..12)) OF PLMN-Identity-EUTRA-5GC using plmn_id_list_eutra_minus5_gc_l = dyn_array; // PLMN-IdentityList-EUTRA-EPC ::= SEQUENCE (SIZE (1..12)) OF PLMN-Identity using plmn_id_list_eutra_epc_l = dyn_array; // ResultsPerCSI-RS-Index ::= SEQUENCE struct results_per_csi_rs_idx_s { bool csi_rs_results_present = false; uint8_t csi_rs_idx = 0; meas_quant_results_s csi_rs_results; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ResultsPerSSB-Index ::= SEQUENCE struct results_per_ssb_idx_s { bool ssb_results_present = false; uint8_t ssb_idx = 0; meas_quant_results_s ssb_results; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CGI-InfoNR ::= SEQUENCE struct cgi_info_nr_s { struct no_sib1_s_ { uint8_t ssb_subcarrier_offset = 0; pdcch_cfg_sib1_s pdcch_cfg_sib1; }; // member variables bool ext = false; bool plmn_id_info_list_present = false; bool freq_band_list_present = false; bool no_sib1_present = false; plmn_id_info_list_l plmn_id_info_list; multi_freq_band_list_nr_l freq_band_list; no_sib1_s_ no_sib1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellAccessRelatedInfo-EUTRA-5GC ::= SEQUENCE struct cell_access_related_info_eutra_minus5_gc_s { bool ranac_minus5gc_present = false; plmn_id_list_eutra_minus5_gc_l plmn_id_list_eutra_minus5gc; fixed_bitstring<24> tac_eutra_minus5gc; uint16_t ranac_minus5gc = 0; cell_id_eutra_minus5_gc_c cell_id_eutra_minus5gc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellAccessRelatedInfo-EUTRA-EPC ::= SEQUENCE struct cell_access_related_info_eutra_epc_s { plmn_id_list_eutra_epc_l plmn_id_list_eutra_epc; fixed_bitstring<16> tac_eutra_epc; fixed_bitstring<28> cell_id_eutra_epc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MultiBandInfoListEUTRA ::= SEQUENCE (SIZE (1..8)) OF INTEGER (1..256) using multi_band_info_list_eutra_l = bounded_array; // ResultsPerCSI-RS-IndexList ::= SEQUENCE (SIZE (1..64)) OF ResultsPerCSI-RS-Index using results_per_csi_rs_idx_list_l = dyn_array; // ResultsPerSSB-IndexList ::= SEQUENCE (SIZE (1..64)) OF ResultsPerSSB-Index using results_per_ssb_idx_list_l = dyn_array; // CGI-InfoEUTRA ::= SEQUENCE struct cgi_info_eutra_s { struct cgi_info_epc_s_ { using cgi_info_epc_list_l_ = dyn_array; // member variables bool cgi_info_epc_list_present = false; cell_access_related_info_eutra_epc_s cgi_info_epc_legacy; cgi_info_epc_list_l_ cgi_info_epc_list; }; using cgi_info_minus5_gc_l_ = dyn_array; // member variables bool cgi_info_epc_present = false; bool cgi_info_minus5_gc_present = false; bool multi_band_info_list_present = false; bool freq_band_ind_prio_present = false; cgi_info_epc_s_ cgi_info_epc; cgi_info_minus5_gc_l_ cgi_info_minus5_gc; uint16_t freq_band_ind = 1; multi_band_info_list_eutra_l multi_band_info_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasQuantityResultsEUTRA ::= SEQUENCE struct meas_quant_results_eutra_s { bool rsrp_present = false; bool rsrq_present = false; bool sinr_present = false; uint8_t rsrp = 0; uint8_t rsrq = 0; uint8_t sinr = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultNR ::= SEQUENCE struct meas_result_nr_s { struct meas_result_s_ { struct cell_results_s_ { bool results_ssb_cell_present = false; bool results_csi_rs_cell_present = false; meas_quant_results_s results_ssb_cell; meas_quant_results_s results_csi_rs_cell; }; struct rs_idx_results_s_ { bool results_ssb_idxes_present = false; bool results_csi_rs_idxes_present = false; results_per_ssb_idx_list_l results_ssb_idxes; results_per_csi_rs_idx_list_l results_csi_rs_idxes; }; // member variables bool rs_idx_results_present = false; cell_results_s_ cell_results; rs_idx_results_s_ rs_idx_results; }; // member variables bool ext = false; bool pci_present = false; uint16_t pci = 0; meas_result_s_ meas_result; // ... // group 0 copy_ptr cgi_info; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultEUTRA ::= SEQUENCE struct meas_result_eutra_s { bool ext = false; bool cgi_info_present = false; uint16_t eutra_pci = 0; meas_quant_results_eutra_s meas_result; cgi_info_eutra_s cgi_info; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultListNR ::= SEQUENCE (SIZE (1..8)) OF MeasResultNR using meas_result_list_nr_l = dyn_array; // UplinkTxDirectCurrentBWP ::= SEQUENCE struct ul_tx_direct_current_bwp_s { uint8_t bwp_id = 0; bool shift7dot5k_hz = false; uint16_t tx_direct_current_location = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-RSTD-Info ::= SEQUENCE struct eutra_rstd_info_s { bool ext = false; uint32_t carrier_freq = 0; uint8_t meas_prs_offset = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MIMO-LayersDL ::= ENUMERATED struct mimo_layers_dl_opts { enum options { two_layers, four_layers, eight_layers, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated mimo_layers_dl_e; // MIMO-LayersUL ::= ENUMERATED struct mimo_layers_ul_opts { enum options { one_layer, two_layers, four_layers, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated mimo_layers_ul_e; // MeasResult2EUTRA ::= SEQUENCE struct meas_result2_eutra_s { bool ext = false; bool meas_result_serving_cell_present = false; bool meas_result_best_neigh_cell_present = false; uint32_t carrier_freq = 0; meas_result_eutra_s meas_result_serving_cell; meas_result_eutra_s meas_result_best_neigh_cell; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResult2NR ::= SEQUENCE struct meas_result2_nr_s { bool ext = false; bool ssb_freq_present = false; bool ref_freq_csi_rs_present = false; bool meas_result_serving_cell_present = false; bool meas_result_neigh_cell_list_nr_present = false; uint32_t ssb_freq = 0; uint32_t ref_freq_csi_rs = 0; meas_result_nr_s meas_result_serving_cell; meas_result_list_nr_l meas_result_neigh_cell_list_nr; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultCellSFTD-NR ::= SEQUENCE struct meas_result_cell_sftd_nr_s { bool rsrp_result_present = false; uint16_t pci = 0; uint16_t sfn_offset_result = 0; int16_t frame_boundary_offset_result = -30720; uint8_t rsrp_result = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultServMO ::= SEQUENCE struct meas_result_serv_mo_s { bool ext = false; bool meas_result_best_neigh_cell_present = false; uint8_t serv_cell_id = 0; meas_result_nr_s meas_result_serving_cell; meas_result_nr_s meas_result_best_neigh_cell; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReducedAggregatedBandwidth ::= ENUMERATED struct reduced_aggregated_bw_opts { enum options { mhz0, mhz10, mhz20, mhz30, mhz40, mhz50, mhz60, mhz80, mhz100, mhz200, mhz300, mhz400, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated reduced_aggregated_bw_e; // UplinkTxDirectCurrentCell ::= SEQUENCE struct ul_tx_direct_current_cell_s { using ul_direct_current_bwp_l_ = dyn_array; using ul_direct_current_bwp_sul_l_ = dyn_array; // member variables bool ext = false; uint8_t serv_cell_idx = 0; ul_direct_current_bwp_l_ ul_direct_current_bwp; // ... // group 0 copy_ptr ul_direct_current_bwp_sul; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRB-CountInfo ::= SEQUENCE struct drb_count_info_s { uint8_t drb_id = 1; uint64_t count_ul = 0; uint64_t count_dl = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-RSTD-InfoList ::= SEQUENCE (SIZE (1..3)) OF EUTRA-RSTD-Info using eutra_rstd_info_list_l = dyn_array; // MeasResultCellListSFTD-NR ::= SEQUENCE (SIZE (1..3)) OF MeasResultCellSFTD-NR using meas_result_cell_list_sftd_nr_l = dyn_array; // MeasResultFreqList ::= SEQUENCE (SIZE (1..8)) OF MeasResult2NR using meas_result_freq_list_l = dyn_array; // MeasResultFreqListFailMRDC ::= SEQUENCE (SIZE (1..8)) OF MeasResult2EUTRA using meas_result_freq_list_fail_mrdc_l = dyn_array; // MeasResultListEUTRA ::= SEQUENCE (SIZE (1..8)) OF MeasResultEUTRA using meas_result_list_eutra_l = dyn_array; // MeasResultSFTD-EUTRA ::= SEQUENCE struct meas_result_sftd_eutra_s { bool rsrp_result_present = false; uint16_t eutra_pci = 0; uint16_t sfn_offset_result = 0; int16_t frame_boundary_offset_result = -30720; uint8_t rsrp_result = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultServFreqListEUTRA-SCG ::= SEQUENCE (SIZE (1..32)) OF MeasResult2EUTRA using meas_result_serv_freq_list_eutra_scg_l = dyn_array; // MeasResultServFreqListNR-SCG ::= SEQUENCE (SIZE (1..32)) OF MeasResult2NR using meas_result_serv_freq_list_nr_scg_l = dyn_array; // MeasResultServMOList ::= SEQUENCE (SIZE (1..32)) OF MeasResultServMO using meas_result_serv_mo_list_l = dyn_array; // OverheatingAssistance ::= SEQUENCE struct overheat_assist_s { struct reduced_max_ccs_s_ { uint8_t reduced_ccs_dl = 0; uint8_t reduced_ccs_ul = 0; }; struct reduced_max_bw_fr1_s_ { reduced_aggregated_bw_e reduced_bw_fr1_dl; reduced_aggregated_bw_e reduced_bw_fr1_ul; }; struct reduced_max_bw_fr2_s_ { reduced_aggregated_bw_e reduced_bw_fr2_dl; reduced_aggregated_bw_e reduced_bw_fr2_ul; }; struct reduced_max_mimo_layers_fr1_s_ { mimo_layers_dl_e reduced_mimo_layers_fr1_dl; mimo_layers_ul_e reduced_mimo_layers_fr1_ul; }; struct reduced_max_mimo_layers_fr2_s_ { mimo_layers_dl_e reduced_mimo_layers_fr2_dl; mimo_layers_ul_e reduced_mimo_layers_fr2_ul; }; // member variables bool reduced_max_ccs_present = false; bool reduced_max_bw_fr1_present = false; bool reduced_max_bw_fr2_present = false; bool reduced_max_mimo_layers_fr1_present = false; bool reduced_max_mimo_layers_fr2_present = false; reduced_max_ccs_s_ reduced_max_ccs; reduced_max_bw_fr1_s_ reduced_max_bw_fr1; reduced_max_bw_fr2_s_ reduced_max_bw_fr2; reduced_max_mimo_layers_fr1_s_ reduced_max_mimo_layers_fr1; reduced_max_mimo_layers_fr2_s_ reduced_max_mimo_layers_fr2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfigurationComplete-v1560-IEs ::= SEQUENCE struct rrc_recfg_complete_v1560_ies_s { struct scg_resp_c_ { struct types_opts { enum options { nr_scg_resp, eutra_scg_resp, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods scg_resp_c_() = default; scg_resp_c_(const scg_resp_c_& other); scg_resp_c_& operator=(const scg_resp_c_& other); ~scg_resp_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dyn_octstring& nr_scg_resp() { assert_choice_type(types::nr_scg_resp, type_, "scg-Response"); return c.get(); } dyn_octstring& eutra_scg_resp() { assert_choice_type(types::eutra_scg_resp, type_, "scg-Response"); return c.get(); } const dyn_octstring& nr_scg_resp() const { assert_choice_type(types::nr_scg_resp, type_, "scg-Response"); return c.get(); } const dyn_octstring& eutra_scg_resp() const { assert_choice_type(types::eutra_scg_resp, type_, "scg-Response"); return c.get(); } dyn_octstring& set_nr_scg_resp(); dyn_octstring& set_eutra_scg_resp(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool scg_resp_present = false; bool non_crit_ext_present = false; scg_resp_c_ scg_resp; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRAT-Container ::= SEQUENCE struct ue_cap_rat_container_s { rat_type_e rat_type; dyn_octstring ue_cap_rat_container; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UplinkTxDirectCurrentList ::= SEQUENCE (SIZE (1..32)) OF UplinkTxDirectCurrentCell using ul_tx_direct_current_list_l = dyn_array; // DRB-CountInfoList ::= SEQUENCE (SIZE (0..29)) OF DRB-CountInfo using drb_count_info_list_l = dyn_array; // DelayBudgetReport ::= CHOICE struct delay_budget_report_c { struct type1_opts { enum options { ms_minus1280, ms_minus640, ms_minus320, ms_minus160, ms_minus80, ms_minus60, ms_minus40, ms_minus20, ms0, ms20, ms40, ms60, ms80, ms160, ms320, ms640, ms1280, nulltype } value; typedef int16_t number_type; const char* to_string() const; int16_t to_number() const; }; typedef enumerated type1_e_; struct types_opts { enum options { type1, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods types type() const { return types::type1; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters type1_e_& type1() { return c; } const type1_e_& type1() const { return c; } private: type1_e_ c; }; // FailureInfoRLC-Bearer ::= SEQUENCE struct fail_info_rlc_bearer_s { struct fail_type_opts { enum options { rlc_fail, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated fail_type_e_; // member variables uint8_t cell_group_id = 0; uint8_t lc_ch_id = 1; fail_type_e_ fail_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FailureReportSCG ::= SEQUENCE struct fail_report_scg_s { struct fail_type_opts { enum options { t310_expiry, random_access_problem, rlc_max_num_retx, synch_recfg_fail_scg, scg_recfg_fail, srb3_integrity_fail, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated fail_type_e_; // member variables bool ext = false; bool meas_result_freq_list_present = false; bool meas_result_scg_fail_present = false; fail_type_e_ fail_type; meas_result_freq_list_l meas_result_freq_list; dyn_octstring meas_result_scg_fail; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FailureReportSCG-EUTRA ::= SEQUENCE struct fail_report_scg_eutra_s { struct fail_type_opts { enum options { t313_expiry, random_access_problem, rlc_max_num_retx, scg_change_fail, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated fail_type_e_; // member variables bool ext = false; bool meas_result_freq_list_mrdc_present = false; bool meas_result_scg_fail_mrdc_present = false; fail_type_e_ fail_type; meas_result_freq_list_fail_mrdc_l meas_result_freq_list_mrdc; dyn_octstring meas_result_scg_fail_mrdc; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // LocationMeasurementInfo ::= CHOICE struct location_meas_info_c { struct types_opts { enum options { eutra_rstd, /*...*/ eutra_fine_timing_detection, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods location_meas_info_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters eutra_rstd_info_list_l& eutra_rstd() { assert_choice_type(types::eutra_rstd, type_, "LocationMeasurementInfo"); return c; } const eutra_rstd_info_list_l& eutra_rstd() const { assert_choice_type(types::eutra_rstd, type_, "LocationMeasurementInfo"); return c; } eutra_rstd_info_list_l& set_eutra_rstd(); void set_eutra_fine_timing_detection(); private: types type_; eutra_rstd_info_list_l c; }; // MeasResults ::= SEQUENCE struct meas_results_s { struct meas_result_neigh_cells_c_ { struct types_opts { enum options { meas_result_list_nr, /*...*/ meas_result_list_eutra, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods meas_result_neigh_cells_c_() = default; meas_result_neigh_cells_c_(const meas_result_neigh_cells_c_& other); meas_result_neigh_cells_c_& operator=(const meas_result_neigh_cells_c_& other); ~meas_result_neigh_cells_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters meas_result_list_nr_l& meas_result_list_nr() { assert_choice_type(types::meas_result_list_nr, type_, "measResultNeighCells"); return c.get(); } meas_result_list_eutra_l& meas_result_list_eutra() { assert_choice_type(types::meas_result_list_eutra, type_, "measResultNeighCells"); return c.get(); } const meas_result_list_nr_l& meas_result_list_nr() const { assert_choice_type(types::meas_result_list_nr, type_, "measResultNeighCells"); return c.get(); } const meas_result_list_eutra_l& meas_result_list_eutra() const { assert_choice_type(types::meas_result_list_eutra, type_, "measResultNeighCells"); return c.get(); } meas_result_list_nr_l& set_meas_result_list_nr(); meas_result_list_eutra_l& set_meas_result_list_eutra(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool meas_result_neigh_cells_present = false; uint8_t meas_id = 1; meas_result_serv_mo_list_l meas_result_serving_mo_list; meas_result_neigh_cells_c_ meas_result_neigh_cells; // ... // group 0 copy_ptr meas_result_serv_freq_list_eutra_scg; copy_ptr meas_result_serv_freq_list_nr_scg; copy_ptr meas_result_sftd_eutra; copy_ptr meas_result_sftd_nr; // group 1 copy_ptr meas_result_cell_list_sftd_nr; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfigurationComplete-v1530-IEs ::= SEQUENCE struct rrc_recfg_complete_v1530_ies_s { bool ul_tx_direct_current_list_present = false; bool non_crit_ext_present = false; ul_tx_direct_current_list_l ul_tx_direct_current_list; rrc_recfg_complete_v1560_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RegisteredAMF ::= SEQUENCE struct registered_amf_s { bool plmn_id_present = false; plmn_id_s plmn_id; fixed_bitstring<24> amf_id; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // S-NSSAI ::= CHOICE struct s_nssai_c { struct types_opts { enum options { sst, sst_sd, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods s_nssai_c() = default; s_nssai_c(const s_nssai_c& other); s_nssai_c& operator=(const s_nssai_c& other); ~s_nssai_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<8>& sst() { assert_choice_type(types::sst, type_, "S-NSSAI"); return c.get >(); } fixed_bitstring<32>& sst_sd() { assert_choice_type(types::sst_sd, type_, "S-NSSAI"); return c.get >(); } const fixed_bitstring<8>& sst() const { assert_choice_type(types::sst, type_, "S-NSSAI"); return c.get >(); } const fixed_bitstring<32>& sst_sd() const { assert_choice_type(types::sst_sd, type_, "S-NSSAI"); return c.get >(); } fixed_bitstring<8>& set_sst(); fixed_bitstring<32>& set_sst_sd(); private: types type_; choice_buffer_t > c; void destroy_(); }; // SCGFailureInformation-v1590-IEs ::= SEQUENCE struct scg_fail_info_v1590_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCGFailureInformationEUTRA-v1590-IEs ::= SEQUENCE struct scg_fail_info_eutra_v1590_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRAT-ContainerList ::= SEQUENCE (SIZE (0..8)) OF UE-CapabilityRAT-Container using ue_cap_rat_container_list_l = dyn_array; // UEAssistanceInformation-v1540-IEs ::= SEQUENCE struct ueassist_info_v1540_ies_s { bool overheat_assist_present = false; bool non_crit_ext_present = false; overheat_assist_s overheat_assist; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CounterCheckResponse-IEs ::= SEQUENCE struct counter_check_resp_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; drb_count_info_list_l drb_count_info_list; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FailureInformation-IEs ::= SEQUENCE struct fail_info_ies_s { bool fail_info_rlc_bearer_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; fail_info_rlc_bearer_s fail_info_rlc_bearer; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // LocationMeasurementIndication-IEs ::= SEQUENCE struct location_meas_ind_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; setup_release_c meas_ind; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasurementReport-IEs ::= SEQUENCE struct meas_report_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; meas_results_s meas_results; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfigurationComplete-IEs ::= SEQUENCE struct rrc_recfg_complete_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; rrc_recfg_complete_v1530_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReestablishmentComplete-IEs ::= SEQUENCE struct rrc_reest_complete_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeComplete-IEs ::= SEQUENCE struct rrc_resume_complete_ies_s { bool ded_nas_msg_present = false; bool sel_plmn_id_present = false; bool ul_tx_direct_current_list_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring ded_nas_msg; uint8_t sel_plmn_id = 1; ul_tx_direct_current_list_l ul_tx_direct_current_list; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetupComplete-IEs ::= SEQUENCE struct rrc_setup_complete_ies_s { struct guami_type_opts { enum options { native, mapped, nulltype } value; const char* to_string() const; }; typedef enumerated guami_type_e_; using s_nssai_list_l_ = dyn_array; struct ng_minus5_g_s_tmsi_value_c_ { struct types_opts { enum options { ng_minus5_g_s_tmsi, ng_minus5_g_s_tmsi_part2, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ng_minus5_g_s_tmsi_value_c_() = default; ng_minus5_g_s_tmsi_value_c_(const ng_minus5_g_s_tmsi_value_c_& other); ng_minus5_g_s_tmsi_value_c_& operator=(const ng_minus5_g_s_tmsi_value_c_& other); ~ng_minus5_g_s_tmsi_value_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<48>& ng_minus5_g_s_tmsi() { assert_choice_type(types::ng_minus5_g_s_tmsi, type_, "ng-5G-S-TMSI-Value"); return c.get >(); } fixed_bitstring<9>& ng_minus5_g_s_tmsi_part2() { assert_choice_type(types::ng_minus5_g_s_tmsi_part2, type_, "ng-5G-S-TMSI-Value"); return c.get >(); } const fixed_bitstring<48>& ng_minus5_g_s_tmsi() const { assert_choice_type(types::ng_minus5_g_s_tmsi, type_, "ng-5G-S-TMSI-Value"); return c.get >(); } const fixed_bitstring<9>& ng_minus5_g_s_tmsi_part2() const { assert_choice_type(types::ng_minus5_g_s_tmsi_part2, type_, "ng-5G-S-TMSI-Value"); return c.get >(); } fixed_bitstring<48>& set_ng_minus5_g_s_tmsi(); fixed_bitstring<9>& set_ng_minus5_g_s_tmsi_part2(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool registered_amf_present = false; bool guami_type_present = false; bool s_nssai_list_present = false; bool ng_minus5_g_s_tmsi_value_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; uint8_t sel_plmn_id = 1; registered_amf_s registered_amf; guami_type_e_ guami_type; s_nssai_list_l_ s_nssai_list; dyn_octstring ded_nas_msg; ng_minus5_g_s_tmsi_value_c_ ng_minus5_g_s_tmsi_value; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCGFailureInformation-IEs ::= SEQUENCE struct scg_fail_info_ies_s { bool fail_report_scg_present = false; bool non_crit_ext_present = false; fail_report_scg_s fail_report_scg; scg_fail_info_v1590_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCGFailureInformationEUTRA-IEs ::= SEQUENCE struct scg_fail_info_eutra_ies_s { bool fail_report_scg_eutra_present = false; bool non_crit_ext_present = false; fail_report_scg_eutra_s fail_report_scg_eutra; scg_fail_info_eutra_v1590_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeComplete-IEs ::= SEQUENCE struct security_mode_complete_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeFailure-IEs ::= SEQUENCE struct security_mode_fail_ies_s { bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UEAssistanceInformation-IEs ::= SEQUENCE struct ueassist_info_ies_s { bool delay_budget_report_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; delay_budget_report_c delay_budget_report; dyn_octstring late_non_crit_ext; ueassist_info_v1540_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UECapabilityInformation-IEs ::= SEQUENCE struct ue_cap_info_ies_s { bool ue_cap_rat_container_list_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; ue_cap_rat_container_list_l ue_cap_rat_container_list; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ULInformationTransfer-IEs ::= SEQUENCE struct ul_info_transfer_ies_s { bool ded_nas_msg_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring ded_nas_msg; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ULInformationTransferMRDC-IEs ::= SEQUENCE struct ul_info_transfer_mrdc_ies_s { bool ul_dcch_msg_nr_present = false; bool ul_dcch_msg_eutra_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; dyn_octstring ul_dcch_msg_nr; dyn_octstring ul_dcch_msg_eutra; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CounterCheckResponse ::= SEQUENCE struct counter_check_resp_s { struct crit_exts_c_ { struct types_opts { enum options { counter_check_resp, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters counter_check_resp_ies_s& counter_check_resp() { assert_choice_type(types::counter_check_resp, type_, "criticalExtensions"); return c; } const counter_check_resp_ies_s& counter_check_resp() const { assert_choice_type(types::counter_check_resp, type_, "criticalExtensions"); return c; } counter_check_resp_ies_s& set_counter_check_resp(); void set_crit_exts_future(); private: types type_; counter_check_resp_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FailureInformation ::= SEQUENCE struct fail_info_s { struct crit_exts_c_ { struct types_opts { enum options { fail_info, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fail_info_ies_s& fail_info() { assert_choice_type(types::fail_info, type_, "criticalExtensions"); return c; } const fail_info_ies_s& fail_info() const { assert_choice_type(types::fail_info, type_, "criticalExtensions"); return c; } fail_info_ies_s& set_fail_info(); void set_crit_exts_future(); private: types type_; fail_info_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // LocationMeasurementIndication ::= SEQUENCE struct location_meas_ind_s { struct crit_exts_c_ { struct types_opts { enum options { location_meas_ind, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters location_meas_ind_ies_s& location_meas_ind() { assert_choice_type(types::location_meas_ind, type_, "criticalExtensions"); return c; } const location_meas_ind_ies_s& location_meas_ind() const { assert_choice_type(types::location_meas_ind, type_, "criticalExtensions"); return c; } location_meas_ind_ies_s& set_location_meas_ind(); void set_crit_exts_future(); private: types type_; location_meas_ind_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasurementReport ::= SEQUENCE struct meas_report_s { struct crit_exts_c_ { struct types_opts { enum options { meas_report, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters meas_report_ies_s& meas_report() { assert_choice_type(types::meas_report, type_, "criticalExtensions"); return c; } const meas_report_ies_s& meas_report() const { assert_choice_type(types::meas_report, type_, "criticalExtensions"); return c; } meas_report_ies_s& set_meas_report(); void set_crit_exts_future(); private: types type_; meas_report_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReconfigurationComplete ::= SEQUENCE struct rrc_recfg_complete_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_recfg_complete, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_recfg_complete_ies_s& rrc_recfg_complete() { assert_choice_type(types::rrc_recfg_complete, type_, "criticalExtensions"); return c; } const rrc_recfg_complete_ies_s& rrc_recfg_complete() const { assert_choice_type(types::rrc_recfg_complete, type_, "criticalExtensions"); return c; } rrc_recfg_complete_ies_s& set_rrc_recfg_complete(); void set_crit_exts_future(); private: types type_; rrc_recfg_complete_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCReestablishmentComplete ::= SEQUENCE struct rrc_reest_complete_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_reest_complete, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_reest_complete_ies_s& rrc_reest_complete() { assert_choice_type(types::rrc_reest_complete, type_, "criticalExtensions"); return c; } const rrc_reest_complete_ies_s& rrc_reest_complete() const { assert_choice_type(types::rrc_reest_complete, type_, "criticalExtensions"); return c; } rrc_reest_complete_ies_s& set_rrc_reest_complete(); void set_crit_exts_future(); private: types type_; rrc_reest_complete_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCResumeComplete ::= SEQUENCE struct rrc_resume_complete_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_resume_complete, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_resume_complete_ies_s& rrc_resume_complete() { assert_choice_type(types::rrc_resume_complete, type_, "criticalExtensions"); return c; } const rrc_resume_complete_ies_s& rrc_resume_complete() const { assert_choice_type(types::rrc_resume_complete, type_, "criticalExtensions"); return c; } rrc_resume_complete_ies_s& set_rrc_resume_complete(); void set_crit_exts_future(); private: types type_; rrc_resume_complete_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRCSetupComplete ::= SEQUENCE struct rrc_setup_complete_s { struct crit_exts_c_ { struct types_opts { enum options { rrc_setup_complete, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rrc_setup_complete_ies_s& rrc_setup_complete() { assert_choice_type(types::rrc_setup_complete, type_, "criticalExtensions"); return c; } const rrc_setup_complete_ies_s& rrc_setup_complete() const { assert_choice_type(types::rrc_setup_complete, type_, "criticalExtensions"); return c; } rrc_setup_complete_ies_s& set_rrc_setup_complete(); void set_crit_exts_future(); private: types type_; rrc_setup_complete_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCGFailureInformation ::= SEQUENCE struct scg_fail_info_s { struct crit_exts_c_ { struct types_opts { enum options { scg_fail_info, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters scg_fail_info_ies_s& scg_fail_info() { assert_choice_type(types::scg_fail_info, type_, "criticalExtensions"); return c; } const scg_fail_info_ies_s& scg_fail_info() const { assert_choice_type(types::scg_fail_info, type_, "criticalExtensions"); return c; } scg_fail_info_ies_s& set_scg_fail_info(); void set_crit_exts_future(); private: types type_; scg_fail_info_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCGFailureInformationEUTRA ::= SEQUENCE struct scg_fail_info_eutra_s { struct crit_exts_c_ { struct types_opts { enum options { scg_fail_info_eutra, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters scg_fail_info_eutra_ies_s& scg_fail_info_eutra() { assert_choice_type(types::scg_fail_info_eutra, type_, "criticalExtensions"); return c; } const scg_fail_info_eutra_ies_s& scg_fail_info_eutra() const { assert_choice_type(types::scg_fail_info_eutra, type_, "criticalExtensions"); return c; } scg_fail_info_eutra_ies_s& set_scg_fail_info_eutra(); void set_crit_exts_future(); private: types type_; scg_fail_info_eutra_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeComplete ::= SEQUENCE struct security_mode_complete_s { struct crit_exts_c_ { struct types_opts { enum options { security_mode_complete, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters security_mode_complete_ies_s& security_mode_complete() { assert_choice_type(types::security_mode_complete, type_, "criticalExtensions"); return c; } const security_mode_complete_ies_s& security_mode_complete() const { assert_choice_type(types::security_mode_complete, type_, "criticalExtensions"); return c; } security_mode_complete_ies_s& set_security_mode_complete(); void set_crit_exts_future(); private: types type_; security_mode_complete_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SecurityModeFailure ::= SEQUENCE struct security_mode_fail_s { struct crit_exts_c_ { struct types_opts { enum options { security_mode_fail, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters security_mode_fail_ies_s& security_mode_fail() { assert_choice_type(types::security_mode_fail, type_, "criticalExtensions"); return c; } const security_mode_fail_ies_s& security_mode_fail() const { assert_choice_type(types::security_mode_fail, type_, "criticalExtensions"); return c; } security_mode_fail_ies_s& set_security_mode_fail(); void set_crit_exts_future(); private: types type_; security_mode_fail_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UEAssistanceInformation ::= SEQUENCE struct ueassist_info_s { struct crit_exts_c_ { struct types_opts { enum options { ue_assist_info, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ueassist_info_ies_s& ue_assist_info() { assert_choice_type(types::ue_assist_info, type_, "criticalExtensions"); return c; } const ueassist_info_ies_s& ue_assist_info() const { assert_choice_type(types::ue_assist_info, type_, "criticalExtensions"); return c; } ueassist_info_ies_s& set_ue_assist_info(); void set_crit_exts_future(); private: types type_; ueassist_info_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UECapabilityInformation ::= SEQUENCE struct ue_cap_info_s { struct crit_exts_c_ { struct types_opts { enum options { ue_cap_info, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ue_cap_info_ies_s& ue_cap_info() { assert_choice_type(types::ue_cap_info, type_, "criticalExtensions"); return c; } const ue_cap_info_ies_s& ue_cap_info() const { assert_choice_type(types::ue_cap_info, type_, "criticalExtensions"); return c; } ue_cap_info_ies_s& set_ue_cap_info(); void set_crit_exts_future(); private: types type_; ue_cap_info_ies_s c; }; // member variables uint8_t rrc_transaction_id = 0; crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ULInformationTransfer ::= SEQUENCE struct ul_info_transfer_s { struct crit_exts_c_ { struct types_opts { enum options { ul_info_transfer, crit_exts_future, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ul_info_transfer_ies_s& ul_info_transfer() { assert_choice_type(types::ul_info_transfer, type_, "criticalExtensions"); return c; } const ul_info_transfer_ies_s& ul_info_transfer() const { assert_choice_type(types::ul_info_transfer, type_, "criticalExtensions"); return c; } ul_info_transfer_ies_s& set_ul_info_transfer(); void set_crit_exts_future(); private: types type_; ul_info_transfer_ies_s c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ULInformationTransferMRDC ::= SEQUENCE struct ul_info_transfer_mrdc_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { ul_info_transfer_mrdc, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ul_info_transfer_mrdc_ies_s& ul_info_transfer_mrdc() { assert_choice_type(types::ul_info_transfer_mrdc, type_, "c1"); return c; } const ul_info_transfer_mrdc_ies_s& ul_info_transfer_mrdc() const { assert_choice_type(types::ul_info_transfer_mrdc, type_, "c1"); return c; } ul_info_transfer_mrdc_ies_s& set_ul_info_transfer_mrdc(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; ul_info_transfer_mrdc_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-DCCH-MessageType ::= CHOICE struct ul_dcch_msg_type_c { struct c1_c_ { struct types_opts { enum options { meas_report, rrc_recfg_complete, rrc_setup_complete, rrc_reest_complete, rrc_resume_complete, security_mode_complete, security_mode_fail, ul_info_transfer, location_meas_ind, ue_cap_info, counter_check_resp, ue_assist_info, fail_info, ul_info_transfer_mrdc, scg_fail_info, scg_fail_info_eutra, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; c1_c_(const c1_c_& other); c1_c_& operator=(const c1_c_& other); ~c1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters meas_report_s& meas_report() { assert_choice_type(types::meas_report, type_, "c1"); return c.get(); } rrc_recfg_complete_s& rrc_recfg_complete() { assert_choice_type(types::rrc_recfg_complete, type_, "c1"); return c.get(); } rrc_setup_complete_s& rrc_setup_complete() { assert_choice_type(types::rrc_setup_complete, type_, "c1"); return c.get(); } rrc_reest_complete_s& rrc_reest_complete() { assert_choice_type(types::rrc_reest_complete, type_, "c1"); return c.get(); } rrc_resume_complete_s& rrc_resume_complete() { assert_choice_type(types::rrc_resume_complete, type_, "c1"); return c.get(); } security_mode_complete_s& security_mode_complete() { assert_choice_type(types::security_mode_complete, type_, "c1"); return c.get(); } security_mode_fail_s& security_mode_fail() { assert_choice_type(types::security_mode_fail, type_, "c1"); return c.get(); } ul_info_transfer_s& ul_info_transfer() { assert_choice_type(types::ul_info_transfer, type_, "c1"); return c.get(); } location_meas_ind_s& location_meas_ind() { assert_choice_type(types::location_meas_ind, type_, "c1"); return c.get(); } ue_cap_info_s& ue_cap_info() { assert_choice_type(types::ue_cap_info, type_, "c1"); return c.get(); } counter_check_resp_s& counter_check_resp() { assert_choice_type(types::counter_check_resp, type_, "c1"); return c.get(); } ueassist_info_s& ue_assist_info() { assert_choice_type(types::ue_assist_info, type_, "c1"); return c.get(); } fail_info_s& fail_info() { assert_choice_type(types::fail_info, type_, "c1"); return c.get(); } ul_info_transfer_mrdc_s& ul_info_transfer_mrdc() { assert_choice_type(types::ul_info_transfer_mrdc, type_, "c1"); return c.get(); } scg_fail_info_s& scg_fail_info() { assert_choice_type(types::scg_fail_info, type_, "c1"); return c.get(); } scg_fail_info_eutra_s& scg_fail_info_eutra() { assert_choice_type(types::scg_fail_info_eutra, type_, "c1"); return c.get(); } const meas_report_s& meas_report() const { assert_choice_type(types::meas_report, type_, "c1"); return c.get(); } const rrc_recfg_complete_s& rrc_recfg_complete() const { assert_choice_type(types::rrc_recfg_complete, type_, "c1"); return c.get(); } const rrc_setup_complete_s& rrc_setup_complete() const { assert_choice_type(types::rrc_setup_complete, type_, "c1"); return c.get(); } const rrc_reest_complete_s& rrc_reest_complete() const { assert_choice_type(types::rrc_reest_complete, type_, "c1"); return c.get(); } const rrc_resume_complete_s& rrc_resume_complete() const { assert_choice_type(types::rrc_resume_complete, type_, "c1"); return c.get(); } const security_mode_complete_s& security_mode_complete() const { assert_choice_type(types::security_mode_complete, type_, "c1"); return c.get(); } const security_mode_fail_s& security_mode_fail() const { assert_choice_type(types::security_mode_fail, type_, "c1"); return c.get(); } const ul_info_transfer_s& ul_info_transfer() const { assert_choice_type(types::ul_info_transfer, type_, "c1"); return c.get(); } const location_meas_ind_s& location_meas_ind() const { assert_choice_type(types::location_meas_ind, type_, "c1"); return c.get(); } const ue_cap_info_s& ue_cap_info() const { assert_choice_type(types::ue_cap_info, type_, "c1"); return c.get(); } const counter_check_resp_s& counter_check_resp() const { assert_choice_type(types::counter_check_resp, type_, "c1"); return c.get(); } const ueassist_info_s& ue_assist_info() const { assert_choice_type(types::ue_assist_info, type_, "c1"); return c.get(); } const fail_info_s& fail_info() const { assert_choice_type(types::fail_info, type_, "c1"); return c.get(); } const ul_info_transfer_mrdc_s& ul_info_transfer_mrdc() const { assert_choice_type(types::ul_info_transfer_mrdc, type_, "c1"); return c.get(); } const scg_fail_info_s& scg_fail_info() const { assert_choice_type(types::scg_fail_info, type_, "c1"); return c.get(); } const scg_fail_info_eutra_s& scg_fail_info_eutra() const { assert_choice_type(types::scg_fail_info_eutra, type_, "c1"); return c.get(); } meas_report_s& set_meas_report(); rrc_recfg_complete_s& set_rrc_recfg_complete(); rrc_setup_complete_s& set_rrc_setup_complete(); rrc_reest_complete_s& set_rrc_reest_complete(); rrc_resume_complete_s& set_rrc_resume_complete(); security_mode_complete_s& set_security_mode_complete(); security_mode_fail_s& set_security_mode_fail(); ul_info_transfer_s& set_ul_info_transfer(); location_meas_ind_s& set_location_meas_ind(); ue_cap_info_s& set_ue_cap_info(); counter_check_resp_s& set_counter_check_resp(); ueassist_info_s& set_ue_assist_info(); fail_info_s& set_fail_info(); ul_info_transfer_mrdc_s& set_ul_info_transfer_mrdc(); scg_fail_info_s& set_scg_fail_info(); scg_fail_info_eutra_s& set_scg_fail_info_eutra(); private: types type_; choice_buffer_t c; void destroy_(); }; struct types_opts { enum options { c1, msg_class_ext, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ul_dcch_msg_type_c() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "UL-DCCH-MessageType"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "UL-DCCH-MessageType"); return c; } c1_c_& set_c1(); void set_msg_class_ext(); private: types type_; c1_c_ c; }; // UL-DCCH-Message ::= SEQUENCE struct ul_dcch_msg_s { ul_dcch_msg_type_c msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BFR-CSIRS-Resource ::= SEQUENCE struct bfr_csirs_res_s { using ra_occasion_list_l_ = dyn_array; // member variables bool ext = false; bool ra_occasion_list_present = false; bool ra_preamb_idx_present = false; uint8_t csi_rs = 0; ra_occasion_list_l_ ra_occasion_list; uint8_t ra_preamb_idx = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BFR-SSB-Resource ::= SEQUENCE struct bfr_ssb_res_s { bool ext = false; uint8_t ssb = 0; uint8_t ra_preamb_idx = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-FrequencyOccupation ::= SEQUENCE struct csi_freq_occupation_s { bool ext = false; uint16_t start_rb = 0; uint16_t nrof_rbs = 24; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-ResourceMapping ::= SEQUENCE struct csi_rs_res_map_s { struct freq_domain_alloc_c_ { struct types_opts { enum options { row1, row2, row4, other, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods freq_domain_alloc_c_() = default; freq_domain_alloc_c_(const freq_domain_alloc_c_& other); freq_domain_alloc_c_& operator=(const freq_domain_alloc_c_& other); ~freq_domain_alloc_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<4>& row1() { assert_choice_type(types::row1, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<12>& row2() { assert_choice_type(types::row2, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<3>& row4() { assert_choice_type(types::row4, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<6>& other() { assert_choice_type(types::other, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<4>& row1() const { assert_choice_type(types::row1, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<12>& row2() const { assert_choice_type(types::row2, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<3>& row4() const { assert_choice_type(types::row4, type_, "frequencyDomainAllocation"); return c.get >(); } const fixed_bitstring<6>& other() const { assert_choice_type(types::other, type_, "frequencyDomainAllocation"); return c.get >(); } fixed_bitstring<4>& set_row1(); fixed_bitstring<12>& set_row2(); fixed_bitstring<3>& set_row4(); fixed_bitstring<6>& set_other(); private: types type_; choice_buffer_t > c; void destroy_(); }; struct nrof_ports_opts { enum options { p1, p2, p4, p8, p12, p16, p24, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_ports_e_; struct cdm_type_opts { enum options { no_cdm, fd_cdm2, cdm4_fd2_td2, cdm8_fd2_td4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated cdm_type_e_; struct density_c_ { struct dot5_opts { enum options { even_prbs, odd_prbs, nulltype } value; const char* to_string() const; }; typedef enumerated dot5_e_; struct types_opts { enum options { dot5, one, three, spare, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods density_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dot5_e_& dot5() { assert_choice_type(types::dot5, type_, "density"); return c; } const dot5_e_& dot5() const { assert_choice_type(types::dot5, type_, "density"); return c; } dot5_e_& set_dot5(); void set_one(); void set_three(); void set_spare(); private: types type_; dot5_e_ c; }; // member variables bool ext = false; bool first_ofdm_symbol_in_time_domain2_present = false; freq_domain_alloc_c_ freq_domain_alloc; nrof_ports_e_ nrof_ports; uint8_t first_ofdm_symbol_in_time_domain = 0; uint8_t first_ofdm_symbol_in_time_domain2 = 2; cdm_type_e_ cdm_type; density_c_ density; csi_freq_occupation_s freq_band; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-ResourcePeriodicityAndOffset ::= CHOICE struct csi_res_periodicity_and_offset_c { struct types_opts { enum options { slots4, slots5, slots8, slots10, slots16, slots20, slots32, slots40, slots64, slots80, slots160, slots320, slots640, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods csi_res_periodicity_and_offset_c() = default; csi_res_periodicity_and_offset_c(const csi_res_periodicity_and_offset_c& other); csi_res_periodicity_and_offset_c& operator=(const csi_res_periodicity_and_offset_c& other); ~csi_res_periodicity_and_offset_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& slots4() { assert_choice_type(types::slots4, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots5() { assert_choice_type(types::slots5, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots8() { assert_choice_type(types::slots8, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots10() { assert_choice_type(types::slots10, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots16() { assert_choice_type(types::slots16, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots20() { assert_choice_type(types::slots20, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots32() { assert_choice_type(types::slots32, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots40() { assert_choice_type(types::slots40, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots64() { assert_choice_type(types::slots64, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots80() { assert_choice_type(types::slots80, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& slots160() { assert_choice_type(types::slots160, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint16_t& slots320() { assert_choice_type(types::slots320, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint16_t& slots640() { assert_choice_type(types::slots640, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots4() const { assert_choice_type(types::slots4, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots5() const { assert_choice_type(types::slots5, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots8() const { assert_choice_type(types::slots8, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots10() const { assert_choice_type(types::slots10, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots16() const { assert_choice_type(types::slots16, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots20() const { assert_choice_type(types::slots20, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots32() const { assert_choice_type(types::slots32, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots40() const { assert_choice_type(types::slots40, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots64() const { assert_choice_type(types::slots64, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots80() const { assert_choice_type(types::slots80, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint8_t& slots160() const { assert_choice_type(types::slots160, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint16_t& slots320() const { assert_choice_type(types::slots320, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } const uint16_t& slots640() const { assert_choice_type(types::slots640, type_, "CSI-ResourcePeriodicityAndOffset"); return c.get(); } uint8_t& set_slots4(); uint8_t& set_slots5(); uint8_t& set_slots8(); uint8_t& set_slots10(); uint8_t& set_slots16(); uint8_t& set_slots20(); uint8_t& set_slots32(); uint8_t& set_slots40(); uint8_t& set_slots64(); uint8_t& set_slots80(); uint8_t& set_slots160(); uint16_t& set_slots320(); uint16_t& set_slots640(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // INT-ConfigurationPerServingCell ::= SEQUENCE struct int_cfg_per_serving_cell_s { uint8_t serving_cell_id = 0; uint8_t position_in_dci = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PTRS-DownlinkConfig ::= SEQUENCE struct ptrs_dl_cfg_s { using freq_density_l_ = std::array; using time_density_l_ = std::array; struct res_elem_offset_opts { enum options { offset01, offset10, offset11, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated res_elem_offset_e_; // member variables bool ext = false; bool freq_density_present = false; bool time_density_present = false; bool epre_ratio_present = false; bool res_elem_offset_present = false; freq_density_l_ freq_density; time_density_l_ time_density; uint8_t epre_ratio = 0; res_elem_offset_e_ res_elem_offset; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // QCL-Info ::= SEQUENCE struct qcl_info_s { struct ref_sig_c_ { struct types_opts { enum options { csi_rs, ssb, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ref_sig_c_() = default; ref_sig_c_(const ref_sig_c_& other); ref_sig_c_& operator=(const ref_sig_c_& other); ~ref_sig_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& csi_rs() { assert_choice_type(types::csi_rs, type_, "referenceSignal"); return c.get(); } uint8_t& ssb() { assert_choice_type(types::ssb, type_, "referenceSignal"); return c.get(); } const uint8_t& csi_rs() const { assert_choice_type(types::csi_rs, type_, "referenceSignal"); return c.get(); } const uint8_t& ssb() const { assert_choice_type(types::ssb, type_, "referenceSignal"); return c.get(); } uint8_t& set_csi_rs(); uint8_t& set_ssb(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct qcl_type_opts { enum options { type_a, type_b, type_c, type_d, nulltype } value; const char* to_string() const; }; typedef enumerated qcl_type_e_; // member variables bool ext = false; bool cell_present = false; bool bwp_id_present = false; uint8_t cell = 0; uint8_t bwp_id = 0; ref_sig_c_ ref_sig; qcl_type_e_ qcl_type; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DMRS-DownlinkConfig ::= SEQUENCE struct dmrs_dl_cfg_s { struct dmrs_add_position_opts { enum options { pos0, pos1, pos3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dmrs_add_position_e_; // member variables bool ext = false; bool dmrs_type_present = false; bool dmrs_add_position_present = false; bool max_len_present = false; bool scrambling_id0_present = false; bool scrambling_id1_present = false; bool phase_tracking_rs_present = false; dmrs_add_position_e_ dmrs_add_position; uint32_t scrambling_id0 = 0; uint32_t scrambling_id1 = 0; setup_release_c phase_tracking_rs; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DownlinkPreemption ::= SEQUENCE struct dl_preemption_s { struct time_freq_set_opts { enum options { set0, set1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated time_freq_set_e_; using int_cfg_per_serving_cell_l_ = dyn_array; // member variables bool ext = false; uint32_t int_rnti = 0; time_freq_set_e_ time_freq_set; uint8_t dci_payload_size = 0; int_cfg_per_serving_cell_l_ int_cfg_per_serving_cell; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-TPC-CommandConfig ::= SEQUENCE struct pucch_tpc_cmd_cfg_s { bool ext = false; bool tpc_idx_pcell_present = false; bool tpc_idx_pucch_scell_present = false; uint8_t tpc_idx_pcell = 1; uint8_t tpc_idx_pucch_scell = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-TPC-CommandConfig ::= SEQUENCE struct pusch_tpc_cmd_cfg_s { bool ext = false; bool tpc_idx_present = false; bool tpc_idx_sul_present = false; bool target_cell_present = false; uint8_t tpc_idx = 1; uint8_t tpc_idx_sul = 1; uint8_t target_cell = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RadioLinkMonitoringRS ::= SEQUENCE struct radio_link_monitoring_rs_s { struct purpose_opts { enum options { beam_fail, rlf, both, nulltype } value; const char* to_string() const; }; typedef enumerated purpose_e_; struct detection_res_c_ { struct types_opts { enum options { ssb_idx, csi_rs_idx, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods detection_res_c_() = default; detection_res_c_(const detection_res_c_& other); detection_res_c_& operator=(const detection_res_c_& other); ~detection_res_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "detectionResource"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "detectionResource"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "detectionResource"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "detectionResource"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; uint8_t radio_link_monitoring_rs_id = 0; purpose_e_ purpose; detection_res_c_ detection_res; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RateMatchPattern ::= SEQUENCE struct rate_match_pattern_s { struct pattern_type_c_ { struct bitmaps_s_ { struct symbols_in_res_block_c_ { struct types_opts { enum options { one_slot, two_slots, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods symbols_in_res_block_c_() = default; symbols_in_res_block_c_(const symbols_in_res_block_c_& other); symbols_in_res_block_c_& operator=(const symbols_in_res_block_c_& other); ~symbols_in_res_block_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<14>& one_slot() { assert_choice_type(types::one_slot, type_, "symbolsInResourceBlock"); return c.get >(); } fixed_bitstring<28>& two_slots() { assert_choice_type(types::two_slots, type_, "symbolsInResourceBlock"); return c.get >(); } const fixed_bitstring<14>& one_slot() const { assert_choice_type(types::one_slot, type_, "symbolsInResourceBlock"); return c.get >(); } const fixed_bitstring<28>& two_slots() const { assert_choice_type(types::two_slots, type_, "symbolsInResourceBlock"); return c.get >(); } fixed_bitstring<14>& set_one_slot(); fixed_bitstring<28>& set_two_slots(); private: types type_; choice_buffer_t > c; void destroy_(); }; struct periodicity_and_pattern_c_ { struct types_opts { enum options { n2, n4, n5, n8, n10, n20, n40, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods periodicity_and_pattern_c_() = default; periodicity_and_pattern_c_(const periodicity_and_pattern_c_& other); periodicity_and_pattern_c_& operator=(const periodicity_and_pattern_c_& other); ~periodicity_and_pattern_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<2>& n2() { assert_choice_type(types::n2, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<4>& n4() { assert_choice_type(types::n4, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<5>& n5() { assert_choice_type(types::n5, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<8>& n8() { assert_choice_type(types::n8, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<10>& n10() { assert_choice_type(types::n10, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<20>& n20() { assert_choice_type(types::n20, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<40>& n40() { assert_choice_type(types::n40, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<2>& n2() const { assert_choice_type(types::n2, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<4>& n4() const { assert_choice_type(types::n4, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<5>& n5() const { assert_choice_type(types::n5, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<8>& n8() const { assert_choice_type(types::n8, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<10>& n10() const { assert_choice_type(types::n10, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<20>& n20() const { assert_choice_type(types::n20, type_, "periodicityAndPattern"); return c.get >(); } const fixed_bitstring<40>& n40() const { assert_choice_type(types::n40, type_, "periodicityAndPattern"); return c.get >(); } fixed_bitstring<2>& set_n2(); fixed_bitstring<4>& set_n4(); fixed_bitstring<5>& set_n5(); fixed_bitstring<8>& set_n8(); fixed_bitstring<10>& set_n10(); fixed_bitstring<20>& set_n20(); fixed_bitstring<40>& set_n40(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool ext = false; bool periodicity_and_pattern_present = false; fixed_bitstring<275> res_blocks; symbols_in_res_block_c_ symbols_in_res_block; periodicity_and_pattern_c_ periodicity_and_pattern; // ... }; struct types_opts { enum options { bitmaps, ctrl_res_set, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods pattern_type_c_() = default; pattern_type_c_(const pattern_type_c_& other); pattern_type_c_& operator=(const pattern_type_c_& other); ~pattern_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters bitmaps_s_& bitmaps() { assert_choice_type(types::bitmaps, type_, "patternType"); return c.get(); } uint8_t& ctrl_res_set() { assert_choice_type(types::ctrl_res_set, type_, "patternType"); return c.get(); } const bitmaps_s_& bitmaps() const { assert_choice_type(types::bitmaps, type_, "patternType"); return c.get(); } const uint8_t& ctrl_res_set() const { assert_choice_type(types::ctrl_res_set, type_, "patternType"); return c.get(); } bitmaps_s_& set_bitmaps(); uint8_t& set_ctrl_res_set(); private: types type_; choice_buffer_t c; void destroy_(); }; struct dummy_opts { enum options { dynamic_value, semi_static, nulltype } value; const char* to_string() const; }; typedef enumerated dummy_e_; // member variables bool ext = false; bool subcarrier_spacing_present = false; uint8_t rate_match_pattern_id = 0; pattern_type_c_ pattern_type; subcarrier_spacing_e subcarrier_spacing; dummy_e_ dummy; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; struct rate_match_pattern_group_item_c_ { struct types_opts { enum options { cell_level, bwp_level, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods rate_match_pattern_group_item_c_() = default; rate_match_pattern_group_item_c_(const rate_match_pattern_group_item_c_& other); rate_match_pattern_group_item_c_& operator=(const rate_match_pattern_group_item_c_& other); ~rate_match_pattern_group_item_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& cell_level() { assert_choice_type(types::cell_level, type_, "RateMatchPatternGroup-item"); return c.get(); } uint8_t& bwp_level() { assert_choice_type(types::bwp_level, type_, "RateMatchPatternGroup-item"); return c.get(); } const uint8_t& cell_level() const { assert_choice_type(types::cell_level, type_, "RateMatchPatternGroup-item"); return c.get(); } const uint8_t& bwp_level() const { assert_choice_type(types::bwp_level, type_, "RateMatchPatternGroup-item"); return c.get(); } uint8_t& set_cell_level(); uint8_t& set_bwp_level(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // RateMatchPatternGroup ::= SEQUENCE (SIZE (1..8)) OF RateMatchPatternGroup-item using rate_match_pattern_group_l = dyn_array; // SRS-TPC-CommandConfig ::= SEQUENCE struct srs_tpc_cmd_cfg_s { bool ext = false; bool start_bit_of_format2_minus3_present = false; bool field_type_format2_minus3_present = false; uint8_t start_bit_of_format2_minus3 = 1; uint8_t field_type_format2_minus3 = 0; // ... // group 0 bool start_bit_of_format2_minus3_sul_present = false; uint8_t start_bit_of_format2_minus3_sul = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TCI-State ::= SEQUENCE struct tci_state_s { bool ext = false; bool qcl_type2_present = false; uint8_t tci_state_id = 0; qcl_info_s qcl_type1; qcl_info_s qcl_type2; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ZP-CSI-RS-Resource ::= SEQUENCE struct zp_csi_rs_res_s { bool ext = false; bool periodicity_and_offset_present = false; uint8_t zp_csi_rs_res_id = 0; csi_rs_res_map_s res_map; csi_res_periodicity_and_offset_c periodicity_and_offset; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ZP-CSI-RS-ResourceSet ::= SEQUENCE struct zp_csi_rs_res_set_s { using zp_csi_rs_res_id_list_l_ = bounded_array; // member variables bool ext = false; uint8_t zp_csi_rs_res_set_id = 0; zp_csi_rs_res_id_list_l_ zp_csi_rs_res_id_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDCCH-Config ::= SEQUENCE struct pdcch_cfg_s { using ctrl_res_set_to_add_mod_list_l_ = dyn_array; using ctrl_res_set_to_release_list_l_ = bounded_array; using search_spaces_to_add_mod_list_l_ = dyn_array; using search_spaces_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool ctrl_res_set_to_add_mod_list_present = false; bool ctrl_res_set_to_release_list_present = false; bool search_spaces_to_add_mod_list_present = false; bool search_spaces_to_release_list_present = false; bool dl_preemption_present = false; bool tpc_pusch_present = false; bool tpc_pucch_present = false; bool tpc_srs_present = false; ctrl_res_set_to_add_mod_list_l_ ctrl_res_set_to_add_mod_list; ctrl_res_set_to_release_list_l_ ctrl_res_set_to_release_list; search_spaces_to_add_mod_list_l_ search_spaces_to_add_mod_list; search_spaces_to_release_list_l_ search_spaces_to_release_list; setup_release_c dl_preemption; setup_release_c tpc_pusch; setup_release_c tpc_pucch; setup_release_c tpc_srs; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDSCH-Config ::= SEQUENCE struct pdsch_cfg_s { using tci_states_to_add_mod_list_l_ = dyn_array; using tci_states_to_release_list_l_ = dyn_array; struct vrb_to_prb_interleaver_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated vrb_to_prb_interleaver_e_; struct res_alloc_opts { enum options { res_alloc_type0, res_alloc_type1, dynamic_switch, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated res_alloc_e_; struct pdsch_aggregation_factor_opts { enum options { n2, n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdsch_aggregation_factor_e_; using rate_match_pattern_to_add_mod_list_l_ = dyn_array; using rate_match_pattern_to_release_list_l_ = bounded_array; struct rbg_size_opts { enum options { cfg1, cfg2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated rbg_size_e_; struct mcs_table_opts { enum options { qam256, qam64_low_se, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated mcs_table_e_; struct max_nrof_code_words_sched_by_dci_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_nrof_code_words_sched_by_dci_e_; struct prb_bundling_type_c_ { struct static_bundling_s_ { struct bundle_size_opts { enum options { n4, wideband, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated bundle_size_e_; // member variables bool bundle_size_present = false; bundle_size_e_ bundle_size; }; struct dynamic_bundling_s_ { struct bundle_size_set1_opts { enum options { n4, wideband, n2_wideband, n4_wideband, nulltype } value; const char* to_string() const; }; typedef enumerated bundle_size_set1_e_; struct bundle_size_set2_opts { enum options { n4, wideband, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated bundle_size_set2_e_; // member variables bool bundle_size_set1_present = false; bool bundle_size_set2_present = false; bundle_size_set1_e_ bundle_size_set1; bundle_size_set2_e_ bundle_size_set2; }; struct types_opts { enum options { static_bundling, dynamic_bundling, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods prb_bundling_type_c_() = default; prb_bundling_type_c_(const prb_bundling_type_c_& other); prb_bundling_type_c_& operator=(const prb_bundling_type_c_& other); ~prb_bundling_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters static_bundling_s_& static_bundling() { assert_choice_type(types::static_bundling, type_, "prb-BundlingType"); return c.get(); } dynamic_bundling_s_& dynamic_bundling() { assert_choice_type(types::dynamic_bundling, type_, "prb-BundlingType"); return c.get(); } const static_bundling_s_& static_bundling() const { assert_choice_type(types::static_bundling, type_, "prb-BundlingType"); return c.get(); } const dynamic_bundling_s_& dynamic_bundling() const { assert_choice_type(types::dynamic_bundling, type_, "prb-BundlingType"); return c.get(); } static_bundling_s_& set_static_bundling(); dynamic_bundling_s_& set_dynamic_bundling(); private: types type_; choice_buffer_t c; void destroy_(); }; using zp_csi_rs_res_to_add_mod_list_l_ = dyn_array; using zp_csi_rs_res_to_release_list_l_ = bounded_array; using aperiodic_zp_csi_rs_res_sets_to_add_mod_list_l_ = dyn_array; using aperiodic_zp_csi_rs_res_sets_to_release_list_l_ = bounded_array; using sp_zp_csi_rs_res_sets_to_add_mod_list_l_ = dyn_array; using sp_zp_csi_rs_res_sets_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool data_scrambling_id_pdsch_present = false; bool dmrs_dl_for_pdsch_map_type_a_present = false; bool dmrs_dl_for_pdsch_map_type_b_present = false; bool tci_states_to_add_mod_list_present = false; bool tci_states_to_release_list_present = false; bool vrb_to_prb_interleaver_present = false; bool pdsch_time_domain_alloc_list_present = false; bool pdsch_aggregation_factor_present = false; bool rate_match_pattern_to_add_mod_list_present = false; bool rate_match_pattern_to_release_list_present = false; bool rate_match_pattern_group1_present = false; bool rate_match_pattern_group2_present = false; bool mcs_table_present = false; bool max_nrof_code_words_sched_by_dci_present = false; bool zp_csi_rs_res_to_add_mod_list_present = false; bool zp_csi_rs_res_to_release_list_present = false; bool aperiodic_zp_csi_rs_res_sets_to_add_mod_list_present = false; bool aperiodic_zp_csi_rs_res_sets_to_release_list_present = false; bool sp_zp_csi_rs_res_sets_to_add_mod_list_present = false; bool sp_zp_csi_rs_res_sets_to_release_list_present = false; bool p_zp_csi_rs_res_set_present = false; uint16_t data_scrambling_id_pdsch = 0; setup_release_c dmrs_dl_for_pdsch_map_type_a; setup_release_c dmrs_dl_for_pdsch_map_type_b; tci_states_to_add_mod_list_l_ tci_states_to_add_mod_list; tci_states_to_release_list_l_ tci_states_to_release_list; vrb_to_prb_interleaver_e_ vrb_to_prb_interleaver; res_alloc_e_ res_alloc; setup_release_c > pdsch_time_domain_alloc_list; pdsch_aggregation_factor_e_ pdsch_aggregation_factor; rate_match_pattern_to_add_mod_list_l_ rate_match_pattern_to_add_mod_list; rate_match_pattern_to_release_list_l_ rate_match_pattern_to_release_list; rate_match_pattern_group_l rate_match_pattern_group1; rate_match_pattern_group_l rate_match_pattern_group2; rbg_size_e_ rbg_size; mcs_table_e_ mcs_table; max_nrof_code_words_sched_by_dci_e_ max_nrof_code_words_sched_by_dci; prb_bundling_type_c_ prb_bundling_type; zp_csi_rs_res_to_add_mod_list_l_ zp_csi_rs_res_to_add_mod_list; zp_csi_rs_res_to_release_list_l_ zp_csi_rs_res_to_release_list; aperiodic_zp_csi_rs_res_sets_to_add_mod_list_l_ aperiodic_zp_csi_rs_res_sets_to_add_mod_list; aperiodic_zp_csi_rs_res_sets_to_release_list_l_ aperiodic_zp_csi_rs_res_sets_to_release_list; sp_zp_csi_rs_res_sets_to_add_mod_list_l_ sp_zp_csi_rs_res_sets_to_add_mod_list; sp_zp_csi_rs_res_sets_to_release_list_l_ sp_zp_csi_rs_res_sets_to_release_list; setup_release_c p_zp_csi_rs_res_set; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RadioLinkMonitoringConfig ::= SEQUENCE struct radio_link_monitoring_cfg_s { using fail_detection_res_to_add_mod_list_l_ = dyn_array; using fail_detection_res_to_release_list_l_ = bounded_array; struct beam_fail_instance_max_count_opts { enum options { n1, n2, n3, n4, n5, n6, n8, n10, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated beam_fail_instance_max_count_e_; struct beam_fail_detection_timer_opts { enum options { pbfd1, pbfd2, pbfd3, pbfd4, pbfd5, pbfd6, pbfd8, pbfd10, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated beam_fail_detection_timer_e_; // member variables bool ext = false; bool fail_detection_res_to_add_mod_list_present = false; bool fail_detection_res_to_release_list_present = false; bool beam_fail_instance_max_count_present = false; bool beam_fail_detection_timer_present = false; fail_detection_res_to_add_mod_list_l_ fail_detection_res_to_add_mod_list; fail_detection_res_to_release_list_l_ fail_detection_res_to_release_list; beam_fail_instance_max_count_e_ beam_fail_instance_max_count; beam_fail_detection_timer_e_ beam_fail_detection_timer; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SPS-Config ::= SEQUENCE struct sps_cfg_s { struct periodicity_opts { enum options { ms10, ms20, ms32, ms40, ms64, ms80, ms128, ms160, ms320, ms640, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated periodicity_e_; // member variables bool ext = false; bool n1_pucch_an_present = false; bool mcs_table_present = false; periodicity_e_ periodicity; uint8_t nrof_harq_processes = 1; uint8_t n1_pucch_an = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-DownlinkDedicated ::= SEQUENCE struct bwp_dl_ded_s { bool ext = false; bool pdcch_cfg_present = false; bool pdsch_cfg_present = false; bool sps_cfg_present = false; bool radio_link_monitoring_cfg_present = false; setup_release_c pdcch_cfg; setup_release_c pdsch_cfg; setup_release_c sps_cfg; setup_release_c radio_link_monitoring_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-Downlink ::= SEQUENCE struct bwp_dl_s { bool ext = false; bool bwp_common_present = false; bool bwp_ded_present = false; uint8_t bwp_id = 0; bwp_dl_common_s bwp_common; bwp_dl_ded_s bwp_ded; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Alpha ::= ENUMERATED struct alpha_opts { enum options { alpha0, alpha04, alpha05, alpha06, alpha07, alpha08, alpha09, alpha1, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated alpha_e; // BetaOffsets ::= SEQUENCE struct beta_offsets_s { bool beta_offset_ack_idx1_present = false; bool beta_offset_ack_idx2_present = false; bool beta_offset_ack_idx3_present = false; bool beta_offset_csi_part1_idx1_present = false; bool beta_offset_csi_part1_idx2_present = false; bool beta_offset_csi_part2_idx1_present = false; bool beta_offset_csi_part2_idx2_present = false; uint8_t beta_offset_ack_idx1 = 0; uint8_t beta_offset_ack_idx2 = 0; uint8_t beta_offset_ack_idx3 = 0; uint8_t beta_offset_csi_part1_idx1 = 0; uint8_t beta_offset_csi_part1_idx2 = 0; uint8_t beta_offset_csi_part2_idx1 = 0; uint8_t beta_offset_csi_part2_idx2 = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // P0-PUCCH ::= SEQUENCE struct p0_pucch_s { uint8_t p0_pucch_id = 1; int8_t p0_pucch_value = -16; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // P0-PUSCH-AlphaSet ::= SEQUENCE struct p0_pusch_alpha_set_s { bool p0_present = false; bool alpha_present = false; uint8_t p0_pusch_alpha_set_id = 0; int8_t p0 = -16; alpha_e alpha; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PTRS-UplinkConfig ::= SEQUENCE struct ptrs_ul_cfg_s { struct transform_precoder_disabled_s_ { using freq_density_l_ = std::array; using time_density_l_ = std::array; struct max_nrof_ports_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_nrof_ports_e_; struct res_elem_offset_opts { enum options { offset01, offset10, offset11, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated res_elem_offset_e_; struct ptrs_pwr_opts { enum options { p00, p01, p10, p11, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated ptrs_pwr_e_; // member variables bool freq_density_present = false; bool time_density_present = false; bool res_elem_offset_present = false; freq_density_l_ freq_density; time_density_l_ time_density; max_nrof_ports_e_ max_nrof_ports; res_elem_offset_e_ res_elem_offset; ptrs_pwr_e_ ptrs_pwr; }; struct transform_precoder_enabled_s_ { using sample_density_l_ = std::array; // member variables bool time_density_transform_precoding_present = false; sample_density_l_ sample_density; }; // member variables bool ext = false; bool transform_precoder_disabled_present = false; bool transform_precoder_enabled_present = false; transform_precoder_disabled_s_ transform_precoder_disabled; transform_precoder_enabled_s_ transform_precoder_enabled; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-MaxCodeRate ::= ENUMERATED struct pucch_max_code_rate_opts { enum options { zero_dot08, zero_dot15, zero_dot25, zero_dot35, zero_dot45, zero_dot60, zero_dot80, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated pucch_max_code_rate_e; // PUCCH-PathlossReferenceRS ::= SEQUENCE struct pucch_pathloss_ref_rs_s { struct ref_sig_c_ { struct types_opts { enum options { ssb_idx, csi_rs_idx, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ref_sig_c_() = default; ref_sig_c_(const ref_sig_c_& other); ref_sig_c_& operator=(const ref_sig_c_& other); ~ref_sig_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables uint8_t pucch_pathloss_ref_rs_id = 0; ref_sig_c_ ref_sig; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-format0 ::= SEQUENCE struct pucch_format0_s { uint8_t init_cyclic_shift = 0; uint8_t nrof_symbols = 1; uint8_t start_symbol_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-format1 ::= SEQUENCE struct pucch_format1_s { uint8_t init_cyclic_shift = 0; uint8_t nrof_symbols = 4; uint8_t start_symbol_idx = 0; uint8_t time_domain_occ = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-format2 ::= SEQUENCE struct pucch_format2_s { uint8_t nrof_prbs = 1; uint8_t nrof_symbols = 1; uint8_t start_symbol_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-format3 ::= SEQUENCE struct pucch_format3_s { uint8_t nrof_prbs = 1; uint8_t nrof_symbols = 4; uint8_t start_symbol_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-format4 ::= SEQUENCE struct pucch_format4_s { struct occ_len_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated occ_len_e_; struct occ_idx_opts { enum options { n0, n1, n2, n3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated occ_idx_e_; // member variables uint8_t nrof_symbols = 4; occ_len_e_ occ_len; occ_idx_e_ occ_idx; uint8_t start_symbol_idx = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-PathlossReferenceRS ::= SEQUENCE struct pusch_pathloss_ref_rs_s { struct ref_sig_c_ { struct types_opts { enum options { ssb_idx, csi_rs_idx, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ref_sig_c_() = default; ref_sig_c_(const ref_sig_c_& other); ref_sig_c_& operator=(const ref_sig_c_& other); ~ref_sig_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables uint8_t pusch_pathloss_ref_rs_id = 0; ref_sig_c_ ref_sig; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRI-PUSCH-PowerControl ::= SEQUENCE struct sri_pusch_pwr_ctrl_s { struct sri_pusch_closed_loop_idx_opts { enum options { i0, i1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sri_pusch_closed_loop_idx_e_; // member variables uint8_t sri_pusch_pwr_ctrl_id = 0; uint8_t sri_pusch_pathloss_ref_rs_id = 0; uint8_t sri_p0_pusch_alpha_set_id = 0; sri_pusch_closed_loop_idx_e_ sri_pusch_closed_loop_idx; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-PeriodicityAndOffset ::= CHOICE struct srs_periodicity_and_offset_c { struct types_opts { enum options { sl1, sl2, sl4, sl5, sl8, sl10, sl16, sl20, sl32, sl40, sl64, sl80, sl160, sl320, sl640, sl1280, sl2560, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods srs_periodicity_and_offset_c() = default; srs_periodicity_and_offset_c(const srs_periodicity_and_offset_c& other); srs_periodicity_and_offset_c& operator=(const srs_periodicity_and_offset_c& other); ~srs_periodicity_and_offset_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& sl2() { assert_choice_type(types::sl2, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl4() { assert_choice_type(types::sl4, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl5() { assert_choice_type(types::sl5, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl8() { assert_choice_type(types::sl8, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl10() { assert_choice_type(types::sl10, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl16() { assert_choice_type(types::sl16, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl20() { assert_choice_type(types::sl20, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl32() { assert_choice_type(types::sl32, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl40() { assert_choice_type(types::sl40, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl64() { assert_choice_type(types::sl64, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl80() { assert_choice_type(types::sl80, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint8_t& sl160() { assert_choice_type(types::sl160, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint16_t& sl320() { assert_choice_type(types::sl320, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint16_t& sl640() { assert_choice_type(types::sl640, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint16_t& sl1280() { assert_choice_type(types::sl1280, type_, "SRS-PeriodicityAndOffset"); return c.get(); } uint16_t& sl2560() { assert_choice_type(types::sl2560, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl2() const { assert_choice_type(types::sl2, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl4() const { assert_choice_type(types::sl4, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl5() const { assert_choice_type(types::sl5, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl8() const { assert_choice_type(types::sl8, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl10() const { assert_choice_type(types::sl10, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl16() const { assert_choice_type(types::sl16, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl20() const { assert_choice_type(types::sl20, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl32() const { assert_choice_type(types::sl32, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl40() const { assert_choice_type(types::sl40, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl64() const { assert_choice_type(types::sl64, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl80() const { assert_choice_type(types::sl80, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint8_t& sl160() const { assert_choice_type(types::sl160, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint16_t& sl320() const { assert_choice_type(types::sl320, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint16_t& sl640() const { assert_choice_type(types::sl640, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint16_t& sl1280() const { assert_choice_type(types::sl1280, type_, "SRS-PeriodicityAndOffset"); return c.get(); } const uint16_t& sl2560() const { assert_choice_type(types::sl2560, type_, "SRS-PeriodicityAndOffset"); return c.get(); } void set_sl1(); uint8_t& set_sl2(); uint8_t& set_sl4(); uint8_t& set_sl5(); uint8_t& set_sl8(); uint8_t& set_sl10(); uint8_t& set_sl16(); uint8_t& set_sl20(); uint8_t& set_sl32(); uint8_t& set_sl40(); uint8_t& set_sl64(); uint8_t& set_sl80(); uint8_t& set_sl160(); uint16_t& set_sl320(); uint16_t& set_sl640(); uint16_t& set_sl1280(); uint16_t& set_sl2560(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // SRS-SpatialRelationInfo ::= SEQUENCE struct srs_spatial_relation_info_s { struct ref_sig_c_ { struct srs_s_ { uint8_t res_id = 0; uint8_t ul_bwp = 0; }; struct types_opts { enum options { ssb_idx, csi_rs_idx, srs, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ref_sig_c_() = default; ref_sig_c_(const ref_sig_c_& other); ref_sig_c_& operator=(const ref_sig_c_& other); ~ref_sig_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } srs_s_& srs() { assert_choice_type(types::srs, type_, "referenceSignal"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } const srs_s_& srs() const { assert_choice_type(types::srs, type_, "referenceSignal"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); srs_s_& set_srs(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool serving_cell_id_present = false; uint8_t serving_cell_id = 0; ref_sig_c_ ref_sig; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-UCI-OnPUSCH ::= CHOICE struct cg_uci_on_pusch_c { using dynamic_l_ = dyn_array; struct types_opts { enum options { dynamic_type, semi_static, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods cg_uci_on_pusch_c() = default; cg_uci_on_pusch_c(const cg_uci_on_pusch_c& other); cg_uci_on_pusch_c& operator=(const cg_uci_on_pusch_c& other); ~cg_uci_on_pusch_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dynamic_l_& dynamic_type() { assert_choice_type(types::dynamic_type, type_, "CG-UCI-OnPUSCH"); return c.get(); } beta_offsets_s& semi_static() { assert_choice_type(types::semi_static, type_, "CG-UCI-OnPUSCH"); return c.get(); } const dynamic_l_& dynamic_type() const { assert_choice_type(types::dynamic_type, type_, "CG-UCI-OnPUSCH"); return c.get(); } const beta_offsets_s& semi_static() const { assert_choice_type(types::semi_static, type_, "CG-UCI-OnPUSCH"); return c.get(); } dynamic_l_& set_dynamic_type(); beta_offsets_s& set_semi_static(); private: types type_; choice_buffer_t c; void destroy_(); }; // DMRS-UplinkConfig ::= SEQUENCE struct dmrs_ul_cfg_s { struct dmrs_add_position_opts { enum options { pos0, pos1, pos3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dmrs_add_position_e_; struct transform_precoding_disabled_s_ { bool ext = false; bool scrambling_id0_present = false; bool scrambling_id1_present = false; uint32_t scrambling_id0 = 0; uint32_t scrambling_id1 = 0; // ... }; struct transform_precoding_enabled_s_ { bool ext = false; bool npusch_id_present = false; bool seq_group_hop_present = false; bool seq_hop_present = false; uint16_t npusch_id = 0; // ... }; // member variables bool ext = false; bool dmrs_type_present = false; bool dmrs_add_position_present = false; bool phase_tracking_rs_present = false; bool max_len_present = false; bool transform_precoding_disabled_present = false; bool transform_precoding_enabled_present = false; dmrs_add_position_e_ dmrs_add_position; setup_release_c phase_tracking_rs; transform_precoding_disabled_s_ transform_precoding_disabled; transform_precoding_enabled_s_ transform_precoding_enabled; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PRACH-ResourceDedicatedBFR ::= CHOICE struct prach_res_ded_bfr_c { struct types_opts { enum options { ssb, csi_rs, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods prach_res_ded_bfr_c() = default; prach_res_ded_bfr_c(const prach_res_ded_bfr_c& other); prach_res_ded_bfr_c& operator=(const prach_res_ded_bfr_c& other); ~prach_res_ded_bfr_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters bfr_ssb_res_s& ssb() { assert_choice_type(types::ssb, type_, "PRACH-ResourceDedicatedBFR"); return c.get(); } bfr_csirs_res_s& csi_rs() { assert_choice_type(types::csi_rs, type_, "PRACH-ResourceDedicatedBFR"); return c.get(); } const bfr_ssb_res_s& ssb() const { assert_choice_type(types::ssb, type_, "PRACH-ResourceDedicatedBFR"); return c.get(); } const bfr_csirs_res_s& csi_rs() const { assert_choice_type(types::csi_rs, type_, "PRACH-ResourceDedicatedBFR"); return c.get(); } bfr_ssb_res_s& set_ssb(); bfr_csirs_res_s& set_csi_rs(); private: types type_; choice_buffer_t c; void destroy_(); }; // PUCCH-FormatConfig ::= SEQUENCE struct pucch_format_cfg_s { struct nrof_slots_opts { enum options { n2, n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_slots_e_; // member variables bool interslot_freq_hop_present = false; bool add_dmrs_present = false; bool max_code_rate_present = false; bool nrof_slots_present = false; bool pi2_bpsk_present = false; bool simul_harq_ack_csi_present = false; pucch_max_code_rate_e max_code_rate; nrof_slots_e_ nrof_slots; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-PowerControl ::= SEQUENCE struct pucch_pwr_ctrl_s { using p0_set_l_ = dyn_array; using pathloss_ref_rss_l_ = dyn_array; // member variables bool ext = false; bool delta_f_pucch_f0_present = false; bool delta_f_pucch_f1_present = false; bool delta_f_pucch_f2_present = false; bool delta_f_pucch_f3_present = false; bool delta_f_pucch_f4_present = false; bool p0_set_present = false; bool pathloss_ref_rss_present = false; bool two_pucch_pc_adjustment_states_present = false; int8_t delta_f_pucch_f0 = -16; int8_t delta_f_pucch_f1 = -16; int8_t delta_f_pucch_f2 = -16; int8_t delta_f_pucch_f3 = -16; int8_t delta_f_pucch_f4 = -16; p0_set_l_ p0_set; pathloss_ref_rss_l_ pathloss_ref_rss; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-Resource ::= SEQUENCE struct pucch_res_s { struct format_c_ { struct types_opts { enum options { format0, format1, format2, format3, format4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods format_c_() = default; format_c_(const format_c_& other); format_c_& operator=(const format_c_& other); ~format_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters pucch_format0_s& format0() { assert_choice_type(types::format0, type_, "format"); return c.get(); } pucch_format1_s& format1() { assert_choice_type(types::format1, type_, "format"); return c.get(); } pucch_format2_s& format2() { assert_choice_type(types::format2, type_, "format"); return c.get(); } pucch_format3_s& format3() { assert_choice_type(types::format3, type_, "format"); return c.get(); } pucch_format4_s& format4() { assert_choice_type(types::format4, type_, "format"); return c.get(); } const pucch_format0_s& format0() const { assert_choice_type(types::format0, type_, "format"); return c.get(); } const pucch_format1_s& format1() const { assert_choice_type(types::format1, type_, "format"); return c.get(); } const pucch_format2_s& format2() const { assert_choice_type(types::format2, type_, "format"); return c.get(); } const pucch_format3_s& format3() const { assert_choice_type(types::format3, type_, "format"); return c.get(); } const pucch_format4_s& format4() const { assert_choice_type(types::format4, type_, "format"); return c.get(); } pucch_format0_s& set_format0(); pucch_format1_s& set_format1(); pucch_format2_s& set_format2(); pucch_format3_s& set_format3(); pucch_format4_s& set_format4(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool intra_slot_freq_hop_present = false; bool second_hop_prb_present = false; uint8_t pucch_res_id = 0; uint16_t start_prb = 0; uint16_t second_hop_prb = 0; format_c_ format; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-ResourceSet ::= SEQUENCE struct pucch_res_set_s { using res_list_l_ = bounded_array; // member variables bool max_payload_size_present = false; uint8_t pucch_res_set_id = 0; res_list_l_ res_list; uint16_t max_payload_size = 4; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-SpatialRelationInfo ::= SEQUENCE struct pucch_spatial_relation_info_s { struct ref_sig_c_ { struct srs_s_ { uint8_t res = 0; uint8_t ul_bwp = 0; }; struct types_opts { enum options { ssb_idx, csi_rs_idx, srs, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ref_sig_c_() = default; ref_sig_c_(const ref_sig_c_& other); ref_sig_c_& operator=(const ref_sig_c_& other); ~ref_sig_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } srs_s_& srs() { assert_choice_type(types::srs, type_, "referenceSignal"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "referenceSignal"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "referenceSignal"); return c.get(); } const srs_s_& srs() const { assert_choice_type(types::srs, type_, "referenceSignal"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); srs_s_& set_srs(); private: types type_; choice_buffer_t c; void destroy_(); }; struct closed_loop_idx_opts { enum options { i0, i1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated closed_loop_idx_e_; // member variables bool serving_cell_id_present = false; uint8_t pucch_spatial_relation_info_id = 1; uint8_t serving_cell_id = 0; ref_sig_c_ ref_sig; uint8_t pucch_pathloss_ref_rs_id = 0; uint8_t p0_pucch_id = 1; closed_loop_idx_e_ closed_loop_idx; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-PowerControl ::= SEQUENCE struct pusch_pwr_ctrl_s { using p0_alpha_sets_l_ = dyn_array; using pathloss_ref_rs_to_add_mod_list_l_ = dyn_array; using pathloss_ref_rs_to_release_list_l_ = bounded_array; using sri_pusch_map_to_add_mod_list_l_ = dyn_array; using sri_pusch_map_to_release_list_l_ = bounded_array; // member variables bool tpc_accumulation_present = false; bool msg3_alpha_present = false; bool p0_nominal_without_grant_present = false; bool p0_alpha_sets_present = false; bool pathloss_ref_rs_to_add_mod_list_present = false; bool pathloss_ref_rs_to_release_list_present = false; bool two_pusch_pc_adjustment_states_present = false; bool delta_mcs_present = false; bool sri_pusch_map_to_add_mod_list_present = false; bool sri_pusch_map_to_release_list_present = false; alpha_e msg3_alpha; int16_t p0_nominal_without_grant = -202; p0_alpha_sets_l_ p0_alpha_sets; pathloss_ref_rs_to_add_mod_list_l_ pathloss_ref_rs_to_add_mod_list; pathloss_ref_rs_to_release_list_l_ pathloss_ref_rs_to_release_list; sri_pusch_map_to_add_mod_list_l_ sri_pusch_map_to_add_mod_list; sri_pusch_map_to_release_list_l_ sri_pusch_map_to_release_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RA-Prioritization ::= SEQUENCE struct ra_prioritization_s { struct pwr_ramp_step_high_prio_opts { enum options { db0, db2, db4, db6, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pwr_ramp_step_high_prio_e_; struct scaling_factor_bi_opts { enum options { zero, dot25, dot5, dot75, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scaling_factor_bi_e_; // member variables bool ext = false; bool scaling_factor_bi_present = false; pwr_ramp_step_high_prio_e_ pwr_ramp_step_high_prio; scaling_factor_bi_e_ scaling_factor_bi; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-Resource ::= SEQUENCE struct srs_res_s { struct nrof_srs_ports_opts { enum options { port1, ports2, ports4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_srs_ports_e_; struct ptrs_port_idx_opts { enum options { n0, n1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ptrs_port_idx_e_; struct tx_comb_c_ { struct n2_s_ { uint8_t comb_offset_n2 = 0; uint8_t cyclic_shift_n2 = 0; }; struct n4_s_ { uint8_t comb_offset_n4 = 0; uint8_t cyclic_shift_n4 = 0; }; struct types_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods tx_comb_c_() = default; tx_comb_c_(const tx_comb_c_& other); tx_comb_c_& operator=(const tx_comb_c_& other); ~tx_comb_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters n2_s_& n2() { assert_choice_type(types::n2, type_, "transmissionComb"); return c.get(); } n4_s_& n4() { assert_choice_type(types::n4, type_, "transmissionComb"); return c.get(); } const n2_s_& n2() const { assert_choice_type(types::n2, type_, "transmissionComb"); return c.get(); } const n4_s_& n4() const { assert_choice_type(types::n4, type_, "transmissionComb"); return c.get(); } n2_s_& set_n2(); n4_s_& set_n4(); private: types type_; choice_buffer_t c; void destroy_(); }; struct res_map_s_ { struct nrof_symbols_opts { enum options { n1, n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_symbols_e_; struct repeat_factor_opts { enum options { n1, n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated repeat_factor_e_; // member variables uint8_t start_position = 0; nrof_symbols_e_ nrof_symbols; repeat_factor_e_ repeat_factor; }; struct freq_hop_s_ { uint8_t c_srs = 0; uint8_t b_srs = 0; uint8_t b_hop = 0; }; struct group_or_seq_hop_opts { enum options { neither, group_hop, seq_hop, nulltype } value; const char* to_string() const; }; typedef enumerated group_or_seq_hop_e_; struct res_type_c_ { struct aperiodic_s_ { bool ext = false; // ... }; struct semi_persistent_s_ { bool ext = false; srs_periodicity_and_offset_c periodicity_and_offset_sp; // ... }; struct periodic_s_ { bool ext = false; srs_periodicity_and_offset_c periodicity_and_offset_p; // ... }; struct types_opts { enum options { aperiodic, semi_persistent, periodic, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods res_type_c_() = default; res_type_c_(const res_type_c_& other); res_type_c_& operator=(const res_type_c_& other); ~res_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters aperiodic_s_& aperiodic() { assert_choice_type(types::aperiodic, type_, "resourceType"); return c.get(); } semi_persistent_s_& semi_persistent() { assert_choice_type(types::semi_persistent, type_, "resourceType"); return c.get(); } periodic_s_& periodic() { assert_choice_type(types::periodic, type_, "resourceType"); return c.get(); } const aperiodic_s_& aperiodic() const { assert_choice_type(types::aperiodic, type_, "resourceType"); return c.get(); } const semi_persistent_s_& semi_persistent() const { assert_choice_type(types::semi_persistent, type_, "resourceType"); return c.get(); } const periodic_s_& periodic() const { assert_choice_type(types::periodic, type_, "resourceType"); return c.get(); } aperiodic_s_& set_aperiodic(); semi_persistent_s_& set_semi_persistent(); periodic_s_& set_periodic(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool ptrs_port_idx_present = false; bool spatial_relation_info_present = false; uint8_t srs_res_id = 0; nrof_srs_ports_e_ nrof_srs_ports; ptrs_port_idx_e_ ptrs_port_idx; tx_comb_c_ tx_comb; res_map_s_ res_map; uint8_t freq_domain_position = 0; uint16_t freq_domain_shift = 0; freq_hop_s_ freq_hop; group_or_seq_hop_e_ group_or_seq_hop; res_type_c_ res_type; uint16_t seq_id = 0; srs_spatial_relation_info_s spatial_relation_info; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-ResourceSet ::= SEQUENCE struct srs_res_set_s { using srs_res_id_list_l_ = bounded_array; struct res_type_c_ { struct aperiodic_s_ { using aperiodic_srs_res_trigger_list_l_ = bounded_array; // member variables bool ext = false; bool csi_rs_present = false; bool slot_offset_present = false; uint8_t aperiodic_srs_res_trigger = 1; uint8_t csi_rs = 0; uint8_t slot_offset = 1; // ... // group 0 copy_ptr aperiodic_srs_res_trigger_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; struct semi_persistent_s_ { bool ext = false; bool associated_csi_rs_present = false; uint8_t associated_csi_rs = 0; // ... }; struct periodic_s_ { bool ext = false; bool associated_csi_rs_present = false; uint8_t associated_csi_rs = 0; // ... }; struct types_opts { enum options { aperiodic, semi_persistent, periodic, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods res_type_c_() = default; res_type_c_(const res_type_c_& other); res_type_c_& operator=(const res_type_c_& other); ~res_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters aperiodic_s_& aperiodic() { assert_choice_type(types::aperiodic, type_, "resourceType"); return c.get(); } semi_persistent_s_& semi_persistent() { assert_choice_type(types::semi_persistent, type_, "resourceType"); return c.get(); } periodic_s_& periodic() { assert_choice_type(types::periodic, type_, "resourceType"); return c.get(); } const aperiodic_s_& aperiodic() const { assert_choice_type(types::aperiodic, type_, "resourceType"); return c.get(); } const semi_persistent_s_& semi_persistent() const { assert_choice_type(types::semi_persistent, type_, "resourceType"); return c.get(); } const periodic_s_& periodic() const { assert_choice_type(types::periodic, type_, "resourceType"); return c.get(); } aperiodic_s_& set_aperiodic(); semi_persistent_s_& set_semi_persistent(); periodic_s_& set_periodic(); private: types type_; choice_buffer_t c; void destroy_(); }; struct usage_opts { enum options { beam_management, codebook, non_codebook, ant_switching, nulltype } value; const char* to_string() const; }; typedef enumerated usage_e_; struct pathloss_ref_rs_c_ { struct types_opts { enum options { ssb_idx, csi_rs_idx, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods pathloss_ref_rs_c_() = default; pathloss_ref_rs_c_(const pathloss_ref_rs_c_& other); pathloss_ref_rs_c_& operator=(const pathloss_ref_rs_c_& other); ~pathloss_ref_rs_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_idx() { assert_choice_type(types::ssb_idx, type_, "pathlossReferenceRS"); return c.get(); } uint8_t& csi_rs_idx() { assert_choice_type(types::csi_rs_idx, type_, "pathlossReferenceRS"); return c.get(); } const uint8_t& ssb_idx() const { assert_choice_type(types::ssb_idx, type_, "pathlossReferenceRS"); return c.get(); } const uint8_t& csi_rs_idx() const { assert_choice_type(types::csi_rs_idx, type_, "pathlossReferenceRS"); return c.get(); } uint8_t& set_ssb_idx(); uint8_t& set_csi_rs_idx(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct srs_pwr_ctrl_adjustment_states_opts { enum options { same_as_fci2, separate_closed_loop, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated srs_pwr_ctrl_adjustment_states_e_; // member variables bool ext = false; bool srs_res_id_list_present = false; bool alpha_present = false; bool p0_present = false; bool pathloss_ref_rs_present = false; bool srs_pwr_ctrl_adjustment_states_present = false; uint8_t srs_res_set_id = 0; srs_res_id_list_l_ srs_res_id_list; res_type_c_ res_type; usage_e_ usage; alpha_e alpha; int16_t p0 = -202; pathloss_ref_rs_c_ pathloss_ref_rs; srs_pwr_ctrl_adjustment_states_e_ srs_pwr_ctrl_adjustment_states; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SchedulingRequestResourceConfig ::= SEQUENCE struct sched_request_res_cfg_s { struct periodicity_and_offset_c_ { struct types_opts { enum options { sym2, sym6or7, sl1, sl2, sl4, sl5, sl8, sl10, sl16, sl20, sl40, sl80, sl160, sl320, sl640, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods periodicity_and_offset_c_() = default; periodicity_and_offset_c_(const periodicity_and_offset_c_& other); periodicity_and_offset_c_& operator=(const periodicity_and_offset_c_& other); ~periodicity_and_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& sl2() { assert_choice_type(types::sl2, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl4() { assert_choice_type(types::sl4, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl5() { assert_choice_type(types::sl5, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl8() { assert_choice_type(types::sl8, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl10() { assert_choice_type(types::sl10, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl16() { assert_choice_type(types::sl16, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl20() { assert_choice_type(types::sl20, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl40() { assert_choice_type(types::sl40, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl80() { assert_choice_type(types::sl80, type_, "periodicityAndOffset"); return c.get(); } uint8_t& sl160() { assert_choice_type(types::sl160, type_, "periodicityAndOffset"); return c.get(); } uint16_t& sl320() { assert_choice_type(types::sl320, type_, "periodicityAndOffset"); return c.get(); } uint16_t& sl640() { assert_choice_type(types::sl640, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl2() const { assert_choice_type(types::sl2, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl4() const { assert_choice_type(types::sl4, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl5() const { assert_choice_type(types::sl5, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl8() const { assert_choice_type(types::sl8, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl10() const { assert_choice_type(types::sl10, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl16() const { assert_choice_type(types::sl16, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl20() const { assert_choice_type(types::sl20, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl40() const { assert_choice_type(types::sl40, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl80() const { assert_choice_type(types::sl80, type_, "periodicityAndOffset"); return c.get(); } const uint8_t& sl160() const { assert_choice_type(types::sl160, type_, "periodicityAndOffset"); return c.get(); } const uint16_t& sl320() const { assert_choice_type(types::sl320, type_, "periodicityAndOffset"); return c.get(); } const uint16_t& sl640() const { assert_choice_type(types::sl640, type_, "periodicityAndOffset"); return c.get(); } void set_sym2(); void set_sym6or7(); void set_sl1(); uint8_t& set_sl2(); uint8_t& set_sl4(); uint8_t& set_sl5(); uint8_t& set_sl8(); uint8_t& set_sl10(); uint8_t& set_sl16(); uint8_t& set_sl20(); uint8_t& set_sl40(); uint8_t& set_sl80(); uint8_t& set_sl160(); uint16_t& set_sl320(); uint16_t& set_sl640(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables bool periodicity_and_offset_present = false; bool res_present = false; uint8_t sched_request_res_id = 1; uint8_t sched_request_id = 0; periodicity_and_offset_c_ periodicity_and_offset; uint8_t res = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UCI-OnPUSCH ::= SEQUENCE struct uci_on_pusch_s { struct beta_offsets_c_ { using dynamic_l_ = std::array; struct types_opts { enum options { dynamic_type, semi_static, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods beta_offsets_c_() = default; beta_offsets_c_(const beta_offsets_c_& other); beta_offsets_c_& operator=(const beta_offsets_c_& other); ~beta_offsets_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters dynamic_l_& dynamic_type() { assert_choice_type(types::dynamic_type, type_, "betaOffsets"); return c.get(); } beta_offsets_s& semi_static() { assert_choice_type(types::semi_static, type_, "betaOffsets"); return c.get(); } const dynamic_l_& dynamic_type() const { assert_choice_type(types::dynamic_type, type_, "betaOffsets"); return c.get(); } const beta_offsets_s& semi_static() const { assert_choice_type(types::semi_static, type_, "betaOffsets"); return c.get(); } dynamic_l_& set_dynamic_type(); beta_offsets_s& set_semi_static(); private: types type_; choice_buffer_t c; void destroy_(); }; struct scaling_opts { enum options { f0p5, f0p65, f0p8, f1, nulltype } value; const char* to_string() const; }; typedef enumerated scaling_e_; // member variables bool beta_offsets_present = false; beta_offsets_c_ beta_offsets; scaling_e_ scaling; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BeamFailureRecoveryConfig ::= SEQUENCE struct beam_fail_recovery_cfg_s { using candidate_beam_rs_list_l_ = dyn_array; struct ssb_per_rach_occasion_opts { enum options { one_eighth, one_fourth, one_half, one, two, four, eight, sixteen, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated ssb_per_rach_occasion_e_; struct beam_fail_recovery_timer_opts { enum options { ms10, ms20, ms40, ms60, ms80, ms100, ms150, ms200, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated beam_fail_recovery_timer_e_; // member variables bool ext = false; bool root_seq_idx_bfr_present = false; bool rach_cfg_bfr_present = false; bool rsrp_thres_ssb_present = false; bool candidate_beam_rs_list_present = false; bool ssb_per_rach_occasion_present = false; bool ra_ssb_occasion_mask_idx_present = false; bool recovery_search_space_id_present = false; bool ra_prioritization_present = false; bool beam_fail_recovery_timer_present = false; uint8_t root_seq_idx_bfr = 0; rach_cfg_generic_s rach_cfg_bfr; uint8_t rsrp_thres_ssb = 0; candidate_beam_rs_list_l_ candidate_beam_rs_list; ssb_per_rach_occasion_e_ ssb_per_rach_occasion; uint8_t ra_ssb_occasion_mask_idx = 0; uint8_t recovery_search_space_id = 0; ra_prioritization_s ra_prioritization; beam_fail_recovery_timer_e_ beam_fail_recovery_timer; // ... // group 0 bool msg1_subcarrier_spacing_present = false; subcarrier_spacing_e msg1_subcarrier_spacing; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ConfiguredGrantConfig ::= SEQUENCE struct cfgured_grant_cfg_s { struct freq_hop_opts { enum options { intra_slot, inter_slot, nulltype } value; const char* to_string() const; }; typedef enumerated freq_hop_e_; struct mcs_table_opts { enum options { qam256, qam64_low_se, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated mcs_table_e_; struct mcs_table_transform_precoder_opts { enum options { qam256, qam64_low_se, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated mcs_table_transform_precoder_e_; struct res_alloc_opts { enum options { res_alloc_type0, res_alloc_type1, dynamic_switch, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated res_alloc_e_; struct pwr_ctrl_loop_to_use_opts { enum options { n0, n1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pwr_ctrl_loop_to_use_e_; struct transform_precoder_opts { enum options { enabled, disabled, nulltype } value; const char* to_string() const; }; typedef enumerated transform_precoder_e_; struct rep_k_opts { enum options { n1, n2, n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated rep_k_e_; struct rep_k_rv_opts { enum options { s1_minus0231, s2_minus0303, s3_minus0000, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated rep_k_rv_e_; struct periodicity_opts { enum options { sym2, sym7, sym1x14, sym2x14, sym4x14, sym5x14, sym8x14, sym10x14, sym16x14, sym20x14, sym32x14, sym40x14, sym64x14, sym80x14, sym128x14, sym160x14, sym256x14, sym320x14, sym512x14, sym640x14, sym1024x14, sym1280x14, sym2560x14, sym5120x14, sym6, sym1x12, sym2x12, sym4x12, sym5x12, sym8x12, sym10x12, sym16x12, sym20x12, sym32x12, sym40x12, sym64x12, sym80x12, sym128x12, sym160x12, sym256x12, sym320x12, sym512x12, sym640x12, sym1280x12, sym2560x12, nulltype } value; const char* to_string() const; }; typedef enumerated periodicity_e_; struct rrc_cfgured_ul_grant_s_ { bool ext = false; bool dmrs_seq_initization_present = false; bool srs_res_ind_present = false; bool freq_hop_offset_present = false; uint16_t time_domain_offset = 0; uint8_t time_domain_alloc = 0; fixed_bitstring<18> freq_domain_alloc; uint8_t ant_port = 0; uint8_t dmrs_seq_initization = 0; uint8_t precoding_and_nof_layers = 0; uint8_t srs_res_ind = 0; uint8_t mcs_and_tbs = 0; uint16_t freq_hop_offset = 1; uint8_t pathloss_ref_idx = 0; // ... }; // member variables bool ext = false; bool freq_hop_present = false; bool mcs_table_present = false; bool mcs_table_transform_precoder_present = false; bool uci_on_pusch_present = false; bool rbg_size_present = false; bool transform_precoder_present = false; bool rep_k_rv_present = false; bool cfgured_grant_timer_present = false; bool rrc_cfgured_ul_grant_present = false; freq_hop_e_ freq_hop; dmrs_ul_cfg_s cg_dmrs_cfg; mcs_table_e_ mcs_table; mcs_table_transform_precoder_e_ mcs_table_transform_precoder; setup_release_c uci_on_pusch; res_alloc_e_ res_alloc; pwr_ctrl_loop_to_use_e_ pwr_ctrl_loop_to_use; uint8_t p0_pusch_alpha = 0; transform_precoder_e_ transform_precoder; uint8_t nrof_harq_processes = 1; rep_k_e_ rep_k; rep_k_rv_e_ rep_k_rv; periodicity_e_ periodicity; uint8_t cfgured_grant_timer = 1; rrc_cfgured_ul_grant_s_ rrc_cfgured_ul_grant; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-Config ::= SEQUENCE struct pucch_cfg_s { using res_set_to_add_mod_list_l_ = dyn_array; using res_set_to_release_list_l_ = bounded_array; using res_to_add_mod_list_l_ = dyn_array; using res_to_release_list_l_ = dyn_array; using sched_request_res_to_add_mod_list_l_ = dyn_array; using sched_request_res_to_release_list_l_ = bounded_array; using multi_csi_pucch_res_list_l_ = bounded_array; using dl_data_to_ul_ack_l_ = bounded_array; using spatial_relation_info_to_add_mod_list_l_ = dyn_array; using spatial_relation_info_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool res_set_to_add_mod_list_present = false; bool res_set_to_release_list_present = false; bool res_to_add_mod_list_present = false; bool res_to_release_list_present = false; bool format1_present = false; bool format2_present = false; bool format3_present = false; bool format4_present = false; bool sched_request_res_to_add_mod_list_present = false; bool sched_request_res_to_release_list_present = false; bool multi_csi_pucch_res_list_present = false; bool dl_data_to_ul_ack_present = false; bool spatial_relation_info_to_add_mod_list_present = false; bool spatial_relation_info_to_release_list_present = false; bool pucch_pwr_ctrl_present = false; res_set_to_add_mod_list_l_ res_set_to_add_mod_list; res_set_to_release_list_l_ res_set_to_release_list; res_to_add_mod_list_l_ res_to_add_mod_list; res_to_release_list_l_ res_to_release_list; setup_release_c format1; setup_release_c format2; setup_release_c format3; setup_release_c format4; sched_request_res_to_add_mod_list_l_ sched_request_res_to_add_mod_list; sched_request_res_to_release_list_l_ sched_request_res_to_release_list; multi_csi_pucch_res_list_l_ multi_csi_pucch_res_list; dl_data_to_ul_ack_l_ dl_data_to_ul_ack; spatial_relation_info_to_add_mod_list_l_ spatial_relation_info_to_add_mod_list; spatial_relation_info_to_release_list_l_ spatial_relation_info_to_release_list; pucch_pwr_ctrl_s pucch_pwr_ctrl; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-Config ::= SEQUENCE struct pusch_cfg_s { struct tx_cfg_opts { enum options { codebook, non_codebook, nulltype } value; const char* to_string() const; }; typedef enumerated tx_cfg_e_; struct freq_hop_opts { enum options { intra_slot, inter_slot, nulltype } value; const char* to_string() const; }; typedef enumerated freq_hop_e_; using freq_hop_offset_lists_l_ = bounded_array; struct res_alloc_opts { enum options { res_alloc_type0, res_alloc_type1, dynamic_switch, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated res_alloc_e_; struct pusch_aggregation_factor_opts { enum options { n2, n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pusch_aggregation_factor_e_; struct mcs_table_opts { enum options { qam256, qam64_low_se, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated mcs_table_e_; struct mcs_table_transform_precoder_opts { enum options { qam256, qam64_low_se, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated mcs_table_transform_precoder_e_; struct transform_precoder_opts { enum options { enabled, disabled, nulltype } value; const char* to_string() const; }; typedef enumerated transform_precoder_e_; struct codebook_subset_opts { enum options { fully_and_partial_and_non_coherent, partial_and_non_coherent, non_coherent, nulltype } value; const char* to_string() const; }; typedef enumerated codebook_subset_e_; // member variables bool ext = false; bool data_scrambling_id_pusch_present = false; bool tx_cfg_present = false; bool dmrs_ul_for_pusch_map_type_a_present = false; bool dmrs_ul_for_pusch_map_type_b_present = false; bool pusch_pwr_ctrl_present = false; bool freq_hop_present = false; bool freq_hop_offset_lists_present = false; bool pusch_time_domain_alloc_list_present = false; bool pusch_aggregation_factor_present = false; bool mcs_table_present = false; bool mcs_table_transform_precoder_present = false; bool transform_precoder_present = false; bool codebook_subset_present = false; bool max_rank_present = false; bool rbg_size_present = false; bool uci_on_pusch_present = false; bool tp_pi2_bpsk_present = false; uint16_t data_scrambling_id_pusch = 0; tx_cfg_e_ tx_cfg; setup_release_c dmrs_ul_for_pusch_map_type_a; setup_release_c dmrs_ul_for_pusch_map_type_b; pusch_pwr_ctrl_s pusch_pwr_ctrl; freq_hop_e_ freq_hop; freq_hop_offset_lists_l_ freq_hop_offset_lists; res_alloc_e_ res_alloc; setup_release_c > pusch_time_domain_alloc_list; pusch_aggregation_factor_e_ pusch_aggregation_factor; mcs_table_e_ mcs_table; mcs_table_transform_precoder_e_ mcs_table_transform_precoder; transform_precoder_e_ transform_precoder; codebook_subset_e_ codebook_subset; uint8_t max_rank = 1; setup_release_c uci_on_pusch; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-Config ::= SEQUENCE struct srs_cfg_s { using srs_res_set_to_release_list_l_ = bounded_array; using srs_res_set_to_add_mod_list_l_ = dyn_array; using srs_res_to_release_list_l_ = dyn_array; using srs_res_to_add_mod_list_l_ = dyn_array; // member variables bool ext = false; bool srs_res_set_to_release_list_present = false; bool srs_res_set_to_add_mod_list_present = false; bool srs_res_to_release_list_present = false; bool srs_res_to_add_mod_list_present = false; bool tpc_accumulation_present = false; srs_res_set_to_release_list_l_ srs_res_set_to_release_list; srs_res_set_to_add_mod_list_l_ srs_res_set_to_add_mod_list; srs_res_to_release_list_l_ srs_res_to_release_list; srs_res_to_add_mod_list_l_ srs_res_to_add_mod_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-UplinkDedicated ::= SEQUENCE struct bwp_ul_ded_s { bool ext = false; bool pucch_cfg_present = false; bool pusch_cfg_present = false; bool cfgured_grant_cfg_present = false; bool srs_cfg_present = false; bool beam_fail_recovery_cfg_present = false; setup_release_c pucch_cfg; setup_release_c pusch_cfg; setup_release_c cfgured_grant_cfg; setup_release_c srs_cfg; setup_release_c beam_fail_recovery_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BWP-Uplink ::= SEQUENCE struct bwp_ul_s { bool ext = false; bool bwp_common_present = false; bool bwp_ded_present = false; uint8_t bwp_id = 0; bwp_ul_common_s bwp_common; bwp_ul_ded_s bwp_ded; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-BandwidthClassEUTRA ::= ENUMERATED struct ca_bw_class_eutra_opts { enum options { a, b, c, d, e, f, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated ca_bw_class_eutra_e; // CA-BandwidthClassNR ::= ENUMERATED struct ca_bw_class_nr_opts { enum options { a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated ca_bw_class_nr_e; // BandParameters ::= CHOICE struct band_params_c { struct eutra_s_ { bool ca_bw_class_dl_eutra_present = false; bool ca_bw_class_ul_eutra_present = false; uint16_t band_eutra = 1; ca_bw_class_eutra_e ca_bw_class_dl_eutra; ca_bw_class_eutra_e ca_bw_class_ul_eutra; }; struct nr_s_ { bool ca_bw_class_dl_nr_present = false; bool ca_bw_class_ul_nr_present = false; uint16_t band_nr = 1; ca_bw_class_nr_e ca_bw_class_dl_nr; ca_bw_class_nr_e ca_bw_class_ul_nr; }; struct types_opts { enum options { eutra, nr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods band_params_c() = default; band_params_c(const band_params_c& other); band_params_c& operator=(const band_params_c& other); ~band_params_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters eutra_s_& eutra() { assert_choice_type(types::eutra, type_, "BandParameters"); return c.get(); } nr_s_& nr() { assert_choice_type(types::nr, type_, "BandParameters"); return c.get(); } const eutra_s_& eutra() const { assert_choice_type(types::eutra, type_, "BandParameters"); return c.get(); } const nr_s_& nr() const { assert_choice_type(types::nr, type_, "BandParameters"); return c.get(); } eutra_s_& set_eutra(); nr_s_& set_nr(); private: types type_; choice_buffer_t c; void destroy_(); }; // CA-ParametersEUTRA ::= SEQUENCE struct ca_params_eutra_s { bool ext = false; bool multiple_timing_advance_present = false; bool simul_rx_tx_present = false; bool supported_naics_minus2_crs_ap_present = false; bool add_rx_tx_performance_req_present = false; bool ue_ca_pwr_class_n_present = false; bool supported_bw_combination_set_eutra_v1530_present = false; bounded_bitstring<1, 8> supported_naics_minus2_crs_ap; bounded_bitstring<1, 32> supported_bw_combination_set_eutra_v1530; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersNR ::= SEQUENCE struct ca_params_nr_s { struct supported_num_tag_opts { enum options { n2, n3, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated supported_num_tag_e_; // member variables bool ext = false; bool dummy_present = false; bool parallel_tx_srs_pucch_pusch_present = false; bool parallel_tx_prach_srs_pucch_pusch_present = false; bool simul_rx_tx_inter_band_ca_present = false; bool simul_rx_tx_sul_present = false; bool diff_numerology_across_pucch_group_present = false; bool diff_numerology_within_pucch_group_smaller_scs_present = false; bool supported_num_tag_present = false; supported_num_tag_e_ supported_num_tag; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MRDC-Parameters ::= SEQUENCE struct mrdc_params_s { struct ul_sharing_eutra_nr_opts { enum options { tdm, fdm, both, nulltype } value; const char* to_string() const; }; typedef enumerated ul_sharing_eutra_nr_e_; struct ul_switching_time_eutra_nr_opts { enum options { type1, type2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ul_switching_time_eutra_nr_e_; struct intra_band_endc_support_opts { enum options { non_contiguous, both, nulltype } value; const char* to_string() const; }; typedef enumerated intra_band_endc_support_e_; // member variables bool ext = false; bool single_ul_tx_present = false; bool dynamic_pwr_sharing_endc_present = false; bool tdm_pattern_present = false; bool ul_sharing_eutra_nr_present = false; bool ul_switching_time_eutra_nr_present = false; bool simul_rx_tx_inter_band_endc_present = false; bool async_intra_band_endc_present = false; ul_sharing_eutra_nr_e_ ul_sharing_eutra_nr; ul_switching_time_eutra_nr_e_ ul_switching_time_eutra_nr; // ... // group 0 bool dual_pa_architecture_present = false; bool intra_band_endc_support_present = false; bool ul_timing_align_eutra_nr_present = false; intra_band_endc_support_e_ intra_band_endc_support; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination ::= SEQUENCE struct band_combination_s { using band_list_l_ = dyn_array; // member variables bool ca_params_eutra_present = false; bool ca_params_nr_present = false; bool mrdc_params_present = false; bool supported_bw_combination_set_present = false; bool pwr_class_v1530_present = false; band_list_l_ band_list; uint16_t feature_set_combination = 0; ca_params_eutra_s ca_params_eutra; ca_params_nr_s ca_params_nr; mrdc_params_s mrdc_params; bounded_bitstring<1, 32> supported_bw_combination_set; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-SwitchingTimeEUTRA ::= SEQUENCE struct srs_switching_time_eutra_s { struct switching_time_dl_opts { enum options { n0, n0dot5, n1, n1dot5, n2, n2dot5, n3, n3dot5, n4, n4dot5, n5, n5dot5, n6, n6dot5, n7, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated switching_time_dl_e_; struct switching_time_ul_opts { enum options { n0, n0dot5, n1, n1dot5, n2, n2dot5, n3, n3dot5, n4, n4dot5, n5, n5dot5, n6, n6dot5, n7, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated switching_time_ul_e_; // member variables bool switching_time_dl_present = false; bool switching_time_ul_present = false; switching_time_dl_e_ switching_time_dl; switching_time_ul_e_ switching_time_ul; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-SwitchingTimeNR ::= SEQUENCE struct srs_switching_time_nr_s { struct switching_time_dl_opts { enum options { n0us, n30us, n100us, n140us, n200us, n300us, n500us, n900us, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated switching_time_dl_e_; struct switching_time_ul_opts { enum options { n0us, n30us, n100us, n140us, n200us, n300us, n500us, n900us, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated switching_time_ul_e_; // member variables bool switching_time_dl_present = false; bool switching_time_ul_present = false; switching_time_dl_e_ switching_time_dl; switching_time_ul_e_ switching_time_ul; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandParameters-v1540 ::= SEQUENCE struct band_params_v1540_s { struct srs_carrier_switch_c_ { struct nr_s_ { using srs_switching_times_list_nr_l_ = dyn_array; // member variables srs_switching_times_list_nr_l_ srs_switching_times_list_nr; }; struct eutra_s_ { using srs_switching_times_list_eutra_l_ = dyn_array; // member variables srs_switching_times_list_eutra_l_ srs_switching_times_list_eutra; }; struct types_opts { enum options { nr, eutra, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods srs_carrier_switch_c_() = default; srs_carrier_switch_c_(const srs_carrier_switch_c_& other); srs_carrier_switch_c_& operator=(const srs_carrier_switch_c_& other); ~srs_carrier_switch_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters nr_s_& nr() { assert_choice_type(types::nr, type_, "srs-CarrierSwitch"); return c.get(); } eutra_s_& eutra() { assert_choice_type(types::eutra, type_, "srs-CarrierSwitch"); return c.get(); } const nr_s_& nr() const { assert_choice_type(types::nr, type_, "srs-CarrierSwitch"); return c.get(); } const eutra_s_& eutra() const { assert_choice_type(types::eutra, type_, "srs-CarrierSwitch"); return c.get(); } nr_s_& set_nr(); eutra_s_& set_eutra(); private: types type_; choice_buffer_t c; void destroy_(); }; struct srs_tx_switch_s_ { struct supported_srs_tx_port_switch_opts { enum options { t1r2, t1r4, t2r4, t1r4_t2r4, t1r1, t2r2, t4r4, not_supported, nulltype } value; const char* to_string() const; }; typedef enumerated supported_srs_tx_port_switch_e_; // member variables bool tx_switch_impact_to_rx_present = false; bool tx_switch_with_another_band_present = false; supported_srs_tx_port_switch_e_ supported_srs_tx_port_switch; uint8_t tx_switch_impact_to_rx = 1; uint8_t tx_switch_with_another_band = 1; }; // member variables bool srs_carrier_switch_present = false; bool srs_tx_switch_present = false; srs_carrier_switch_c_ srs_carrier_switch; srs_tx_switch_s_ srs_tx_switch; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersNR-v1540 ::= SEQUENCE struct ca_params_nr_v1540_s { struct csi_rs_im_reception_for_feedback_per_band_comb_s_ { bool max_num_simul_nzp_csi_rs_act_bwp_all_cc_present = false; bool total_num_ports_simul_nzp_csi_rs_act_bwp_all_cc_present = false; uint8_t max_num_simul_nzp_csi_rs_act_bwp_all_cc = 1; uint16_t total_num_ports_simul_nzp_csi_rs_act_bwp_all_cc = 2; }; // member variables bool simul_srs_assoc_csi_rs_all_cc_present = false; bool csi_rs_im_reception_for_feedback_per_band_comb_present = false; bool simul_csi_reports_all_cc_present = false; bool dual_pa_architecture_present = false; uint8_t simul_srs_assoc_csi_rs_all_cc = 5; csi_rs_im_reception_for_feedback_per_band_comb_s_ csi_rs_im_reception_for_feedback_per_band_comb; uint8_t simul_csi_reports_all_cc = 5; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1540 ::= SEQUENCE struct band_combination_v1540_s { using band_list_v1540_l_ = dyn_array; // member variables bool ca_params_nr_v1540_present = false; band_list_v1540_l_ band_list_v1540; ca_params_nr_v1540_s ca_params_nr_v1540; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersNR-v1550 ::= SEQUENCE struct ca_params_nr_v1550_s { bool dummy_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1550 ::= SEQUENCE struct band_combination_v1550_s { ca_params_nr_v1550_s ca_params_nr_v1550; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersNR-v1560 ::= SEQUENCE struct ca_params_nr_v1560_s { bool diff_numerology_within_pucch_group_larger_scs_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersEUTRA-v1560 ::= SEQUENCE struct ca_params_eutra_v1560_s { bool fd_mimo_total_weighted_layers_present = false; uint8_t fd_mimo_total_weighted_layers = 2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersNRDC ::= SEQUENCE struct ca_params_nrdc_s { bool ca_params_nr_for_dc_present = false; bool ca_params_nr_for_dc_v1540_present = false; bool ca_params_nr_for_dc_v1550_present = false; bool ca_params_nr_for_dc_v1560_present = false; bool feature_set_combination_dc_present = false; ca_params_nr_s ca_params_nr_for_dc; ca_params_nr_v1540_s ca_params_nr_for_dc_v1540; ca_params_nr_v1550_s ca_params_nr_for_dc_v1550; ca_params_nr_v1560_s ca_params_nr_for_dc_v1560; uint16_t feature_set_combination_dc = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1560 ::= SEQUENCE struct band_combination_v1560_s { bool ne_dc_bc_present = false; bool ca_params_nrdc_present = false; bool ca_params_eutra_v1560_present = false; bool ca_params_nr_v1560_present = false; ca_params_nrdc_s ca_params_nrdc; ca_params_eutra_v1560_s ca_params_eutra_v1560; ca_params_nr_v1560_s ca_params_nr_v1560; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CA-ParametersEUTRA-v1570 ::= SEQUENCE struct ca_params_eutra_v1570_s { bool dl_minus1024_qam_total_weighted_layers_present = false; uint8_t dl_minus1024_qam_total_weighted_layers = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1570 ::= SEQUENCE struct band_combination_v1570_s { ca_params_eutra_v1570_s ca_params_eutra_v1570; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MRDC-Parameters-v1580 ::= SEQUENCE struct mrdc_params_v1580_s { bool dynamic_pwr_sharing_nedc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1580 ::= SEQUENCE struct band_combination_v1580_s { mrdc_params_v1580_s mrdc_params_v1580; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MRDC-Parameters-v1590 ::= SEQUENCE struct mrdc_params_v1590_s { bool inter_band_contiguous_mrdc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombination-v1590 ::= SEQUENCE struct band_combination_v1590_s { bool supported_bw_combination_set_intra_endc_present = false; bounded_bitstring<1, 32> supported_bw_combination_set_intra_endc; mrdc_params_v1590_s mrdc_params_v1590; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombinationList ::= SEQUENCE (SIZE (1..65536)) OF BandCombination using band_combination_list_l = dyn_array; // BandCombinationList-v1540 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1540 using band_combination_list_v1540_l = dyn_array; // BandCombinationList-v1550 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1550 using band_combination_list_v1550_l = dyn_array; // BandCombinationList-v1560 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1560 using band_combination_list_v1560_l = dyn_array; // BandCombinationList-v1570 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1570 using band_combination_list_v1570_l = dyn_array; // BandCombinationList-v1580 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1580 using band_combination_list_v1580_l = dyn_array; // BandCombinationList-v1590 ::= SEQUENCE (SIZE (1..65536)) OF BandCombination-v1590 using band_combination_list_v1590_l = dyn_array; // SupportedCSI-RS-Resource ::= SEQUENCE struct supported_csi_rs_res_s { struct max_num_tx_ports_per_res_opts { enum options { p2, p4, p8, p12, p16, p24, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_tx_ports_per_res_e_; // member variables max_num_tx_ports_per_res_e_ max_num_tx_ports_per_res; uint8_t max_num_res_per_band = 1; uint16_t total_num_tx_ports_per_band = 2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BeamManagementSSB-CSI-RS ::= SEQUENCE struct beam_management_ssb_csi_rs_s { struct max_num_ssb_csi_rs_res_one_tx_opts { enum options { n0, n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_ssb_csi_rs_res_one_tx_e_; struct max_num_csi_rs_res_opts { enum options { n0, n4, n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_csi_rs_res_e_; struct max_num_csi_rs_res_two_tx_opts { enum options { n0, n4, n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_csi_rs_res_two_tx_e_; struct supported_csi_rs_density_opts { enum options { one, three, one_and_three, nulltype } value; const char* to_string() const; }; typedef enumerated supported_csi_rs_density_e_; struct max_num_aperiodic_csi_rs_res_opts { enum options { n0, n1, n4, n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_aperiodic_csi_rs_res_e_; // member variables bool supported_csi_rs_density_present = false; max_num_ssb_csi_rs_res_one_tx_e_ max_num_ssb_csi_rs_res_one_tx; max_num_csi_rs_res_e_ max_num_csi_rs_res; max_num_csi_rs_res_two_tx_e_ max_num_csi_rs_res_two_tx; supported_csi_rs_density_e_ supported_csi_rs_density; max_num_aperiodic_csi_rs_res_e_ max_num_aperiodic_csi_rs_res; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-ForTracking ::= SEQUENCE struct csi_rs_for_tracking_s { uint8_t max_burst_len = 1; uint8_t max_simul_res_sets_per_cc = 1; uint8_t max_cfgured_res_sets_per_cc = 1; uint16_t max_cfgured_res_sets_all_cc = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-IM-ReceptionForFeedback ::= SEQUENCE struct csi_rs_im_reception_for_feedback_s { struct max_cfg_num_csi_im_per_cc_opts { enum options { n1, n2, n4, n8, n16, n32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_cfg_num_csi_im_per_cc_e_; // member variables uint8_t max_cfg_num_nzp_csi_rs_per_cc = 1; uint16_t max_cfg_num_ports_across_nzp_csi_rs_per_cc = 2; max_cfg_num_csi_im_per_cc_e_ max_cfg_num_csi_im_per_cc; uint8_t max_num_simul_nzp_csi_rs_per_cc = 1; uint16_t total_num_ports_simul_nzp_csi_rs_per_cc = 2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-RS-ProcFrameworkForSRS ::= SEQUENCE struct csi_rs_proc_framework_for_srs_s { uint8_t max_num_periodic_srs_assoc_csi_rs_per_bwp = 1; uint8_t max_num_aperiodic_srs_assoc_csi_rs_per_bwp = 1; uint8_t max_num_sp_srs_assoc_csi_rs_per_bwp = 0; uint8_t simul_srs_assoc_csi_rs_per_cc = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-ReportFramework ::= SEQUENCE struct csi_report_framework_s { struct max_num_aperiodic_csi_trigger_state_per_cc_opts { enum options { n3, n7, n15, n31, n63, n128, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_aperiodic_csi_trigger_state_per_cc_e_; // member variables uint8_t max_num_periodic_csi_per_bwp_for_csi_report = 1; uint8_t max_num_aperiodic_csi_per_bwp_for_csi_report = 1; uint8_t max_num_semi_persistent_csi_per_bwp_for_csi_report = 0; uint8_t max_num_periodic_csi_per_bwp_for_beam_report = 1; uint8_t max_num_aperiodic_csi_per_bwp_for_beam_report = 1; max_num_aperiodic_csi_trigger_state_per_cc_e_ max_num_aperiodic_csi_trigger_state_per_cc; uint8_t max_num_semi_persistent_csi_per_bwp_for_beam_report = 0; uint8_t simul_csi_reports_per_cc = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CodebookParameters ::= SEQUENCE struct codebook_params_s { struct type1_s_ { struct single_panel_s_ { using supported_csi_rs_res_list_l_ = dyn_array; struct modes_opts { enum options { mode1, mode1and_mode2, nulltype } value; const char* to_string() const; }; typedef enumerated modes_e_; // member variables supported_csi_rs_res_list_l_ supported_csi_rs_res_list; modes_e_ modes; uint8_t max_num_csi_rs_per_res_set = 1; }; struct multi_panel_s_ { using supported_csi_rs_res_list_l_ = dyn_array; struct modes_opts { enum options { mode1, mode2, both, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated modes_e_; struct nrof_panels_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_panels_e_; // member variables supported_csi_rs_res_list_l_ supported_csi_rs_res_list; modes_e_ modes; nrof_panels_e_ nrof_panels; uint8_t max_num_csi_rs_per_res_set = 1; }; // member variables bool multi_panel_present = false; single_panel_s_ single_panel; multi_panel_s_ multi_panel; }; struct type2_s_ { using supported_csi_rs_res_list_l_ = dyn_array; struct amplitude_scaling_type_opts { enum options { wideband, wideband_and_subband, nulltype } value; const char* to_string() const; }; typedef enumerated amplitude_scaling_type_e_; // member variables bool amplitude_subset_restrict_present = false; supported_csi_rs_res_list_l_ supported_csi_rs_res_list; uint8_t param_lx = 2; amplitude_scaling_type_e_ amplitude_scaling_type; }; struct type2_port_sel_s_ { using supported_csi_rs_res_list_l_ = dyn_array; struct amplitude_scaling_type_opts { enum options { wideband, wideband_and_subband, nulltype } value; const char* to_string() const; }; typedef enumerated amplitude_scaling_type_e_; // member variables supported_csi_rs_res_list_l_ supported_csi_rs_res_list; uint8_t param_lx = 2; amplitude_scaling_type_e_ amplitude_scaling_type; }; // member variables bool type2_present = false; bool type2_port_sel_present = false; type1_s_ type1; type2_s_ type2; type2_port_sel_s_ type2_port_sel; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyG ::= SEQUENCE struct dummy_g_s { struct max_num_ssb_csi_rs_res_one_tx_opts { enum options { n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_ssb_csi_rs_res_one_tx_e_; struct max_num_ssb_csi_rs_res_two_tx_opts { enum options { n0, n4, n8, n16, n32, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_ssb_csi_rs_res_two_tx_e_; struct supported_csi_rs_density_opts { enum options { one, three, one_and_three, nulltype } value; const char* to_string() const; }; typedef enumerated supported_csi_rs_density_e_; // member variables max_num_ssb_csi_rs_res_one_tx_e_ max_num_ssb_csi_rs_res_one_tx; max_num_ssb_csi_rs_res_two_tx_e_ max_num_ssb_csi_rs_res_two_tx; supported_csi_rs_density_e_ supported_csi_rs_density; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyH ::= SEQUENCE struct dummy_h_s { uint8_t burst_len = 1; uint8_t max_simul_res_sets_per_cc = 1; uint8_t max_cfgured_res_sets_per_cc = 1; uint8_t max_cfgured_res_sets_all_cc = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PTRS-DensityRecommendationDL ::= SEQUENCE struct ptrs_density_recommendation_dl_s { uint16_t freq_density1 = 1; uint16_t freq_density2 = 1; uint8_t time_density1 = 0; uint8_t time_density2 = 0; uint8_t time_density3 = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PTRS-DensityRecommendationUL ::= SEQUENCE struct ptrs_density_recommendation_ul_s { uint16_t freq_density1 = 1; uint16_t freq_density2 = 1; uint8_t time_density1 = 0; uint8_t time_density2 = 0; uint8_t time_density3 = 0; uint16_t sample_density1 = 1; uint16_t sample_density2 = 1; uint16_t sample_density3 = 1; uint16_t sample_density4 = 1; uint16_t sample_density5 = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SpatialRelations ::= SEQUENCE struct spatial_relations_s { struct max_num_cfgured_spatial_relations_opts { enum options { n4, n8, n16, n32, n64, n96, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_cfgured_spatial_relations_e_; struct max_num_active_spatial_relations_opts { enum options { n1, n2, n4, n8, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_active_spatial_relations_e_; struct max_num_dl_rs_qcl_type_d_opts { enum options { n1, n2, n4, n8, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_dl_rs_qcl_type_d_e_; // member variables bool add_active_spatial_relation_pucch_present = false; max_num_cfgured_spatial_relations_e_ max_num_cfgured_spatial_relations; max_num_active_spatial_relations_e_ max_num_active_spatial_relations; max_num_dl_rs_qcl_type_d_e_ max_num_dl_rs_qcl_type_d; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MIMO-ParametersPerBand ::= SEQUENCE struct mimo_params_per_band_s { struct tci_state_pdsch_s_ { struct max_num_cfgured_tcistates_per_cc_opts { enum options { n4, n8, n16, n32, n64, n128, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_cfgured_tcistates_per_cc_e_; struct max_num_active_tci_per_bwp_opts { enum options { n1, n2, n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_active_tci_per_bwp_e_; // member variables bool max_num_cfgured_tcistates_per_cc_present = false; bool max_num_active_tci_per_bwp_present = false; max_num_cfgured_tcistates_per_cc_e_ max_num_cfgured_tcistates_per_cc; max_num_active_tci_per_bwp_e_ max_num_active_tci_per_bwp; }; struct pusch_trans_coherence_opts { enum options { non_coherent, partial_coherent, full_coherent, nulltype } value; const char* to_string() const; }; typedef enumerated pusch_trans_coherence_e_; struct max_num_rx_tx_beam_switch_dl_s_ { struct scs_minus15k_hz_opts { enum options { n4, n7, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus15k_hz_e_; struct scs_minus30k_hz_opts { enum options { n4, n7, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus30k_hz_e_; struct scs_minus60k_hz_opts { enum options { n4, n7, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { n4, n7, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; struct scs_minus240k_hz_opts { enum options { n4, n7, n14, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus240k_hz_e_; // member variables bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; bool scs_minus240k_hz_present = false; scs_minus15k_hz_e_ scs_minus15k_hz; scs_minus30k_hz_e_ scs_minus30k_hz; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; scs_minus240k_hz_e_ scs_minus240k_hz; }; struct max_num_non_group_beam_report_opts { enum options { n1, n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_non_group_beam_report_e_; struct ul_beam_management_s_ { struct max_num_srs_res_per_set_bm_opts { enum options { n2, n4, n8, n16, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_srs_res_per_set_bm_e_; // member variables max_num_srs_res_per_set_bm_e_ max_num_srs_res_per_set_bm; uint8_t max_num_srs_res_set = 1; }; struct beam_report_timing_s_ { struct scs_minus15k_hz_opts { enum options { sym2, sym4, sym8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus15k_hz_e_; struct scs_minus30k_hz_opts { enum options { sym4, sym8, sym14, sym28, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus30k_hz_e_; struct scs_minus60k_hz_opts { enum options { sym8, sym14, sym28, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { sym14, sym28, sym56, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus15k_hz_e_ scs_minus15k_hz; scs_minus30k_hz_e_ scs_minus30k_hz; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; struct ptrs_density_recommendation_set_dl_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; ptrs_density_recommendation_dl_s scs_minus15k_hz; ptrs_density_recommendation_dl_s scs_minus30k_hz; ptrs_density_recommendation_dl_s scs_minus60k_hz; ptrs_density_recommendation_dl_s scs_minus120k_hz; }; struct ptrs_density_recommendation_set_ul_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; ptrs_density_recommendation_ul_s scs_minus15k_hz; ptrs_density_recommendation_ul_s scs_minus30k_hz; ptrs_density_recommendation_ul_s scs_minus60k_hz; ptrs_density_recommendation_ul_s scs_minus120k_hz; }; struct beam_switch_timing_s_ { struct scs_minus60k_hz_opts { enum options { sym14, sym28, sym48, sym224, sym336, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { sym14, sym28, sym48, sym224, sym336, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; using srs_assoc_csi_rs_l_ = dyn_array; // member variables bool ext = false; bool tci_state_pdsch_present = false; bool add_active_tci_state_pdcch_present = false; bool pusch_trans_coherence_present = false; bool beam_correspondence_without_ul_beam_sweeping_present = false; bool periodic_beam_report_present = false; bool aperiodic_beam_report_present = false; bool sp_beam_report_pucch_present = false; bool sp_beam_report_pusch_present = false; bool dummy1_present = false; bool max_num_rx_beam_present = false; bool max_num_rx_tx_beam_switch_dl_present = false; bool max_num_non_group_beam_report_present = false; bool group_beam_report_present = false; bool ul_beam_management_present = false; bool max_num_csi_rs_bfd_present = false; bool max_num_ssb_bfd_present = false; bool max_num_csi_rs_ssb_cbd_present = false; bool dummy2_present = false; bool two_ports_ptrs_ul_present = false; bool dummy5_present = false; bool dummy3_present = false; bool beam_report_timing_present = false; bool ptrs_density_recommendation_set_dl_present = false; bool ptrs_density_recommendation_set_ul_present = false; bool dummy4_present = false; bool aperiodic_trs_present = false; tci_state_pdsch_s_ tci_state_pdsch; pusch_trans_coherence_e_ pusch_trans_coherence; dummy_g_s dummy1; uint8_t max_num_rx_beam = 2; max_num_rx_tx_beam_switch_dl_s_ max_num_rx_tx_beam_switch_dl; max_num_non_group_beam_report_e_ max_num_non_group_beam_report; ul_beam_management_s_ ul_beam_management; uint8_t max_num_csi_rs_bfd = 1; uint8_t max_num_ssb_bfd = 1; uint16_t max_num_csi_rs_ssb_cbd = 1; srs_res_s dummy5; uint8_t dummy3 = 1; beam_report_timing_s_ beam_report_timing; ptrs_density_recommendation_set_dl_s_ ptrs_density_recommendation_set_dl; ptrs_density_recommendation_set_ul_s_ ptrs_density_recommendation_set_ul; dummy_h_s dummy4; // ... // group 0 bool dummy6_present = false; copy_ptr beam_management_ssb_csi_rs; copy_ptr beam_switch_timing; copy_ptr codebook_params; copy_ptr csi_rs_im_reception_for_feedback; copy_ptr csi_rs_proc_framework_for_srs; copy_ptr csi_report_framework; copy_ptr csi_rs_for_tracking; copy_ptr srs_assoc_csi_rs; copy_ptr spatial_relations; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandNR ::= SEQUENCE struct band_nr_s { struct bwp_same_numerology_opts { enum options { upto2, upto4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated bwp_same_numerology_e_; struct ue_pwr_class_opts { enum options { pc1, pc2, pc3, pc4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ue_pwr_class_e_; struct ch_bws_dl_c_ { struct fr1_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; fixed_bitstring<10> scs_minus15k_hz; fixed_bitstring<10> scs_minus30k_hz; fixed_bitstring<10> scs_minus60k_hz; }; struct fr2_s_ { bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; fixed_bitstring<3> scs_minus60k_hz; fixed_bitstring<3> scs_minus120k_hz; }; struct types_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ch_bws_dl_c_() = default; ch_bws_dl_c_(const ch_bws_dl_c_& other); ch_bws_dl_c_& operator=(const ch_bws_dl_c_& other); ~ch_bws_dl_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fr1_s_& fr1() { assert_choice_type(types::fr1, type_, "channelBWs-DL"); return c.get(); } fr2_s_& fr2() { assert_choice_type(types::fr2, type_, "channelBWs-DL"); return c.get(); } const fr1_s_& fr1() const { assert_choice_type(types::fr1, type_, "channelBWs-DL"); return c.get(); } const fr2_s_& fr2() const { assert_choice_type(types::fr2, type_, "channelBWs-DL"); return c.get(); } fr1_s_& set_fr1(); fr2_s_& set_fr2(); private: types type_; choice_buffer_t c; void destroy_(); }; struct ch_bws_ul_c_ { struct fr1_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; fixed_bitstring<10> scs_minus15k_hz; fixed_bitstring<10> scs_minus30k_hz; fixed_bitstring<10> scs_minus60k_hz; }; struct fr2_s_ { bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; fixed_bitstring<3> scs_minus60k_hz; fixed_bitstring<3> scs_minus120k_hz; }; struct types_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ch_bws_ul_c_() = default; ch_bws_ul_c_(const ch_bws_ul_c_& other); ch_bws_ul_c_& operator=(const ch_bws_ul_c_& other); ~ch_bws_ul_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fr1_s_& fr1() { assert_choice_type(types::fr1, type_, "channelBWs-UL"); return c.get(); } fr2_s_& fr2() { assert_choice_type(types::fr2, type_, "channelBWs-UL"); return c.get(); } const fr1_s_& fr1() const { assert_choice_type(types::fr1, type_, "channelBWs-UL"); return c.get(); } const fr2_s_& fr2() const { assert_choice_type(types::fr2, type_, "channelBWs-UL"); return c.get(); } fr1_s_& set_fr1(); fr2_s_& set_fr2(); private: types type_; choice_buffer_t c; void destroy_(); }; struct max_ul_duty_cycle_pc2_fr1_opts { enum options { n60, n70, n80, n90, n100, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_ul_duty_cycle_pc2_fr1_e_; struct max_ul_duty_cycle_fr2_opts { enum options { n15, n20, n25, n30, n40, n50, n60, n70, n80, n90, n100, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_ul_duty_cycle_fr2_e_; struct ch_bws_dl_v1590_c_ { struct fr1_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; fixed_bitstring<16> scs_minus15k_hz; fixed_bitstring<16> scs_minus30k_hz; fixed_bitstring<16> scs_minus60k_hz; }; struct fr2_s_ { bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; fixed_bitstring<8> scs_minus60k_hz; fixed_bitstring<8> scs_minus120k_hz; }; struct types_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ch_bws_dl_v1590_c_() = default; ch_bws_dl_v1590_c_(const ch_bws_dl_v1590_c_& other); ch_bws_dl_v1590_c_& operator=(const ch_bws_dl_v1590_c_& other); ~ch_bws_dl_v1590_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fr1_s_& fr1() { assert_choice_type(types::fr1, type_, "channelBWs-DL-v1590"); return c.get(); } fr2_s_& fr2() { assert_choice_type(types::fr2, type_, "channelBWs-DL-v1590"); return c.get(); } const fr1_s_& fr1() const { assert_choice_type(types::fr1, type_, "channelBWs-DL-v1590"); return c.get(); } const fr2_s_& fr2() const { assert_choice_type(types::fr2, type_, "channelBWs-DL-v1590"); return c.get(); } fr1_s_& set_fr1(); fr2_s_& set_fr2(); private: types type_; choice_buffer_t c; void destroy_(); }; struct ch_bws_ul_v1590_c_ { struct fr1_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; fixed_bitstring<16> scs_minus15k_hz; fixed_bitstring<16> scs_minus30k_hz; fixed_bitstring<16> scs_minus60k_hz; }; struct fr2_s_ { bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; fixed_bitstring<8> scs_minus60k_hz; fixed_bitstring<8> scs_minus120k_hz; }; struct types_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods ch_bws_ul_v1590_c_() = default; ch_bws_ul_v1590_c_(const ch_bws_ul_v1590_c_& other); ch_bws_ul_v1590_c_& operator=(const ch_bws_ul_v1590_c_& other); ~ch_bws_ul_v1590_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fr1_s_& fr1() { assert_choice_type(types::fr1, type_, "channelBWs-UL-v1590"); return c.get(); } fr2_s_& fr2() { assert_choice_type(types::fr2, type_, "channelBWs-UL-v1590"); return c.get(); } const fr1_s_& fr1() const { assert_choice_type(types::fr1, type_, "channelBWs-UL-v1590"); return c.get(); } const fr2_s_& fr2() const { assert_choice_type(types::fr2, type_, "channelBWs-UL-v1590"); return c.get(); } fr1_s_& set_fr1(); fr2_s_& set_fr2(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool modified_mpr_behaviour_present = false; bool mimo_params_per_band_present = false; bool extended_cp_present = false; bool multiple_tci_present = false; bool bwp_without_restrict_present = false; bool bwp_same_numerology_present = false; bool bwp_diff_numerology_present = false; bool cross_carrier_sched_same_scs_present = false; bool pdsch_minus256_qam_fr2_present = false; bool pusch_minus256_qam_present = false; bool ue_pwr_class_present = false; bool rate_matching_lte_crs_present = false; bool ch_bws_dl_present = false; bool ch_bws_ul_present = false; uint16_t band_nr = 1; fixed_bitstring<8> modified_mpr_behaviour; mimo_params_per_band_s mimo_params_per_band; bwp_same_numerology_e_ bwp_same_numerology; ue_pwr_class_e_ ue_pwr_class; ch_bws_dl_c_ ch_bws_dl; ch_bws_ul_c_ ch_bws_ul; // ... // group 0 bool max_ul_duty_cycle_pc2_fr1_present = false; max_ul_duty_cycle_pc2_fr1_e_ max_ul_duty_cycle_pc2_fr1; // group 1 bool pucch_spatial_rel_info_mac_ce_present = false; bool pwr_boosting_pi2_bpsk_present = false; // group 2 bool max_ul_duty_cycle_fr2_present = false; max_ul_duty_cycle_fr2_e_ max_ul_duty_cycle_fr2; // group 3 copy_ptr ch_bws_dl_v1590; copy_ptr ch_bws_ul_v1590; // group 4 bool asymmetric_bw_combination_set_present = false; bounded_bitstring<1, 32> asymmetric_bw_combination_set; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CFRA-CSIRS-Resource ::= SEQUENCE struct cfra_csirs_res_s { using ra_occasion_list_l_ = dyn_array; // member variables bool ext = false; uint8_t csi_rs = 0; ra_occasion_list_l_ ra_occasion_list; uint8_t ra_preamb_idx = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CFRA-SSB-Resource ::= SEQUENCE struct cfra_ssb_res_s { bool ext = false; uint8_t ssb = 0; uint8_t ra_preamb_idx = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CFRA ::= SEQUENCE struct cfra_s { struct occasions_s_ { struct ssb_per_rach_occasion_opts { enum options { one_eighth, one_fourth, one_half, one, two, four, eight, sixteen, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated ssb_per_rach_occasion_e_; // member variables bool ssb_per_rach_occasion_present = false; rach_cfg_generic_s rach_cfg_generic; ssb_per_rach_occasion_e_ ssb_per_rach_occasion; }; struct res_c_ { struct ssb_s_ { using ssb_res_list_l_ = dyn_array; // member variables ssb_res_list_l_ ssb_res_list; uint8_t ra_ssb_occasion_mask_idx = 0; }; struct csirs_s_ { using csirs_res_list_l_ = dyn_array; // member variables csirs_res_list_l_ csirs_res_list; uint8_t rsrp_thres_csi_rs = 0; }; struct types_opts { enum options { ssb, csirs, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods res_c_() = default; res_c_(const res_c_& other); res_c_& operator=(const res_c_& other); ~res_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ssb_s_& ssb() { assert_choice_type(types::ssb, type_, "resources"); return c.get(); } csirs_s_& csirs() { assert_choice_type(types::csirs, type_, "resources"); return c.get(); } const ssb_s_& ssb() const { assert_choice_type(types::ssb, type_, "resources"); return c.get(); } const csirs_s_& csirs() const { assert_choice_type(types::csirs, type_, "resources"); return c.get(); } ssb_s_& set_ssb(); csirs_s_& set_csirs(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool occasions_present = false; occasions_s_ occasions; res_c_ res; // ... // group 0 bool total_nof_ra_preambs_present = false; uint8_t total_nof_ra_preambs = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-AssociatedReportConfigInfo ::= SEQUENCE struct csi_associated_report_cfg_info_s { struct res_for_ch_c_ { struct nzp_csi_rs_s_ { using qcl_info_l_ = bounded_array; // member variables bool qcl_info_present = false; uint8_t res_set = 1; qcl_info_l_ qcl_info; }; struct types_opts { enum options { nzp_csi_rs, csi_ssb_res_set, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods res_for_ch_c_() = default; res_for_ch_c_(const res_for_ch_c_& other); res_for_ch_c_& operator=(const res_for_ch_c_& other); ~res_for_ch_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters nzp_csi_rs_s_& nzp_csi_rs() { assert_choice_type(types::nzp_csi_rs, type_, "resourcesForChannel"); return c.get(); } uint8_t& csi_ssb_res_set() { assert_choice_type(types::csi_ssb_res_set, type_, "resourcesForChannel"); return c.get(); } const nzp_csi_rs_s_& nzp_csi_rs() const { assert_choice_type(types::nzp_csi_rs, type_, "resourcesForChannel"); return c.get(); } const uint8_t& csi_ssb_res_set() const { assert_choice_type(types::csi_ssb_res_set, type_, "resourcesForChannel"); return c.get(); } nzp_csi_rs_s_& set_nzp_csi_rs(); uint8_t& set_csi_ssb_res_set(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool csi_im_res_for_interference_present = false; bool nzp_csi_rs_res_for_interference_present = false; uint8_t report_cfg_id = 0; res_for_ch_c_ res_for_ch; uint8_t csi_im_res_for_interference = 1; uint8_t nzp_csi_rs_res_for_interference = 1; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-AperiodicTriggerState ::= SEQUENCE struct csi_aperiodic_trigger_state_s { using associated_report_cfg_info_list_l_ = dyn_array; // member variables bool ext = false; associated_report_cfg_info_list_l_ associated_report_cfg_info_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-AperiodicTriggerStateList ::= SEQUENCE (SIZE (1..128)) OF CSI-AperiodicTriggerState using csi_aperiodic_trigger_state_list_l = dyn_array; // CSI-IM-Resource ::= SEQUENCE struct csi_im_res_s { struct csi_im_res_elem_pattern_c_ { struct pattern0_s_ { struct subcarrier_location_p0_opts { enum options { s0, s2, s4, s6, s8, s10, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated subcarrier_location_p0_e_; // member variables subcarrier_location_p0_e_ subcarrier_location_p0; uint8_t symbol_location_p0 = 0; }; struct pattern1_s_ { struct subcarrier_location_p1_opts { enum options { s0, s4, s8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated subcarrier_location_p1_e_; // member variables subcarrier_location_p1_e_ subcarrier_location_p1; uint8_t symbol_location_p1 = 0; }; struct types_opts { enum options { pattern0, pattern1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods csi_im_res_elem_pattern_c_() = default; csi_im_res_elem_pattern_c_(const csi_im_res_elem_pattern_c_& other); csi_im_res_elem_pattern_c_& operator=(const csi_im_res_elem_pattern_c_& other); ~csi_im_res_elem_pattern_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters pattern0_s_& pattern0() { assert_choice_type(types::pattern0, type_, "csi-IM-ResourceElementPattern"); return c.get(); } pattern1_s_& pattern1() { assert_choice_type(types::pattern1, type_, "csi-IM-ResourceElementPattern"); return c.get(); } const pattern0_s_& pattern0() const { assert_choice_type(types::pattern0, type_, "csi-IM-ResourceElementPattern"); return c.get(); } const pattern1_s_& pattern1() const { assert_choice_type(types::pattern1, type_, "csi-IM-ResourceElementPattern"); return c.get(); } pattern0_s_& set_pattern0(); pattern1_s_& set_pattern1(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool csi_im_res_elem_pattern_present = false; bool freq_band_present = false; bool periodicity_and_offset_present = false; uint8_t csi_im_res_id = 0; csi_im_res_elem_pattern_c_ csi_im_res_elem_pattern; csi_freq_occupation_s freq_band; csi_res_periodicity_and_offset_c periodicity_and_offset; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-IM-ResourceSet ::= SEQUENCE struct csi_im_res_set_s { using csi_im_res_l_ = bounded_array; // member variables bool ext = false; uint8_t csi_im_res_set_id = 0; csi_im_res_l_ csi_im_res; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-ReportPeriodicityAndOffset ::= CHOICE struct csi_report_periodicity_and_offset_c { struct types_opts { enum options { slots4, slots5, slots8, slots10, slots16, slots20, slots40, slots80, slots160, slots320, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods csi_report_periodicity_and_offset_c() = default; csi_report_periodicity_and_offset_c(const csi_report_periodicity_and_offset_c& other); csi_report_periodicity_and_offset_c& operator=(const csi_report_periodicity_and_offset_c& other); ~csi_report_periodicity_and_offset_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& slots4() { assert_choice_type(types::slots4, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots5() { assert_choice_type(types::slots5, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots8() { assert_choice_type(types::slots8, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots10() { assert_choice_type(types::slots10, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots16() { assert_choice_type(types::slots16, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots20() { assert_choice_type(types::slots20, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots40() { assert_choice_type(types::slots40, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots80() { assert_choice_type(types::slots80, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& slots160() { assert_choice_type(types::slots160, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint16_t& slots320() { assert_choice_type(types::slots320, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots4() const { assert_choice_type(types::slots4, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots5() const { assert_choice_type(types::slots5, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots8() const { assert_choice_type(types::slots8, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots10() const { assert_choice_type(types::slots10, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots16() const { assert_choice_type(types::slots16, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots20() const { assert_choice_type(types::slots20, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots40() const { assert_choice_type(types::slots40, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots80() const { assert_choice_type(types::slots80, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint8_t& slots160() const { assert_choice_type(types::slots160, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } const uint16_t& slots320() const { assert_choice_type(types::slots320, type_, "CSI-ReportPeriodicityAndOffset"); return c.get(); } uint8_t& set_slots4(); uint8_t& set_slots5(); uint8_t& set_slots8(); uint8_t& set_slots10(); uint8_t& set_slots16(); uint8_t& set_slots20(); uint8_t& set_slots40(); uint8_t& set_slots80(); uint8_t& set_slots160(); uint16_t& set_slots320(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // CSI-SemiPersistentOnPUSCH-TriggerState ::= SEQUENCE struct csi_semi_persistent_on_pusch_trigger_state_s { bool ext = false; uint8_t associated_report_cfg_info = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CodebookConfig ::= SEQUENCE struct codebook_cfg_s { struct codebook_type_c_ { struct type1_s_ { struct sub_type_c_ { struct type_i_single_panel_s_ { struct nr_of_ant_ports_c_ { struct two_s_ { fixed_bitstring<6> two_tx_codebook_subset_restrict; }; struct more_than_two_s_ { struct n1_n2_c_ { struct types_opts { enum options { two_one_type_i_single_panel_restrict, two_two_type_i_single_panel_restrict, four_one_type_i_single_panel_restrict, three_two_type_i_single_panel_restrict, six_one_type_i_single_panel_restrict, four_two_type_i_single_panel_restrict, eight_one_type_i_single_panel_restrict, four_three_type_i_single_panel_restrict, six_two_type_i_single_panel_restrict, twelve_one_type_i_single_panel_restrict, four_four_type_i_single_panel_restrict, eight_two_type_i_single_panel_restrict, sixteen_one_type_i_single_panel_restrict, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods n1_n2_c_() = default; n1_n2_c_(const n1_n2_c_& other); n1_n2_c_& operator=(const n1_n2_c_& other); ~n1_n2_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<8>& two_one_type_i_single_panel_restrict() { assert_choice_type(types::two_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<64>& two_two_type_i_single_panel_restrict() { assert_choice_type(types::two_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<16>& four_one_type_i_single_panel_restrict() { assert_choice_type(types::four_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<96>& three_two_type_i_single_panel_restrict() { assert_choice_type(types::three_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<24>& six_one_type_i_single_panel_restrict() { assert_choice_type(types::six_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<128>& four_two_type_i_single_panel_restrict() { assert_choice_type(types::four_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<32>& eight_one_type_i_single_panel_restrict() { assert_choice_type(types::eight_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<192>& four_three_type_i_single_panel_restrict() { assert_choice_type(types::four_three_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<192>& six_two_type_i_single_panel_restrict() { assert_choice_type(types::six_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<48>& twelve_one_type_i_single_panel_restrict() { assert_choice_type(types::twelve_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<256>& four_four_type_i_single_panel_restrict() { assert_choice_type(types::four_four_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<256>& eight_two_type_i_single_panel_restrict() { assert_choice_type(types::eight_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<64>& sixteen_one_type_i_single_panel_restrict() { assert_choice_type(types::sixteen_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<8>& two_one_type_i_single_panel_restrict() const { assert_choice_type(types::two_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<64>& two_two_type_i_single_panel_restrict() const { assert_choice_type(types::two_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<16>& four_one_type_i_single_panel_restrict() const { assert_choice_type(types::four_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<96>& three_two_type_i_single_panel_restrict() const { assert_choice_type(types::three_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<24>& six_one_type_i_single_panel_restrict() const { assert_choice_type(types::six_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<128>& four_two_type_i_single_panel_restrict() const { assert_choice_type(types::four_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<32>& eight_one_type_i_single_panel_restrict() const { assert_choice_type(types::eight_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<192>& four_three_type_i_single_panel_restrict() const { assert_choice_type(types::four_three_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<192>& six_two_type_i_single_panel_restrict() const { assert_choice_type(types::six_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<48>& twelve_one_type_i_single_panel_restrict() const { assert_choice_type(types::twelve_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<256>& four_four_type_i_single_panel_restrict() const { assert_choice_type(types::four_four_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<256>& eight_two_type_i_single_panel_restrict() const { assert_choice_type(types::eight_two_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } const fixed_bitstring<64>& sixteen_one_type_i_single_panel_restrict() const { assert_choice_type(types::sixteen_one_type_i_single_panel_restrict, type_, "n1-n2"); return c.get >(); } fixed_bitstring<8>& set_two_one_type_i_single_panel_restrict(); fixed_bitstring<64>& set_two_two_type_i_single_panel_restrict(); fixed_bitstring<16>& set_four_one_type_i_single_panel_restrict(); fixed_bitstring<96>& set_three_two_type_i_single_panel_restrict(); fixed_bitstring<24>& set_six_one_type_i_single_panel_restrict(); fixed_bitstring<128>& set_four_two_type_i_single_panel_restrict(); fixed_bitstring<32>& set_eight_one_type_i_single_panel_restrict(); fixed_bitstring<192>& set_four_three_type_i_single_panel_restrict(); fixed_bitstring<192>& set_six_two_type_i_single_panel_restrict(); fixed_bitstring<48>& set_twelve_one_type_i_single_panel_restrict(); fixed_bitstring<256>& set_four_four_type_i_single_panel_restrict(); fixed_bitstring<256>& set_eight_two_type_i_single_panel_restrict(); fixed_bitstring<64>& set_sixteen_one_type_i_single_panel_restrict(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool type_i_single_panel_codebook_subset_restrict_i2_present = false; n1_n2_c_ n1_n2; fixed_bitstring<16> type_i_single_panel_codebook_subset_restrict_i2; }; struct types_opts { enum options { two, more_than_two, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods nr_of_ant_ports_c_() = default; nr_of_ant_ports_c_(const nr_of_ant_ports_c_& other); nr_of_ant_ports_c_& operator=(const nr_of_ant_ports_c_& other); ~nr_of_ant_ports_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters two_s_& two() { assert_choice_type(types::two, type_, "nrOfAntennaPorts"); return c.get(); } more_than_two_s_& more_than_two() { assert_choice_type(types::more_than_two, type_, "nrOfAntennaPorts"); return c.get(); } const two_s_& two() const { assert_choice_type(types::two, type_, "nrOfAntennaPorts"); return c.get(); } const more_than_two_s_& more_than_two() const { assert_choice_type(types::more_than_two, type_, "nrOfAntennaPorts"); return c.get(); } two_s_& set_two(); more_than_two_s_& set_more_than_two(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables nr_of_ant_ports_c_ nr_of_ant_ports; fixed_bitstring<8> type_i_single_panel_ri_restrict; }; struct type_i_multi_panel_s_ { struct ng_n1_n2_c_ { struct types_opts { enum options { two_two_one_type_i_multi_panel_restrict, two_four_one_type_i_multi_panel_restrict, four_two_one_type_i_multi_panel_restrict, two_two_two_type_i_multi_panel_restrict, two_eight_one_type_i_multi_panel_restrict, four_four_one_type_i_multi_panel_restrict, two_four_two_type_i_multi_panel_restrict, four_two_two_type_i_multi_panel_restrict, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ng_n1_n2_c_() = default; ng_n1_n2_c_(const ng_n1_n2_c_& other); ng_n1_n2_c_& operator=(const ng_n1_n2_c_& other); ~ng_n1_n2_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<8>& two_two_one_type_i_multi_panel_restrict() { assert_choice_type(types::two_two_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<16>& two_four_one_type_i_multi_panel_restrict() { assert_choice_type(types::two_four_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<8>& four_two_one_type_i_multi_panel_restrict() { assert_choice_type(types::four_two_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<64>& two_two_two_type_i_multi_panel_restrict() { assert_choice_type(types::two_two_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<32>& two_eight_one_type_i_multi_panel_restrict() { assert_choice_type(types::two_eight_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<16>& four_four_one_type_i_multi_panel_restrict() { assert_choice_type(types::four_four_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<128>& two_four_two_type_i_multi_panel_restrict() { assert_choice_type(types::two_four_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<64>& four_two_two_type_i_multi_panel_restrict() { assert_choice_type(types::four_two_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<8>& two_two_one_type_i_multi_panel_restrict() const { assert_choice_type(types::two_two_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<16>& two_four_one_type_i_multi_panel_restrict() const { assert_choice_type(types::two_four_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<8>& four_two_one_type_i_multi_panel_restrict() const { assert_choice_type(types::four_two_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<64>& two_two_two_type_i_multi_panel_restrict() const { assert_choice_type(types::two_two_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<32>& two_eight_one_type_i_multi_panel_restrict() const { assert_choice_type(types::two_eight_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<16>& four_four_one_type_i_multi_panel_restrict() const { assert_choice_type(types::four_four_one_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<128>& two_four_two_type_i_multi_panel_restrict() const { assert_choice_type(types::two_four_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } const fixed_bitstring<64>& four_two_two_type_i_multi_panel_restrict() const { assert_choice_type(types::four_two_two_type_i_multi_panel_restrict, type_, "ng-n1-n2"); return c.get >(); } fixed_bitstring<8>& set_two_two_one_type_i_multi_panel_restrict(); fixed_bitstring<16>& set_two_four_one_type_i_multi_panel_restrict(); fixed_bitstring<8>& set_four_two_one_type_i_multi_panel_restrict(); fixed_bitstring<64>& set_two_two_two_type_i_multi_panel_restrict(); fixed_bitstring<32>& set_two_eight_one_type_i_multi_panel_restrict(); fixed_bitstring<16>& set_four_four_one_type_i_multi_panel_restrict(); fixed_bitstring<128>& set_two_four_two_type_i_multi_panel_restrict(); fixed_bitstring<64>& set_four_two_two_type_i_multi_panel_restrict(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables ng_n1_n2_c_ ng_n1_n2; fixed_bitstring<4> ri_restrict; }; struct types_opts { enum options { type_i_single_panel, type_i_multi_panel, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods sub_type_c_() = default; sub_type_c_(const sub_type_c_& other); sub_type_c_& operator=(const sub_type_c_& other); ~sub_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters type_i_single_panel_s_& type_i_single_panel() { assert_choice_type(types::type_i_single_panel, type_, "subType"); return c.get(); } type_i_multi_panel_s_& type_i_multi_panel() { assert_choice_type(types::type_i_multi_panel, type_, "subType"); return c.get(); } const type_i_single_panel_s_& type_i_single_panel() const { assert_choice_type(types::type_i_single_panel, type_, "subType"); return c.get(); } const type_i_multi_panel_s_& type_i_multi_panel() const { assert_choice_type(types::type_i_multi_panel, type_, "subType"); return c.get(); } type_i_single_panel_s_& set_type_i_single_panel(); type_i_multi_panel_s_& set_type_i_multi_panel(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables sub_type_c_ sub_type; uint8_t codebook_mode = 1; }; struct type2_s_ { struct sub_type_c_ { struct type_ii_s_ { struct n1_n2_codebook_subset_restrict_c_ { struct types_opts { enum options { two_one, two_two, four_one, three_two, six_one, four_two, eight_one, four_three, six_two, twelve_one, four_four, eight_two, sixteen_one, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods n1_n2_codebook_subset_restrict_c_() = default; n1_n2_codebook_subset_restrict_c_(const n1_n2_codebook_subset_restrict_c_& other); n1_n2_codebook_subset_restrict_c_& operator=(const n1_n2_codebook_subset_restrict_c_& other); ~n1_n2_codebook_subset_restrict_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<16>& two_one() { assert_choice_type(types::two_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<43>& two_two() { assert_choice_type(types::two_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<32>& four_one() { assert_choice_type(types::four_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<59>& three_two() { assert_choice_type(types::three_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<48>& six_one() { assert_choice_type(types::six_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<75>& four_two() { assert_choice_type(types::four_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<64>& eight_one() { assert_choice_type(types::eight_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<107>& four_three() { assert_choice_type(types::four_three, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<107>& six_two() { assert_choice_type(types::six_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<96>& twelve_one() { assert_choice_type(types::twelve_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<139>& four_four() { assert_choice_type(types::four_four, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<139>& eight_two() { assert_choice_type(types::eight_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<128>& sixteen_one() { assert_choice_type(types::sixteen_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<16>& two_one() const { assert_choice_type(types::two_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<43>& two_two() const { assert_choice_type(types::two_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<32>& four_one() const { assert_choice_type(types::four_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<59>& three_two() const { assert_choice_type(types::three_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<48>& six_one() const { assert_choice_type(types::six_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<75>& four_two() const { assert_choice_type(types::four_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<64>& eight_one() const { assert_choice_type(types::eight_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<107>& four_three() const { assert_choice_type(types::four_three, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<107>& six_two() const { assert_choice_type(types::six_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<96>& twelve_one() const { assert_choice_type(types::twelve_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<139>& four_four() const { assert_choice_type(types::four_four, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<139>& eight_two() const { assert_choice_type(types::eight_two, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } const fixed_bitstring<128>& sixteen_one() const { assert_choice_type(types::sixteen_one, type_, "n1-n2-codebookSubsetRestriction"); return c.get >(); } fixed_bitstring<16>& set_two_one(); fixed_bitstring<43>& set_two_two(); fixed_bitstring<32>& set_four_one(); fixed_bitstring<59>& set_three_two(); fixed_bitstring<48>& set_six_one(); fixed_bitstring<75>& set_four_two(); fixed_bitstring<64>& set_eight_one(); fixed_bitstring<107>& set_four_three(); fixed_bitstring<107>& set_six_two(); fixed_bitstring<96>& set_twelve_one(); fixed_bitstring<139>& set_four_four(); fixed_bitstring<139>& set_eight_two(); fixed_bitstring<128>& set_sixteen_one(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables n1_n2_codebook_subset_restrict_c_ n1_n2_codebook_subset_restrict; fixed_bitstring<2> type_ii_ri_restrict; }; struct type_ii_port_sel_s_ { struct port_sel_sampling_size_opts { enum options { n1, n2, n3, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated port_sel_sampling_size_e_; // member variables bool port_sel_sampling_size_present = false; port_sel_sampling_size_e_ port_sel_sampling_size; fixed_bitstring<2> type_ii_port_sel_ri_restrict; }; struct types_opts { enum options { type_ii, type_ii_port_sel, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods sub_type_c_() = default; sub_type_c_(const sub_type_c_& other); sub_type_c_& operator=(const sub_type_c_& other); ~sub_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters type_ii_s_& type_ii() { assert_choice_type(types::type_ii, type_, "subType"); return c.get(); } type_ii_port_sel_s_& type_ii_port_sel() { assert_choice_type(types::type_ii_port_sel, type_, "subType"); return c.get(); } const type_ii_s_& type_ii() const { assert_choice_type(types::type_ii, type_, "subType"); return c.get(); } const type_ii_port_sel_s_& type_ii_port_sel() const { assert_choice_type(types::type_ii_port_sel, type_, "subType"); return c.get(); } type_ii_s_& set_type_ii(); type_ii_port_sel_s_& set_type_ii_port_sel(); private: types type_; choice_buffer_t c; void destroy_(); }; struct phase_alphabet_size_opts { enum options { n4, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated phase_alphabet_size_e_; struct nof_beams_opts { enum options { two, three, four, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nof_beams_e_; // member variables sub_type_c_ sub_type; phase_alphabet_size_e_ phase_alphabet_size; bool subband_amplitude = false; nof_beams_e_ nof_beams; }; struct types_opts { enum options { type1, type2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods codebook_type_c_() = default; codebook_type_c_(const codebook_type_c_& other); codebook_type_c_& operator=(const codebook_type_c_& other); ~codebook_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters type1_s_& type1() { assert_choice_type(types::type1, type_, "codebookType"); return c.get(); } type2_s_& type2() { assert_choice_type(types::type2, type_, "codebookType"); return c.get(); } const type1_s_& type1() const { assert_choice_type(types::type1, type_, "codebookType"); return c.get(); } const type2_s_& type2() const { assert_choice_type(types::type2, type_, "codebookType"); return c.get(); } type1_s_& set_type1(); type2_s_& set_type2(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables codebook_type_c_ codebook_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUCCH-CSI-Resource ::= SEQUENCE struct pucch_csi_res_s { uint8_t ul_bw_part_id = 0; uint8_t pucch_res = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PortIndexFor8Ranks ::= CHOICE struct port_idx_for8_ranks_c { struct port_idx8_s_ { using rank2_minus8_l_ = std::array; using rank3_minus8_l_ = std::array; using rank4_minus8_l_ = std::array; using rank5_minus8_l_ = std::array; using rank6_minus8_l_ = std::array; using rank7_minus8_l_ = std::array; using rank8_minus8_l_ = std::array; // member variables bool rank1_minus8_present = false; bool rank2_minus8_present = false; bool rank3_minus8_present = false; bool rank4_minus8_present = false; bool rank5_minus8_present = false; bool rank6_minus8_present = false; bool rank7_minus8_present = false; bool rank8_minus8_present = false; uint8_t rank1_minus8 = 0; rank2_minus8_l_ rank2_minus8; rank3_minus8_l_ rank3_minus8; rank4_minus8_l_ rank4_minus8; rank5_minus8_l_ rank5_minus8; rank6_minus8_l_ rank6_minus8; rank7_minus8_l_ rank7_minus8; rank8_minus8_l_ rank8_minus8; }; struct port_idx4_s_ { using rank2_minus4_l_ = std::array; using rank3_minus4_l_ = std::array; using rank4_minus4_l_ = std::array; // member variables bool rank1_minus4_present = false; bool rank2_minus4_present = false; bool rank3_minus4_present = false; bool rank4_minus4_present = false; uint8_t rank1_minus4 = 0; rank2_minus4_l_ rank2_minus4; rank3_minus4_l_ rank3_minus4; rank4_minus4_l_ rank4_minus4; }; struct port_idx2_s_ { using rank2_minus2_l_ = std::array; // member variables bool rank1_minus2_present = false; bool rank2_minus2_present = false; uint8_t rank1_minus2 = 0; rank2_minus2_l_ rank2_minus2; }; struct types_opts { enum options { port_idx8, port_idx4, port_idx2, port_idx1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods port_idx_for8_ranks_c() = default; port_idx_for8_ranks_c(const port_idx_for8_ranks_c& other); port_idx_for8_ranks_c& operator=(const port_idx_for8_ranks_c& other); ~port_idx_for8_ranks_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters port_idx8_s_& port_idx8() { assert_choice_type(types::port_idx8, type_, "PortIndexFor8Ranks"); return c.get(); } port_idx4_s_& port_idx4() { assert_choice_type(types::port_idx4, type_, "PortIndexFor8Ranks"); return c.get(); } port_idx2_s_& port_idx2() { assert_choice_type(types::port_idx2, type_, "PortIndexFor8Ranks"); return c.get(); } const port_idx8_s_& port_idx8() const { assert_choice_type(types::port_idx8, type_, "PortIndexFor8Ranks"); return c.get(); } const port_idx4_s_& port_idx4() const { assert_choice_type(types::port_idx4, type_, "PortIndexFor8Ranks"); return c.get(); } const port_idx2_s_& port_idx2() const { assert_choice_type(types::port_idx2, type_, "PortIndexFor8Ranks"); return c.get(); } port_idx8_s_& set_port_idx8(); port_idx4_s_& set_port_idx4(); port_idx2_s_& set_port_idx2(); void set_port_idx1(); private: types type_; choice_buffer_t c; void destroy_(); }; // CSI-ReportConfig ::= SEQUENCE struct csi_report_cfg_s { struct report_cfg_type_c_ { struct periodic_s_ { using pucch_csi_res_list_l_ = dyn_array; // member variables csi_report_periodicity_and_offset_c report_slot_cfg; pucch_csi_res_list_l_ pucch_csi_res_list; }; struct semi_persistent_on_pucch_s_ { using pucch_csi_res_list_l_ = dyn_array; // member variables csi_report_periodicity_and_offset_c report_slot_cfg; pucch_csi_res_list_l_ pucch_csi_res_list; }; struct semi_persistent_on_pusch_s_ { struct report_slot_cfg_opts { enum options { sl5, sl10, sl20, sl40, sl80, sl160, sl320, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated report_slot_cfg_e_; using report_slot_offset_list_l_ = bounded_array; // member variables report_slot_cfg_e_ report_slot_cfg; report_slot_offset_list_l_ report_slot_offset_list; uint8_t p0alpha = 0; }; struct aperiodic_s_ { using report_slot_offset_list_l_ = bounded_array; // member variables report_slot_offset_list_l_ report_slot_offset_list; }; struct types_opts { enum options { periodic, semi_persistent_on_pucch, semi_persistent_on_pusch, aperiodic, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods report_cfg_type_c_() = default; report_cfg_type_c_(const report_cfg_type_c_& other); report_cfg_type_c_& operator=(const report_cfg_type_c_& other); ~report_cfg_type_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters periodic_s_& periodic() { assert_choice_type(types::periodic, type_, "reportConfigType"); return c.get(); } semi_persistent_on_pucch_s_& semi_persistent_on_pucch() { assert_choice_type(types::semi_persistent_on_pucch, type_, "reportConfigType"); return c.get(); } semi_persistent_on_pusch_s_& semi_persistent_on_pusch() { assert_choice_type(types::semi_persistent_on_pusch, type_, "reportConfigType"); return c.get(); } aperiodic_s_& aperiodic() { assert_choice_type(types::aperiodic, type_, "reportConfigType"); return c.get(); } const periodic_s_& periodic() const { assert_choice_type(types::periodic, type_, "reportConfigType"); return c.get(); } const semi_persistent_on_pucch_s_& semi_persistent_on_pucch() const { assert_choice_type(types::semi_persistent_on_pucch, type_, "reportConfigType"); return c.get(); } const semi_persistent_on_pusch_s_& semi_persistent_on_pusch() const { assert_choice_type(types::semi_persistent_on_pusch, type_, "reportConfigType"); return c.get(); } const aperiodic_s_& aperiodic() const { assert_choice_type(types::aperiodic, type_, "reportConfigType"); return c.get(); } periodic_s_& set_periodic(); semi_persistent_on_pucch_s_& set_semi_persistent_on_pucch(); semi_persistent_on_pusch_s_& set_semi_persistent_on_pusch(); aperiodic_s_& set_aperiodic(); private: types type_; choice_buffer_t c; void destroy_(); }; struct report_quant_c_ { struct cri_ri_i1_cqi_s_ { struct pdsch_bundle_size_for_csi_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdsch_bundle_size_for_csi_e_; // member variables bool pdsch_bundle_size_for_csi_present = false; pdsch_bundle_size_for_csi_e_ pdsch_bundle_size_for_csi; }; struct types_opts { enum options { none, cri_ri_pmi_cqi, cri_ri_i1, cri_ri_i1_cqi, cri_ri_cqi, cri_rsrp, ssb_idx_rsrp, cri_ri_li_pmi_cqi, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods report_quant_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters cri_ri_i1_cqi_s_& cri_ri_i1_cqi() { assert_choice_type(types::cri_ri_i1_cqi, type_, "reportQuantity"); return c; } const cri_ri_i1_cqi_s_& cri_ri_i1_cqi() const { assert_choice_type(types::cri_ri_i1_cqi, type_, "reportQuantity"); return c; } void set_none(); void set_cri_ri_pmi_cqi(); void set_cri_ri_i1(); cri_ri_i1_cqi_s_& set_cri_ri_i1_cqi(); void set_cri_ri_cqi(); void set_cri_rsrp(); void set_ssb_idx_rsrp(); void set_cri_ri_li_pmi_cqi(); private: types type_; cri_ri_i1_cqi_s_ c; }; struct report_freq_cfg_s_ { struct cqi_format_ind_opts { enum options { wideband_cqi, subband_cqi, nulltype } value; const char* to_string() const; }; typedef enumerated cqi_format_ind_e_; struct pmi_format_ind_opts { enum options { wideband_pmi, subband_pmi, nulltype } value; const char* to_string() const; }; typedef enumerated pmi_format_ind_e_; struct csi_report_band_c_ { struct types_opts { enum options { subbands3, subbands4, subbands5, subbands6, subbands7, subbands8, subbands9, subbands10, subbands11, subbands12, subbands13, subbands14, subbands15, subbands16, subbands17, subbands18, // ... subbands19_v1530, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods csi_report_band_c_() = default; csi_report_band_c_(const csi_report_band_c_& other); csi_report_band_c_& operator=(const csi_report_band_c_& other); ~csi_report_band_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<3>& subbands3() { assert_choice_type(types::subbands3, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<4>& subbands4() { assert_choice_type(types::subbands4, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<5>& subbands5() { assert_choice_type(types::subbands5, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<6>& subbands6() { assert_choice_type(types::subbands6, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<7>& subbands7() { assert_choice_type(types::subbands7, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<8>& subbands8() { assert_choice_type(types::subbands8, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<9>& subbands9() { assert_choice_type(types::subbands9, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<10>& subbands10() { assert_choice_type(types::subbands10, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<11>& subbands11() { assert_choice_type(types::subbands11, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<12>& subbands12() { assert_choice_type(types::subbands12, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<13>& subbands13() { assert_choice_type(types::subbands13, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<14>& subbands14() { assert_choice_type(types::subbands14, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<15>& subbands15() { assert_choice_type(types::subbands15, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<16>& subbands16() { assert_choice_type(types::subbands16, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<17>& subbands17() { assert_choice_type(types::subbands17, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<18>& subbands18() { assert_choice_type(types::subbands18, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<19>& subbands19_v1530() { assert_choice_type(types::subbands19_v1530, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<3>& subbands3() const { assert_choice_type(types::subbands3, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<4>& subbands4() const { assert_choice_type(types::subbands4, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<5>& subbands5() const { assert_choice_type(types::subbands5, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<6>& subbands6() const { assert_choice_type(types::subbands6, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<7>& subbands7() const { assert_choice_type(types::subbands7, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<8>& subbands8() const { assert_choice_type(types::subbands8, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<9>& subbands9() const { assert_choice_type(types::subbands9, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<10>& subbands10() const { assert_choice_type(types::subbands10, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<11>& subbands11() const { assert_choice_type(types::subbands11, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<12>& subbands12() const { assert_choice_type(types::subbands12, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<13>& subbands13() const { assert_choice_type(types::subbands13, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<14>& subbands14() const { assert_choice_type(types::subbands14, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<15>& subbands15() const { assert_choice_type(types::subbands15, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<16>& subbands16() const { assert_choice_type(types::subbands16, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<17>& subbands17() const { assert_choice_type(types::subbands17, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<18>& subbands18() const { assert_choice_type(types::subbands18, type_, "csi-ReportingBand"); return c.get >(); } const fixed_bitstring<19>& subbands19_v1530() const { assert_choice_type(types::subbands19_v1530, type_, "csi-ReportingBand"); return c.get >(); } fixed_bitstring<3>& set_subbands3(); fixed_bitstring<4>& set_subbands4(); fixed_bitstring<5>& set_subbands5(); fixed_bitstring<6>& set_subbands6(); fixed_bitstring<7>& set_subbands7(); fixed_bitstring<8>& set_subbands8(); fixed_bitstring<9>& set_subbands9(); fixed_bitstring<10>& set_subbands10(); fixed_bitstring<11>& set_subbands11(); fixed_bitstring<12>& set_subbands12(); fixed_bitstring<13>& set_subbands13(); fixed_bitstring<14>& set_subbands14(); fixed_bitstring<15>& set_subbands15(); fixed_bitstring<16>& set_subbands16(); fixed_bitstring<17>& set_subbands17(); fixed_bitstring<18>& set_subbands18(); fixed_bitstring<19>& set_subbands19_v1530(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool cqi_format_ind_present = false; bool pmi_format_ind_present = false; bool csi_report_band_present = false; cqi_format_ind_e_ cqi_format_ind; pmi_format_ind_e_ pmi_format_ind; csi_report_band_c_ csi_report_band; }; struct time_restrict_for_ch_meass_opts { enum options { cfgured, not_cfgured, nulltype } value; const char* to_string() const; }; typedef enumerated time_restrict_for_ch_meass_e_; struct time_restrict_for_interference_meass_opts { enum options { cfgured, not_cfgured, nulltype } value; const char* to_string() const; }; typedef enumerated time_restrict_for_interference_meass_e_; struct dummy_opts { enum options { n1, n2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dummy_e_; struct group_based_beam_report_c_ { struct disabled_s_ { struct nrof_reported_rs_opts { enum options { n1, n2, n3, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_reported_rs_e_; // member variables bool nrof_reported_rs_present = false; nrof_reported_rs_e_ nrof_reported_rs; }; struct types_opts { enum options { enabled, disabled, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods group_based_beam_report_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters disabled_s_& disabled() { assert_choice_type(types::disabled, type_, "groupBasedBeamReporting"); return c; } const disabled_s_& disabled() const { assert_choice_type(types::disabled, type_, "groupBasedBeamReporting"); return c; } void set_enabled(); disabled_s_& set_disabled(); private: types type_; disabled_s_ c; }; struct cqi_table_opts { enum options { table1, table2, table3, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated cqi_table_e_; struct subband_size_opts { enum options { value1, value2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated subband_size_e_; using non_pmi_port_ind_l_ = dyn_array; struct semi_persistent_on_pusch_v1530_s_ { struct report_slot_cfg_v1530_opts { enum options { sl4, sl8, sl16, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated report_slot_cfg_v1530_e_; // member variables report_slot_cfg_v1530_e_ report_slot_cfg_v1530; }; // member variables bool ext = false; bool carrier_present = false; bool csi_im_res_for_interference_present = false; bool nzp_csi_rs_res_for_interference_present = false; bool report_freq_cfg_present = false; bool codebook_cfg_present = false; bool dummy_present = false; bool cqi_table_present = false; bool non_pmi_port_ind_present = false; uint8_t report_cfg_id = 0; uint8_t carrier = 0; uint8_t res_for_ch_meas = 0; uint8_t csi_im_res_for_interference = 0; uint8_t nzp_csi_rs_res_for_interference = 0; report_cfg_type_c_ report_cfg_type; report_quant_c_ report_quant; report_freq_cfg_s_ report_freq_cfg; time_restrict_for_ch_meass_e_ time_restrict_for_ch_meass; time_restrict_for_interference_meass_e_ time_restrict_for_interference_meass; codebook_cfg_s codebook_cfg; dummy_e_ dummy; group_based_beam_report_c_ group_based_beam_report; cqi_table_e_ cqi_table; subband_size_e_ subband_size; non_pmi_port_ind_l_ non_pmi_port_ind; // ... // group 0 copy_ptr semi_persistent_on_pusch_v1530; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-ResourceConfig ::= SEQUENCE struct csi_res_cfg_s { struct csi_rs_res_set_list_c_ { struct nzp_csi_rs_ssb_s_ { using nzp_csi_rs_res_set_list_l_ = bounded_array; using csi_ssb_res_set_list_l_ = std::array; // member variables bool nzp_csi_rs_res_set_list_present = false; bool csi_ssb_res_set_list_present = false; nzp_csi_rs_res_set_list_l_ nzp_csi_rs_res_set_list; csi_ssb_res_set_list_l_ csi_ssb_res_set_list; }; using csi_im_res_set_list_l_ = bounded_array; struct types_opts { enum options { nzp_csi_rs_ssb, csi_im_res_set_list, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods csi_rs_res_set_list_c_() = default; csi_rs_res_set_list_c_(const csi_rs_res_set_list_c_& other); csi_rs_res_set_list_c_& operator=(const csi_rs_res_set_list_c_& other); ~csi_rs_res_set_list_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters nzp_csi_rs_ssb_s_& nzp_csi_rs_ssb() { assert_choice_type(types::nzp_csi_rs_ssb, type_, "csi-RS-ResourceSetList"); return c.get(); } csi_im_res_set_list_l_& csi_im_res_set_list() { assert_choice_type(types::csi_im_res_set_list, type_, "csi-RS-ResourceSetList"); return c.get(); } const nzp_csi_rs_ssb_s_& nzp_csi_rs_ssb() const { assert_choice_type(types::nzp_csi_rs_ssb, type_, "csi-RS-ResourceSetList"); return c.get(); } const csi_im_res_set_list_l_& csi_im_res_set_list() const { assert_choice_type(types::csi_im_res_set_list, type_, "csi-RS-ResourceSetList"); return c.get(); } nzp_csi_rs_ssb_s_& set_nzp_csi_rs_ssb(); csi_im_res_set_list_l_& set_csi_im_res_set_list(); private: types type_; choice_buffer_t c; void destroy_(); }; struct res_type_opts { enum options { aperiodic, semi_persistent, periodic, nulltype } value; const char* to_string() const; }; typedef enumerated res_type_e_; // member variables bool ext = false; uint8_t csi_res_cfg_id = 0; csi_rs_res_set_list_c_ csi_rs_res_set_list; uint8_t bwp_id = 0; res_type_e_ res_type; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-SSB-ResourceSet ::= SEQUENCE struct csi_ssb_res_set_s { using csi_ssb_res_list_l_ = dyn_array; // member variables bool ext = false; uint8_t csi_ssb_res_set_id = 0; csi_ssb_res_list_l_ csi_ssb_res_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-SemiPersistentOnPUSCH-TriggerStateList ::= SEQUENCE (SIZE (1..64)) OF CSI-SemiPersistentOnPUSCH-TriggerState using csi_semi_persistent_on_pusch_trigger_state_list_l = dyn_array; // NZP-CSI-RS-Resource ::= SEQUENCE struct nzp_csi_rs_res_s { struct pwr_ctrl_offset_ss_opts { enum options { db_minus3, db0, db3, db6, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated pwr_ctrl_offset_ss_e_; // member variables bool ext = false; bool pwr_ctrl_offset_ss_present = false; bool periodicity_and_offset_present = false; bool qcl_info_periodic_csi_rs_present = false; uint8_t nzp_csi_rs_res_id = 0; csi_rs_res_map_s res_map; int8_t pwr_ctrl_offset = -8; pwr_ctrl_offset_ss_e_ pwr_ctrl_offset_ss; uint16_t scrambling_id = 0; csi_res_periodicity_and_offset_c periodicity_and_offset; uint8_t qcl_info_periodic_csi_rs = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NZP-CSI-RS-ResourceSet ::= SEQUENCE struct nzp_csi_rs_res_set_s { using nzp_csi_rs_res_l_ = dyn_array; struct repeat_opts { enum options { on, off, nulltype } value; const char* to_string() const; }; typedef enumerated repeat_e_; // member variables bool ext = false; bool repeat_present = false; bool aperiodic_trigger_offset_present = false; bool trs_info_present = false; uint8_t nzp_csi_res_set_id = 0; nzp_csi_rs_res_l_ nzp_csi_rs_res; repeat_e_ repeat; uint8_t aperiodic_trigger_offset = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CSI-MeasConfig ::= SEQUENCE struct csi_meas_cfg_s { using nzp_csi_rs_res_to_add_mod_list_l_ = dyn_array; using nzp_csi_rs_res_to_release_list_l_ = dyn_array; using nzp_csi_rs_res_set_to_add_mod_list_l_ = dyn_array; using nzp_csi_rs_res_set_to_release_list_l_ = dyn_array; using csi_im_res_to_add_mod_list_l_ = dyn_array; using csi_im_res_to_release_list_l_ = bounded_array; using csi_im_res_set_to_add_mod_list_l_ = dyn_array; using csi_im_res_set_to_release_list_l_ = dyn_array; using csi_ssb_res_set_to_add_mod_list_l_ = dyn_array; using csi_ssb_res_set_to_release_list_l_ = dyn_array; using csi_res_cfg_to_add_mod_list_l_ = dyn_array; using csi_res_cfg_to_release_list_l_ = dyn_array; using csi_report_cfg_to_add_mod_list_l_ = dyn_array; using csi_report_cfg_to_release_list_l_ = dyn_array; // member variables bool ext = false; bool nzp_csi_rs_res_to_add_mod_list_present = false; bool nzp_csi_rs_res_to_release_list_present = false; bool nzp_csi_rs_res_set_to_add_mod_list_present = false; bool nzp_csi_rs_res_set_to_release_list_present = false; bool csi_im_res_to_add_mod_list_present = false; bool csi_im_res_to_release_list_present = false; bool csi_im_res_set_to_add_mod_list_present = false; bool csi_im_res_set_to_release_list_present = false; bool csi_ssb_res_set_to_add_mod_list_present = false; bool csi_ssb_res_set_to_release_list_present = false; bool csi_res_cfg_to_add_mod_list_present = false; bool csi_res_cfg_to_release_list_present = false; bool csi_report_cfg_to_add_mod_list_present = false; bool csi_report_cfg_to_release_list_present = false; bool report_trigger_size_present = false; bool aperiodic_trigger_state_list_present = false; bool semi_persistent_on_pusch_trigger_state_list_present = false; nzp_csi_rs_res_to_add_mod_list_l_ nzp_csi_rs_res_to_add_mod_list; nzp_csi_rs_res_to_release_list_l_ nzp_csi_rs_res_to_release_list; nzp_csi_rs_res_set_to_add_mod_list_l_ nzp_csi_rs_res_set_to_add_mod_list; nzp_csi_rs_res_set_to_release_list_l_ nzp_csi_rs_res_set_to_release_list; csi_im_res_to_add_mod_list_l_ csi_im_res_to_add_mod_list; csi_im_res_to_release_list_l_ csi_im_res_to_release_list; csi_im_res_set_to_add_mod_list_l_ csi_im_res_set_to_add_mod_list; csi_im_res_set_to_release_list_l_ csi_im_res_set_to_release_list; csi_ssb_res_set_to_add_mod_list_l_ csi_ssb_res_set_to_add_mod_list; csi_ssb_res_set_to_release_list_l_ csi_ssb_res_set_to_release_list; csi_res_cfg_to_add_mod_list_l_ csi_res_cfg_to_add_mod_list; csi_res_cfg_to_release_list_l_ csi_res_cfg_to_release_list; csi_report_cfg_to_add_mod_list_l_ csi_report_cfg_to_add_mod_list; csi_report_cfg_to_release_list_l_ csi_report_cfg_to_release_list; uint8_t report_trigger_size = 0; setup_release_c > aperiodic_trigger_state_list; setup_release_c > semi_persistent_on_pusch_trigger_state_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-MBSFN-SubframeConfig ::= SEQUENCE struct eutra_mbsfn_sf_cfg_s { struct radioframe_alloc_period_opts { enum options { n1, n2, n4, n8, n16, n32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated radioframe_alloc_period_e_; struct sf_alloc1_c_ { struct types_opts { enum options { one_frame, four_frames, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods sf_alloc1_c_() = default; sf_alloc1_c_(const sf_alloc1_c_& other); sf_alloc1_c_& operator=(const sf_alloc1_c_& other); ~sf_alloc1_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<6>& one_frame() { assert_choice_type(types::one_frame, type_, "subframeAllocation1"); return c.get >(); } fixed_bitstring<24>& four_frames() { assert_choice_type(types::four_frames, type_, "subframeAllocation1"); return c.get >(); } const fixed_bitstring<6>& one_frame() const { assert_choice_type(types::one_frame, type_, "subframeAllocation1"); return c.get >(); } const fixed_bitstring<24>& four_frames() const { assert_choice_type(types::four_frames, type_, "subframeAllocation1"); return c.get >(); } fixed_bitstring<6>& set_one_frame(); fixed_bitstring<24>& set_four_frames(); private: types type_; choice_buffer_t > c; void destroy_(); }; struct sf_alloc2_c_ { struct types_opts { enum options { one_frame, four_frames, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods sf_alloc2_c_() = default; sf_alloc2_c_(const sf_alloc2_c_& other); sf_alloc2_c_& operator=(const sf_alloc2_c_& other); ~sf_alloc2_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<2>& one_frame() { assert_choice_type(types::one_frame, type_, "subframeAllocation2"); return c.get >(); } fixed_bitstring<8>& four_frames() { assert_choice_type(types::four_frames, type_, "subframeAllocation2"); return c.get >(); } const fixed_bitstring<2>& one_frame() const { assert_choice_type(types::one_frame, type_, "subframeAllocation2"); return c.get >(); } const fixed_bitstring<8>& four_frames() const { assert_choice_type(types::four_frames, type_, "subframeAllocation2"); return c.get >(); } fixed_bitstring<2>& set_one_frame(); fixed_bitstring<8>& set_four_frames(); private: types type_; choice_buffer_t > c; void destroy_(); }; // member variables bool ext = false; bool sf_alloc2_present = false; radioframe_alloc_period_e_ radioframe_alloc_period; uint8_t radioframe_alloc_offset = 0; sf_alloc1_c_ sf_alloc1; sf_alloc2_c_ sf_alloc2; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-CC-SetIndex ::= SEQUENCE struct srs_cc_set_idx_s { bool cc_set_idx_present = false; bool cc_idx_in_one_cc_set_present = false; uint8_t cc_set_idx = 0; uint8_t cc_idx_in_one_cc_set = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SlotFormatCombination ::= SEQUENCE struct slot_format_combination_s { using slot_formats_l_ = dyn_array; // member variables uint16_t slot_format_combination_id = 0; slot_formats_l_ slot_formats; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-MBSFN-SubframeConfigList ::= SEQUENCE (SIZE (1..8)) OF EUTRA-MBSFN-SubframeConfig using eutra_mbsfn_sf_cfg_list_l = dyn_array; // FrequencyInfoDL ::= SEQUENCE struct freq_info_dl_s { using scs_specific_carrier_list_l_ = dyn_array; // member variables bool ext = false; bool absolute_freq_ssb_present = false; uint32_t absolute_freq_ssb = 0; multi_freq_band_list_nr_l freq_band_list; uint32_t absolute_freq_point_a = 0; scs_specific_carrier_list_l_ scs_specific_carrier_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FrequencyInfoUL ::= SEQUENCE struct freq_info_ul_s { using scs_specific_carrier_list_l_ = dyn_array; // member variables bool ext = false; bool freq_band_list_present = false; bool absolute_freq_point_a_present = false; bool add_spec_emission_present = false; bool p_max_present = false; bool freq_shift7p5khz_present = false; multi_freq_band_list_nr_l freq_band_list; uint32_t absolute_freq_point_a = 0; scs_specific_carrier_list_l_ scs_specific_carrier_list; uint8_t add_spec_emission = 0; int8_t p_max = -30; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-CodeBlockGroupTransmission ::= SEQUENCE struct pusch_code_block_group_tx_s { struct max_code_block_groups_per_transport_block_opts { enum options { n2, n4, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_code_block_groups_per_transport_block_e_; // member variables bool ext = false; max_code_block_groups_per_transport_block_e_ max_code_block_groups_per_transport_block; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SRS-TPC-PDCCH-Config ::= SEQUENCE struct srs_tpc_pdcch_cfg_s { using srs_cc_set_idxlist_l_ = dyn_array; // member variables bool srs_cc_set_idxlist_present = false; srs_cc_set_idxlist_l_ srs_cc_set_idxlist; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SlotFormatCombinationsPerCell ::= SEQUENCE struct slot_format_combinations_per_cell_s { using slot_format_combinations_l_ = dyn_array; // member variables bool ext = false; bool subcarrier_spacing2_present = false; bool slot_format_combinations_present = false; bool position_in_dci_present = false; uint8_t serving_cell_id = 0; subcarrier_spacing_e subcarrier_spacing; subcarrier_spacing_e subcarrier_spacing2; slot_format_combinations_l_ slot_format_combinations; uint8_t position_in_dci = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DownlinkConfigCommon ::= SEQUENCE struct dl_cfg_common_s { bool ext = false; bool freq_info_dl_present = false; bool init_dl_bwp_present = false; freq_info_dl_s freq_info_dl; bwp_dl_common_s init_dl_bwp; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDSCH-CodeBlockGroupTransmission ::= SEQUENCE struct pdsch_code_block_group_tx_s { struct max_code_block_groups_per_transport_block_opts { enum options { n2, n4, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_code_block_groups_per_transport_block_e_; // member variables bool ext = false; max_code_block_groups_per_transport_block_e_ max_code_block_groups_per_transport_block; bool code_block_group_flush_ind = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PUSCH-ServingCellConfig ::= SEQUENCE struct pusch_serving_cell_cfg_s { struct xoverhead_opts { enum options { xoh6, xoh12, xoh18, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated xoverhead_e_; // member variables bool ext = false; bool code_block_group_tx_present = false; bool rate_matching_present = false; bool xoverhead_present = false; setup_release_c code_block_group_tx; xoverhead_e_ xoverhead; // ... // group 0 bool max_mimo_layers_present = false; bool processing_type2_enabled_present = false; uint8_t max_mimo_layers = 1; bool processing_type2_enabled = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PollByte ::= ENUMERATED struct poll_byte_opts { enum options { kb1, kb2, kb5, kb8, kb10, kb15, kb25, kb50, kb75, kb100, kb125, kb250, kb375, kb500, kb750, kb1000, kb1250, kb1500, kb2000, kb3000, kb4000, kb4500, kb5000, kb5500, kb6000, kb6500, kb7000, kb7500, mb8, mb9, mb10, mb11, mb12, mb13, mb14, mb15, mb16, mb17, mb18, mb20, mb25, mb30, mb40, infinity, spare20, spare19, spare18, spare17, spare16, spare15, spare14, spare13, spare12, spare11, spare10, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef int32_t number_type; const char* to_string() const; int32_t to_number() const; }; typedef enumerated poll_byte_e; // PollPDU ::= ENUMERATED struct poll_pdu_opts { enum options { p4, p8, p16, p32, p64, p128, p256, p512, p1024, p2048, p4096, p6144, p8192, p12288, p16384, p20480, p24576, p28672, p32768, p40960, p49152, p57344, p65536, infinity, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef int32_t number_type; const char* to_string() const; int32_t to_number() const; }; typedef enumerated poll_pdu_e; // RateMatchPatternLTE-CRS ::= SEQUENCE struct rate_match_pattern_lte_crs_s { struct carrier_bw_dl_opts { enum options { n6, n15, n25, n50, n75, n100, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated carrier_bw_dl_e_; struct nrof_crs_ports_opts { enum options { n1, n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_crs_ports_e_; struct v_shift_opts { enum options { n0, n1, n2, n3, n4, n5, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated v_shift_e_; // member variables bool mbsfn_sf_cfg_list_present = false; uint16_t carrier_freq_dl = 0; carrier_bw_dl_e_ carrier_bw_dl; eutra_mbsfn_sf_cfg_list_l mbsfn_sf_cfg_list; nrof_crs_ports_e_ nrof_crs_ports; v_shift_e_ v_shift; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SN-FieldLengthAM ::= ENUMERATED struct sn_field_len_am_opts { enum options { size12, size18, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sn_field_len_am_e; // SN-FieldLengthUM ::= ENUMERATED struct sn_field_len_um_opts { enum options { size6, size12, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sn_field_len_um_e; // SRS-CarrierSwitching ::= SEQUENCE struct srs_carrier_switching_s { struct srs_switch_from_carrier_opts { enum options { sul, nul, nulltype } value; const char* to_string() const; }; typedef enumerated srs_switch_from_carrier_e_; struct srs_tpc_pdcch_group_c_ { using type_a_l_ = dyn_array; struct types_opts { enum options { type_a, type_b, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods srs_tpc_pdcch_group_c_() = default; srs_tpc_pdcch_group_c_(const srs_tpc_pdcch_group_c_& other); srs_tpc_pdcch_group_c_& operator=(const srs_tpc_pdcch_group_c_& other); ~srs_tpc_pdcch_group_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters type_a_l_& type_a() { assert_choice_type(types::type_a, type_, "srs-TPC-PDCCH-Group"); return c.get(); } srs_tpc_pdcch_cfg_s& type_b() { assert_choice_type(types::type_b, type_, "srs-TPC-PDCCH-Group"); return c.get(); } const type_a_l_& type_a() const { assert_choice_type(types::type_a, type_, "srs-TPC-PDCCH-Group"); return c.get(); } const srs_tpc_pdcch_cfg_s& type_b() const { assert_choice_type(types::type_b, type_, "srs-TPC-PDCCH-Group"); return c.get(); } type_a_l_& set_type_a(); srs_tpc_pdcch_cfg_s& set_type_b(); private: types type_; choice_buffer_t c; void destroy_(); }; using monitoring_cells_l_ = bounded_array; // member variables bool ext = false; bool srs_switch_from_serv_cell_idx_present = false; bool srs_tpc_pdcch_group_present = false; bool monitoring_cells_present = false; uint8_t srs_switch_from_serv_cell_idx = 0; srs_switch_from_carrier_e_ srs_switch_from_carrier; srs_tpc_pdcch_group_c_ srs_tpc_pdcch_group; monitoring_cells_l_ monitoring_cells; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SlotFormatIndicator ::= SEQUENCE struct slot_format_ind_s { using slot_format_comb_to_add_mod_list_l_ = dyn_array; using slot_format_comb_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool slot_format_comb_to_add_mod_list_present = false; bool slot_format_comb_to_release_list_present = false; uint32_t sfi_rnti = 0; uint8_t dci_payload_size = 1; slot_format_comb_to_add_mod_list_l_ slot_format_comb_to_add_mod_list; slot_format_comb_to_release_list_l_ slot_format_comb_to_release_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // T-PollRetransmit ::= ENUMERATED struct t_poll_retx_opts { enum options { ms5, ms10, ms15, ms20, ms25, ms30, ms35, ms40, ms45, ms50, ms55, ms60, ms65, ms70, ms75, ms80, ms85, ms90, ms95, ms100, ms105, ms110, ms115, ms120, ms125, ms130, ms135, ms140, ms145, ms150, ms155, ms160, ms165, ms170, ms175, ms180, ms185, ms190, ms195, ms200, ms205, ms210, ms215, ms220, ms225, ms230, ms235, ms240, ms245, ms250, ms300, ms350, ms400, ms450, ms500, ms800, ms1000, ms2000, ms4000, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t_poll_retx_e; // T-Reassembly ::= ENUMERATED struct t_reassembly_opts { enum options { ms0, ms5, ms10, ms15, ms20, ms25, ms30, ms35, ms40, ms45, ms50, ms55, ms60, ms65, ms70, ms75, ms80, ms85, ms90, ms95, ms100, ms110, ms120, ms130, ms140, ms150, ms160, ms170, ms180, ms190, ms200, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated t_reassembly_e; // T-StatusProhibit ::= ENUMERATED struct t_status_prohibit_opts { enum options { ms0, ms5, ms10, ms15, ms20, ms25, ms30, ms35, ms40, ms45, ms50, ms55, ms60, ms65, ms70, ms75, ms80, ms85, ms90, ms95, ms100, ms105, ms110, ms115, ms120, ms125, ms130, ms135, ms140, ms145, ms150, ms155, ms160, ms165, ms170, ms175, ms180, ms185, ms190, ms195, ms200, ms205, ms210, ms215, ms220, ms225, ms230, ms235, ms240, ms245, ms250, ms300, ms350, ms400, ms450, ms500, ms800, ms1000, ms1200, ms1600, ms2000, ms2400, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t_status_prohibit_e; // TDD-UL-DL-SlotConfig ::= SEQUENCE struct tdd_ul_dl_slot_cfg_s { struct symbols_c_ { struct explicit_s_ { bool nrof_dl_symbols_present = false; bool nrof_ul_symbols_present = false; uint8_t nrof_dl_symbols = 1; uint8_t nrof_ul_symbols = 1; }; struct types_opts { enum options { all_dl, all_ul, explicit_type, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods symbols_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters explicit_s_& explicit_type() { assert_choice_type(types::explicit_type, type_, "symbols"); return c; } const explicit_s_& explicit_type() const { assert_choice_type(types::explicit_type, type_, "symbols"); return c; } void set_all_dl(); void set_all_ul(); explicit_s_& set_explicit_type(); private: types type_; explicit_s_ c; }; // member variables uint16_t slot_idx = 0; symbols_c_ symbols; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UplinkConfigCommon ::= SEQUENCE struct ul_cfg_common_s { bool freq_info_ul_present = false; bool init_ul_bwp_present = false; freq_info_ul_s freq_info_ul; bwp_ul_common_s init_ul_bwp; time_align_timer_e dummy; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CrossCarrierSchedulingConfig ::= SEQUENCE struct cross_carrier_sched_cfg_s { struct sched_cell_info_c_ { struct own_s_ { bool cif_presence = false; }; struct other_s_ { uint8_t sched_cell_id = 0; uint8_t cif_in_sched_cell = 1; }; struct types_opts { enum options { own, other, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods sched_cell_info_c_() = default; sched_cell_info_c_(const sched_cell_info_c_& other); sched_cell_info_c_& operator=(const sched_cell_info_c_& other); ~sched_cell_info_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters own_s_& own() { assert_choice_type(types::own, type_, "schedulingCellInfo"); return c.get(); } other_s_& other() { assert_choice_type(types::other, type_, "schedulingCellInfo"); return c.get(); } const own_s_& own() const { assert_choice_type(types::own, type_, "schedulingCellInfo"); return c.get(); } const other_s_& other() const { assert_choice_type(types::other, type_, "schedulingCellInfo"); return c.get(); } own_s_& set_own(); other_s_& set_other(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; sched_cell_info_c_ sched_cell_info; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DL-AM-RLC ::= SEQUENCE struct dl_am_rlc_s { bool sn_field_len_present = false; sn_field_len_am_e sn_field_len; t_reassembly_e t_reassembly; t_status_prohibit_e t_status_prohibit; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DL-UM-RLC ::= SEQUENCE struct dl_um_rlc_s { bool sn_field_len_present = false; sn_field_len_um_e sn_field_len; t_reassembly_e t_reassembly; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDCCH-ServingCellConfig ::= SEQUENCE struct pdcch_serving_cell_cfg_s { bool ext = false; bool slot_format_ind_present = false; setup_release_c slot_format_ind; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDSCH-ServingCellConfig ::= SEQUENCE struct pdsch_serving_cell_cfg_s { struct xoverhead_opts { enum options { xoh6, xoh12, xoh18, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated xoverhead_e_; struct nrof_harq_processes_for_pdsch_opts { enum options { n2, n4, n6, n10, n12, n16, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated nrof_harq_processes_for_pdsch_e_; // member variables bool ext = false; bool code_block_group_tx_present = false; bool xoverhead_present = false; bool nrof_harq_processes_for_pdsch_present = false; bool pucch_cell_present = false; setup_release_c code_block_group_tx; xoverhead_e_ xoverhead; nrof_harq_processes_for_pdsch_e_ nrof_harq_processes_for_pdsch; uint8_t pucch_cell = 0; // ... // group 0 bool max_mimo_layers_present = false; bool processing_type2_enabled_present = false; uint8_t max_mimo_layers = 1; bool processing_type2_enabled = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RACH-ConfigDedicated ::= SEQUENCE struct rach_cfg_ded_s { bool ext = false; bool cfra_present = false; bool ra_prioritization_present = false; cfra_s cfra; ra_prioritization_s ra_prioritization; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SchedulingRequestToAddMod ::= SEQUENCE struct sched_request_to_add_mod_s { struct sr_prohibit_timer_opts { enum options { ms1, ms2, ms4, ms8, ms16, ms32, ms64, ms128, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sr_prohibit_timer_e_; struct sr_trans_max_opts { enum options { n4, n8, n16, n32, n64, spare3, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated sr_trans_max_e_; // member variables bool sr_prohibit_timer_present = false; uint8_t sched_request_id = 0; sr_prohibit_timer_e_ sr_prohibit_timer; sr_trans_max_e_ sr_trans_max; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ServingCellConfigCommon ::= SEQUENCE struct serving_cell_cfg_common_s { struct n_timing_advance_offset_opts { enum options { n0, n25600, n39936, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated n_timing_advance_offset_e_; struct ssb_positions_in_burst_c_ { struct types_opts { enum options { short_bitmap, medium_bitmap, long_bitmap, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods ssb_positions_in_burst_c_() = default; ssb_positions_in_burst_c_(const ssb_positions_in_burst_c_& other); ssb_positions_in_burst_c_& operator=(const ssb_positions_in_burst_c_& other); ~ssb_positions_in_burst_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fixed_bitstring<4>& short_bitmap() { assert_choice_type(types::short_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } fixed_bitstring<8>& medium_bitmap() { assert_choice_type(types::medium_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } fixed_bitstring<64>& long_bitmap() { assert_choice_type(types::long_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } const fixed_bitstring<4>& short_bitmap() const { assert_choice_type(types::short_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } const fixed_bitstring<8>& medium_bitmap() const { assert_choice_type(types::medium_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } const fixed_bitstring<64>& long_bitmap() const { assert_choice_type(types::long_bitmap, type_, "ssb-PositionsInBurst"); return c.get >(); } fixed_bitstring<4>& set_short_bitmap(); fixed_bitstring<8>& set_medium_bitmap(); fixed_bitstring<64>& set_long_bitmap(); private: types type_; choice_buffer_t > c; void destroy_(); }; struct ssb_periodicity_serving_cell_opts { enum options { ms5, ms10, ms20, ms40, ms80, ms160, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ssb_periodicity_serving_cell_e_; struct dmrs_type_a_position_opts { enum options { pos2, pos3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated dmrs_type_a_position_e_; using rate_match_pattern_to_add_mod_list_l_ = dyn_array; using rate_match_pattern_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool pci_present = false; bool dl_cfg_common_present = false; bool ul_cfg_common_present = false; bool supplementary_ul_cfg_present = false; bool n_timing_advance_offset_present = false; bool ssb_positions_in_burst_present = false; bool ssb_periodicity_serving_cell_present = false; bool lte_crs_to_match_around_present = false; bool rate_match_pattern_to_add_mod_list_present = false; bool rate_match_pattern_to_release_list_present = false; bool ssb_subcarrier_spacing_present = false; bool tdd_ul_dl_cfg_common_present = false; uint16_t pci = 0; dl_cfg_common_s dl_cfg_common; ul_cfg_common_s ul_cfg_common; ul_cfg_common_s supplementary_ul_cfg; n_timing_advance_offset_e_ n_timing_advance_offset; ssb_positions_in_burst_c_ ssb_positions_in_burst; ssb_periodicity_serving_cell_e_ ssb_periodicity_serving_cell; dmrs_type_a_position_e_ dmrs_type_a_position; setup_release_c lte_crs_to_match_around; rate_match_pattern_to_add_mod_list_l_ rate_match_pattern_to_add_mod_list; rate_match_pattern_to_release_list_l_ rate_match_pattern_to_release_list; subcarrier_spacing_e ssb_subcarrier_spacing; tdd_ul_dl_cfg_common_s tdd_ul_dl_cfg_common; int8_t ss_pbch_block_pwr = -60; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TAG ::= SEQUENCE struct tag_s { bool ext = false; uint8_t tag_id = 0; time_align_timer_e time_align_timer; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TDD-UL-DL-ConfigDedicated ::= SEQUENCE struct tdd_ul_dl_cfg_ded_s { using slot_specific_cfgs_to_add_mod_list_l_ = dyn_array; using slot_specific_cfgs_to_release_list_l_ = dyn_array; // member variables bool ext = false; bool slot_specific_cfgs_to_add_mod_list_present = false; bool slot_specific_cfgs_to_release_list_present = false; slot_specific_cfgs_to_add_mod_list_l_ slot_specific_cfgs_to_add_mod_list; slot_specific_cfgs_to_release_list_l_ slot_specific_cfgs_to_release_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-AM-RLC ::= SEQUENCE struct ul_am_rlc_s { struct max_retx_thres_opts { enum options { t1, t2, t3, t4, t6, t8, t16, t32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_retx_thres_e_; // member variables bool sn_field_len_present = false; sn_field_len_am_e sn_field_len; t_poll_retx_e t_poll_retx; poll_pdu_e poll_pdu; poll_byte_e poll_byte; max_retx_thres_e_ max_retx_thres; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UL-UM-RLC ::= SEQUENCE struct ul_um_rlc_s { bool sn_field_len_present = false; sn_field_len_um_e sn_field_len; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UplinkConfig ::= SEQUENCE struct ul_cfg_s { using ul_bwp_to_release_list_l_ = bounded_array; using ul_bwp_to_add_mod_list_l_ = dyn_array; using ul_ch_bw_per_scs_list_l_ = dyn_array; // member variables bool ext = false; bool init_ul_bwp_present = false; bool ul_bwp_to_release_list_present = false; bool ul_bwp_to_add_mod_list_present = false; bool first_active_ul_bwp_id_present = false; bool pusch_serving_cell_cfg_present = false; bool carrier_switching_present = false; bwp_ul_ded_s init_ul_bwp; ul_bwp_to_release_list_l_ ul_bwp_to_release_list; ul_bwp_to_add_mod_list_l_ ul_bwp_to_add_mod_list; uint8_t first_active_ul_bwp_id = 0; setup_release_c pusch_serving_cell_cfg; setup_release_c carrier_switching; // ... // group 0 bool pwr_boost_pi2_bpsk_present = false; bool pwr_boost_pi2_bpsk = false; copy_ptr ul_ch_bw_per_scs_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BSR-Config ::= SEQUENCE struct bsr_cfg_s { struct periodic_bsr_timer_opts { enum options { sf1, sf5, sf10, sf16, sf20, sf32, sf40, sf64, sf80, sf128, sf160, sf320, sf640, sf1280, sf2560, infinity, nulltype } value; typedef int16_t number_type; const char* to_string() const; int16_t to_number() const; }; typedef enumerated periodic_bsr_timer_e_; struct retx_bsr_timer_opts { enum options { sf10, sf20, sf40, sf80, sf160, sf320, sf640, sf1280, sf2560, sf5120, sf10240, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated retx_bsr_timer_e_; struct lc_ch_sr_delay_timer_opts { enum options { sf20, sf40, sf64, sf128, sf512, sf1024, sf2560, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated lc_ch_sr_delay_timer_e_; // member variables bool ext = false; bool lc_ch_sr_delay_timer_present = false; periodic_bsr_timer_e_ periodic_bsr_timer; retx_bsr_timer_e_ retx_bsr_timer; lc_ch_sr_delay_timer_e_ lc_ch_sr_delay_timer; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRX-Config ::= SEQUENCE struct drx_cfg_s { struct drx_on_dur_timer_c_ { struct milli_seconds_opts { enum options { ms1, ms2, ms3, ms4, ms5, ms6, ms8, ms10, ms20, ms30, ms40, ms50, ms60, ms80, ms100, ms200, ms300, ms400, ms500, ms600, ms800, ms1000, ms1200, ms1600, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated milli_seconds_e_; struct types_opts { enum options { sub_milli_seconds, milli_seconds, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods drx_on_dur_timer_c_() = default; drx_on_dur_timer_c_(const drx_on_dur_timer_c_& other); drx_on_dur_timer_c_& operator=(const drx_on_dur_timer_c_& other); ~drx_on_dur_timer_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& sub_milli_seconds() { assert_choice_type(types::sub_milli_seconds, type_, "drx-onDurationTimer"); return c.get(); } milli_seconds_e_& milli_seconds() { assert_choice_type(types::milli_seconds, type_, "drx-onDurationTimer"); return c.get(); } const uint8_t& sub_milli_seconds() const { assert_choice_type(types::sub_milli_seconds, type_, "drx-onDurationTimer"); return c.get(); } const milli_seconds_e_& milli_seconds() const { assert_choice_type(types::milli_seconds, type_, "drx-onDurationTimer"); return c.get(); } uint8_t& set_sub_milli_seconds(); milli_seconds_e_& set_milli_seconds(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct drx_inactivity_timer_opts { enum options { ms0, ms1, ms2, ms3, ms4, ms5, ms6, ms8, ms10, ms20, ms30, ms40, ms50, ms60, ms80, ms100, ms200, ms300, ms500, ms750, ms1280, ms1920, ms2560, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated drx_inactivity_timer_e_; struct drx_retx_timer_dl_opts { enum options { sl0, sl1, sl2, sl4, sl6, sl8, sl16, sl24, sl33, sl40, sl64, sl80, sl96, sl112, sl128, sl160, sl320, spare15, spare14, spare13, spare12, spare11, spare10, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated drx_retx_timer_dl_e_; struct drx_retx_timer_ul_opts { enum options { sl0, sl1, sl2, sl4, sl6, sl8, sl16, sl24, sl33, sl40, sl64, sl80, sl96, sl112, sl128, sl160, sl320, spare15, spare14, spare13, spare12, spare11, spare10, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated drx_retx_timer_ul_e_; struct drx_long_cycle_start_offset_c_ { struct types_opts { enum options { ms10, ms20, ms32, ms40, ms60, ms64, ms70, ms80, ms128, ms160, ms256, ms320, ms512, ms640, ms1024, ms1280, ms2048, ms2560, ms5120, ms10240, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods drx_long_cycle_start_offset_c_() = default; drx_long_cycle_start_offset_c_(const drx_long_cycle_start_offset_c_& other); drx_long_cycle_start_offset_c_& operator=(const drx_long_cycle_start_offset_c_& other); ~drx_long_cycle_start_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ms10() { assert_choice_type(types::ms10, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms20() { assert_choice_type(types::ms20, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms32() { assert_choice_type(types::ms32, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms40() { assert_choice_type(types::ms40, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms60() { assert_choice_type(types::ms60, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms64() { assert_choice_type(types::ms64, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms70() { assert_choice_type(types::ms70, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms80() { assert_choice_type(types::ms80, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms128() { assert_choice_type(types::ms128, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms160() { assert_choice_type(types::ms160, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms256() { assert_choice_type(types::ms256, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms320() { assert_choice_type(types::ms320, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms512() { assert_choice_type(types::ms512, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms640() { assert_choice_type(types::ms640, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms1024() { assert_choice_type(types::ms1024, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms1280() { assert_choice_type(types::ms1280, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms2048() { assert_choice_type(types::ms2048, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms2560() { assert_choice_type(types::ms2560, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms5120() { assert_choice_type(types::ms5120, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms10240() { assert_choice_type(types::ms10240, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms10() const { assert_choice_type(types::ms10, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms20() const { assert_choice_type(types::ms20, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms32() const { assert_choice_type(types::ms32, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms40() const { assert_choice_type(types::ms40, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms60() const { assert_choice_type(types::ms60, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms64() const { assert_choice_type(types::ms64, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms70() const { assert_choice_type(types::ms70, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms80() const { assert_choice_type(types::ms80, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms128() const { assert_choice_type(types::ms128, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms160() const { assert_choice_type(types::ms160, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms256() const { assert_choice_type(types::ms256, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms320() const { assert_choice_type(types::ms320, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms512() const { assert_choice_type(types::ms512, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms640() const { assert_choice_type(types::ms640, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms1024() const { assert_choice_type(types::ms1024, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms1280() const { assert_choice_type(types::ms1280, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms2048() const { assert_choice_type(types::ms2048, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms2560() const { assert_choice_type(types::ms2560, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms5120() const { assert_choice_type(types::ms5120, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms10240() const { assert_choice_type(types::ms10240, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& set_ms10(); uint8_t& set_ms20(); uint8_t& set_ms32(); uint8_t& set_ms40(); uint8_t& set_ms60(); uint8_t& set_ms64(); uint8_t& set_ms70(); uint8_t& set_ms80(); uint8_t& set_ms128(); uint8_t& set_ms160(); uint16_t& set_ms256(); uint16_t& set_ms320(); uint16_t& set_ms512(); uint16_t& set_ms640(); uint16_t& set_ms1024(); uint16_t& set_ms1280(); uint16_t& set_ms2048(); uint16_t& set_ms2560(); uint16_t& set_ms5120(); uint16_t& set_ms10240(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct short_drx_s_ { struct drx_short_cycle_opts { enum options { ms2, ms3, ms4, ms5, ms6, ms7, ms8, ms10, ms14, ms16, ms20, ms30, ms32, ms35, ms40, ms64, ms80, ms128, ms160, ms256, ms320, ms512, ms640, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated drx_short_cycle_e_; // member variables drx_short_cycle_e_ drx_short_cycle; uint8_t drx_short_cycle_timer = 1; }; // member variables bool short_drx_present = false; drx_on_dur_timer_c_ drx_on_dur_timer; drx_inactivity_timer_e_ drx_inactivity_timer; uint8_t drx_harq_rtt_timer_dl = 0; uint8_t drx_harq_rtt_timer_ul = 0; drx_retx_timer_dl_e_ drx_retx_timer_dl; drx_retx_timer_ul_e_ drx_retx_timer_ul; drx_long_cycle_start_offset_c_ drx_long_cycle_start_offset; short_drx_s_ short_drx; uint8_t drx_slot_offset = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DataInactivityTimer ::= ENUMERATED struct data_inactivity_timer_opts { enum options { s1, s2, s3, s5, s7, s10, s15, s20, s40, s50, s60, s80, s100, s120, s150, s180, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated data_inactivity_timer_e; // LogicalChannelConfig ::= SEQUENCE struct lc_ch_cfg_s { struct ul_specific_params_s_ { struct prioritised_bit_rate_opts { enum options { kbps0, kbps8, kbps16, kbps32, kbps64, kbps128, kbps256, kbps512, kbps1024, kbps2048, kbps4096, kbps8192, kbps16384, kbps32768, kbps65536, infinity, nulltype } value; typedef int32_t number_type; const char* to_string() const; int32_t to_number() const; }; typedef enumerated prioritised_bit_rate_e_; struct bucket_size_dur_opts { enum options { ms5, ms10, ms20, ms50, ms100, ms150, ms300, ms500, ms1000, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated bucket_size_dur_e_; using allowed_serving_cells_l_ = bounded_array; using allowed_scs_list_l_ = bounded_array; struct max_pusch_dur_opts { enum options { ms0p02, ms0p04, ms0p0625, ms0p125, ms0p25, ms0p5, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated max_pusch_dur_e_; struct bit_rate_query_prohibit_timer_opts { enum options { s0, s0dot4, s0dot8, s1dot6, s3, s6, s12, s30, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated bit_rate_query_prohibit_timer_e_; // member variables bool ext = false; bool allowed_serving_cells_present = false; bool allowed_scs_list_present = false; bool max_pusch_dur_present = false; bool cfgured_grant_type1_allowed_present = false; bool lc_ch_group_present = false; bool sched_request_id_present = false; uint8_t prio = 1; prioritised_bit_rate_e_ prioritised_bit_rate; bucket_size_dur_e_ bucket_size_dur; allowed_serving_cells_l_ allowed_serving_cells; allowed_scs_list_l_ allowed_scs_list; max_pusch_dur_e_ max_pusch_dur; uint8_t lc_ch_group = 0; uint8_t sched_request_id = 0; bool lc_ch_sr_mask = false; bool lc_ch_sr_delay_timer_applied = false; // ... bool bit_rate_query_prohibit_timer_present = false; bit_rate_query_prohibit_timer_e_ bit_rate_query_prohibit_timer; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // member variables bool ext = false; bool ul_specific_params_present = false; ul_specific_params_s_ ul_specific_params; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PHR-Config ::= SEQUENCE struct phr_cfg_s { struct phr_periodic_timer_opts { enum options { sf10, sf20, sf50, sf100, sf200, sf500, sf1000, infinity, nulltype } value; typedef int16_t number_type; const char* to_string() const; int16_t to_number() const; }; typedef enumerated phr_periodic_timer_e_; struct phr_prohibit_timer_opts { enum options { sf0, sf10, sf20, sf50, sf100, sf200, sf500, sf1000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated phr_prohibit_timer_e_; struct phr_tx_pwr_factor_change_opts { enum options { db1, db3, db6, infinity, nulltype } value; typedef int8_t number_type; const char* to_string() const; int8_t to_number() const; }; typedef enumerated phr_tx_pwr_factor_change_e_; struct phr_mode_other_cg_opts { enum options { real, virtual_value, nulltype } value; const char* to_string() const; }; typedef enumerated phr_mode_other_cg_e_; // member variables bool ext = false; phr_periodic_timer_e_ phr_periodic_timer; phr_prohibit_timer_e_ phr_prohibit_timer; phr_tx_pwr_factor_change_e_ phr_tx_pwr_factor_change; bool multiple_phr = false; bool dummy = false; bool phr_type2_other_cell = false; phr_mode_other_cg_e_ phr_mode_other_cg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RLC-Config ::= CHOICE struct rlc_cfg_c { struct am_s_ { ul_am_rlc_s ul_am_rlc; dl_am_rlc_s dl_am_rlc; }; struct um_bi_dir_s_ { ul_um_rlc_s ul_um_rlc; dl_um_rlc_s dl_um_rlc; }; struct um_uni_dir_ul_s_ { ul_um_rlc_s ul_um_rlc; }; struct um_uni_dir_dl_s_ { dl_um_rlc_s dl_um_rlc; }; struct types_opts { enum options { am, um_bi_dir, um_uni_dir_ul, um_uni_dir_dl, /*...*/ nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods rlc_cfg_c() = default; rlc_cfg_c(const rlc_cfg_c& other); rlc_cfg_c& operator=(const rlc_cfg_c& other); ~rlc_cfg_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters am_s_& am() { assert_choice_type(types::am, type_, "RLC-Config"); return c.get(); } um_bi_dir_s_& um_bi_dir() { assert_choice_type(types::um_bi_dir, type_, "RLC-Config"); return c.get(); } um_uni_dir_ul_s_& um_uni_dir_ul() { assert_choice_type(types::um_uni_dir_ul, type_, "RLC-Config"); return c.get(); } um_uni_dir_dl_s_& um_uni_dir_dl() { assert_choice_type(types::um_uni_dir_dl, type_, "RLC-Config"); return c.get(); } const am_s_& am() const { assert_choice_type(types::am, type_, "RLC-Config"); return c.get(); } const um_bi_dir_s_& um_bi_dir() const { assert_choice_type(types::um_bi_dir, type_, "RLC-Config"); return c.get(); } const um_uni_dir_ul_s_& um_uni_dir_ul() const { assert_choice_type(types::um_uni_dir_ul, type_, "RLC-Config"); return c.get(); } const um_uni_dir_dl_s_& um_uni_dir_dl() const { assert_choice_type(types::um_uni_dir_dl, type_, "RLC-Config"); return c.get(); } am_s_& set_am(); um_bi_dir_s_& set_um_bi_dir(); um_uni_dir_ul_s_& set_um_uni_dir_ul(); um_uni_dir_dl_s_& set_um_uni_dir_dl(); private: types type_; choice_buffer_t c; void destroy_(); }; // RLF-TimersAndConstants ::= SEQUENCE struct rlf_timers_and_consts_s { struct t310_opts { enum options { ms0, ms50, ms100, ms200, ms500, ms1000, ms2000, ms4000, ms6000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t310_e_; struct n310_opts { enum options { n1, n2, n3, n4, n6, n8, n10, n20, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated n310_e_; struct n311_opts { enum options { n1, n2, n3, n4, n5, n6, n8, n10, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated n311_e_; struct t311_opts { enum options { ms1000, ms3000, ms5000, ms10000, ms15000, ms20000, ms30000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t311_e_; // member variables bool ext = false; t310_e_ t310; n310_e_ n310; n311_e_ n311; // ... // group 0 t311_e_ t311; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReconfigurationWithSync ::= SEQUENCE struct recfg_with_sync_s { struct t304_opts { enum options { ms50, ms100, ms150, ms200, ms500, ms1000, ms2000, ms10000, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated t304_e_; struct rach_cfg_ded_c_ { struct types_opts { enum options { ul, supplementary_ul, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods rach_cfg_ded_c_() = default; rach_cfg_ded_c_(const rach_cfg_ded_c_& other); rach_cfg_ded_c_& operator=(const rach_cfg_ded_c_& other); ~rach_cfg_ded_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters rach_cfg_ded_s& ul() { assert_choice_type(types::ul, type_, "rach-ConfigDedicated"); return c.get(); } rach_cfg_ded_s& supplementary_ul() { assert_choice_type(types::supplementary_ul, type_, "rach-ConfigDedicated"); return c.get(); } const rach_cfg_ded_s& ul() const { assert_choice_type(types::ul, type_, "rach-ConfigDedicated"); return c.get(); } const rach_cfg_ded_s& supplementary_ul() const { assert_choice_type(types::supplementary_ul, type_, "rach-ConfigDedicated"); return c.get(); } rach_cfg_ded_s& set_ul(); rach_cfg_ded_s& set_supplementary_ul(); private: types type_; choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool sp_cell_cfg_common_present = false; bool rach_cfg_ded_present = false; serving_cell_cfg_common_s sp_cell_cfg_common; uint32_t new_ue_id = 0; t304_e_ t304; rach_cfg_ded_c_ rach_cfg_ded; // ... // group 0 copy_ptr smtc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SchedulingRequestConfig ::= SEQUENCE struct sched_request_cfg_s { using sched_request_to_add_mod_list_l_ = dyn_array; using sched_request_to_release_list_l_ = bounded_array; // member variables bool sched_request_to_add_mod_list_present = false; bool sched_request_to_release_list_present = false; sched_request_to_add_mod_list_l_ sched_request_to_add_mod_list; sched_request_to_release_list_l_ sched_request_to_release_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ServingCellConfig ::= SEQUENCE struct serving_cell_cfg_s { using dl_bwp_to_release_list_l_ = bounded_array; using dl_bwp_to_add_mod_list_l_ = dyn_array; struct bwp_inactivity_timer_opts { enum options { ms2, ms3, ms4, ms5, ms6, ms8, ms10, ms20, ms30, ms40, ms50, ms60, ms80, ms100, ms200, ms300, ms500, ms750, ms1280, ms1920, ms2560, spare10, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated bwp_inactivity_timer_e_; struct scell_deactivation_timer_opts { enum options { ms20, ms40, ms80, ms160, ms200, ms240, ms320, ms400, ms480, ms520, ms640, ms720, ms840, ms1280, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated scell_deactivation_timer_e_; struct pathloss_ref_linking_opts { enum options { sp_cell, scell, nulltype } value; const char* to_string() const; }; typedef enumerated pathloss_ref_linking_e_; using rate_match_pattern_to_add_mod_list_l_ = dyn_array; using rate_match_pattern_to_release_list_l_ = bounded_array; using dl_ch_bw_per_scs_list_l_ = dyn_array; // member variables bool ext = false; bool tdd_ul_dl_cfg_ded_present = false; bool init_dl_bwp_present = false; bool dl_bwp_to_release_list_present = false; bool dl_bwp_to_add_mod_list_present = false; bool first_active_dl_bwp_id_present = false; bool bwp_inactivity_timer_present = false; bool default_dl_bwp_id_present = false; bool ul_cfg_present = false; bool supplementary_ul_present = false; bool pdcch_serving_cell_cfg_present = false; bool pdsch_serving_cell_cfg_present = false; bool csi_meas_cfg_present = false; bool scell_deactivation_timer_present = false; bool cross_carrier_sched_cfg_present = false; bool dummy_present = false; bool pathloss_ref_linking_present = false; bool serving_cell_mo_present = false; tdd_ul_dl_cfg_ded_s tdd_ul_dl_cfg_ded; bwp_dl_ded_s init_dl_bwp; dl_bwp_to_release_list_l_ dl_bwp_to_release_list; dl_bwp_to_add_mod_list_l_ dl_bwp_to_add_mod_list; uint8_t first_active_dl_bwp_id = 0; bwp_inactivity_timer_e_ bwp_inactivity_timer; uint8_t default_dl_bwp_id = 0; ul_cfg_s ul_cfg; ul_cfg_s supplementary_ul; setup_release_c pdcch_serving_cell_cfg; setup_release_c pdsch_serving_cell_cfg; setup_release_c csi_meas_cfg; scell_deactivation_timer_e_ scell_deactivation_timer; cross_carrier_sched_cfg_s cross_carrier_sched_cfg; uint8_t tag_id = 0; pathloss_ref_linking_e_ pathloss_ref_linking; uint8_t serving_cell_mo = 1; // ... // group 0 copy_ptr > lte_crs_to_match_around; copy_ptr rate_match_pattern_to_add_mod_list; copy_ptr rate_match_pattern_to_release_list; copy_ptr dl_ch_bw_per_scs_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // TAG-Config ::= SEQUENCE struct tag_cfg_s { using tag_to_release_list_l_ = bounded_array; using tag_to_add_mod_list_l_ = dyn_array; // member variables bool tag_to_release_list_present = false; bool tag_to_add_mod_list_present = false; tag_to_release_list_l_ tag_to_release_list; tag_to_add_mod_list_l_ tag_to_add_mod_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MAC-CellGroupConfig ::= SEQUENCE struct mac_cell_group_cfg_s { bool ext = false; bool drx_cfg_present = false; bool sched_request_cfg_present = false; bool bsr_cfg_present = false; bool tag_cfg_present = false; bool phr_cfg_present = false; setup_release_c drx_cfg; sched_request_cfg_s sched_request_cfg; bsr_cfg_s bsr_cfg; tag_cfg_s tag_cfg; setup_release_c phr_cfg; bool skip_ul_tx_dynamic = false; // ... // group 0 bool csi_mask_present = false; bool csi_mask = false; copy_ptr > data_inactivity_timer; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PhysicalCellGroupConfig ::= SEQUENCE struct phys_cell_group_cfg_s { struct pdsch_harq_ack_codebook_opts { enum options { semi_static, dynamic_value, nulltype } value; const char* to_string() const; }; typedef enumerated pdsch_harq_ack_codebook_e_; struct xscale_opts { enum options { db0, db6, spare2, spare1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated xscale_e_; // member variables bool ext = false; bool harq_ack_spatial_bundling_pucch_present = false; bool harq_ack_spatial_bundling_pusch_present = false; bool p_nr_fr1_present = false; bool tpc_srs_rnti_present = false; bool tpc_pucch_rnti_present = false; bool tpc_pusch_rnti_present = false; bool sp_csi_rnti_present = false; bool cs_rnti_present = false; int8_t p_nr_fr1 = -30; pdsch_harq_ack_codebook_e_ pdsch_harq_ack_codebook; uint32_t tpc_srs_rnti = 0; uint32_t tpc_pucch_rnti = 0; uint32_t tpc_pusch_rnti = 0; uint32_t sp_csi_rnti = 0; setup_release_c > cs_rnti; // ... // group 0 bool mcs_c_rnti_present = false; bool p_ue_fr1_present = false; uint32_t mcs_c_rnti = 0; int8_t p_ue_fr1 = -30; // group 1 bool xscale_present = false; xscale_e_ xscale; // group 2 copy_ptr > > pdcch_blind_detection; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RLC-BearerConfig ::= SEQUENCE struct rlc_bearer_cfg_s { struct served_radio_bearer_c_ { struct types_opts { enum options { srb_id, drb_id, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods served_radio_bearer_c_() = default; served_radio_bearer_c_(const served_radio_bearer_c_& other); served_radio_bearer_c_& operator=(const served_radio_bearer_c_& other); ~served_radio_bearer_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& srb_id() { assert_choice_type(types::srb_id, type_, "servedRadioBearer"); return c.get(); } uint8_t& drb_id() { assert_choice_type(types::drb_id, type_, "servedRadioBearer"); return c.get(); } const uint8_t& srb_id() const { assert_choice_type(types::srb_id, type_, "servedRadioBearer"); return c.get(); } const uint8_t& drb_id() const { assert_choice_type(types::drb_id, type_, "servedRadioBearer"); return c.get(); } uint8_t& set_srb_id(); uint8_t& set_drb_id(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables bool ext = false; bool served_radio_bearer_present = false; bool reestablish_rlc_present = false; bool rlc_cfg_present = false; bool mac_lc_ch_cfg_present = false; uint8_t lc_ch_id = 1; served_radio_bearer_c_ served_radio_bearer; rlc_cfg_c rlc_cfg; lc_ch_cfg_s mac_lc_ch_cfg; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SCellConfig ::= SEQUENCE struct scell_cfg_s { bool ext = false; bool scell_cfg_common_present = false; bool scell_cfg_ded_present = false; uint8_t scell_idx = 1; serving_cell_cfg_common_s scell_cfg_common; serving_cell_cfg_s scell_cfg_ded; // ... // group 0 copy_ptr smtc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SpCellConfig ::= SEQUENCE struct sp_cell_cfg_s { bool ext = false; bool serv_cell_idx_present = false; bool recfg_with_sync_present = false; bool rlf_timers_and_consts_present = false; bool rlm_in_sync_out_of_sync_thres_present = false; bool sp_cell_cfg_ded_present = false; uint8_t serv_cell_idx = 0; recfg_with_sync_s recfg_with_sync; setup_release_c rlf_timers_and_consts; serving_cell_cfg_s sp_cell_cfg_ded; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CellGroupConfig ::= SEQUENCE struct cell_group_cfg_s { using rlc_bearer_to_add_mod_list_l_ = dyn_array; using rlc_bearer_to_release_list_l_ = bounded_array; using scell_to_add_mod_list_l_ = dyn_array; using scell_to_release_list_l_ = bounded_array; // member variables bool ext = false; bool rlc_bearer_to_add_mod_list_present = false; bool rlc_bearer_to_release_list_present = false; bool mac_cell_group_cfg_present = false; bool phys_cell_group_cfg_present = false; bool sp_cell_cfg_present = false; bool scell_to_add_mod_list_present = false; bool scell_to_release_list_present = false; uint8_t cell_group_id = 0; rlc_bearer_to_add_mod_list_l_ rlc_bearer_to_add_mod_list; rlc_bearer_to_release_list_l_ rlc_bearer_to_release_list; mac_cell_group_cfg_s mac_cell_group_cfg; phys_cell_group_cfg_s phys_cell_group_cfg; sp_cell_cfg_s sp_cell_cfg; scell_to_add_mod_list_l_ scell_to_add_mod_list; scell_to_release_list_l_ scell_to_release_list; // ... // group 0 bool report_ul_tx_direct_current_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-ParametersCommon ::= SEQUENCE struct eutra_params_common_s { bool ext = false; bool mfbi_eutra_present = false; bool modified_mpr_behavior_eutra_present = false; bool multi_ns_pmax_eutra_present = false; bool rs_sinr_meas_eutra_present = false; fixed_bitstring<32> modified_mpr_behavior_eutra; // ... // group 0 bool ne_dc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-ParametersXDD-Diff ::= SEQUENCE struct eutra_params_xdd_diff_s { bool ext = false; bool rsrq_meas_wideband_eutra_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // EUTRA-Parameters ::= SEQUENCE struct eutra_params_s { using supported_band_list_eutra_l_ = dyn_array; // member variables bool ext = false; bool eutra_params_common_present = false; bool eutra_params_xdd_diff_present = false; supported_band_list_eutra_l_ supported_band_list_eutra; eutra_params_common_s eutra_params_common; eutra_params_xdd_diff_s eutra_params_xdd_diff; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSet ::= CHOICE struct feature_set_c { struct eutra_s_ { uint16_t dl_set_eutra = 0; uint16_t ul_set_eutra = 0; }; struct nr_s_ { uint16_t dl_set_nr = 0; uint16_t ul_set_nr = 0; }; struct types_opts { enum options { eutra, nr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods feature_set_c() = default; feature_set_c(const feature_set_c& other); feature_set_c& operator=(const feature_set_c& other); ~feature_set_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters eutra_s_& eutra() { assert_choice_type(types::eutra, type_, "FeatureSet"); return c.get(); } nr_s_& nr() { assert_choice_type(types::nr, type_, "FeatureSet"); return c.get(); } const eutra_s_& eutra() const { assert_choice_type(types::eutra, type_, "FeatureSet"); return c.get(); } const nr_s_& nr() const { assert_choice_type(types::nr, type_, "FeatureSet"); return c.get(); } eutra_s_& set_eutra(); nr_s_& set_nr(); private: types type_; choice_buffer_t c; void destroy_(); }; // FeatureSetsPerBand ::= SEQUENCE (SIZE (1..128)) OF FeatureSet using feature_sets_per_band_l = dyn_array; // FeatureSetCombination ::= SEQUENCE (SIZE (1..32)) OF FeatureSetsPerBand using feature_set_combination_l = dyn_array; // DummyA ::= SEQUENCE struct dummy_a_s { struct max_num_ports_across_nzp_csi_rs_per_cc_opts { enum options { p2, p4, p8, p12, p16, p24, p32, p40, p48, p56, p64, p72, p80, p88, p96, p104, p112, p120, p128, p136, p144, p152, p160, p168, p176, p184, p192, p200, p208, p216, p224, p232, p240, p248, p256, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated max_num_ports_across_nzp_csi_rs_per_cc_e_; struct max_num_cs_im_per_cc_opts { enum options { n1, n2, n4, n8, n16, n32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_cs_im_per_cc_e_; struct max_num_simul_csi_rs_act_bwp_all_cc_opts { enum options { n5, n6, n7, n8, n9, n10, n12, n14, n16, n18, n20, n22, n24, n26, n28, n30, n32, n34, n36, n38, n40, n42, n44, n46, n48, n50, n52, n54, n56, n58, n60, n62, n64, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_simul_csi_rs_act_bwp_all_cc_e_; struct total_num_ports_simul_csi_rs_act_bwp_all_cc_opts { enum options { p8, p12, p16, p24, p32, p40, p48, p56, p64, p72, p80, p88, p96, p104, p112, p120, p128, p136, p144, p152, p160, p168, p176, p184, p192, p200, p208, p216, p224, p232, p240, p248, p256, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated total_num_ports_simul_csi_rs_act_bwp_all_cc_e_; // member variables uint8_t max_num_nzp_csi_rs_per_cc = 1; max_num_ports_across_nzp_csi_rs_per_cc_e_ max_num_ports_across_nzp_csi_rs_per_cc; max_num_cs_im_per_cc_e_ max_num_cs_im_per_cc; max_num_simul_csi_rs_act_bwp_all_cc_e_ max_num_simul_csi_rs_act_bwp_all_cc; total_num_ports_simul_csi_rs_act_bwp_all_cc_e_ total_num_ports_simul_csi_rs_act_bwp_all_cc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyB ::= SEQUENCE struct dummy_b_s { struct max_num_tx_ports_per_res_opts { enum options { p2, p4, p8, p12, p16, p24, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_tx_ports_per_res_e_; struct supported_codebook_mode_opts { enum options { mode1, mode1_and_mode2, nulltype } value; const char* to_string() const; }; typedef enumerated supported_codebook_mode_e_; // member variables max_num_tx_ports_per_res_e_ max_num_tx_ports_per_res; uint8_t max_num_res = 1; uint16_t total_num_tx_ports = 2; supported_codebook_mode_e_ supported_codebook_mode; uint8_t max_num_csi_rs_per_res_set = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyC ::= SEQUENCE struct dummy_c_s { struct max_num_tx_ports_per_res_opts { enum options { p8, p16, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_tx_ports_per_res_e_; struct supported_codebook_mode_opts { enum options { mode1, mode2, both, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated supported_codebook_mode_e_; struct supported_num_panels_opts { enum options { n2, n4, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated supported_num_panels_e_; // member variables max_num_tx_ports_per_res_e_ max_num_tx_ports_per_res; uint8_t max_num_res = 1; uint16_t total_num_tx_ports = 2; supported_codebook_mode_e_ supported_codebook_mode; supported_num_panels_e_ supported_num_panels; uint8_t max_num_csi_rs_per_res_set = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyD ::= SEQUENCE struct dummy_d_s { struct max_num_tx_ports_per_res_opts { enum options { p4, p8, p12, p16, p24, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_tx_ports_per_res_e_; struct amplitude_scaling_type_opts { enum options { wideband, wideband_and_subband, nulltype } value; const char* to_string() const; }; typedef enumerated amplitude_scaling_type_e_; // member variables bool amplitude_subset_restrict_present = false; max_num_tx_ports_per_res_e_ max_num_tx_ports_per_res; uint8_t max_num_res = 1; uint16_t total_num_tx_ports = 2; uint8_t param_lx = 2; amplitude_scaling_type_e_ amplitude_scaling_type; uint8_t max_num_csi_rs_per_res_set = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyE ::= SEQUENCE struct dummy_e_s { struct max_num_tx_ports_per_res_opts { enum options { p4, p8, p12, p16, p24, p32, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_tx_ports_per_res_e_; struct amplitude_scaling_type_opts { enum options { wideband, wideband_and_subband, nulltype } value; const char* to_string() const; }; typedef enumerated amplitude_scaling_type_e_; // member variables max_num_tx_ports_per_res_e_ max_num_tx_ports_per_res; uint8_t max_num_res = 1; uint16_t total_num_tx_ports = 2; uint8_t param_lx = 2; amplitude_scaling_type_e_ amplitude_scaling_type; uint8_t max_num_csi_rs_per_res_set = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqSeparationClass ::= ENUMERATED struct freq_separation_class_opts { enum options { c1, c2, c3, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated freq_separation_class_e; // FeatureSetDownlink ::= SEQUENCE struct feature_set_dl_s { using feature_set_list_per_dl_cc_l_ = bounded_array; struct scaling_factor_opts { enum options { f0p4, f0p75, f0p8, nulltype } value; const char* to_string() const; }; typedef enumerated scaling_factor_e_; struct pdcch_monitoring_any_occasions_opts { enum options { without_dci_gap, with_dci_gap, nulltype } value; const char* to_string() const; }; typedef enumerated pdcch_monitoring_any_occasions_e_; struct time_dur_for_qcl_s_ { struct scs_minus60k_hz_opts { enum options { s7, s14, s28, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { s14, s28, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; struct pdsch_processing_type1_different_tb_per_slot_s_ { struct scs_minus15k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus15k_hz_e_; struct scs_minus30k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus30k_hz_e_; struct scs_minus60k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus15k_hz_e_ scs_minus15k_hz; scs_minus30k_hz_e_ scs_minus30k_hz; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; using dummy4_l_ = dyn_array; using dummy5_l_ = dyn_array; using dummy6_l_ = dyn_array; using dummy7_l_ = dyn_array; // member variables bool intra_band_freq_separation_dl_present = false; bool scaling_factor_present = false; bool cross_carrier_sched_other_scs_present = false; bool scell_without_ssb_present = false; bool csi_rs_meas_scell_without_ssb_present = false; bool dummy1_present = false; bool type1_minus3_css_present = false; bool pdcch_monitoring_any_occasions_present = false; bool dummy2_present = false; bool ue_specific_ul_dl_assign_present = false; bool search_space_sharing_ca_dl_present = false; bool time_dur_for_qcl_present = false; bool pdsch_processing_type1_different_tb_per_slot_present = false; bool dummy3_present = false; bool dummy4_present = false; bool dummy5_present = false; bool dummy6_present = false; bool dummy7_present = false; feature_set_list_per_dl_cc_l_ feature_set_list_per_dl_cc; freq_separation_class_e intra_band_freq_separation_dl; scaling_factor_e_ scaling_factor; pdcch_monitoring_any_occasions_e_ pdcch_monitoring_any_occasions; time_dur_for_qcl_s_ time_dur_for_qcl; pdsch_processing_type1_different_tb_per_slot_s_ pdsch_processing_type1_different_tb_per_slot; dummy_a_s dummy3; dummy4_l_ dummy4; dummy5_l_ dummy5; dummy6_l_ dummy6; dummy7_l_ dummy7; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ProcessingParameters ::= SEQUENCE struct processing_params_s { struct fallback_opts { enum options { sc, cap1_only, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated fallback_e_; struct different_tb_per_slot_s_ { bool upto1_present = false; bool upto2_present = false; bool upto4_present = false; bool upto7_present = false; uint8_t upto1 = 1; uint8_t upto2 = 1; uint8_t upto4 = 1; uint8_t upto7 = 1; }; // member variables bool different_tb_per_slot_present = false; fallback_e_ fallback; different_tb_per_slot_s_ different_tb_per_slot; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetDownlink-v1540 ::= SEQUENCE struct feature_set_dl_v1540_s { struct pdcch_monitoring_any_occasions_with_span_gap_s_ { struct scs_minus15k_hz_opts { enum options { set1, set2, set3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus15k_hz_e_; struct scs_minus30k_hz_opts { enum options { set1, set2, set3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus30k_hz_e_; struct scs_minus60k_hz_opts { enum options { set1, set2, set3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { set1, set2, set3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus15k_hz_e_ scs_minus15k_hz; scs_minus30k_hz_e_ scs_minus30k_hz; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; struct pdsch_processing_type2_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; processing_params_s scs_minus15k_hz; processing_params_s scs_minus30k_hz; processing_params_s scs_minus60k_hz; }; struct pdsch_processing_type2_limited_s_ { struct different_tb_per_slot_scs_minus30k_hz_opts { enum options { upto1, upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated different_tb_per_slot_scs_minus30k_hz_e_; // member variables different_tb_per_slot_scs_minus30k_hz_e_ different_tb_per_slot_scs_minus30k_hz; }; // member variables bool one_fl_dmrs_two_add_dmrs_dl_present = false; bool add_dmrs_dl_alt_present = false; bool two_fl_dmrs_two_add_dmrs_dl_present = false; bool one_fl_dmrs_three_add_dmrs_dl_present = false; bool pdcch_monitoring_any_occasions_with_span_gap_present = false; bool pdsch_separation_with_gap_present = false; bool pdsch_processing_type2_present = false; bool pdsch_processing_type2_limited_present = false; bool dl_mcs_table_alt_dynamic_ind_present = false; pdcch_monitoring_any_occasions_with_span_gap_s_ pdcch_monitoring_any_occasions_with_span_gap; pdsch_processing_type2_s_ pdsch_processing_type2; pdsch_processing_type2_limited_s_ pdsch_processing_type2_limited; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetDownlink-v15a0 ::= SEQUENCE struct feature_set_dl_v15a0_s { bool supported_srs_res_present = false; srs_res_s supported_srs_res; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ModulationOrder ::= ENUMERATED struct mod_order_opts { enum options { bpsk_halfpi, bpsk, qpsk, qam16, qam64, qam256, nulltype } value; typedef float number_type; const char* to_string() const; float to_number() const; const char* to_number_string() const; }; typedef enumerated mod_order_e; // SupportedBandwidth ::= CHOICE struct supported_bw_c { struct fr1_opts { enum options { mhz5, mhz10, mhz15, mhz20, mhz25, mhz30, mhz40, mhz50, mhz60, mhz80, mhz100, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated fr1_e_; struct fr2_opts { enum options { mhz50, mhz100, mhz200, mhz400, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated fr2_e_; struct types_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods supported_bw_c() = default; supported_bw_c(const supported_bw_c& other); supported_bw_c& operator=(const supported_bw_c& other); ~supported_bw_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters fr1_e_& fr1() { assert_choice_type(types::fr1, type_, "SupportedBandwidth"); return c.get(); } fr2_e_& fr2() { assert_choice_type(types::fr2, type_, "SupportedBandwidth"); return c.get(); } const fr1_e_& fr1() const { assert_choice_type(types::fr1, type_, "SupportedBandwidth"); return c.get(); } const fr2_e_& fr2() const { assert_choice_type(types::fr2, type_, "SupportedBandwidth"); return c.get(); } fr1_e_& set_fr1(); fr2_e_& set_fr2(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // FeatureSetDownlinkPerCC ::= SEQUENCE struct feature_set_dl_per_cc_s { bool ch_bw_minus90mhz_present = false; bool max_num_mimo_layers_pdsch_present = false; bool supported_mod_order_dl_present = false; subcarrier_spacing_e supported_subcarrier_spacing_dl; supported_bw_c supported_bw_dl; mimo_layers_dl_e max_num_mimo_layers_pdsch; mod_order_e supported_mod_order_dl; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyF ::= SEQUENCE struct dummy_f_s { uint8_t max_num_periodic_csi_report_per_bwp = 1; uint8_t max_num_aperiodic_csi_report_per_bwp = 1; uint8_t max_num_semi_persistent_csi_report_per_bwp = 0; uint8_t simul_csi_reports_all_cc = 5; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DummyI ::= SEQUENCE struct dummy_i_s { struct supported_srs_tx_port_switch_opts { enum options { t1r2, t1r4, t2r4, t1r4_t2r4, tr_equal, nulltype } value; const char* to_string() const; }; typedef enumerated supported_srs_tx_port_switch_e_; // member variables bool tx_switch_impact_to_rx_present = false; supported_srs_tx_port_switch_e_ supported_srs_tx_port_switch; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetUplink ::= SEQUENCE struct feature_set_ul_s { using feature_set_list_per_ul_cc_l_ = bounded_array; struct scaling_factor_opts { enum options { f0p4, f0p75, f0p8, nulltype } value; const char* to_string() const; }; typedef enumerated scaling_factor_e_; struct pusch_processing_type1_different_tb_per_slot_s_ { struct scs_minus15k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus15k_hz_e_; struct scs_minus30k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus30k_hz_e_; struct scs_minus60k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus60k_hz_e_; struct scs_minus120k_hz_opts { enum options { upto2, upto4, upto7, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated scs_minus120k_hz_e_; // member variables bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; bool scs_minus120k_hz_present = false; scs_minus15k_hz_e_ scs_minus15k_hz; scs_minus30k_hz_e_ scs_minus30k_hz; scs_minus60k_hz_e_ scs_minus60k_hz; scs_minus120k_hz_e_ scs_minus120k_hz; }; // member variables bool scaling_factor_present = false; bool cross_carrier_sched_other_scs_present = false; bool intra_band_freq_separation_ul_present = false; bool search_space_sharing_ca_ul_present = false; bool dummy1_present = false; bool supported_srs_res_present = false; bool two_pucch_group_present = false; bool dynamic_switch_sul_present = false; bool simul_tx_sul_non_sul_present = false; bool pusch_processing_type1_different_tb_per_slot_present = false; bool dummy2_present = false; feature_set_list_per_ul_cc_l_ feature_set_list_per_ul_cc; scaling_factor_e_ scaling_factor; freq_separation_class_e intra_band_freq_separation_ul; dummy_i_s dummy1; srs_res_s supported_srs_res; pusch_processing_type1_different_tb_per_slot_s_ pusch_processing_type1_different_tb_per_slot; dummy_f_s dummy2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetUplink-v1540 ::= SEQUENCE struct feature_set_ul_v1540_s { struct pusch_processing_type2_s_ { bool scs_minus15k_hz_present = false; bool scs_minus30k_hz_present = false; bool scs_minus60k_hz_present = false; processing_params_s scs_minus15k_hz; processing_params_s scs_minus30k_hz; processing_params_s scs_minus60k_hz; }; // member variables bool zero_slot_offset_aperiodic_srs_present = false; bool pa_phase_discontinuity_impacts_present = false; bool pusch_separation_with_gap_present = false; bool pusch_processing_type2_present = false; bool ul_mcs_table_alt_dynamic_ind_present = false; pusch_processing_type2_s_ pusch_processing_type2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetUplinkPerCC ::= SEQUENCE struct feature_set_ul_per_cc_s { struct mimo_cb_pusch_s_ { bool max_num_mimo_layers_cb_pusch_present = false; mimo_layers_ul_e max_num_mimo_layers_cb_pusch; uint8_t max_num_srs_res_per_set = 1; }; // member variables bool ch_bw_minus90mhz_present = false; bool mimo_cb_pusch_present = false; bool max_num_mimo_layers_non_cb_pusch_present = false; bool supported_mod_order_ul_present = false; subcarrier_spacing_e supported_subcarrier_spacing_ul; supported_bw_c supported_bw_ul; mimo_cb_pusch_s_ mimo_cb_pusch; mimo_layers_ul_e max_num_mimo_layers_non_cb_pusch; mod_order_e supported_mod_order_ul; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSetUplinkPerCC-v1540 ::= SEQUENCE struct feature_set_ul_per_cc_v1540_s { struct mimo_non_cb_pusch_s_ { uint8_t max_num_srs_res_per_set = 1; uint8_t max_num_simul_srs_res_tx = 1; }; // member variables bool mimo_non_cb_pusch_present = false; mimo_non_cb_pusch_s_ mimo_non_cb_pusch; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FeatureSets ::= SEQUENCE struct feature_sets_s { using feature_sets_dl_l_ = dyn_array; using feature_sets_dl_per_cc_l_ = dyn_array; using feature_sets_ul_l_ = dyn_array; using feature_sets_ul_per_cc_l_ = dyn_array; using feature_sets_dl_v1540_l_ = dyn_array; using feature_sets_ul_v1540_l_ = dyn_array; using feature_sets_ul_per_cc_v1540_l_ = dyn_array; using feature_sets_dl_v15a0_l_ = dyn_array; // member variables bool ext = false; bool feature_sets_dl_present = false; bool feature_sets_dl_per_cc_present = false; bool feature_sets_ul_present = false; bool feature_sets_ul_per_cc_present = false; feature_sets_dl_l_ feature_sets_dl; feature_sets_dl_per_cc_l_ feature_sets_dl_per_cc; feature_sets_ul_l_ feature_sets_ul; feature_sets_ul_per_cc_l_ feature_sets_ul_per_cc; // ... // group 0 copy_ptr feature_sets_dl_v1540; copy_ptr feature_sets_ul_v1540; copy_ptr feature_sets_ul_per_cc_v1540; // group 1 copy_ptr feature_sets_dl_v15a0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AggregatedBandwidth ::= ENUMERATED struct aggregated_bw_opts { enum options { mhz50, mhz100, mhz150, mhz200, mhz250, mhz300, mhz350, mhz400, mhz450, mhz500, mhz550, mhz600, mhz650, mhz700, mhz750, mhz800, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated aggregated_bw_e; // FreqBandInformationEUTRA ::= SEQUENCE struct freq_band_info_eutra_s { bool ca_bw_class_dl_eutra_present = false; bool ca_bw_class_ul_eutra_present = false; uint16_t band_eutra = 1; ca_bw_class_eutra_e ca_bw_class_dl_eutra; ca_bw_class_eutra_e ca_bw_class_ul_eutra; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqBandInformationNR ::= SEQUENCE struct freq_band_info_nr_s { bool max_bw_requested_dl_present = false; bool max_bw_requested_ul_present = false; bool max_carriers_requested_dl_present = false; bool max_carriers_requested_ul_present = false; uint16_t band_nr = 1; aggregated_bw_e max_bw_requested_dl; aggregated_bw_e max_bw_requested_ul; uint8_t max_carriers_requested_dl = 1; uint8_t max_carriers_requested_ul = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FreqBandInformation ::= CHOICE struct freq_band_info_c { struct types_opts { enum options { band_info_eutra, band_info_nr, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods freq_band_info_c() = default; freq_band_info_c(const freq_band_info_c& other); freq_band_info_c& operator=(const freq_band_info_c& other); ~freq_band_info_c() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters freq_band_info_eutra_s& band_info_eutra() { assert_choice_type(types::band_info_eutra, type_, "FreqBandInformation"); return c.get(); } freq_band_info_nr_s& band_info_nr() { assert_choice_type(types::band_info_nr, type_, "FreqBandInformation"); return c.get(); } const freq_band_info_eutra_s& band_info_eutra() const { assert_choice_type(types::band_info_eutra, type_, "FreqBandInformation"); return c.get(); } const freq_band_info_nr_s& band_info_nr() const { assert_choice_type(types::band_info_nr, type_, "FreqBandInformation"); return c.get(); } freq_band_info_eutra_s& set_band_info_eutra(); freq_band_info_nr_s& set_band_info_nr(); private: types type_; choice_buffer_t c; void destroy_(); }; // FreqBandList ::= SEQUENCE (SIZE (1..1280)) OF FreqBandInformation using freq_band_list_l = dyn_array; // IMS-ParametersCommon ::= SEQUENCE struct ims_params_common_s { bool ext = false; bool voice_over_eutra_minus5_gc_present = false; // ... // group 0 bool voice_over_scg_bearer_eutra_minus5_gc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // IMS-ParametersFRX-Diff ::= SEQUENCE struct ims_params_frx_diff_s { bool ext = false; bool voice_over_nr_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // IMS-Parameters ::= SEQUENCE struct ims_params_s { bool ext = false; bool ims_params_common_present = false; bool ims_params_frx_diff_present = false; ims_params_common_s ims_params_common; ims_params_frx_diff_s ims_params_frx_diff; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // InterRAT-Parameters ::= SEQUENCE struct inter_rat_params_s { bool ext = false; bool eutra_present = false; eutra_params_s eutra; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MAC-ParametersCommon ::= SEQUENCE struct mac_params_common_s { bool ext = false; bool lcp_restrict_present = false; bool dummy_present = false; bool lch_to_scell_restrict_present = false; // ... // group 0 bool recommended_bit_rate_present = false; bool recommended_bit_rate_query_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MAC-ParametersXDD-Diff ::= SEQUENCE struct mac_params_xdd_diff_s { bool ext = false; bool skip_ul_tx_dynamic_present = false; bool lc_ch_sr_delay_timer_present = false; bool long_drx_cycle_present = false; bool short_drx_cycle_present = false; bool multiple_sr_cfgs_present = false; bool multiple_cfgured_grants_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MAC-Parameters ::= SEQUENCE struct mac_params_s { bool mac_params_common_present = false; bool mac_params_xdd_diff_present = false; mac_params_common_s mac_params_common; mac_params_xdd_diff_s mac_params_xdd_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersCommon ::= SEQUENCE struct meas_and_mob_params_common_s { struct max_num_csi_rs_rrm_rs_sinr_opts { enum options { n4, n8, n16, n32, n64, n96, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_csi_rs_rrm_rs_sinr_e_; // member variables bool ext = false; bool supported_gap_pattern_present = false; bool ssb_rlm_present = false; bool ssb_and_csi_rs_rlm_present = false; fixed_bitstring<22> supported_gap_pattern; // ... // group 0 bool event_b_meas_and_report_present = false; bool ho_fdd_tdd_present = false; bool eutra_cgi_report_present = false; bool nr_cgi_report_present = false; // group 1 bool independent_gap_cfg_present = false; bool periodic_eutra_meas_and_report_present = false; bool ho_fr1_fr2_present = false; bool max_num_csi_rs_rrm_rs_sinr_present = false; max_num_csi_rs_rrm_rs_sinr_e_ max_num_csi_rs_rrm_rs_sinr; // group 2 bool nr_cgi_report_endc_present = false; // group 3 bool eutra_cgi_report_nedc_present = false; bool eutra_cgi_report_nrdc_present = false; bool nr_cgi_report_nedc_present = false; bool nr_cgi_report_nrdc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersFRX-Diff ::= SEQUENCE struct meas_and_mob_params_frx_diff_s { struct max_num_res_csi_rs_rlm_opts { enum options { n2, n4, n6, n8, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated max_num_res_csi_rs_rlm_e_; // member variables bool ext = false; bool ss_sinr_meas_present = false; bool csi_rsrp_and_rsrq_meas_with_ssb_present = false; bool csi_rsrp_and_rsrq_meas_without_ssb_present = false; bool csi_sinr_meas_present = false; bool csi_rs_rlm_present = false; // ... // group 0 bool ho_inter_f_present = false; bool ho_lte_epc_present = false; bool ho_lte_minus5_gc_present = false; // group 1 bool max_num_res_csi_rs_rlm_present = false; max_num_res_csi_rs_rlm_e_ max_num_res_csi_rs_rlm; // group 2 bool simul_rx_data_ssb_diff_numerology_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersXDD-Diff ::= SEQUENCE struct meas_and_mob_params_xdd_diff_s { bool ext = false; bool intra_and_inter_f_meas_and_report_present = false; bool event_a_meas_and_report_present = false; // ... // group 0 bool ho_inter_f_present = false; bool ho_lte_epc_present = false; bool ho_lte_minus5_gc_present = false; // group 1 bool sftd_meas_nr_neigh_present = false; bool sftd_meas_nr_neigh_drx_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParameters ::= SEQUENCE struct meas_and_mob_params_s { bool meas_and_mob_params_common_present = false; bool meas_and_mob_params_xdd_diff_present = false; bool meas_and_mob_params_frx_diff_present = false; meas_and_mob_params_common_s meas_and_mob_params_common; meas_and_mob_params_xdd_diff_s meas_and_mob_params_xdd_diff; meas_and_mob_params_frx_diff_s meas_and_mob_params_frx_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC-Common ::= SEQUENCE struct meas_and_mob_params_mrdc_common_s { bool independent_gap_cfg_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC-FRX-Diff ::= SEQUENCE struct meas_and_mob_params_mrdc_frx_diff_s { bool simul_rx_data_ssb_diff_numerology_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC-XDD-Diff ::= SEQUENCE struct meas_and_mob_params_mrdc_xdd_diff_s { bool sftd_meas_ps_cell_present = false; bool sftd_meas_nr_cell_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC ::= SEQUENCE struct meas_and_mob_params_mrdc_s { bool meas_and_mob_params_mrdc_common_present = false; bool meas_and_mob_params_mrdc_xdd_diff_present = false; bool meas_and_mob_params_mrdc_frx_diff_present = false; meas_and_mob_params_mrdc_common_s meas_and_mob_params_mrdc_common; meas_and_mob_params_mrdc_xdd_diff_s meas_and_mob_params_mrdc_xdd_diff; meas_and_mob_params_mrdc_frx_diff_s meas_and_mob_params_mrdc_frx_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC-XDD-Diff-v1560 ::= SEQUENCE struct meas_and_mob_params_mrdc_xdd_diff_v1560_s { bool sftd_meas_ps_cell_nedc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasAndMobParametersMRDC-v1560 ::= SEQUENCE struct meas_and_mob_params_mrdc_v1560_s { bool meas_and_mob_params_mrdc_xdd_diff_v1560_present = false; meas_and_mob_params_mrdc_xdd_diff_v1560_s meas_and_mob_params_mrdc_xdd_diff_v1560; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasResultCellListSFTD-EUTRA ::= SEQUENCE (SIZE (1..3)) OF MeasResultSFTD-EUTRA using meas_result_cell_list_sftd_eutra_l = dyn_array; // MeasResultList2NR ::= SEQUENCE (SIZE (1..8)) OF MeasResult2NR using meas_result_list2_nr_l = dyn_array; // MeasResultSCG-Failure ::= SEQUENCE struct meas_result_scg_fail_s { bool ext = false; meas_result_list2_nr_l meas_result_per_mo_list; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // GeneralParametersMRDC-XDD-Diff ::= SEQUENCE struct general_params_mrdc_xdd_diff_s { bool ext = false; bool split_srb_with_one_ul_path_present = false; bool split_drb_with_ul_both_mcg_scg_present = false; bool srb3_present = false; bool v2x_eutra_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-MRDC-CapabilityAddFRX-Mode ::= SEQUENCE struct ue_mrdc_cap_add_frx_mode_s { meas_and_mob_params_mrdc_frx_diff_s meas_and_mob_params_mrdc_frx_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-MRDC-CapabilityAddXDD-Mode ::= SEQUENCE struct ue_mrdc_cap_add_xdd_mode_s { bool meas_and_mob_params_mrdc_xdd_diff_present = false; bool general_params_mrdc_xdd_diff_present = false; meas_and_mob_params_mrdc_xdd_diff_s meas_and_mob_params_mrdc_xdd_diff; general_params_mrdc_xdd_diff_s general_params_mrdc_xdd_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NRDC-Parameters ::= SEQUENCE struct nrdc_params_s { bool meas_and_mob_params_nrdc_present = false; bool general_params_nrdc_present = false; bool fdd_add_ue_nrdc_cap_present = false; bool tdd_add_ue_nrdc_cap_present = false; bool fr1_add_ue_nrdc_cap_present = false; bool fr2_add_ue_nrdc_cap_present = false; bool late_non_crit_ext_present = false; bool dummy_present = false; meas_and_mob_params_mrdc_s meas_and_mob_params_nrdc; general_params_mrdc_xdd_diff_s general_params_nrdc; ue_mrdc_cap_add_xdd_mode_s fdd_add_ue_nrdc_cap; ue_mrdc_cap_add_xdd_mode_s tdd_add_ue_nrdc_cap; ue_mrdc_cap_add_frx_mode_s fr1_add_ue_nrdc_cap; ue_mrdc_cap_add_frx_mode_s fr2_add_ue_nrdc_cap; dyn_octstring late_non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CarrierAggregationVariant ::= SEQUENCE struct carrier_aggregation_variant_s { bool fr1fdd_fr1_tdd_ca_sp_cell_on_fr1_fdd_present = false; bool fr1fdd_fr1_tdd_ca_sp_cell_on_fr1_tdd_present = false; bool fr1fdd_fr2_tdd_ca_sp_cell_on_fr1_fdd_present = false; bool fr1fdd_fr2_tdd_ca_sp_cell_on_fr2_tdd_present = false; bool fr1tdd_fr2_tdd_ca_sp_cell_on_fr1_tdd_present = false; bool fr1tdd_fr2_tdd_ca_sp_cell_on_fr2_tdd_present = false; bool fr1fdd_fr1_tdd_fr2_tdd_ca_sp_cell_on_fr1_fdd_present = false; bool fr1fdd_fr1_tdd_fr2_tdd_ca_sp_cell_on_fr1_tdd_present = false; bool fr1fdd_fr1_tdd_fr2_tdd_ca_sp_cell_on_fr2_tdd_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersCommon ::= SEQUENCE struct phy_params_common_s { struct bwp_switching_delay_opts { enum options { type1, type2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated bwp_switching_delay_e_; // member variables bool ext = false; bool csi_rs_cfra_for_ho_present = false; bool dynamic_prb_bundling_dl_present = false; bool sp_csi_report_pucch_present = false; bool sp_csi_report_pusch_present = false; bool nzp_csi_rs_intef_mgmt_present = false; bool type2_sp_csi_feedback_long_pucch_present = false; bool precoder_granularity_coreset_present = false; bool dynamic_harq_ack_codebook_present = false; bool semi_static_harq_ack_codebook_present = false; bool spatial_bundling_harq_ack_present = false; bool dynamic_beta_offset_ind_harq_ack_csi_present = false; bool pucch_repeat_f1_minus3_minus4_present = false; bool ra_type0_pusch_present = false; bool dynamic_switch_ra_type0_minus1_pdsch_present = false; bool dynamic_switch_ra_type0_minus1_pusch_present = false; bool pdsch_map_type_a_present = false; bool pdsch_map_type_b_present = false; bool interleaving_vrb_to_prb_pdsch_present = false; bool inter_slot_freq_hop_pusch_present = false; bool type1_pusch_repeat_multi_slots_present = false; bool type2_pusch_repeat_multi_slots_present = false; bool pusch_repeat_multi_slots_present = false; bool pdsch_repeat_multi_slots_present = false; bool dl_sps_present = false; bool cfgured_ul_grant_type1_present = false; bool cfgured_ul_grant_type2_present = false; bool pre_empt_ind_dl_present = false; bool cbg_trans_ind_dl_present = false; bool cbg_trans_ind_ul_present = false; bool cbg_flush_ind_dl_present = false; bool dynamic_harq_ack_code_b_cbg_retx_dl_present = false; bool rate_matching_resrc_set_semi_static_present = false; bool rate_matching_resrc_set_dynamic_present = false; bool bwp_switching_delay_present = false; bwp_switching_delay_e_ bwp_switching_delay; // ... // group 0 bool dummy_present = false; // group 1 bool max_num_search_spaces_present = false; bool rate_matching_ctrl_resrc_set_dynamic_present = false; bool max_layers_mimo_ind_present = false; // group 2 copy_ptr sp_cell_placement; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersFR1 ::= SEQUENCE struct phy_params_fr1_s { struct pdsch_re_map_fr1_per_symbol_opts { enum options { n10, n20, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdsch_re_map_fr1_per_symbol_e_; struct pdsch_re_map_fr1_per_slot_opts { enum options { n16, n32, n48, n64, n80, n96, n112, n128, n144, n160, n176, n192, n208, n224, n240, n256, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated pdsch_re_map_fr1_per_slot_e_; // member variables bool ext = false; bool pdcch_monitoring_single_occasion_present = false; bool scs_minus60k_hz_present = false; bool pdsch_minus256_qam_fr1_present = false; bool pdsch_re_map_fr1_per_symbol_present = false; pdsch_re_map_fr1_per_symbol_e_ pdsch_re_map_fr1_per_symbol; // ... // group 0 bool pdsch_re_map_fr1_per_slot_present = false; pdsch_re_map_fr1_per_slot_e_ pdsch_re_map_fr1_per_slot; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersFR2 ::= SEQUENCE struct phy_params_fr2_s { struct pdsch_re_map_fr2_per_symbol_opts { enum options { n6, n20, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated pdsch_re_map_fr2_per_symbol_e_; struct pdsch_re_map_fr2_per_slot_opts { enum options { n16, n32, n48, n64, n80, n96, n112, n128, n144, n160, n176, n192, n208, n224, n240, n256, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated pdsch_re_map_fr2_per_slot_e_; // member variables bool ext = false; bool dummy_present = false; bool pdsch_re_map_fr2_per_symbol_present = false; pdsch_re_map_fr2_per_symbol_e_ pdsch_re_map_fr2_per_symbol; // ... // group 0 bool pcell_fr2_present = false; bool pdsch_re_map_fr2_per_slot_present = false; pdsch_re_map_fr2_per_slot_e_ pdsch_re_map_fr2_per_slot; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersFRX-Diff ::= SEQUENCE struct phy_params_frx_diff_s { struct supported_dmrs_type_dl_opts { enum options { type1, type1_and2, nulltype } value; const char* to_string() const; }; typedef enumerated supported_dmrs_type_dl_e_; struct supported_dmrs_type_ul_opts { enum options { type1, type1_and2, nulltype } value; const char* to_string() const; }; typedef enumerated supported_dmrs_type_ul_e_; struct mux_sr_harq_ack_csi_pucch_once_per_slot_s_ { bool same_symbol_present = false; bool diff_symbol_present = false; }; struct pdcch_blind_detection_nrdc_s_ { uint8_t pdcch_blind_detection_mcg_ue = 1; uint8_t pdcch_blind_detection_scg_ue = 1; }; // member variables bool ext = false; bool dynamic_sfi_present = false; bool dummy1_present = false; bool two_fl_dmrs_present = false; bool dummy2_present = false; bool dummy3_present = false; bool supported_dmrs_type_dl_present = false; bool supported_dmrs_type_ul_present = false; bool semi_open_loop_csi_present = false; bool csi_report_without_pmi_present = false; bool csi_report_without_cqi_present = false; bool one_ports_ptrs_present = false; bool two_pucch_f0_minus2_consec_symbols_present = false; bool pucch_f2_with_fh_present = false; bool pucch_f3_with_fh_present = false; bool pucch_f4_with_fh_present = false; bool pucch_f0_minus2_without_fh_present = false; bool pucch_f1_minus3_minus4_without_fh_present = false; bool mux_sr_harq_ack_csi_pucch_multi_per_slot_present = false; bool uci_code_block_segmentation_present = false; bool one_pucch_long_and_short_format_present = false; bool two_pucch_any_others_in_slot_present = false; bool intra_slot_freq_hop_pusch_present = false; bool pusch_lbrm_present = false; bool pdcch_blind_detection_ca_present = false; bool tpc_pusch_rnti_present = false; bool tpc_pucch_rnti_present = false; bool tpc_srs_rnti_present = false; bool absolute_tpc_cmd_present = false; bool two_different_tpc_loop_pusch_present = false; bool two_different_tpc_loop_pucch_present = false; bool pusch_half_pi_bpsk_present = false; bool pucch_f3_minus4_half_pi_bpsk_present = false; bool almost_contiguous_cp_ofdm_ul_present = false; bool sp_csi_rs_present = false; bool sp_csi_im_present = false; bool tdd_multi_dl_ul_switch_per_slot_present = false; bool multiple_coreset_present = false; fixed_bitstring<2> dummy1; fixed_bitstring<2> two_fl_dmrs; fixed_bitstring<2> dummy2; fixed_bitstring<2> dummy3; supported_dmrs_type_dl_e_ supported_dmrs_type_dl; supported_dmrs_type_ul_e_ supported_dmrs_type_ul; fixed_bitstring<2> one_ports_ptrs; uint8_t pdcch_blind_detection_ca = 4; // ... // group 0 bool mux_sr_harq_ack_pucch_present = false; bool mux_multiple_group_ctrl_ch_overlap_present = false; bool dl_sched_offset_pdsch_type_a_present = false; bool dl_sched_offset_pdsch_type_b_present = false; bool ul_sched_offset_present = false; bool dl_minus64_qam_mcs_table_alt_present = false; bool ul_minus64_qam_mcs_table_alt_present = false; bool cqi_table_alt_present = false; bool one_fl_dmrs_two_add_dmrs_ul_present = false; bool two_fl_dmrs_two_add_dmrs_ul_present = false; bool one_fl_dmrs_three_add_dmrs_ul_present = false; copy_ptr csi_rs_im_reception_for_feedback; copy_ptr csi_rs_proc_framework_for_srs; copy_ptr csi_report_framework; copy_ptr mux_sr_harq_ack_csi_pucch_once_per_slot; // group 1 bool mux_harq_ack_pusch_diff_symbol_present = false; copy_ptr pdcch_blind_detection_nrdc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersXDD-Diff ::= SEQUENCE struct phy_params_xdd_diff_s { bool ext = false; bool dynamic_sfi_present = false; bool two_pucch_f0_minus2_consec_symbols_present = false; bool two_different_tpc_loop_pusch_present = false; bool two_different_tpc_loop_pucch_present = false; // ... // group 0 bool dl_sched_offset_pdsch_type_a_present = false; bool dl_sched_offset_pdsch_type_b_present = false; bool ul_sched_offset_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-Parameters ::= SEQUENCE struct phy_params_s { bool phy_params_common_present = false; bool phy_params_xdd_diff_present = false; bool phy_params_frx_diff_present = false; bool phy_params_fr1_present = false; bool phy_params_fr2_present = false; phy_params_common_s phy_params_common; phy_params_xdd_diff_s phy_params_xdd_diff; phy_params_frx_diff_s phy_params_frx_diff; phy_params_fr1_s phy_params_fr1; phy_params_fr2_s phy_params_fr2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NAICS-Capability-Entry ::= SEQUENCE struct naics_cap_entry_s { struct nof_aggregated_prb_opts { enum options { n50, n75, n100, n125, n150, n175, n200, n225, n250, n275, n300, n350, n400, n450, n500, spare, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated nof_aggregated_prb_e_; // member variables bool ext = false; uint8_t nof_naics_capable_cc = 1; nof_aggregated_prb_e_ nof_aggregated_prb; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // Phy-ParametersMRDC ::= SEQUENCE struct phy_params_mrdc_s { using naics_cap_list_l_ = dyn_array; // member variables bool ext = false; bool naics_cap_list_present = false; naics_cap_list_l_ naics_cap_list; // ... // group 0 copy_ptr sp_cell_placement; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RF-Parameters ::= SEQUENCE struct rf_params_s { using supported_band_list_nr_l_ = dyn_array; // member variables bool ext = false; bool supported_band_combination_list_present = false; bool applied_freq_band_list_filt_present = false; supported_band_list_nr_l_ supported_band_list_nr; band_combination_list_l supported_band_combination_list; freq_band_list_l applied_freq_band_list_filt; // ... // group 0 bool srs_switching_time_requested_present = false; copy_ptr supported_band_combination_list_v1540; // group 1 copy_ptr supported_band_combination_list_v1550; // group 2 copy_ptr supported_band_combination_list_v1560; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RF-ParametersMRDC ::= SEQUENCE struct rf_params_mrdc_s { struct supported_band_combination_list_nedc_only_v15a0_s_ { bool supported_band_combination_list_v1540_present = false; bool supported_band_combination_list_v1560_present = false; bool supported_band_combination_list_v1570_present = false; bool supported_band_combination_list_v1580_present = false; bool supported_band_combination_list_v1590_present = false; band_combination_list_v1540_l supported_band_combination_list_v1540; band_combination_list_v1560_l supported_band_combination_list_v1560; band_combination_list_v1570_l supported_band_combination_list_v1570; band_combination_list_v1580_l supported_band_combination_list_v1580; band_combination_list_v1590_l supported_band_combination_list_v1590; }; // member variables bool ext = false; bool supported_band_combination_list_present = false; bool applied_freq_band_list_filt_present = false; band_combination_list_l supported_band_combination_list; freq_band_list_l applied_freq_band_list_filt; // ... // group 0 bool srs_switching_time_requested_present = false; copy_ptr supported_band_combination_list_v1540; // group 1 copy_ptr supported_band_combination_list_v1550; // group 2 copy_ptr supported_band_combination_list_v1560; copy_ptr supported_band_combination_list_nedc_only; // group 3 copy_ptr supported_band_combination_list_v1570; // group 4 copy_ptr supported_band_combination_list_v1580; // group 5 copy_ptr supported_band_combination_list_v1590; // group 6 copy_ptr supported_band_combination_list_nedc_only_v15a0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRequestFilterNR-v1540 ::= SEQUENCE struct ue_cap_request_filt_nr_v1540_s { bool srs_switching_time_request_present = false; bool non_crit_ext_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRequestFilterNR ::= SEQUENCE struct ue_cap_request_filt_nr_s { bool freq_band_list_filt_present = false; bool non_crit_ext_present = false; freq_band_list_l freq_band_list_filt; ue_cap_request_filt_nr_v1540_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-MRDC-CapabilityAddXDD-Mode-v1560 ::= SEQUENCE struct ue_mrdc_cap_add_xdd_mode_v1560_s { bool meas_and_mob_params_mrdc_xdd_diff_v1560_present = false; meas_and_mob_params_mrdc_xdd_diff_v1560_s meas_and_mob_params_mrdc_xdd_diff_v1560; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PDCP-ParametersMRDC ::= SEQUENCE struct pdcp_params_mrdc_s { bool pdcp_dupl_split_srb_present = false; bool pdcp_dupl_split_drb_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-MRDC-Capability-v1560 ::= SEQUENCE struct ue_mrdc_cap_v1560_s { bool rx_filts_present = false; bool meas_and_mob_params_mrdc_v1560_present = false; bool fdd_add_ue_mrdc_cap_v1560_present = false; bool tdd_add_ue_mrdc_cap_v1560_present = false; bool non_crit_ext_present = false; dyn_octstring rx_filts; meas_and_mob_params_mrdc_v1560_s meas_and_mob_params_mrdc_v1560; ue_mrdc_cap_add_xdd_mode_v1560_s fdd_add_ue_mrdc_cap_v1560; ue_mrdc_cap_add_xdd_mode_v1560_s tdd_add_ue_mrdc_cap_v1560; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-MRDC-Capability ::= SEQUENCE struct ue_mrdc_cap_s { using feature_set_combinations_l_ = dyn_array; // member variables bool meas_and_mob_params_mrdc_present = false; bool phy_params_mrdc_v1530_present = false; bool general_params_mrdc_present = false; bool fdd_add_ue_mrdc_cap_present = false; bool tdd_add_ue_mrdc_cap_present = false; bool fr1_add_ue_mrdc_cap_present = false; bool fr2_add_ue_mrdc_cap_present = false; bool feature_set_combinations_present = false; bool pdcp_params_mrdc_v1530_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; meas_and_mob_params_mrdc_s meas_and_mob_params_mrdc; phy_params_mrdc_s phy_params_mrdc_v1530; rf_params_mrdc_s rf_params_mrdc; general_params_mrdc_xdd_diff_s general_params_mrdc; ue_mrdc_cap_add_xdd_mode_s fdd_add_ue_mrdc_cap; ue_mrdc_cap_add_xdd_mode_s tdd_add_ue_mrdc_cap; ue_mrdc_cap_add_frx_mode_s fr1_add_ue_mrdc_cap; ue_mrdc_cap_add_frx_mode_s fr2_add_ue_mrdc_cap; feature_set_combinations_l_ feature_set_combinations; pdcp_params_mrdc_s pdcp_params_mrdc_v1530; dyn_octstring late_non_crit_ext; ue_mrdc_cap_v1560_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NRDC-Parameters-v1570 ::= SEQUENCE struct nrdc_params_v1570_s { bool sfn_sync_nrdc_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability-v1570 ::= SEQUENCE struct ue_nr_cap_v1570_s { bool nrdc_params_v1570_present = false; bool non_crit_ext_present = false; nrdc_params_v1570_s nrdc_params_v1570; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability-v1560 ::= SEQUENCE struct ue_nr_cap_v1560_s { bool nrdc_params_present = false; bool rx_filts_present = false; bool non_crit_ext_present = false; nrdc_params_s nrdc_params; dyn_octstring rx_filts; ue_nr_cap_v1570_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SDAP-Parameters ::= SEQUENCE struct sdap_params_s { bool ext = false; bool as_reflective_qos_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability-v1550 ::= SEQUENCE struct ue_nr_cap_v1550_s { bool reduced_cp_latency_present = false; bool non_crit_ext_present = false; ue_nr_cap_v1560_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-CapabilityAddFRX-Mode ::= SEQUENCE struct ue_nr_cap_add_frx_mode_s { bool phy_params_frx_diff_present = false; bool meas_and_mob_params_frx_diff_present = false; phy_params_frx_diff_s phy_params_frx_diff; meas_and_mob_params_frx_diff_s meas_and_mob_params_frx_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-CapabilityAddFRX-Mode-v1540 ::= SEQUENCE struct ue_nr_cap_add_frx_mode_v1540_s { bool ims_params_frx_diff_present = false; ims_params_frx_diff_s ims_params_frx_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability-v1540 ::= SEQUENCE struct ue_nr_cap_v1540_s { bool sdap_params_present = false; bool overheat_ind_present = false; bool ims_params_present = false; bool fr1_add_ue_nr_cap_v1540_present = false; bool fr2_add_ue_nr_cap_v1540_present = false; bool fr1_fr2_add_ue_nr_cap_present = false; bool non_crit_ext_present = false; sdap_params_s sdap_params; ims_params_s ims_params; ue_nr_cap_add_frx_mode_v1540_s fr1_add_ue_nr_cap_v1540; ue_nr_cap_add_frx_mode_v1540_s fr2_add_ue_nr_cap_v1540; ue_nr_cap_add_frx_mode_s fr1_fr2_add_ue_nr_cap; ue_nr_cap_v1550_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-CapabilityAddXDD-Mode-v1530 ::= SEQUENCE struct ue_nr_cap_add_xdd_mode_v1530_s { eutra_params_xdd_diff_s eutra_params_xdd_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AccessStratumRelease ::= ENUMERATED struct access_stratum_release_opts { enum options { rel15, spare7, spare6, spare5, spare4, spare3, spare2, spare1, /*...*/ nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated access_stratum_release_e; // PDCP-Parameters ::= SEQUENCE struct pdcp_params_s { struct supported_rohc_profiles_s_ { bool profile0x0000 = false; bool profile0x0001 = false; bool profile0x0002 = false; bool profile0x0003 = false; bool profile0x0004 = false; bool profile0x0006 = false; bool profile0x0101 = false; bool profile0x0102 = false; bool profile0x0103 = false; bool profile0x0104 = false; }; struct max_num_rohc_context_sessions_opts { enum options { cs2, cs4, cs8, cs12, cs16, cs24, cs32, cs48, cs64, cs128, cs256, cs512, cs1024, cs16384, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated max_num_rohc_context_sessions_e_; // member variables bool ext = false; bool ul_only_rohc_profiles_present = false; bool continue_rohc_context_present = false; bool out_of_order_delivery_present = false; bool short_sn_present = false; bool pdcp_dupl_srb_present = false; bool pdcp_dupl_mcg_or_scg_drb_present = false; supported_rohc_profiles_s_ supported_rohc_profiles; max_num_rohc_context_sessions_e_ max_num_rohc_context_sessions; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RLC-Parameters ::= SEQUENCE struct rlc_params_s { bool ext = false; bool am_with_short_sn_present = false; bool um_with_short_sn_present = false; bool um_with_long_sn_present = false; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability-v1530 ::= SEQUENCE struct ue_nr_cap_v1530_s { bool fdd_add_ue_nr_cap_v1530_present = false; bool tdd_add_ue_nr_cap_v1530_present = false; bool dummy_present = false; bool inter_rat_params_present = false; bool inactive_state_present = false; bool delay_budget_report_present = false; bool non_crit_ext_present = false; ue_nr_cap_add_xdd_mode_v1530_s fdd_add_ue_nr_cap_v1530; ue_nr_cap_add_xdd_mode_v1530_s tdd_add_ue_nr_cap_v1530; inter_rat_params_s inter_rat_params; ue_nr_cap_v1540_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-CapabilityAddXDD-Mode ::= SEQUENCE struct ue_nr_cap_add_xdd_mode_s { bool phy_params_xdd_diff_present = false; bool mac_params_xdd_diff_present = false; bool meas_and_mob_params_xdd_diff_present = false; phy_params_xdd_diff_s phy_params_xdd_diff; mac_params_xdd_diff_s mac_params_xdd_diff; meas_and_mob_params_xdd_diff_s meas_and_mob_params_xdd_diff; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-NR-Capability ::= SEQUENCE struct ue_nr_cap_s { using feature_set_combinations_l_ = dyn_array; // member variables bool rlc_params_present = false; bool mac_params_present = false; bool meas_and_mob_params_present = false; bool fdd_add_ue_nr_cap_present = false; bool tdd_add_ue_nr_cap_present = false; bool fr1_add_ue_nr_cap_present = false; bool fr2_add_ue_nr_cap_present = false; bool feature_sets_present = false; bool feature_set_combinations_present = false; bool late_non_crit_ext_present = false; bool non_crit_ext_present = false; access_stratum_release_e access_stratum_release; pdcp_params_s pdcp_params; rlc_params_s rlc_params; mac_params_s mac_params; phy_params_s phy_params; rf_params_s rf_params; meas_and_mob_params_s meas_and_mob_params; ue_nr_cap_add_xdd_mode_s fdd_add_ue_nr_cap; ue_nr_cap_add_xdd_mode_s tdd_add_ue_nr_cap; ue_nr_cap_add_frx_mode_s fr1_add_ue_nr_cap; ue_nr_cap_add_frx_mode_s fr2_add_ue_nr_cap; feature_sets_s feature_sets; feature_set_combinations_l_ feature_set_combinations; dyn_octstring late_non_crit_ext; ue_nr_cap_v1530_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UE-CapabilityRequestFilterCommon ::= SEQUENCE struct ue_cap_request_filt_common_s { struct mrdc_request_s_ { bool omit_en_dc_present = false; bool include_nr_dc_present = false; bool include_ne_dc_present = false; }; // member variables bool ext = false; bool mrdc_request_present = false; mrdc_request_s_ mrdc_request; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UECapabilityEnquiry-v1560-IEs ::= SEQUENCE struct ue_cap_enquiry_v1560_ies_s { bool cap_request_filt_common_present = false; bool non_crit_ext_present = false; ue_cap_request_filt_common_s cap_request_filt_common; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AS-Config ::= SEQUENCE struct as_cfg_s { bool ext = false; dyn_octstring rrc_recfg; // ... // group 0 bool source_rb_sn_cfg_present = false; bool source_scg_nr_cfg_present = false; bool source_scg_eutra_cfg_present = false; dyn_octstring source_rb_sn_cfg; dyn_octstring source_scg_nr_cfg; dyn_octstring source_scg_eutra_cfg; // group 1 bool source_scg_cfgured_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombinationInfo ::= SEQUENCE struct band_combination_info_s { using allowed_feature_sets_list_l_ = dyn_array; // member variables uint32_t band_combination_idx = 1; allowed_feature_sets_list_l_ allowed_feature_sets_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReestabNCellInfo ::= SEQUENCE struct reestab_ncell_info_s { fixed_bitstring<36> cell_id; fixed_bitstring<256> key_g_node_b_star; fixed_bitstring<16> short_mac_i; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // BandCombinationInfoList ::= SEQUENCE (SIZE (1..65536)) OF BandCombinationInfo using band_combination_info_list_l = dyn_array; // ReestabNCellInfoList ::= SEQUENCE (SIZE (1..32)) OF ReestabNCellInfo using reestab_ncell_info_list_l = dyn_array; // SelectedBandEntriesMN ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..32) using sel_band_entries_mn_l = bounded_array; // BandCombinationInfoSN ::= SEQUENCE struct band_combination_info_sn_s { uint32_t band_combination_idx = 1; uint8_t requested_feature_sets = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ConfigRestrictInfoSCG ::= SEQUENCE struct cfg_restrict_info_scg_s { struct pwr_coordination_fr1_s_ { bool p_max_nr_fr1_present = false; bool p_max_eutra_present = false; bool p_max_ue_fr1_present = false; int8_t p_max_nr_fr1 = -30; int8_t p_max_eutra = -30; int8_t p_max_ue_fr1 = -30; }; struct serv_cell_idx_range_scg_s_ { uint8_t low_bound = 0; uint8_t up_bound = 0; }; using sel_band_entries_mn_list_l_ = dyn_array; // member variables bool ext = false; bool allowed_bc_list_mrdc_present = false; bool pwr_coordination_fr1_present = false; bool serv_cell_idx_range_scg_present = false; bool max_meas_freqs_scg_present = false; bool dummy_present = false; band_combination_info_list_l allowed_bc_list_mrdc; pwr_coordination_fr1_s_ pwr_coordination_fr1; serv_cell_idx_range_scg_s_ serv_cell_idx_range_scg; uint8_t max_meas_freqs_scg = 1; uint8_t dummy = 1; // ... // group 0 bool pdcch_blind_detection_scg_present = false; bool max_num_rohc_context_sessions_sn_present = false; copy_ptr sel_band_entries_mn_list; uint8_t pdcch_blind_detection_scg = 1; uint16_t max_num_rohc_context_sessions_sn = 0; // group 1 bool max_intra_freq_meas_identities_scg_present = false; bool max_inter_freq_meas_identities_scg_present = false; uint8_t max_intra_freq_meas_identities_scg = 1; uint8_t max_inter_freq_meas_identities_scg = 1; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // ReestablishmentInfo ::= SEQUENCE struct reest_info_s { bool add_reestab_info_list_present = false; uint16_t source_pci = 0; fixed_bitstring<16> target_cell_short_mac_i; reestab_ncell_info_list_l add_reestab_info_list; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AS-Context ::= SEQUENCE struct as_context_s { bool ext = false; bool reest_info_present = false; bool cfg_restrict_info_present = false; reest_info_s reest_info; cfg_restrict_info_scg_s cfg_restrict_info; // ... // group 0 copy_ptr ran_notif_area_info; // group 1 bool ue_assist_info_present = false; dyn_octstring ue_assist_info; // group 2 copy_ptr sel_band_combination_sn; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AffectedCarrierFreqCombEUTRA ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..262143) using affected_carrier_freq_comb_eutra_l = bounded_array; // AffectedCarrierFreqCombNR ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..3279165) using affected_carrier_freq_comb_nr_l = bounded_array; // VictimSystemType ::= SEQUENCE struct victim_sys_type_s { bool gps_present = false; bool glonass_present = false; bool bds_present = false; bool galileo_present = false; bool wlan_present = false; bool bluetooth_present = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // AffectedCarrierFreqCombInfoMRDC ::= SEQUENCE struct affected_carrier_freq_comb_info_mrdc_s { struct interference_direction_mrdc_opts { enum options { eutra_nr, nr, other, utra_nr_other, nr_other, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated interference_direction_mrdc_e_; struct affected_carrier_freq_comb_mrdc_s_ { bool affected_carrier_freq_comb_eutra_present = false; affected_carrier_freq_comb_eutra_l affected_carrier_freq_comb_eutra; affected_carrier_freq_comb_nr_l affected_carrier_freq_comb_nr; }; // member variables bool affected_carrier_freq_comb_mrdc_present = false; victim_sys_type_s victim_sys_type; interference_direction_mrdc_e_ interference_direction_mrdc; affected_carrier_freq_comb_mrdc_s_ affected_carrier_freq_comb_mrdc; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PH-UplinkCarrierSCG ::= SEQUENCE struct ph_ul_carrier_scg_s { struct ph_type1or3_opts { enum options { type1, type3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ph_type1or3_e_; // member variables bool ext = false; ph_type1or3_e_ ph_type1or3; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-Config-v1590-IEs ::= SEQUENCE struct cg_cfg_v1590_ies_s { using scell_frequencies_sn_nr_l_ = bounded_array; using scell_frequencies_sn_eutra_l_ = bounded_array; // member variables bool scell_frequencies_sn_nr_present = false; bool scell_frequencies_sn_eutra_present = false; bool non_crit_ext_present = false; scell_frequencies_sn_nr_l_ scell_frequencies_sn_nr; scell_frequencies_sn_eutra_l_ scell_frequencies_sn_eutra; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CandidateServingFreqListEUTRA ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..262143) using candidate_serving_freq_list_eutra_l = bounded_array; // PH-InfoSCG ::= SEQUENCE struct ph_info_scg_s { bool ext = false; bool ph_supplementary_ul_present = false; uint8_t serv_cell_idx = 0; ph_ul_carrier_scg_s ph_ul; ph_ul_carrier_scg_s ph_supplementary_ul; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-Config-v1560-IEs ::= SEQUENCE struct cg_cfg_v1560_ies_s { struct report_cgi_request_eutra_s_ { struct requested_cell_info_eutra_s_ { uint32_t eutra_freq = 0; uint16_t cell_for_which_to_report_cgi_eutra = 0; }; // member variables bool requested_cell_info_eutra_present = false; requested_cell_info_eutra_s_ requested_cell_info_eutra; }; // member variables bool pscell_freq_eutra_present = false; bool scg_cell_group_cfg_eutra_present = false; bool candidate_cell_info_list_sn_eutra_present = false; bool candidate_serving_freq_list_eutra_present = false; bool need_for_gaps_present = false; bool drx_cfg_scg_present = false; bool report_cgi_request_eutra_present = false; bool non_crit_ext_present = false; uint32_t pscell_freq_eutra = 0; dyn_octstring scg_cell_group_cfg_eutra; dyn_octstring candidate_cell_info_list_sn_eutra; candidate_serving_freq_list_eutra_l candidate_serving_freq_list_eutra; drx_cfg_s drx_cfg_scg; report_cgi_request_eutra_s_ report_cgi_request_eutra; cg_cfg_v1590_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FR-Info ::= SEQUENCE struct fr_info_s { struct fr_type_opts { enum options { fr1, fr2, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated fr_type_e_; // member variables uint8_t serv_cell_idx = 0; fr_type_e_ fr_type; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // NR-FreqInfo ::= SEQUENCE struct nr_freq_info_s { bool ext = false; bool measured_freq_present = false; uint32_t measured_freq = 0; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PH-TypeListSCG ::= SEQUENCE (SIZE (1..32)) OF PH-InfoSCG using ph_type_list_scg_l = dyn_array; // CG-Config-v1540-IEs ::= SEQUENCE struct cg_cfg_v1540_ies_s { struct report_cgi_request_nr_s_ { struct requested_cell_info_s_ { uint32_t ssb_freq = 0; uint16_t cell_for_which_to_report_cgi = 0; }; // member variables bool requested_cell_info_present = false; requested_cell_info_s_ requested_cell_info; }; // member variables bool pscell_freq_present = false; bool report_cgi_request_nr_present = false; bool ph_info_scg_present = false; bool non_crit_ext_present = false; uint32_t pscell_freq = 0; report_cgi_request_nr_s_ report_cgi_request_nr; ph_type_list_scg_l ph_info_scg; cg_cfg_v1560_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CandidateServingFreqListNR ::= SEQUENCE (SIZE (1..32)) OF INTEGER (0..3279165) using candidate_serving_freq_list_nr_l = bounded_array; // ConfigRestrictModReqSCG ::= SEQUENCE struct cfg_restrict_mod_req_scg_s { bool ext = false; bool requested_bc_mrdc_present = false; bool requested_p_max_fr1_present = false; band_combination_info_sn_s requested_bc_mrdc; int8_t requested_p_max_fr1 = -30; // ... // group 0 bool requested_pdcch_blind_detection_scg_present = false; bool requested_p_max_eutra_present = false; uint8_t requested_pdcch_blind_detection_scg = 1; int8_t requested_p_max_eutra = -30; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // DRX-Info ::= SEQUENCE struct drx_info_s { struct drx_long_cycle_start_offset_c_ { struct types_opts { enum options { ms10, ms20, ms32, ms40, ms60, ms64, ms70, ms80, ms128, ms160, ms256, ms320, ms512, ms640, ms1024, ms1280, ms2048, ms2560, ms5120, ms10240, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated types; // choice methods drx_long_cycle_start_offset_c_() = default; drx_long_cycle_start_offset_c_(const drx_long_cycle_start_offset_c_& other); drx_long_cycle_start_offset_c_& operator=(const drx_long_cycle_start_offset_c_& other); ~drx_long_cycle_start_offset_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ms10() { assert_choice_type(types::ms10, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms20() { assert_choice_type(types::ms20, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms32() { assert_choice_type(types::ms32, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms40() { assert_choice_type(types::ms40, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms60() { assert_choice_type(types::ms60, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms64() { assert_choice_type(types::ms64, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms70() { assert_choice_type(types::ms70, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms80() { assert_choice_type(types::ms80, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms128() { assert_choice_type(types::ms128, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& ms160() { assert_choice_type(types::ms160, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms256() { assert_choice_type(types::ms256, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms320() { assert_choice_type(types::ms320, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms512() { assert_choice_type(types::ms512, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms640() { assert_choice_type(types::ms640, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms1024() { assert_choice_type(types::ms1024, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms1280() { assert_choice_type(types::ms1280, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms2048() { assert_choice_type(types::ms2048, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms2560() { assert_choice_type(types::ms2560, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms5120() { assert_choice_type(types::ms5120, type_, "drx-LongCycleStartOffset"); return c.get(); } uint16_t& ms10240() { assert_choice_type(types::ms10240, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms10() const { assert_choice_type(types::ms10, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms20() const { assert_choice_type(types::ms20, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms32() const { assert_choice_type(types::ms32, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms40() const { assert_choice_type(types::ms40, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms60() const { assert_choice_type(types::ms60, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms64() const { assert_choice_type(types::ms64, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms70() const { assert_choice_type(types::ms70, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms80() const { assert_choice_type(types::ms80, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms128() const { assert_choice_type(types::ms128, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint8_t& ms160() const { assert_choice_type(types::ms160, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms256() const { assert_choice_type(types::ms256, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms320() const { assert_choice_type(types::ms320, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms512() const { assert_choice_type(types::ms512, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms640() const { assert_choice_type(types::ms640, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms1024() const { assert_choice_type(types::ms1024, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms1280() const { assert_choice_type(types::ms1280, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms2048() const { assert_choice_type(types::ms2048, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms2560() const { assert_choice_type(types::ms2560, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms5120() const { assert_choice_type(types::ms5120, type_, "drx-LongCycleStartOffset"); return c.get(); } const uint16_t& ms10240() const { assert_choice_type(types::ms10240, type_, "drx-LongCycleStartOffset"); return c.get(); } uint8_t& set_ms10(); uint8_t& set_ms20(); uint8_t& set_ms32(); uint8_t& set_ms40(); uint8_t& set_ms60(); uint8_t& set_ms64(); uint8_t& set_ms70(); uint8_t& set_ms80(); uint8_t& set_ms128(); uint8_t& set_ms160(); uint16_t& set_ms256(); uint16_t& set_ms320(); uint16_t& set_ms512(); uint16_t& set_ms640(); uint16_t& set_ms1024(); uint16_t& set_ms1280(); uint16_t& set_ms2048(); uint16_t& set_ms2560(); uint16_t& set_ms5120(); uint16_t& set_ms10240(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; struct short_drx_s_ { struct drx_short_cycle_opts { enum options { ms2, ms3, ms4, ms5, ms6, ms7, ms8, ms10, ms14, ms16, ms20, ms30, ms32, ms35, ms40, ms64, ms80, ms128, ms160, ms256, ms320, ms512, ms640, spare9, spare8, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated drx_short_cycle_e_; // member variables drx_short_cycle_e_ drx_short_cycle; uint8_t drx_short_cycle_timer = 1; }; // member variables bool short_drx_present = false; drx_long_cycle_start_offset_c_ drx_long_cycle_start_offset; short_drx_s_ short_drx; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // FR-InfoList ::= SEQUENCE (SIZE (1..31)) OF FR-Info using fr_info_list_l = dyn_array; // MeasConfigSN ::= SEQUENCE struct meas_cfg_sn_s { using measured_frequencies_sn_l_ = dyn_array; // member variables bool ext = false; bool measured_frequencies_sn_present = false; measured_frequencies_sn_l_ measured_frequencies_sn; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-Config-IEs ::= SEQUENCE struct cg_cfg_ies_s { bool scg_cell_group_cfg_present = false; bool scg_rb_cfg_present = false; bool cfg_restrict_mod_req_present = false; bool drx_info_scg_present = false; bool candidate_cell_info_list_sn_present = false; bool meas_cfg_sn_present = false; bool sel_band_combination_present = false; bool fr_info_list_scg_present = false; bool candidate_serving_freq_list_nr_present = false; bool non_crit_ext_present = false; dyn_octstring scg_cell_group_cfg; dyn_octstring scg_rb_cfg; cfg_restrict_mod_req_scg_s cfg_restrict_mod_req; drx_info_s drx_info_scg; dyn_octstring candidate_cell_info_list_sn; meas_cfg_sn_s meas_cfg_sn; band_combination_info_sn_s sel_band_combination; fr_info_list_l fr_info_list_scg; candidate_serving_freq_list_nr_l candidate_serving_freq_list_nr; cg_cfg_v1540_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-Config ::= SEQUENCE struct cg_cfg_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { cg_cfg, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters cg_cfg_ies_s& cg_cfg() { assert_choice_type(types::cg_cfg, type_, "c1"); return c; } const cg_cfg_ies_s& cg_cfg() const { assert_choice_type(types::cg_cfg, type_, "c1"); return c; } cg_cfg_ies_s& set_cg_cfg(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; cg_cfg_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-ConfigInfo-v1590-IEs ::= SEQUENCE struct cg_cfg_info_v1590_ies_s { using serv_frequencies_mn_nr_l_ = bounded_array; // member variables bool serv_frequencies_mn_nr_present = false; bool non_crit_ext_present = false; serv_frequencies_mn_nr_l_ serv_frequencies_mn_nr; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PH-UplinkCarrierMCG ::= SEQUENCE struct ph_ul_carrier_mcg_s { struct ph_type1or3_opts { enum options { type1, type3, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated ph_type1or3_e_; // member variables bool ext = false; ph_type1or3_e_ ph_type1or3; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // SFTD-FrequencyList-EUTRA ::= SEQUENCE (SIZE (1..3)) OF INTEGER (0..262143) using sftd_freq_list_eutra_l = bounded_array; // SFTD-FrequencyList-NR ::= SEQUENCE (SIZE (1..3)) OF INTEGER (0..3279165) using sftd_freq_list_nr_l = bounded_array; // CG-ConfigInfo-v1570-IEs ::= SEQUENCE struct cg_cfg_info_v1570_ies_s { bool sftd_freq_list_nr_present = false; bool sftd_freq_list_eutra_present = false; bool non_crit_ext_present = false; sftd_freq_list_nr_l sftd_freq_list_nr; sftd_freq_list_eutra_l sftd_freq_list_eutra; cg_cfg_info_v1590_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PH-InfoMCG ::= SEQUENCE struct ph_info_mcg_s { bool ext = false; bool ph_supplementary_ul_present = false; uint8_t serv_cell_idx = 0; ph_ul_carrier_mcg_s ph_ul; ph_ul_carrier_mcg_s ph_supplementary_ul; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-ConfigInfo-v1560-IEs ::= SEQUENCE struct cg_cfg_info_v1560_ies_s { struct scg_fail_info_eutra_s_ { struct fail_type_eutra_opts { enum options { t313_expiry, random_access_problem, rlc_max_num_retx, scg_change_fail, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated fail_type_eutra_e_; // member variables fail_type_eutra_e_ fail_type_eutra; dyn_octstring meas_result_scg_eutra; }; struct meas_result_report_cgi_eutra_s_ { uint32_t eutra_freq = 0; uint16_t cell_for_which_to_report_cgi_eutra = 0; cgi_info_eutra_s cgi_info_eutra; }; // member variables bool candidate_cell_info_list_mn_eutra_present = false; bool candidate_cell_info_list_sn_eutra_present = false; bool source_cfg_scg_eutra_present = false; bool scg_fail_info_eutra_present = false; bool drx_cfg_mcg_present = false; bool meas_result_report_cgi_eutra_present = false; bool meas_result_cell_list_sftd_eutra_present = false; bool fr_info_list_mcg_present = false; bool non_crit_ext_present = false; dyn_octstring candidate_cell_info_list_mn_eutra; dyn_octstring candidate_cell_info_list_sn_eutra; dyn_octstring source_cfg_scg_eutra; scg_fail_info_eutra_s_ scg_fail_info_eutra; drx_cfg_s drx_cfg_mcg; meas_result_report_cgi_eutra_s_ meas_result_report_cgi_eutra; meas_result_cell_list_sftd_eutra_l meas_result_cell_list_sftd_eutra; fr_info_list_l fr_info_list_mcg; cg_cfg_info_v1570_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // PH-TypeListMCG ::= SEQUENCE (SIZE (1..32)) OF PH-InfoMCG using ph_type_list_mcg_l = dyn_array; // CG-ConfigInfo-v1540-IEs ::= SEQUENCE struct cg_cfg_info_v1540_ies_s { struct meas_result_report_cgi_s_ { uint32_t ssb_freq = 0; uint16_t cell_for_which_to_report_cgi = 0; cgi_info_nr_s cgi_info; }; // member variables bool ph_info_mcg_present = false; bool meas_result_report_cgi_present = false; bool non_crit_ext_present = false; ph_type_list_mcg_l ph_info_mcg; meas_result_report_cgi_s_ meas_result_report_cgi; cg_cfg_info_v1560_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MRDC-AssistanceInfo ::= SEQUENCE struct mrdc_assist_info_s { using affected_carrier_freq_comb_info_list_mrdc_l_ = dyn_array; // member variables bool ext = false; affected_carrier_freq_comb_info_list_mrdc_l_ affected_carrier_freq_comb_info_list_mrdc; // ... // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasConfigMN ::= SEQUENCE struct meas_cfg_mn_s { using measured_frequencies_mn_l_ = dyn_array; struct gap_purpose_opts { enum options { per_ue, per_fr1, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated gap_purpose_e_; // member variables bool ext = false; bool measured_frequencies_mn_present = false; bool meas_gap_cfg_present = false; bool gap_purpose_present = false; measured_frequencies_mn_l_ measured_frequencies_mn; setup_release_c meas_gap_cfg; gap_purpose_e_ gap_purpose; // ... // group 0 copy_ptr > meas_gap_cfg_fr2; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-ConfigInfo-IEs ::= SEQUENCE struct cg_cfg_info_ies_s { struct scg_fail_info_s_ { struct fail_type_opts { enum options { t310_expiry, random_access_problem, rlc_max_num_retx, synch_recfg_fail_scg, scg_recfg_fail, srb3_integrity_fail, nulltype } value; typedef uint16_t number_type; const char* to_string() const; uint16_t to_number() const; }; typedef enumerated fail_type_e_; // member variables fail_type_e_ fail_type; dyn_octstring meas_result_scg; }; // member variables bool ue_cap_info_present = false; bool candidate_cell_info_list_mn_present = false; bool candidate_cell_info_list_sn_present = false; bool meas_result_cell_list_sftd_nr_present = false; bool scg_fail_info_present = false; bool cfg_restrict_info_present = false; bool drx_info_mcg_present = false; bool meas_cfg_mn_present = false; bool source_cfg_scg_present = false; bool scg_rb_cfg_present = false; bool mcg_rb_cfg_present = false; bool mrdc_assist_info_present = false; bool non_crit_ext_present = false; dyn_octstring ue_cap_info; meas_result_list2_nr_l candidate_cell_info_list_mn; dyn_octstring candidate_cell_info_list_sn; meas_result_cell_list_sftd_nr_l meas_result_cell_list_sftd_nr; scg_fail_info_s_ scg_fail_info; cfg_restrict_info_scg_s cfg_restrict_info; drx_info_s drx_info_mcg; meas_cfg_mn_s meas_cfg_mn; dyn_octstring source_cfg_scg; dyn_octstring scg_rb_cfg; dyn_octstring mcg_rb_cfg; mrdc_assist_info_s mrdc_assist_info; cg_cfg_info_v1540_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // CG-ConfigInfo ::= SEQUENCE struct cg_cfg_info_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { cg_cfg_info, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters cg_cfg_info_ies_s& cg_cfg_info() { assert_choice_type(types::cg_cfg_info, type_, "c1"); return c; } const cg_cfg_info_ies_s& cg_cfg_info() const { assert_choice_type(types::cg_cfg_info, type_, "c1"); return c; } cg_cfg_info_ies_s& set_cg_cfg_info(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; cg_cfg_info_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; struct cells_triggered_list_item_c_ { struct types_opts { enum options { pci, pci_eutra, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods cells_triggered_list_item_c_() = default; cells_triggered_list_item_c_(const cells_triggered_list_item_c_& other); cells_triggered_list_item_c_& operator=(const cells_triggered_list_item_c_& other); ~cells_triggered_list_item_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint16_t& pci() { assert_choice_type(types::pci, type_, "CellsTriggeredList-item"); return c.get(); } uint16_t& pci_eutra() { assert_choice_type(types::pci_eutra, type_, "CellsTriggeredList-item"); return c.get(); } const uint16_t& pci() const { assert_choice_type(types::pci, type_, "CellsTriggeredList-item"); return c.get(); } const uint16_t& pci_eutra() const { assert_choice_type(types::pci_eutra, type_, "CellsTriggeredList-item"); return c.get(); } uint16_t& set_pci(); uint16_t& set_pci_eutra(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // CellsTriggeredList ::= SEQUENCE (SIZE (1..32)) OF CellsTriggeredList-item using cells_triggered_list_l = dyn_array; // HandoverCommand-IEs ::= SEQUENCE struct ho_cmd_ies_s { bool non_crit_ext_present = false; dyn_octstring ho_cmd_msg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // HandoverCommand ::= SEQUENCE struct ho_cmd_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { ho_cmd, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ho_cmd_ies_s& ho_cmd() { assert_choice_type(types::ho_cmd, type_, "c1"); return c; } const ho_cmd_ies_s& ho_cmd() const { assert_choice_type(types::ho_cmd, type_, "c1"); return c; } ho_cmd_ies_s& set_ho_cmd(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; ho_cmd_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // RRM-Config ::= SEQUENCE struct rrm_cfg_s { struct ue_inactive_time_opts { enum options { s1, s2, s3, s5, s7, s10, s15, s20, s25, s30, s40, s50, min1, min1s20, min1s40, min2, min2s30, min3, min3s30, min4, min5, min6, min7, min8, min9, min10, min12, min14, min17, min20, min24, min28, min33, min38, min44, min50, hr1, hr1min30, hr2, hr2min30, hr3, hr3min30, hr4, hr5, hr6, hr8, hr10, hr13, hr16, hr20, day1, day1hr12, day2, day2hr12, day3, day4, day5, day7, day10, day14, day19, day24, day30, day_more_than30, nulltype } value; const char* to_string() const; }; typedef enumerated ue_inactive_time_e_; // member variables bool ext = false; bool ue_inactive_time_present = false; bool candidate_cell_info_list_present = false; ue_inactive_time_e_ ue_inactive_time; meas_result_list2_nr_l candidate_cell_info_list; // ... // group 0 copy_ptr candidate_cell_info_list_sn_eutra; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // HandoverPreparationInformation-IEs ::= SEQUENCE struct ho_prep_info_ies_s { bool source_cfg_present = false; bool rrm_cfg_present = false; bool as_context_present = false; bool non_crit_ext_present = false; ue_cap_rat_container_list_l ue_cap_rat_list; as_cfg_s source_cfg; rrm_cfg_s rrm_cfg; as_context_s as_context; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // HandoverPreparationInformation ::= SEQUENCE struct ho_prep_info_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { ho_prep_info, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ho_prep_info_ies_s& ho_prep_info() { assert_choice_type(types::ho_prep_info, type_, "c1"); return c; } const ho_prep_info_ies_s& ho_prep_info() const { assert_choice_type(types::ho_prep_info, type_, "c1"); return c; } ho_prep_info_ies_s& set_ho_prep_info(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; ho_prep_info_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasTiming ::= SEQUENCE struct meas_timing_s { struct freq_and_timing_s_ { bool ss_rssi_meas_present = false; uint32_t carrier_freq = 0; subcarrier_spacing_e ssb_subcarrier_spacing; ssb_mtc_s ssb_meas_timing_cfg; ss_rssi_meas_s ss_rssi_meas; }; // member variables bool ext = false; bool freq_and_timing_present = false; freq_and_timing_s_ freq_and_timing; // ... // group 0 bool pci_present = false; copy_ptr ssb_to_measure; uint16_t pci = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasTimingList ::= SEQUENCE (SIZE (1..32)) OF MeasTiming using meas_timing_list_l = dyn_array; // MeasurementTimingConfiguration-v1550-IEs ::= SEQUENCE struct meas_timing_cfg_v1550_ies_s { bool non_crit_ext_present = false; bool camp_on_first_ssb = false; bool ps_cell_only_on_first_ssb = false; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasurementTimingConfiguration-IEs ::= SEQUENCE struct meas_timing_cfg_ies_s { bool meas_timing_present = false; bool non_crit_ext_present = false; meas_timing_list_l meas_timing; meas_timing_cfg_v1550_ies_s non_crit_ext; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // MeasurementTimingConfiguration ::= SEQUENCE struct meas_timing_cfg_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { meas_timing_conf, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters meas_timing_cfg_ies_s& meas_timing_conf() { assert_choice_type(types::meas_timing_conf, type_, "c1"); return c; } const meas_timing_cfg_ies_s& meas_timing_conf() const { assert_choice_type(types::meas_timing_conf, type_, "c1"); return c; } meas_timing_cfg_ies_s& set_meas_timing_conf(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; meas_timing_cfg_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UERadioAccessCapabilityInformation-IEs ::= SEQUENCE struct ue_radio_access_cap_info_ies_s { bool non_crit_ext_present = false; dyn_octstring ue_radio_access_cap_info; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UERadioAccessCapabilityInformation ::= SEQUENCE struct ue_radio_access_cap_info_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { ue_radio_access_cap_info, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ue_radio_access_cap_info_ies_s& ue_radio_access_cap_info() { assert_choice_type(types::ue_radio_access_cap_info, type_, "c1"); return c; } const ue_radio_access_cap_info_ies_s& ue_radio_access_cap_info() const { assert_choice_type(types::ue_radio_access_cap_info, type_, "c1"); return c; } ue_radio_access_cap_info_ies_s& set_ue_radio_access_cap_info(); void set_spare7(); void set_spare6(); void set_spare5(); void set_spare4(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; ue_radio_access_cap_info_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UERadioPagingInformation-IEs ::= SEQUENCE struct ue_radio_paging_info_ies_s { using supported_band_list_nr_for_paging_l_ = dyn_array; // member variables bool supported_band_list_nr_for_paging_present = false; bool non_crit_ext_present = false; supported_band_list_nr_for_paging_l_ supported_band_list_nr_for_paging; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // UERadioPagingInformation ::= SEQUENCE struct ue_radio_paging_info_s { struct crit_exts_c_ { struct c1_c_ { struct types_opts { enum options { ue_radio_paging_info, spare7, spare6, spare5, spare4, spare3, spare2, spare1, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods c1_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters ue_radio_paging_info_ies_s& ue_radio_paging_info() { assert_choice_type(types::ue_radio_paging_info, type_, "c1"); return c; } const ue_radio_paging_info_ies_s& ue_radio_paging_info() const { assert_choice_type(types::ue_radio_paging_info, type_, "c1"); return c; } ue_radio_paging_info_ies_s& set_ue_radio_paging_info(); void set_spare7(); void set_spare6(); void set_spare5(); void set_spare4(); void set_spare3(); void set_spare2(); void set_spare1(); private: types type_; ue_radio_paging_info_ies_s c; }; struct types_opts { enum options { c1, crit_exts_future, nulltype } value; typedef uint8_t number_type; const char* to_string() const; uint8_t to_number() const; }; typedef enumerated types; // choice methods crit_exts_c_() = default; void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters c1_c_& c1() { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } const c1_c_& c1() const { assert_choice_type(types::c1, type_, "criticalExtensions"); return c; } c1_c_& set_c1(); void set_crit_exts_future(); private: types type_; c1_c_ c; }; // member variables crit_exts_c_ crit_exts; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // VarMeasConfig ::= SEQUENCE struct var_meas_cfg_s { struct s_measure_cfg_c_ { struct types_opts { enum options { ssb_rsrp, csi_rsrp, nulltype } value; const char* to_string() const; }; typedef enumerated types; // choice methods s_measure_cfg_c_() = default; s_measure_cfg_c_(const s_measure_cfg_c_& other); s_measure_cfg_c_& operator=(const s_measure_cfg_c_& other); ~s_measure_cfg_c_() { destroy_(); } void set(types::options e = types::nulltype); types type() const { return type_; } SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; // getters uint8_t& ssb_rsrp() { assert_choice_type(types::ssb_rsrp, type_, "s-MeasureConfig"); return c.get(); } uint8_t& csi_rsrp() { assert_choice_type(types::csi_rsrp, type_, "s-MeasureConfig"); return c.get(); } const uint8_t& ssb_rsrp() const { assert_choice_type(types::ssb_rsrp, type_, "s-MeasureConfig"); return c.get(); } const uint8_t& csi_rsrp() const { assert_choice_type(types::csi_rsrp, type_, "s-MeasureConfig"); return c.get(); } uint8_t& set_ssb_rsrp(); uint8_t& set_csi_rsrp(); private: types type_; pod_choice_buffer_t c; void destroy_(); }; // member variables bool meas_id_list_present = false; bool meas_obj_list_present = false; bool report_cfg_list_present = false; bool quant_cfg_present = false; bool s_measure_cfg_present = false; meas_id_to_add_mod_list_l meas_id_list; meas_obj_to_add_mod_list_l meas_obj_list; report_cfg_to_add_mod_list_l report_cfg_list; quant_cfg_s quant_cfg; s_measure_cfg_c_ s_measure_cfg; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // VarMeasReport ::= SEQUENCE struct var_meas_report_s { bool cells_triggered_list_present = false; uint8_t meas_id = 1; cells_triggered_list_l cells_triggered_list; int64_t nof_reports_sent = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // VarMeasReportList ::= SEQUENCE (SIZE (1..64)) OF VarMeasReport using var_meas_report_list_l = dyn_array; // VarResumeMAC-Input ::= SEQUENCE struct var_resume_mac_input_s { uint16_t source_pci = 0; fixed_bitstring<36> target_cell_id; uint32_t source_c_rnti = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; // VarShortMAC-Input ::= SEQUENCE struct var_short_mac_input_s { uint16_t source_pci = 0; fixed_bitstring<36> target_cell_id; uint32_t source_c_rnti = 0; // sequence methods SRSASN_CODE pack(bit_ref& bref) const; SRSASN_CODE unpack(cbit_ref& bref); void to_json(json_writer& j) const; }; } // namespace rrc_nr } // namespace asn1 #endif // SRSASN1_RRC_NR_H