Issue-ID: SIM-18
[sim/e2-interface.git] / e2sim / e2apv1sim / encode_e2apv1.cpp
index dd26279..7484a45 100644 (file)
+#include <stdio.h>
+#include <string.h>
+#include <iostream>
+#include <unistd.h>
 
-#include "encode_e2apv1.hpp"
-
-void buildSubsReq(E2AP_PDU_t *pdu) {
-  ASN_STRUCT_RESET(asn_DEF_E2AP_PDU, pdu);
-
-  pdu->choice.initiatingMessage = (InitiatingMessage_t *)calloc(1, sizeof(InitiatingMessage_t));
-  pdu->present = E2AP_PDU_PR_initiatingMessage;
-
-  auto *initMsg = pdu->choice.initiatingMessage;
-  ASN_STRUCT_RESET(asn_DEF_InitiatingMessage, initMsg);
-  initMsg->procedureCode = ProcedureCode_id_RICsubscription;
-  initMsg->criticality = Criticality_reject;
-  initMsg->value.present = InitiatingMessage__value_PR_RICsubscriptionRequest;
-
-  auto *subReq = &(initMsg->value.choice.RICsubscriptionRequest);
-  ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest, subReq);
-
-  { // RICrequestID
-    auto *e = (RICsubscriptionRequest_IEs_t *)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
-    ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, e);
-    e->id = ProtocolIE_ID_id_RICrequestID;
-    e->value.present = RICsubscriptionRequest_IEs__value_PR_RICrequestID;
-    e->value.choice.RICrequestID.ricRequestorID = 88;
-    e->value.choice.RICrequestID.ricInstanceID = 5;
-    ASN_SEQUENCE_ADD(&subReq->protocolIEs.list, e);
-  }
-  { // RANfunctionID
-    auto *e = (RICsubscriptionRequest_IEs_t *)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
-    ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, e);
-    e->id = ProtocolIE_ID_id_RANfunctionID;
-    e->criticality = Criticality_reject;
-    e->value.present = RICsubscriptionRequest_IEs__value_PR_RANfunctionID;
-    e->value.choice.RANfunctionID = 8;
-    ASN_SEQUENCE_ADD(&subReq->protocolIEs.list, e);
-  }
-  { // RICrequestID
-    auto *e = (RICsubscriptionRequest_IEs_t *)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
-    ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, e);
-    e->id = ProtocolIE_ID_id_RICsubscriptionDetails;
-    e->criticality = Criticality_reject;
-    e->value.present = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
-
-    uint8_t buf[10] = {1,2,3,4,5,6,7,8,9,0} ;
-    e->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition.size = 10;
-    e->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition.buf = (uint8_t *)calloc(1, 10);
-    memcpy(e->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition.buf,
-          buf,
-          e->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition.size);
-    { // item 1
-      auto ie = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_ItemIEs_t));
-      ASN_STRUCT_RESET(asn_DEF_RICaction_ToBeSetup_ItemIEs, ie);
-      ie->id = ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
-      ie->criticality = Criticality_ignore;
-      ie->value.present = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionID = 22;
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionType = RICactionType_report;
-
-      auto *ad = (RICactionDefinition_t *)calloc(1, sizeof(RICactionDefinition_t));
-      ASN_STRUCT_RESET(asn_DEF_RICactionDefinition, ad);
-      ad->size = 10;
-      uint8_t buf[10] = {1,2,3,4,5,6,7,8,9,0} ;
-      ad->buf = (uint8_t *)calloc(1, ad->size);
-      memcpy(ad->buf, buf, ad->size);
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionDefinition = ad;
-
-      auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
-      ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
-
-      sa->ricTimeToWait = RICtimeToWait_w500ms;
-      sa->ricSubsequentActionType = RICsubsequentActionType_continue;
-
-      ie->value.choice.RICaction_ToBeSetup_Item.ricSubsequentAction = sa;
-      ASN_SEQUENCE_ADD(&e->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, ie);
-    }
-
-    { // item 2
-      auto ie = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_ItemIEs_t));
-      ASN_STRUCT_RESET(asn_DEF_RICaction_ToBeSetup_ItemIEs, ie);
-      ie->id = ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
-      ie->criticality = Criticality_ignore;
-      ie->value.present = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionID = 47;
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionType = RICactionType_policy;
-
-      auto *ad = (RICactionDefinition_t *)calloc(1, sizeof(RICactionDefinition_t));
-      ASN_STRUCT_RESET(asn_DEF_RICactionDefinition, ad);
-      ad->size = 10;
-      uint8_t buf[10] = {1,2,3,4,5,6,7,8,9,0} ;
-      ad->buf = (uint8_t *)calloc(1, ad->size);
-      memcpy(ad->buf, buf, ad->size);
-      ie->value.choice.RICaction_ToBeSetup_Item.ricActionDefinition = ad;
-
-      auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
-      ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
-
-      sa->ricTimeToWait = RICtimeToWait_w5s;
-      sa->ricSubsequentActionType = RICsubsequentActionType_wait;
-
-      ie->value.choice.RICaction_ToBeSetup_Item.ricSubsequentAction = sa;
-      ASN_SEQUENCE_ADD(&e->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, ie);
-    }
-
-    ASN_SEQUENCE_ADD(&subReq->protocolIEs.list, e);
-  }
+#include <iterator>
+#include <vector>
 
 
+#include "encode_e2apv1.hpp"
 
