/*
 * Generated by asn1c-0.9.28 (http://lionet.info/asn1c)
 * From ASN.1 module "HNBAP-IEs"
 * 	found in "../../asn1/hnbap/HNBAP-IEs.asn"
 * 	`asn1c -gen-PER`
 */

#include "TransportInfo.h"

static asn_per_constraints_t asn_PER_type_transportAssociation_constr_3 GCC_NOTUSED = {
	{ APC_CONSTRAINED | APC_EXTENSIBLE,  1,  1,  0l,  1l }	/* (0..1,...) */,
	{ APC_UNCONSTRAINED,	-1, -1,  0,  0 },
	0, 0	/* No PER value map */
};
static asn_TYPE_member_t asn_MBR_transportAssociation_3[] = {
	{ ATF_NOFLAGS, 0, offsetof(struct transportAssociation, choice.gtp_TEI),
		(ASN_TAG_CLASS_CONTEXT | (0 << 2)),
		-1,	/* IMPLICIT tag at current level */
		&asn_DEF_GTP_TEI,
		0,	/* Defer constraints checking to the member type */
		0,	/* No PER visible constraints */
		0,
		"gtp-TEI"
		},
	{ ATF_NOFLAGS, 0, offsetof(struct transportAssociation, choice.bindingID),
		(ASN_TAG_CLASS_CONTEXT | (1 << 2)),
		-1,	/* IMPLICIT tag at current level */
		&asn_DEF_BindingID,
		0,	/* Defer constraints checking to the member type */
		0,	/* No PER visible constraints */
		0,
		"bindingID"
		},
};
static const asn_TYPE_tag2member_t asn_MAP_transportAssociation_tag2el_3[] = {
    { (ASN_TAG_CLASS_CONTEXT | (0 << 2)), 0, 0, 0 }, /* gtp-TEI */
    { (ASN_TAG_CLASS_CONTEXT | (1 << 2)), 1, 0, 0 } /* bindingID */
};
static asn_CHOICE_specifics_t asn_SPC_transportAssociation_specs_3 = {
	sizeof(struct transportAssociation),
	offsetof(struct transportAssociation, _asn_ctx),
	offsetof(struct transportAssociation, present),
	sizeof(((struct transportAssociation *)0)->present),
	asn_MAP_transportAssociation_tag2el_3,
	2,	/* Count of tags in the map */
	0,
	2	/* Extensions start */
};
static /* Use -fall-defs-global to expose */
asn_TYPE_descriptor_t asn_DEF_transportAssociation_3 = {
	"transportAssociation",
	"transportAssociation",
	CHOICE_free,
	CHOICE_print,
	CHOICE_constraint,
	CHOICE_decode_ber,
	CHOICE_encode_der,
	CHOICE_decode_xer,
	CHOICE_encode_xer,
	CHOICE_decode_uper,
	CHOICE_encode_uper,
	CHOICE_decode_aper,
	CHOICE_encode_aper,
	CHOICE_outmost_tag,
	0,	/* No effective tags (pointer) */
	0,	/* No effective tags (count) */
	0,	/* No tags (pointer) */
	0,	/* No tags (count) */
	&asn_PER_type_transportAssociation_constr_3,
	asn_MBR_transportAssociation_3,
	2,	/* Elements count */
	&asn_SPC_transportAssociation_specs_3	/* Additional specs */
};

static asn_TYPE_member_t asn_MBR_TransportInfo_1[] = {
	{ ATF_NOFLAGS, 0, offsetof(struct TransportInfo, transportLayerAddress),
		(ASN_TAG_CLASS_CONTEXT | (0 << 2)),
		-1,	/* IMPLICIT tag at current level */
		&asn_DEF_TransportLayerAddress,
		0,	/* Defer constraints checking to the member type */
		0,	/* No PER visible constraints */
		0,
		"transportLayerAddress"
		},
	{ ATF_NOFLAGS, 0, offsetof(struct TransportInfo, transportAssociation),
		(ASN_TAG_CLASS_CONTEXT | (1 << 2)),
		+1,	/* EXPLICIT tag at current level */
		&asn_DEF_transportAssociation_3,
		0,	/* Defer constraints checking to the member type */
		0,	/* No PER visible constraints */
		0,
		"transportAssociation"
		},
	{ ATF_POINTER, 1, offsetof(struct TransportInfo, iE_Extensions),
		(ASN_TAG_CLASS_CONTEXT | (2 << 2)),
		-1,	/* IMPLICIT tag at current level */
		&asn_DEF_IE_Extensions,
		0,	/* Defer constraints checking to the member type */
		0,	/* No PER visible constraints */
		0,
		"iE-Extensions"
		},
};
static const int asn_MAP_TransportInfo_oms_1[] = { 2 };
static const ber_tlv_tag_t asn_DEF_TransportInfo_tags_1[] = {
	(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
static const asn_TYPE_tag2member_t asn_MAP_TransportInfo_tag2el_1[] = {
    { (ASN_TAG_CLASS_CONTEXT | (0 << 2)), 0, 0, 0 }, /* transportLayerAddress */
    { (ASN_TAG_CLASS_CONTEXT | (1 << 2)), 1, 0, 0 }, /* transportAssociation */
    { (ASN_TAG_CLASS_CONTEXT | (2 << 2)), 2, 0, 0 } /* iE-Extensions */
};
static asn_SEQUENCE_specifics_t asn_SPC_TransportInfo_specs_1 = {
	sizeof(struct TransportInfo),
	offsetof(struct TransportInfo, _asn_ctx),
	asn_MAP_TransportInfo_tag2el_1,
	3,	/* Count of tags in the map */
	asn_MAP_TransportInfo_oms_1,	/* Optional members */
	1, 0,	/* Root/Additions */
	2,	/* Start extensions */
	4	/* Stop extensions */
};
asn_TYPE_descriptor_t asn_DEF_TransportInfo = {
	"TransportInfo",
	"TransportInfo",
	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_TransportInfo_tags_1,
	sizeof(asn_DEF_TransportInfo_tags_1)
		/sizeof(asn_DEF_TransportInfo_tags_1[0]), /* 1 */
	asn_DEF_TransportInfo_tags_1,	/* Same as above */
	sizeof(asn_DEF_TransportInfo_tags_1)
		/sizeof(asn_DEF_TransportInfo_tags_1[0]), /* 1 */
	0,	/* No PER visible constraints */
	asn_MBR_TransportInfo_1,
	3,	/* Elements count */
	&asn_SPC_TransportInfo_specs_1	/* Additional specs */
};

