blob: 0ea1245b4568722d32b10a066f1fd0564bea4619 [file] [log] [blame]
/*** <<< INCLUDES [PacketId] >>> ***/
#include <NativeInteger.h>
/*** <<< TYPE-DECLS [PacketId] >>> ***/
typedef long PacketId_t;
/*** <<< FUNC-DECLS [PacketId] >>> ***/
extern asn_per_constraints_t asn_PER_type_PacketId_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_PacketId;
asn_struct_free_f PacketId_free;
asn_struct_print_f PacketId_print;
asn_constr_check_f PacketId_constraint;
ber_type_decoder_f PacketId_decode_ber;
der_type_encoder_f PacketId_encode_der;
xer_type_decoder_f PacketId_decode_xer;
xer_type_encoder_f PacketId_encode_xer;
per_type_decoder_f PacketId_decode_uper;
per_type_encoder_f PacketId_encode_uper;
/*** <<< CODE [PacketId] >>> ***/
int
PacketId_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
long value;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
value = *(const long *)sptr;
if((value >= 0 && value <= 65535)) {
/* Constraint check succeeded */
return 0;
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using NativeInteger,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [PacketId] >>> ***/
asn_per_constraints_t asn_PER_type_PacketId_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 16, 16, 0, 65535 } /* (0..65535) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [PacketId] >>> ***/
static const ber_tlv_tag_t asn_DEF_PacketId_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (2 << 2))
};
asn_TYPE_descriptor_t asn_DEF_PacketId = {
"PacketId",
"PacketId",
&asn_OP_NativeInteger,
asn_DEF_PacketId_tags_1,
sizeof(asn_DEF_PacketId_tags_1)
/sizeof(asn_DEF_PacketId_tags_1[0]), /* 1 */
asn_DEF_PacketId_tags_1, /* Same as above */
sizeof(asn_DEF_PacketId_tags_1)
/sizeof(asn_DEF_PacketId_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_PacketId_constr_1, PacketId_constraint },
0, 0, /* No members */
0 /* No specifics */
};
/*** <<< INCLUDES [Color] >>> ***/
#include <NativeEnumerated.h>
/*** <<< DEPS [Color] >>> ***/
typedef enum Color {
Color_red = 0,
Color_green = 1,
Color_blue = 2
} e_Color;
/*** <<< TYPE-DECLS [Color] >>> ***/
typedef long Color_t;
/*** <<< FUNC-DECLS [Color] >>> ***/
extern asn_per_constraints_t asn_PER_type_Color_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_Color;
extern const asn_INTEGER_specifics_t asn_SPC_Color_specs_1;
asn_struct_free_f Color_free;
asn_struct_print_f Color_print;
asn_constr_check_f Color_constraint;
ber_type_decoder_f Color_decode_ber;
der_type_encoder_f Color_encode_der;
xer_type_decoder_f Color_decode_xer;
xer_type_encoder_f Color_encode_xer;
per_type_decoder_f Color_decode_uper;
per_type_encoder_f Color_encode_uper;
/*** <<< CODE [Color] >>> ***/
/*
* This type is implemented using NativeEnumerated,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Color] >>> ***/
asn_per_constraints_t asn_PER_type_Color_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 2, 2, 0, 2 } /* (0..2) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Color] >>> ***/
static const asn_INTEGER_enum_map_t asn_MAP_Color_value2enum_1[] = {
{ 0, 3, "red" },
{ 1, 5, "green" },
{ 2, 4, "blue" }
};
static const unsigned int asn_MAP_Color_enum2value_1[] = {
2, /* blue(2) */
1, /* green(1) */
0 /* red(0) */
};
const asn_INTEGER_specifics_t asn_SPC_Color_specs_1 = {
asn_MAP_Color_value2enum_1, /* "tag" => N; sorted by tag */
asn_MAP_Color_enum2value_1, /* N => "tag"; sorted by N */
3, /* Number of elements in the maps */
0, /* Enumeration is not extensible */
1, /* Strict enumeration */
0, /* Native long size */
0
};
static const ber_tlv_tag_t asn_DEF_Color_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Color = {
"Color",
"Color",
&asn_OP_NativeEnumerated,
asn_DEF_Color_tags_1,
sizeof(asn_DEF_Color_tags_1)
/sizeof(asn_DEF_Color_tags_1[0]), /* 1 */
asn_DEF_Color_tags_1, /* Same as above */
sizeof(asn_DEF_Color_tags_1)
/sizeof(asn_DEF_Color_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Color_constr_1, NativeEnumerated_constraint },
0, 0, /* Defined elsewhere */
&asn_SPC_Color_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Valid] >>> ***/
#include <NativeEnumerated.h>
/*** <<< DEPS [Valid] >>> ***/
typedef enum Valid {
Valid_crc_nok = 0,
Valid_crc_ok = 1
} e_Valid;
/*** <<< TYPE-DECLS [Valid] >>> ***/
typedef long Valid_t;
/*** <<< FUNC-DECLS [Valid] >>> ***/
extern asn_per_constraints_t asn_PER_type_Valid_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_Valid;
extern const asn_INTEGER_specifics_t asn_SPC_Valid_specs_1;
asn_struct_free_f Valid_free;
asn_struct_print_f Valid_print;
asn_constr_check_f Valid_constraint;
ber_type_decoder_f Valid_decode_ber;
der_type_encoder_f Valid_encode_der;
xer_type_decoder_f Valid_decode_xer;
xer_type_encoder_f Valid_encode_xer;
per_type_decoder_f Valid_decode_uper;
per_type_encoder_f Valid_encode_uper;
/*** <<< CODE [Valid] >>> ***/
/*
* This type is implemented using NativeEnumerated,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Valid] >>> ***/
asn_per_constraints_t asn_PER_type_Valid_constr_1 CC_NOTUSED = {
{ APC_CONSTRAINED, 1, 1, 0, 1 } /* (0..1) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Valid] >>> ***/
static const asn_INTEGER_enum_map_t asn_MAP_Valid_value2enum_1[] = {
{ 0, 7, "crc-nok" },
{ 1, 6, "crc-ok" }
};
static const unsigned int asn_MAP_Valid_enum2value_1[] = {
0, /* crc-nok(0) */
1 /* crc-ok(1) */
};
const asn_INTEGER_specifics_t asn_SPC_Valid_specs_1 = {
asn_MAP_Valid_value2enum_1, /* "tag" => N; sorted by tag */
asn_MAP_Valid_enum2value_1, /* N => "tag"; sorted by N */
2, /* Number of elements in the maps */
0, /* Enumeration is not extensible */
1, /* Strict enumeration */
0, /* Native long size */
0
};
static const ber_tlv_tag_t asn_DEF_Valid_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (10 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Valid = {
"Valid",
"Valid",
&asn_OP_NativeEnumerated,
asn_DEF_Valid_tags_1,
sizeof(asn_DEF_Valid_tags_1)
/sizeof(asn_DEF_Valid_tags_1[0]), /* 1 */
asn_DEF_Valid_tags_1, /* Same as above */
sizeof(asn_DEF_Valid_tags_1)
/sizeof(asn_DEF_Valid_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Valid_constr_1, NativeEnumerated_constraint },
0, 0, /* Defined elsewhere */
&asn_SPC_Valid_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Packet-List] >>> ***/
#include "UpperLayer-List.h"
/*** <<< TYPE-DECLS [Packet-List] >>> ***/
typedef UpperLayer_List_41P0_t Packet_List_t;
/*** <<< FUNC-DECLS [Packet-List] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_Packet_List;
asn_struct_free_f Packet_List_free;
asn_struct_print_f Packet_List_print;
asn_constr_check_f Packet_List_constraint;
ber_type_decoder_f Packet_List_decode_ber;
der_type_encoder_f Packet_List_encode_der;
xer_type_decoder_f Packet_List_decode_xer;
xer_type_encoder_f Packet_List_encode_xer;
per_type_decoder_f Packet_List_decode_uper;
per_type_encoder_f Packet_List_encode_uper;
/*** <<< CODE [Packet-List] >>> ***/
int
Packet_List_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
size_t size;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
/* Determine the number of elements */
size = _A_CSEQUENCE_FROM_VOID(sptr)->count;
if((size >= 1 && size <= 256)) {
/* Perform validation of the inner elements */
return SEQUENCE_OF_constraint(td, sptr, ctfailcb, app_key);
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using UpperLayer_List_41P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [Packet-List] >>> ***/
static asn_per_constraints_t asn_PER_type_Packet_List_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Packet-List] >>> ***/
static const ber_tlv_tag_t asn_DEF_Packet_List_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_Packet_List = {
"Packet-List",
"Packet-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_Packet_List_tags_1,
sizeof(asn_DEF_Packet_List_tags_1)
/sizeof(asn_DEF_Packet_List_tags_1[0]), /* 1 */
asn_DEF_Packet_List_tags_1, /* Same as above */
sizeof(asn_DEF_Packet_List_tags_1)
/sizeof(asn_DEF_Packet_List_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_Packet_List_constr_1, Packet_List_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [UpperLayer-List] >>> ***/
#include "LowerLayer-List.h"
/*** <<< TYPE-DECLS [UpperLayer-List] >>> ***/
typedef LowerLayer_List_45P0_t UpperLayer_List_41P0_t;
/*** <<< FUNC-DECLS [UpperLayer-List] >>> ***/
extern asn_per_constraints_t asn_PER_type_UpperLayer_List_41P0_constr_1;
extern asn_TYPE_descriptor_t asn_DEF_UpperLayer_List_41P0;
asn_struct_free_f UpperLayer_List_41P0_free;
asn_struct_print_f UpperLayer_List_41P0_print;
asn_constr_check_f UpperLayer_List_41P0_constraint;
ber_type_decoder_f UpperLayer_List_41P0_decode_ber;
der_type_encoder_f UpperLayer_List_41P0_encode_der;
xer_type_decoder_f UpperLayer_List_41P0_decode_xer;
xer_type_encoder_f UpperLayer_List_41P0_encode_xer;
per_type_decoder_f UpperLayer_List_41P0_decode_uper;
per_type_encoder_f UpperLayer_List_41P0_encode_uper;
/*** <<< CODE [UpperLayer-List] >>> ***/
int
UpperLayer_List_41P0_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
size_t size;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
/* Determine the number of elements */
size = _A_CSEQUENCE_FROM_VOID(sptr)->count;
if((size >= 1 && size <= 256)) {
/* Perform validation of the inner elements */
return SEQUENCE_OF_constraint(td, sptr, ctfailcb, app_key);
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
/*
* This type is implemented using LowerLayer_List_45P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< CTDEFS [UpperLayer-List] >>> ***/
asn_per_constraints_t asn_PER_type_UpperLayer_List_41P0_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [UpperLayer-List] >>> ***/
static const ber_tlv_tag_t asn_DEF_UpperLayer_List_41P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_UpperLayer_List_41P0 = {
"UpperLayer-List",
"UpperLayer-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_UpperLayer_List_41P0_tags_1,
sizeof(asn_DEF_UpperLayer_List_41P0_tags_1)
/sizeof(asn_DEF_UpperLayer_List_41P0_tags_1[0]), /* 1 */
asn_DEF_UpperLayer_List_41P0_tags_1, /* Same as above */
sizeof(asn_DEF_UpperLayer_List_41P0_tags_1)
/sizeof(asn_DEF_UpperLayer_List_41P0_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_UpperLayer_List_41P0_constr_1, UpperLayer_List_41P0_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [LowerLayer-List] >>> ***/
#include <asn_SEQUENCE_OF.h>
#include <constr_SEQUENCE_OF.h>
/*** <<< FWD-DECLS [LowerLayer-List] >>> ***/
struct SinglePacket;
/*** <<< TYPE-DECLS [LowerLayer-List] >>> ***/
typedef struct LowerLayer_List_45P0 {
A_SEQUENCE_OF(struct SinglePacket) list;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} LowerLayer_List_45P0_t;
/*** <<< FUNC-DECLS [LowerLayer-List] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_LowerLayer_List_45P0;
extern asn_SET_OF_specifics_t asn_SPC_LowerLayer_List_45P0_specs_1;
extern asn_TYPE_member_t asn_MBR_LowerLayer_List_45P0_1[1];
extern asn_per_constraints_t asn_PER_type_LowerLayer_List_45P0_constr_1;
/*** <<< POST-INCLUDE [LowerLayer-List] >>> ***/
#include "SinglePacket.h"
/*** <<< CTDEFS [LowerLayer-List] >>> ***/
asn_per_constraints_t asn_PER_type_LowerLayer_List_45P0_constr_1 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_CONSTRAINED, 8, 8, 1, 256 } /* (SIZE(1..256)) */,
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [LowerLayer-List] >>> ***/
asn_TYPE_member_t asn_MBR_LowerLayer_List_45P0_1[] = {
{ ATF_POINTER, 0, 0,
.tag = (ASN_TAG_CLASS_UNIVERSAL | (16 << 2)),
.tag_mode = 0,
.type = &asn_DEF_SinglePacket_48P0,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = 0, .general_constraints = 0 },
0, 0, /* No default value */
.name = ""
},
};
static const ber_tlv_tag_t asn_DEF_LowerLayer_List_45P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_SET_OF_specifics_t asn_SPC_LowerLayer_List_45P0_specs_1 = {
sizeof(struct LowerLayer_List_45P0),
offsetof(struct LowerLayer_List_45P0, _asn_ctx),
0, /* XER encoding is XMLDelimitedItemList */
};
asn_TYPE_descriptor_t asn_DEF_LowerLayer_List_45P0 = {
"LowerLayer-List",
"LowerLayer-List",
&asn_OP_SEQUENCE_OF,
asn_DEF_LowerLayer_List_45P0_tags_1,
sizeof(asn_DEF_LowerLayer_List_45P0_tags_1)
/sizeof(asn_DEF_LowerLayer_List_45P0_tags_1[0]), /* 1 */
asn_DEF_LowerLayer_List_45P0_tags_1, /* Same as above */
sizeof(asn_DEF_LowerLayer_List_45P0_tags_1)
/sizeof(asn_DEF_LowerLayer_List_45P0_tags_1[0]), /* 1 */
{ 0, &asn_PER_type_LowerLayer_List_45P0_constr_1, SEQUENCE_OF_constraint },
asn_MBR_LowerLayer_List_45P0_1,
1, /* Single element */
&asn_SPC_LowerLayer_List_45P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [SinglePacket] >>> ***/
#include "Packet.h"
/*** <<< TYPE-DECLS [SinglePacket] >>> ***/
typedef Packet_51P0_t SinglePacket_48P0_t;
/*** <<< FUNC-DECLS [SinglePacket] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_SinglePacket_48P0;
asn_struct_free_f SinglePacket_48P0_free;
asn_struct_print_f SinglePacket_48P0_print;
asn_constr_check_f SinglePacket_48P0_constraint;
ber_type_decoder_f SinglePacket_48P0_decode_ber;
der_type_encoder_f SinglePacket_48P0_encode_der;
xer_type_decoder_f SinglePacket_48P0_decode_xer;
xer_type_encoder_f SinglePacket_48P0_encode_xer;
per_type_decoder_f SinglePacket_48P0_decode_uper;
per_type_encoder_f SinglePacket_48P0_encode_uper;
/*** <<< CODE [SinglePacket] >>> ***/
/*
* This type is implemented using Packet_51P0,
* so here we adjust the DEF accordingly.
*/
/*** <<< STAT-DEFS [SinglePacket] >>> ***/
static const ber_tlv_tag_t asn_DEF_SinglePacket_48P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
asn_TYPE_descriptor_t asn_DEF_SinglePacket_48P0 = {
"SinglePacket",
"SinglePacket",
&asn_OP_SEQUENCE,
asn_DEF_SinglePacket_48P0_tags_1,
sizeof(asn_DEF_SinglePacket_48P0_tags_1)
/sizeof(asn_DEF_SinglePacket_48P0_tags_1[0]), /* 1 */
asn_DEF_SinglePacket_48P0_tags_1, /* Same as above */
sizeof(asn_DEF_SinglePacket_48P0_tags_1)
/sizeof(asn_DEF_SinglePacket_48P0_tags_1[0]), /* 1 */
{ 0, 0, SEQUENCE_constraint },
asn_MBR_Packet_51P0_1,
3, /* Elements count */
&asn_SPC_Packet_51P0_specs_1 /* Additional specs */
};
/*** <<< INCLUDES [Packet] >>> ***/
#include "PacketId.h"
#include "Color.h"
#include <ANY.h>
#include <asn_ioc.h>
#include <OPEN_TYPE.h>
#include <constr_CHOICE.h>
#include <constr_SEQUENCE.h>
/*** <<< DEPS [Packet] >>> ***/
typedef enum value_PR {
value_PR_NOTHING, /* No components present */
} value_PR;
/*** <<< TYPE-DECLS [Packet] >>> ***/
typedef struct Packet_51P0 {
PacketId_t id;
Color_t color;
struct value {
value_PR present;
union Packet_51P0__value_u {
} choice;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} value;
/* Context for parsing across buffer boundaries */
asn_struct_ctx_t _asn_ctx;
} Packet_51P0_t;
/*** <<< FUNC-DECLS [Packet] >>> ***/
extern asn_TYPE_descriptor_t asn_DEF_Packet_51P0;
extern asn_SEQUENCE_specifics_t asn_SPC_Packet_51P0_specs_1;
extern asn_TYPE_member_t asn_MBR_Packet_51P0_1[3];
/*** <<< IOC-TABLES [Packet] >>> ***/
static const asn_ioc_cell_t asn_IOS_ClassItem_1_rows[] = {
};
static const asn_ioc_set_t asn_IOS_ClassItem_1[] = {
0, 0, asn_IOS_ClassItem_1_rows
};
/*** <<< CODE [Packet] >>> ***/
static int
memb_id_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
long value;
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
value = *(const long *)sptr;
if((value >= 0 && value <= 65535)) {
/* Constraint check succeeded */
return 0;
} else {
ASN__CTFAIL(app_key, td, sptr,
"%s: constraint failed (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
}
static int
memb_color_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
if(1 /* No applicable constraints whatsoever */) {
/* Nothing is here. See below */
}
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
}
static int
memb_value_constraint_1(const asn_TYPE_descriptor_t *td, const void *sptr,
asn_app_constraint_failed_f *ctfailcb, void *app_key) {
if(!sptr) {
ASN__CTFAIL(app_key, td, sptr,
"%s: value not given (%s:%d)",
td->name, __FILE__, __LINE__);
return -1;
}
if(1 /* No applicable constraints whatsoever */) {
/* Nothing is here. See below */
}
return td->encoding_constraints.general_constraints(td, sptr, ctfailcb, app_key);
}
/*** <<< CTDEFS [Packet] >>> ***/
static asn_per_constraints_t asn_PER_memb_id_constr_2 CC_NOTUSED = {
{ APC_CONSTRAINED, 16, 16, 0, 65535 } /* (0..65535) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
static asn_per_constraints_t asn_PER_memb_color_constr_3 CC_NOTUSED = {
{ APC_CONSTRAINED, 2, 2, 0, 2 } /* (0..2) */,
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
static asn_per_constraints_t asn_PER_memb_value_constr_4 CC_NOTUSED = {
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
{ APC_UNCONSTRAINED, -1, -1, 0, 0 },
0, 0 /* No PER value map */
};
/*** <<< STAT-DEFS [Packet] >>> ***/
static asn_CHOICE_specifics_t asn_SPC_value_specs_4 = {
sizeof(struct value),
offsetof(struct value, _asn_ctx),
offsetof(struct value, present),
sizeof(((struct value *)0)->present),
0, /* No top level tags */
0, /* No tags in the map */
0, 0,
.first_extension = -1 /* Extensions start */
};
static /* Use -fall-defs-global to expose */
asn_TYPE_descriptor_t asn_DEF_value_4 = {
"value",
"value",
&asn_OP_OPEN_TYPE,
0, /* No effective tags (pointer) */
0, /* No effective tags (count) */
0, /* No tags (pointer) */
0, /* No tags (count) */
{ 0, 0, OPEN_TYPE_constraint },
0, 0, /* No members */
&asn_SPC_value_specs_4 /* Additional specs */
};
asn_TYPE_member_t asn_MBR_Packet_51P0_1[] = {
{ ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, id),
.tag = (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)),
.tag_mode = 0,
.type = &asn_DEF_PacketId,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_id_constr_2, .general_constraints = memb_id_constraint_1 },
0, 0, /* No default value */
.name = "id"
},
{ ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, color),
.tag = (ASN_TAG_CLASS_UNIVERSAL | (10 << 2)),
.tag_mode = 0,
.type = &asn_DEF_Color,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_color_constr_3, .general_constraints = memb_color_constraint_1 },
0, 0, /* No default value */
.name = "color"
},
{ ATF_OPEN_TYPE | ATF_NOFLAGS, 0, offsetof(struct Packet_51P0, value),
.tag = -1 /* Ambiguous tag (ANY?) */,
.tag_mode = 0,
.type = &asn_DEF_value_4,
.type_selector = 0,
{ .oer_constraints = 0, .per_constraints = &asn_PER_memb_value_constr_4, .general_constraints = memb_value_constraint_1 },
0, 0, /* No default value */
.name = "value"
},
};
static const ber_tlv_tag_t asn_DEF_Packet_51P0_tags_1[] = {
(ASN_TAG_CLASS_UNIVERSAL | (16 << 2))
};
static const asn_TYPE_tag2member_t asn_MAP_Packet_51P0_tag2el_1[] = {
{ (ASN_TAG_CLASS_UNIVERSAL | (2 << 2)), 0, 0, 0 }, /* id */
{ (ASN_TAG_CLASS_UNIVERSAL | (10 << 2)), 1, 0, 0 } /* color */
};
asn_SEQUENCE_specifics_t asn_SPC_Packet_51P0_specs_1 = {
sizeof(struct Packet_51P0),
offsetof(struct Packet_51P0, _asn_ctx),
.tag2el = asn_MAP_Packet_51P0_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_Packet_51P0 = {
"Packet",
"Packet",
&asn_OP_SEQUENCE,
asn_DEF_Packet_51P0_tags_1,
sizeof(asn_DEF_Packet_51P0_tags_1)
/sizeof(asn_DEF_Packet_51P0_tags_1[0]), /* 1 */
asn_DEF_Packet_51P0_tags_1, /* Same as above */
sizeof(asn_DEF_Packet_51P0_tags_1)
/sizeof(asn_DEF_Packet_51P0_tags_1[0]), /* 1 */
{ 0, 0, SEQUENCE_constraint },
asn_MBR_Packet_51P0_1,
3, /* Elements count */
&asn_SPC_Packet_51P0_specs_1 /* Additional specs */
};