/*** <<< INCLUDES [T1] >>> ***/ #include #include #include /*** <<< TYPE-DECLS [T1] >>> ***/ typedef struct T1 { INTEGER_t i; ANY_t any; /* Context for parsing across buffer boundaries */ asn_struct_ctx_t _asn_ctx; } T1_t; /*** <<< FUNC-DECLS [T1] >>> ***/ extern asn_TYPE_descriptor_t asn_DEF_T1; /*** <<< STAT-DEFS [T1] >>> ***/ static asn_TYPE_member_t asn_MBR_T1_1[] = { { ATF_NOFLAGS, 0, offsetof(struct T1, i), .tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), .tag_mode = 0, .type = &asn_DEF_INTEGER, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "i" }, { ATF_ANY_TYPE | ATF_NOFLAGS, 0, offsetof(struct T1, any), .tag = -1 /* Ambiguous tag (ANY?) */, .tag_mode = 0, .type = &asn_DEF_ANY, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "any" }, }; static const ber_tlv_tag_t asn_DEF_T1_tags_1[] = { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) }; static const asn_TYPE_tag2member_t asn_MAP_T1_tag2el_1[] = { { (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 0, 0, 0 } /* i */ }; static asn_SEQUENCE_specifics_t asn_SPC_T1_specs_1 = { sizeof(struct T1), offsetof(struct T1, _asn_ctx), .tag2el = asn_MAP_T1_tag2el_1, .tag2el_count = 1, /* Count of tags in the map */ 0, 0, 0, /* Optional elements (not needed) */ -1, /* First extension addition */ }; asn_TYPE_descriptor_t asn_DEF_T1 = { "T1", "T1", &asn_OP_SEQUENCE, asn_DEF_T1_tags_1, sizeof(asn_DEF_T1_tags_1) /sizeof(asn_DEF_T1_tags_1[0]), /* 1 */ asn_DEF_T1_tags_1, /* Same as above */ sizeof(asn_DEF_T1_tags_1) /sizeof(asn_DEF_T1_tags_1[0]), /* 1 */ { 0, 0, SEQUENCE_constraint }, asn_MBR_T1_1, 2, /* Elements count */ &asn_SPC_T1_specs_1 /* Additional specs */ }; /*** <<< INCLUDES [T2] >>> ***/ #include #include #include /*** <<< TYPE-DECLS [T2] >>> ***/ typedef struct T2 { INTEGER_t i; ANY_t *any; /* OPTIONAL */ /* Context for parsing across buffer boundaries */ asn_struct_ctx_t _asn_ctx; } T2_t; /*** <<< FUNC-DECLS [T2] >>> ***/ extern asn_TYPE_descriptor_t asn_DEF_T2; /*** <<< STAT-DEFS [T2] >>> ***/ static asn_TYPE_member_t asn_MBR_T2_1[] = { { ATF_NOFLAGS, 0, offsetof(struct T2, i), .tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), .tag_mode = 0, .type = &asn_DEF_INTEGER, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "i" }, { ATF_POINTER, 1, offsetof(struct T2, any), .tag = (ASN_TAG_CLASS_CONTEXT | (0 << 2)), .tag_mode = +1, /* EXPLICIT tag at current level */ .type = &asn_DEF_ANY, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "any" }, }; static const ber_tlv_tag_t asn_DEF_T2_tags_1[] = { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) }; static const asn_TYPE_tag2member_t asn_MAP_T2_tag2el_1[] = { { (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 0, 0, 0 }, /* i */ { (ASN_TAG_CLASS_CONTEXT | (0 << 2)), 1, 0, 0 } /* any */ }; static asn_SEQUENCE_specifics_t asn_SPC_T2_specs_1 = { sizeof(struct T2), offsetof(struct T2, _asn_ctx), .tag2el = asn_MAP_T2_tag2el_1, .tag2el_count = 2, /* Count of tags in the map */ 0, 0, 0, /* Optional elements (not needed) */ -1, /* First extension addition */ }; asn_TYPE_descriptor_t asn_DEF_T2 = { "T2", "T2", &asn_OP_SEQUENCE, asn_DEF_T2_tags_1, sizeof(asn_DEF_T2_tags_1) /sizeof(asn_DEF_T2_tags_1[0]), /* 1 */ asn_DEF_T2_tags_1, /* Same as above */ sizeof(asn_DEF_T2_tags_1) /sizeof(asn_DEF_T2_tags_1[0]), /* 1 */ { 0, 0, SEQUENCE_constraint }, asn_MBR_T2_1, 2, /* Elements count */ &asn_SPC_T2_specs_1 /* Additional specs */ }; /*** <<< INCLUDES [T3] >>> ***/ #include #include /*** <<< TYPE-DECLS [T3] >>> ***/ typedef struct T3 { ANY_t any1; ANY_t any2; /* Context for parsing across buffer boundaries */ asn_struct_ctx_t _asn_ctx; } T3_t; /*** <<< FUNC-DECLS [T3] >>> ***/ extern asn_TYPE_descriptor_t asn_DEF_T3; /*** <<< STAT-DEFS [T3] >>> ***/ static asn_TYPE_member_t asn_MBR_T3_1[] = { { ATF_ANY_TYPE | ATF_NOFLAGS, 0, offsetof(struct T3, any1), .tag = -1 /* Ambiguous tag (ANY?) */, .tag_mode = 0, .type = &asn_DEF_ANY, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "any1" }, { ATF_ANY_TYPE | ATF_NOFLAGS, 0, offsetof(struct T3, any2), .tag = -1 /* Ambiguous tag (ANY?) */, .tag_mode = 0, .type = &asn_DEF_ANY, .type_selector = 0, { .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 }, 0, 0, /* No default value */ .name = "any2" }, }; static const ber_tlv_tag_t asn_DEF_T3_tags_1[] = { (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)) }; static asn_SEQUENCE_specifics_t asn_SPC_T3_specs_1 = { sizeof(struct T3), offsetof(struct T3, _asn_ctx), 0, /* No top level tags */ 0, /* No tags in the map */ 0, 0, 0, /* Optional elements (not needed) */ -1, /* First extension addition */ }; asn_TYPE_descriptor_t asn_DEF_T3 = { "T3", "T3", &asn_OP_SEQUENCE, asn_DEF_T3_tags_1, sizeof(asn_DEF_T3_tags_1) /sizeof(asn_DEF_T3_tags_1[0]), /* 1 */ asn_DEF_T3_tags_1, /* Same as above */ sizeof(asn_DEF_T3_tags_1) /sizeof(asn_DEF_T3_tags_1[0]), /* 1 */ { 0, 0, SEQUENCE_constraint }, asn_MBR_T3_1, 2, /* Elements count */ &asn_SPC_T3_specs_1 /* Additional specs */ };