Add User-level metrics
Issue-ID: SIM-18

Signed-off-by: Ron Shacham <rshacham@research.att.com>
Change-Id: Ifcf571d8dfd23cafd2299464c0fadf65e7d25fe4
diff --git a/e2sim/e2apv1sim/ASN1c/C-RNTI.c b/e2sim/e2apv1sim/ASN1c/C-RNTI.c
new file mode 100644
index 0000000..e626083
--- /dev/null
+++ b/e2sim/e2apv1sim/ASN1c/C-RNTI.c
@@ -0,0 +1,65 @@
+/*
+ * Generated by asn1c-0.9.29 (http://lionet.info/asn1c)
+ * From ASN.1 module "E2SM-KPM-IEs"
+ * 	found in "/home/rshacham/e2sm-kpm-v01.02.asn"
+ * 	`asn1c -fcompound-names`
+ */
+
+#include "C-RNTI.h"
+
+int
+C_RNTI_constraint(const asn_TYPE_descriptor_t *td, const void *sptr,
+			asn_app_constraint_failed_f *ctfailcb, void *app_key) {
+	const OCTET_STRING_t *st = (const OCTET_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;
+	}
+	
+	size = st->size;
+	
+	if((size == 2)) {
+		/* 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 OCTET_STRING,
+ * so here we adjust the DEF accordingly.
+ */
+static asn_oer_constraints_t asn_OER_type_C_RNTI_constr_1 CC_NOTUSED = {
+	{ 0, 0 },
+	2	/* (SIZE(2..2)) */};
+asn_per_constraints_t asn_PER_type_C_RNTI_constr_1 CC_NOTUSED = {
+	{ APC_UNCONSTRAINED,	-1, -1,  0,  0 },
+	{ APC_CONSTRAINED,	 0,  0,  2,  2 }	/* (SIZE(2..2)) */,
+	0, 0	/* No PER value map */
+};
+static const ber_tlv_tag_t asn_DEF_C_RNTI_tags_1[] = {
+	(ASN_TAG_CLASS_UNIVERSAL | (4 << 2))
+};
+asn_TYPE_descriptor_t asn_DEF_C_RNTI = {
+	"C-RNTI",
+	"C-RNTI",
+	&asn_OP_OCTET_STRING,
+	asn_DEF_C_RNTI_tags_1,
+	sizeof(asn_DEF_C_RNTI_tags_1)
+		/sizeof(asn_DEF_C_RNTI_tags_1[0]), /* 1 */
+	asn_DEF_C_RNTI_tags_1,	/* Same as above */
+	sizeof(asn_DEF_C_RNTI_tags_1)
+		/sizeof(asn_DEF_C_RNTI_tags_1[0]), /* 1 */
+	{ &asn_OER_type_C_RNTI_constr_1, &asn_PER_type_C_RNTI_constr_1, C_RNTI_constraint },
+	0, 0,	/* No members */
+	&asn_SPC_OCTET_STRING_specs	/* Additional specs */
+};
+