+extern "C" {
+#include "E2SM-KPM-RANfunction-Description.h"
+
+#include "e2ap_asn1c_codec.h"
+#include "GlobalE2node-ID.h"
+#include "GlobalE2node-gNB-ID.h"
+#include "GlobalgNB-ID.h"
+#include "OCTET_STRING.h"
+#include "asn_application.h"
+#include "GNB-ID-Choice.h"
+#include "ProtocolIE-Field.h"
+#include "E2setupRequest.h"
+#include "RICaction-ToBeSetup-Item.h"
+#include "RICactions-ToBeSetup-List.h"
+#include "RICeventTriggerDefinition.h"
+#include "RICsubscriptionRequest.h"
+#include "RICsubscriptionResponse.h"
+#include "ProtocolIE-SingleContainer.h"
+#include "RANfunctions-List.h"
+#include "RICindication.h"
+#include "RICsubsequentActionType.h"
+#include "RICsubsequentAction.h"  
+#include "RICtimeToWait.h"
+  
 }
 
 void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
   
-  //  uint8_t *buf = (uint8_t *)"gnb1";
+  //  uint8_t *buf = (uint8_t *)"gnb1"
 
   BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
   gnb_bstring->buf = (uint8_t*)calloc(1,4);
@@ -120,13 +47,13 @@ void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
   gnb_bstring->buf[2] = 0x77;
   gnb_bstring->buf[3] = 0x88;
 
-  gnb_bstring->bits_unused = 0;
+  gnb_bstring->bits_unused = 3;
 
-  uint8_t *buf2 = (uint8_t *)"plmn3";
+  uint8_t *buf2 = (uint8_t *)"747";
   OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
-  plmn->buf = (uint8_t*)calloc(1,5);
-  memcpy(plmn->buf, buf2, 5);;
-  plmn->size = 5;
+  plmn->buf = (uint8_t*)calloc(1,3);
+  memcpy(plmn->buf, buf2, 3);
+  plmn->size = 3;
 
   GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
   GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
@@ -146,15 +73,15 @@ void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
   globale2nodeid->present = pres;
   globale2nodeid->choice.gNB = e2gnb;
   
-  E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));;
+  E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
   E2setupRequestIEs__value_PR pres3;
   pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
-  e2setuprid->id = 4;
+  e2setuprid->id = 3;
   e2setuprid->criticality = 0;
   e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
   e2setuprid->value.present = pres3;
 
-  /*
+
   auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
   ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
   ranFlistIEs->criticality = 0;
@@ -167,16 +94,43 @@ void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
   itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
   itemIes->value.choice.RANfunction_Item.ranFunctionID = 1;
 
-  ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);  
-  */
+  E2SM_KPM_RANfunction_Description_t *ranfunc_desc =
+    (E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
+  encode_kpm_function_description(ranfunc_desc);
+
+  uint8_t e2smbuffer[8192];
+  size_t e2smbuffer_size = 8192;
+
+  asn_codec_ctx_t *opt_cod;  
+
+  asn_enc_rval_t er =
+    asn_encode_to_buffer(opt_cod,
+                        ATS_ALIGNED_BASIC_PER,
+                        &asn_DEF_E2SM_KPM_RANfunction_Description,
+                        ranfunc_desc, e2smbuffer, e2smbuffer_size);
+  
+  fprintf(stderr, "er encded is %d\n", er.encoded);
+  fprintf(stderr, "after encoding message\n");
+
+  OCTET_STRING_t *ranfuncdesc_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
+  ranfuncdesc_str->buf = (uint8_t*)calloc(1,er.encoded);
+  ranfuncdesc_str->size = er.encoded;
+  memcpy(ranfuncdesc_str->buf, e2smbuffer, er.encoded);
+  
+
+  itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *ranfuncdesc_str;
+  itemIes->value.choice.RANfunction_Item.ranFunctionRevision = (long)2;
+
+  ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
+
   E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
   ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2setuprid);
