diff options
Diffstat (limited to 'src/hnbap/HNBAP_TMSILAI.c')
-rw-r--r-- | src/hnbap/HNBAP_TMSILAI.c | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/src/hnbap/HNBAP_TMSILAI.c b/src/hnbap/HNBAP_TMSILAI.c new file mode 100644 index 0000000..05ea97b --- /dev/null +++ b/src/hnbap/HNBAP_TMSILAI.c @@ -0,0 +1,108 @@ +/* + * Generated by asn1c-0.9.28 (http://lionet.info/asn1c) + * From ASN.1 module "HNBAP-IEs" + * found in "../../asn1/hnbap/HNBAP-IEs.asn" + * `asn1c -R -fcompound-names` + */ + +#include <osmocom/hnbap/HNBAP_TMSILAI.h> + +static int +memb_tMSI_constraint_1(asn_TYPE_descriptor_t *td, const void *sptr, + asn_app_constraint_failed_f *ctfailcb, void *app_key) { + const BIT_STRING_t *st = (const BIT_STRING_t *)sptr; + size_t size; + + if(!sptr) { + _ASN_CTFAIL(app_key, td, sptr, + "%s: value not given (%s:%d)", + td->name, __FILE__, __LINE__); + return -1; + } + + if(st->size > 0) { + /* Size in bits */ + size = 8 * st->size - (st->bits_unused & 0x07); + } else { + size = 0; + } + + if((size == 32l)) { + /* Constraint check succeeded */ + return 0; + } else { + _ASN_CTFAIL(app_key, td, sptr, + "%s: constraint failed (%s:%d)", + td->name, __FILE__, __LINE__); + return -1; + } +} + +static asn_per_constraints_t asn_PER_memb_tMSI_constr_2 GCC_NOTUSED = { + { APC_UNCONSTRAINED, -1, -1, 0, 0 }, + { APC_CONSTRAINED, 0, 0, 32l, 32l } /* (SIZE(32..32)) */, + 0, 0 /* No PER value map */ +}; +static asn_TYPE_member_t asn_MBR_HNBAP_TMSILAI_1[] = { + { ATF_NOFLAGS, 0, offsetof(struct HNBAP_TMSILAI, tMSI), + (ASN_TAG_CLASS_CONTEXT | (0 << 2)), + -1, /* IMPLICIT tag at current level */ + &asn_DEF_BIT_STRING, + memb_tMSI_constraint_1, + &asn_PER_memb_tMSI_constr_2, + 0, + "tMSI" + }, + { ATF_NOFLAGS, 0, offsetof(struct HNBAP_TMSILAI, lAI), + (ASN_TAG_CLASS_CONTEXT | (1 << 2)), + -1, /* IMPLICIT tag at current level */ + &asn_DEF_HNBAP_LAI, + 0, /* Defer constraints checking to the member type */ + 0, /* No PER visible constraints */ + 0, + "lAI" + }, +}; +static const ber_tlv_tag_t asn_DEF_HNBAP_TMSILAI_tags_1[] = { + (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) +}; +static const asn_TYPE_tag2member_t asn_MAP_HNBAP_TMSILAI_tag2el_1[] = { + { (ASN_TAG_CLASS_CONTEXT | (0 << 2)), 0, 0, 0 }, /* tMSI */ + { (ASN_TAG_CLASS_CONTEXT | (1 << 2)), 1, 0, 0 } /* lAI */ +}; +static asn_SEQUENCE_specifics_t asn_SPC_HNBAP_TMSILAI_specs_1 = { + sizeof(struct HNBAP_TMSILAI), + offsetof(struct HNBAP_TMSILAI, _asn_ctx), + asn_MAP_HNBAP_TMSILAI_tag2el_1, + 2, /* Count of tags in the map */ + 0, 0, 0, /* Optional elements (not needed) */ + -1, /* Start extensions */ + -1 /* Stop extensions */ +}; +asn_TYPE_descriptor_t asn_DEF_HNBAP_TMSILAI = { + "HNBAP_TMSILAI", + "HNBAP_TMSILAI", + SEQUENCE_free, + SEQUENCE_print, + SEQUENCE_constraint, + SEQUENCE_decode_ber, + SEQUENCE_encode_der, + SEQUENCE_decode_xer, + SEQUENCE_encode_xer, + SEQUENCE_decode_uper, + SEQUENCE_encode_uper, + SEQUENCE_decode_aper, + SEQUENCE_encode_aper, + 0, /* Use generic outmost tag fetcher */ + asn_DEF_HNBAP_TMSILAI_tags_1, + sizeof(asn_DEF_HNBAP_TMSILAI_tags_1) + /sizeof(asn_DEF_HNBAP_TMSILAI_tags_1[0]), /* 1 */ + asn_DEF_HNBAP_TMSILAI_tags_1, /* Same as above */ + sizeof(asn_DEF_HNBAP_TMSILAI_tags_1) + /sizeof(asn_DEF_HNBAP_TMSILAI_tags_1[0]), /* 1 */ + 0, /* No PER visible constraints */ + asn_MBR_HNBAP_TMSILAI_1, + 2, /* Elements count */ + &asn_SPC_HNBAP_TMSILAI_specs_1 /* Additional specs */ +}; + |