-  //  ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
+  ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
 
   InitiatingMessage__value_PR pres4;
   pres4 = InitiatingMessage__value_PR_E2setupRequest;
   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
-  //  initmsg->procedureCode = 1;
+
   initmsg->procedureCode = ProcedureCode_id_E2setup;
   initmsg->criticality = Criticality_reject;
   initmsg->value.present = pres4;
@@ -188,20 +142,7 @@ void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
 
   e2ap_pdu->present = pres5;
   e2ap_pdu->choice.initiatingMessage = initmsg;
-  /*
-  fprintf(stderr, "testing PER encoding of e2ap_pdu\n");
-
-  uint8_t e2apbuffer[8192];
-  size_t e2apbuffer_size = 8192;
-
-  auto er =
-    asn_encode_to_buffer(nullptr,
-                        ATS_ALIGNED_BASIC_PER,
-                        &asn_DEF_E2AP_PDU,
-                        e2ap_pdu, e2apbuffer, e2apbuffer_size);
 
-  fprintf(stderr, "er encded is %d\n", er.encoded);  
-  */
 }
 
 
@@ -336,7 +277,7 @@ void generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
   
   ricsubrid->criticality = 0;
   ricsubrid->value.present = pres3;
-  printf("sub6.3\n");    
+  printf("sub6.3\n");
 
   ricsubrid->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition = *triggerdef;
   printf("sub6.4\n");
@@ -385,7 +326,434 @@ void generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
 
 }
 
+void generate_e2apv1_subscription_response_success(E2AP_PDU *e2ap_pdu, long reqActionIdsAccepted[],
+                                                  long reqActionIdsRejected[], int accept_size, int reject_size,
+                                                  long reqRequestorId, long reqInstanceId) {
+
+  RICsubscriptionResponse_IEs_t *respricreqid =
+    (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+  
+  respricreqid->id = ProtocolIE_ID_id_RICrequestID;
+  respricreqid->criticality = 0;
+  respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
+  respricreqid->value.choice.RICrequestID.ricRequestorID = reqRequestorId;
+  
+  respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
+
+
+  RICsubscriptionResponse_IEs_t *ricactionadmitted =
+    (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+  ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
+  ricactionadmitted->criticality = 0;
+  ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
+
+  RICaction_Admitted_List_t* admlist = 
+    (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
+  ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
+
+  //  int numAccept = sizeof(reqActionIdsAccepted);
+  int numAccept = accept_size;
+  int numReject = reject_size;
+  //  int numReject = sizeof(reqActionIdsRejected);
+
+  
+  for (int i=0; i < numAccept ; i++) {
+    fprintf(stderr, "in for loop i = %d\n", i);
+
+    long aid = reqActionIdsAccepted[i];
+
+    RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
+    admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
+    admitie->criticality = 0;
+    admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
+    admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
+    
+    ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
+
+  }
+
+  RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
+  ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
+  ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
+  
+
+  if (numReject > 0) {
+
+    RICsubscriptionResponse_IEs_t *ricactionrejected =
+      (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+    ricactionrejected->id = ProtocolIE_ID_id_RICactions_NotAdmitted;
+    ricactionrejected->criticality = 0;
+    ricactionrejected->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_NotAdmitted_List;
+    
+    RICaction_NotAdmitted_List_t* rejectlist = 
+      (RICaction_NotAdmitted_List_t*)calloc(1,sizeof(RICaction_NotAdmitted_List_t));
+    ricactionadmitted->value.choice.RICaction_NotAdmitted_List = *rejectlist;
+    
+    for (int i=0; i < numReject; i++) {
+      fprintf(stderr, "in for loop i = %d\n", i);
+      
+      long aid = reqActionIdsRejected[i];
+      
+      RICaction_NotAdmitted_ItemIEs_t *noadmitie = (RICaction_NotAdmitted_ItemIEs_t*)calloc(1,sizeof(RICaction_NotAdmitted_ItemIEs_t));
+      noadmitie->id = ProtocolIE_ID_id_RICaction_NotAdmitted_Item;
+      noadmitie->criticality = 0;
+      noadmitie->value.present = RICaction_NotAdmitted_ItemIEs__value_PR_RICaction_NotAdmitted_Item;
+      noadmitie->value.choice.RICaction_NotAdmitted_Item.ricActionID = aid;
+      
+      ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
+      ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);      
+    }
+  }
+
+
+  SuccessfulOutcome__value_PR pres2;
+  pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
+  SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
+  successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
+  successoutcome->criticality = 0;
+  successoutcome->value.present = pres2;
+  successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
+
+  E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
+  
+  e2ap_pdu->present = pres5;
+  e2ap_pdu->choice.successfulOutcome = successoutcome;
+
+  char *error_buf = (char*)calloc(300, sizeof(char));
+  size_t errlen;
+
+  asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
+  printf("error length %d\n", errlen);
+  printf("error buf %s\n", error_buf);
+
+  
+}
+
+void generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
+
+  //Gather details of the request
+
+  RICsubscriptionRequest_t orig_req =
+    sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
+  
+  RICsubscriptionResponse_IEs_t *ricreqid =
+    (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+                                          
+  int count = orig_req.protocolIEs.list.count;
+  int size = orig_req.protocolIEs.list.size;
+  
+  RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
+
+  fprintf(stderr, "count%d\n", count);
+  fprintf(stderr, "size%d\n", size);
+
+  RICsubscriptionRequest_IEs__value_PR pres;
+
+  long responseRequestorId;
+  long responseInstanceId;
+  long responseActionId;
+
+  std::vector<long> actionIds;
+
+  for (int i=0; i < count; i++) {
+    RICsubscriptionRequest_IEs_t *next_ie = ies[i];
+    pres = next_ie->value.present;
+    
+    fprintf(stderr, "next present value %d\n", pres);
+
+    switch(pres) {
+    case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
+      {
+       RICrequestID_t reqId = next_ie->value.choice.RICrequestID;
+       long requestorId = reqId.ricRequestorID;
+       long instanceId = reqId.ricInstanceID;
+       fprintf(stderr, "requestorId %d\n", requestorId);
+       fprintf(stderr, "instanceId %d\n", instanceId);
+       responseRequestorId = requestorId;
+       responseInstanceId = instanceId;
+               
+       break;
+      }
+    case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
+      break;
+    case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
+      {
+       RICsubscriptionDetails_t subDetails = next_ie->value.choice.RICsubscriptionDetails; 
+       RICeventTriggerDefinition_t triggerDef = subDetails.ricEventTriggerDefinition;
+       RICactions_ToBeSetup_List_t actionList = subDetails.ricAction_ToBeSetup_List;
+       
+       int actionCount = actionList.list.count;
+       fprintf(stderr, "action count%d\n", actionCount);
+
+       auto **item_array = actionList.list.array;
+
+       for (int i=0; i < actionCount; i++) {
+         //RICaction_ToBeSetup_Item_t
+         auto *next_item = item_array[i];
+         RICactionID_t actionId = ((RICaction_ToBeSetup_ItemIEs*)next_item)->value.choice.RICaction_ToBeSetup_Item.ricActionID;
+         fprintf(stderr, "Next Action ID %ld\n", actionId);
+         responseActionId = actionId;
+         actionIds.push_back(responseActionId);
+       }
+       
+       break;
+      }
+    }
+    
+  }
+
+  fprintf(stderr, "After Processing Subscription Request\n");
+
+  fprintf(stderr, "requestorId %d\n", responseRequestorId);
+  fprintf(stderr, "instanceId %d\n", responseInstanceId);
+
+
+  for (int i=0; i < actionIds.size(); i++) {
+    fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
+    
+  }
+
+
+  RICsubscriptionResponse_IEs_t *respricreqid =
+    (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+  
+  respricreqid->id = ProtocolIE_ID_id_RICrequestID;
+  respricreqid->criticality = 0;
+  respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
+  respricreqid->value.choice.RICrequestID.ricRequestorID = responseRequestorId;
+  
+  respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
+
+
+  RICsubscriptionResponse_IEs_t *ricactionadmitted =
+    (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
+  ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
+  ricactionadmitted->criticality = 0;
+  ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
+
+  RICaction_Admitted_List_t* admlist = 
+    (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
+  ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
+
+  for (int i=0; i < actionIds.size(); i++) {
+    fprintf(stderr, "in for loop i = %d\n", i);
+
+    long aid = actionIds.at(i);
+
+    RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
+    admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
+    admitie->criticality = 0;
+    admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
+    admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
+    
+    ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
+
+  }
+
+
+  RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
+  
+  ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
+  ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
+
+
+  SuccessfulOutcome__value_PR pres2;
+  pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
+  SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
+  successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
+  successoutcome->criticality = 0;
+  successoutcome->value.present = pres2;
+  successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
+
+  E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
+  
+  e2ap_pdu->present = pres5;
+  e2ap_pdu->choice.successfulOutcome = successoutcome;
+
+  char *error_buf = (char*)calloc(300, sizeof(char));
+  size_t errlen;
+
+  asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
+  printf("error length %d\n", errlen);
+  printf("error buf %s\n", error_buf);
+  
+}
+
+void generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
+                                                     long requestorId,
+                                                     long instanceId,
+                                                     long ranFunctionId,
+                                                     long actionId,
+                                                     long seqNum,
+                                                     uint8_t *ind_header_buf,
+                                                     int header_length,
+                                                     uint8_t *ind_message_buf,
+                                                     int message_length) {
+
+  fprintf(stderr, "ind1\n");
+  RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+  RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
+
+  RICindication_IEs__value_PR pres3;
+
+  pres3 = RICindication_IEs__value_PR_RICrequestID;
+  ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
+  ricind_ies->criticality = 0;
+  ricind_ies->value.present = pres3;
+  ricind_ies->value.choice.RICrequestID.ricRequestorID = requestorId;
+  ricind_ies->value.choice.RICrequestID.ricInstanceID = instanceId;
+
+  fprintf(stderr, "ind2\n");
+
+  pres3 = RICindication_IEs__value_PR_RANfunctionID;
+  ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
+  ricind_ies2->criticality = 0;
+  ricind_ies2->value.present = pres3;
+  ricind_ies2->value.choice.RANfunctionID = ranFunctionId;
+
+  
+  ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
+  ricind_ies3->criticality = 0;
+  pres3 =  RICindication_IEs__value_PR_RICactionID;
+  ricind_ies3->value.present = pres3;
+  ricind_ies3->value.choice.RICactionID = actionId;
+
+
+  pres3 = RICindication_IEs__value_PR_RICindicationSN;
+  ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
+  ricind_ies4->criticality = 0;
+  ricind_ies4->value.present = pres3;
+  ricind_ies4->value.choice.RICindicationSN = seqNum;
+
+  //Indication type is REPORT
+  pres3 = RICindication_IEs__value_PR_RICindicationType;
+  ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
+  ricind_ies5->criticality = 0;
+  ricind_ies5->value.present = pres3;
+  ricind_ies5->value.choice.RICindicationType = 0;
+
+
+  uint8_t *buf2 = (uint8_t *)"reportheader";
+  OCTET_STRING_t *hdr_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
+
+  hdr_str->buf = (uint8_t*)calloc(1,header_length);
+  hdr_str->size = header_length;
+  memcpy(hdr_str->buf, ind_header_buf, header_length);
+
+  fprintf(stderr, "ind3\n");
+
+  ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
+
+  pres3 = RICindication_IEs__value_PR_RICindicationHeader;
+  ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
+  ricind_ies6->criticality = 0;
+  ricind_ies6->value.present = pres3;
+  ricind_ies6->value.choice.RICindicationHeader.size = header_length;
+  memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, ind_header_buf, header_length);
+  
+  ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
+
+
+  
+
+  pres3 = RICindication_IEs__value_PR_RICindicationMessage;
+  ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
+  fprintf(stderr, "after encoding message 1\n");
+
+  ricind_ies7->criticality = 0;
+  ricind_ies7->value.present = pres3;
+
+  fprintf(stderr, "after encoding message 2\n");
+
+  fprintf(stderr, "after encoding message 3\n");      
+  ricind_ies7->value.choice.RICindicationMessage.size = message_length;
+
+  fprintf(stderr, "after encoding message 4\n");
+  memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
+
+  fprintf(stderr, "after encoding message 5\n");      
+
+  uint8_t *cpid_buf = (uint8_t *)"cpid";
+  OCTET_STRING_t cpid_str;
+
+  printf("5.1\n");
+
+  int cpid_buf_len = strlen((char*)cpid_buf);
+  pres3 = RICindication_IEs__value_PR_RICcallProcessID;
+  ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
+
+  ricind_ies8->criticality = 0;
+  ricind_ies8->value.present = pres3;
+
+  ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
+  ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
+
+  memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
+
+  printf("5.2\n");
+
+  RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
+
+  
+  int ret;
+
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
+  
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
+
+  printf("5.3\n");
 
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
+
+  printf("5.35\n");
+  
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
+
+  printf("5.36\n");
+  
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
+
+  printf("5.4\n");
+  
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
+
+  printf("5.5\n");
+
+  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);  
+  
+  //  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);    
+
+
+  InitiatingMessage__value_PR pres4;
+  pres4 = InitiatingMessage__value_PR_RICindication;
+  InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
+  initmsg->procedureCode = 5;
+  initmsg->criticality = 1;
+  initmsg->value.present = pres4;
+  initmsg->value.choice.RICindication = *ricindication;
+
+  E2AP_PDU_PR pres5;
+  pres5 = E2AP_PDU_PR_initiatingMessage;
+  
+  e2ap_pdu->present = pres5;
+  e2ap_pdu->choice.initiatingMessage = initmsg;
+
+  char *error_buf = (char*)calloc(300, sizeof(char));
+  size_t errlen;
+
+  asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
+  printf("error length %d\n", errlen);
+  printf("error buf %s\n", error_buf);
+
+  xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);  
+
+}
 
 void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
   fprintf(stderr, "ind1\n");
@@ -454,15 +822,51 @@ void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
   memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, buf2, 12);
   
   ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
-  uint8_t *buf9 = (uint8_t *)"reportmsg";
-  OCTET_STRING_t *msg_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
-  msg_str->buf = (uint8_t*)calloc(1,9);
-  msg_str->size = 9;
-  memcpy(msg_str->buf, buf9, 9);
+  //  uint8_t *buf9 = (uint8_t *)"reportmsg";
+
+  /*
+  E2SM_KPM_IndicationMessage_t *e2sm_ind_msg =
+    (E2SM_KPM_IndicationMessage_t*)calloc(1,sizeof(E2SM_KPM_IndicationMessage_t));
+
+  encode_kpm(e2sm_ind_msg);
+  */
+
+  E2SM_KPM_RANfunction_Description_t *e2sm_desc =
+    (E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
+
+  encode_kpm_function_description(e2sm_desc);
+  
+  
+  uint8_t e2smbuffer[8192];
+  size_t e2smbuffer_size = 8192;
 
-  fprintf(stderr, "ind4\n");  
+  asn_codec_ctx_t *opt_cod;
+
+  
+  asn_enc_rval_t er =
+    asn_encode_to_buffer(opt_cod,
+                        ATS_ALIGNED_BASIC_PER,
+                        &asn_DEF_E2SM_KPM_RANfunction_Description,
+                        e2sm_desc, e2smbuffer, e2smbuffer_size);
+    
+    /*
+    asn_encode_to_buffer(opt_cod,
+                        ATS_ALIGNED_BASIC_PER,
+                        &asn_DEF_E2SM_KPM_IndicationMessage,
+                        e2sm_ind_msg, e2smbuffer, e2smbuffer_size);    
+    */
 
 
+  
+  fprintf(stderr, "er encded is %d\n", er.encoded);
+  fprintf(stderr, "after encoding message\n");
+  
+  OCTET_STRING_t *msg_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
+  msg_str->buf = (uint8_t*)calloc(1,er.encoded);
+  msg_str->size = er.encoded;
+  memcpy(msg_str->buf, e2smbuffer, er.encoded);
+  
+
   pres3 = RICindication_IEs__value_PR_RICindicationMessage;
   ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
   fprintf(stderr, "after encoding message 1\n");
@@ -473,10 +877,10 @@ void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
   fprintf(stderr, "after encoding message 2\n");
 
   fprintf(stderr, "after encoding message 3\n");      
-  ricind_ies7->value.choice.RICindicationMessage.size = 9;
+  ricind_ies7->value.choice.RICindicationMessage.size = er.encoded;
 
   fprintf(stderr, "after encoding message 4\n");      
-  memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, buf9, 9);
+  memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, e2smbuffer, er.encoded);
 
   fprintf(stderr, "after encoding message 5\n");      
 
@@ -536,5 +940,11 @@ void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
   printf("error length %d\n", errlen);
   printf("error buf %s\n", error_buf);
 
-  //  xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
+  xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
+}
+
+
+void generate_e2apv1_indication_response(E2AP_PDU *e2ap_pdu) {
+
+
 }