3 /*****************************************************************************
5 # Copyright 2020 AT&T Intellectual Property *
7 # Licensed under the Apache License, Version 2.0 (the "License"); *
8 # you may not use this file except in compliance with the License. *
9 # You may obtain a copy of the License at *
11 # http://www.apache.org/licenses/LICENSE-2.0 *
13 # Unless required by applicable law or agreed to in writing, software *
14 # distributed under the License is distributed on an "AS IS" BASIS, *
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
16 # See the License for the specific language governing permissions and *
17 # limitations under the License. *
19 ******************************************************************************/
30 #include "encode_e2apv1.hpp"
33 //#include "E2SM-KPM-RANfunction-Description.h"
35 #include "e2ap_asn1c_codec.h"
36 #include "GlobalE2node-ID.h"
37 #include "GlobalE2node-gNB-ID.h"
38 #include "GlobalgNB-ID.h"
39 #include "OCTET_STRING.h"
40 #include "asn_application.h"
41 #include "GNB-ID-Choice.h"
42 #include "ProtocolIE-Field.h"
43 #include "E2setupRequest.h"
44 #include "RICaction-ToBeSetup-Item.h"
45 #include "RICactions-ToBeSetup-List.h"
46 #include "RICeventTriggerDefinition.h"
47 #include "RICsubscriptionRequest.h"
48 #include "RICsubscriptionResponse.h"
49 #include "ProtocolIE-SingleContainer.h"
50 #include "RANfunctions-List.h"
51 #include "RICindication.h"
52 #include "RICsubsequentActionType.h"
53 #include "RICsubsequentAction.h"
54 #include "RICtimeToWait.h"
58 long encoding::get_function_id_from_subscription(E2AP_PDU_t *e2ap_pdu) {
60 RICsubscriptionRequest_t orig_req =
61 e2ap_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
63 RICsubscriptionResponse_IEs_t *ricreqid =
64 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
66 int count = orig_req.protocolIEs.list.count;
67 int size = orig_req.protocolIEs.list.size;
69 RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
71 fprintf(stderr, "count%d\n", count);
72 fprintf(stderr, "size%d\n", size);
74 RICsubscriptionRequest_IEs__value_PR pres;
78 for (int i=0; i < count; i++) {
79 RICsubscriptionRequest_IEs_t *next_ie = ies[i];
80 pres = next_ie->value.present;
82 fprintf(stderr, "next present value %d\n", pres);
84 if (pres == RICsubscriptionRequest_IEs__value_PR_RANfunctionID) {
85 func_id = next_ie->value.choice.RANfunctionID;
94 void encoding::generate_e2apv1_setup_request_parameterized(E2AP_PDU_t *e2ap_pdu, std::vector<ran_func_info> all_funcs) {
95 // long ranFunctionId, uint8_t *ranFuncDescEncoded, int ranFuncLength) {
97 // uint8_t *buf = (uint8_t *)"gnb1"
99 BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
100 gnb_bstring->buf = (uint8_t*)calloc(1,4);
101 gnb_bstring->size = 4;
102 gnb_bstring->buf[0] = 0xB5;
103 gnb_bstring->buf[1] = 0xC6;
104 gnb_bstring->buf[2] = 0x77;
105 gnb_bstring->buf[3] = 0x88;
107 gnb_bstring->bits_unused = 3;
109 uint8_t *buf2 = (uint8_t *)"747";
110 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
111 plmn->buf = (uint8_t*)calloc(1,3);
112 memcpy(plmn->buf, buf2, 3);
115 GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
116 GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
117 gnbchoice->present = pres2;
118 gnbchoice->choice.gnb_ID = *gnb_bstring;
120 GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
121 gnb->plmn_id = *plmn;
122 gnb->gnb_id = *gnbchoice;
124 GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
125 e2gnb->global_gNB_ID = *gnb;
127 GlobalE2node_ID_t *globale2nodeid = (GlobalE2node_ID_t*)calloc(1, sizeof(GlobalE2node_ID_t));
128 GlobalE2node_ID_PR pres;
129 pres = GlobalE2node_ID_PR_gNB;
130 globale2nodeid->present = pres;
131 globale2nodeid->choice.gNB = e2gnb;
133 E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
134 E2setupRequestIEs__value_PR pres3;
135 pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
137 e2setuprid->criticality = 0;
138 e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
139 e2setuprid->value.present = pres3;
142 auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
143 ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
144 ranFlistIEs->criticality = 0;
145 ranFlistIEs->id = ProtocolIE_ID_id_RANfunctionsAdded;
146 ranFlistIEs->value.present = E2setupRequestIEs__value_PR_RANfunctions_List;
149 for (int i = 0; i < all_funcs.size(); i++) {
151 ran_func_info nextRanFunc = all_funcs.at(i);
152 long nextRanFuncId = nextRanFunc.ranFunctionId;
153 OCTET_STRING_t *nextRanFuncDesc = nextRanFunc.ranFunctionDesc;
154 long nextRanFuncRev = nextRanFunc.ranFunctionRev;
156 auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
157 itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
158 itemIes->criticality = Criticality_reject;
159 itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
160 itemIes->value.choice.RANfunction_Item.ranFunctionID = nextRanFuncId;
162 int ranFuncLength = strlen((char*)nextRanFuncDesc);
164 itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
165 itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev;
167 ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
171 E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
172 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2setuprid);
173 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
175 InitiatingMessage__value_PR pres4;
176 pres4 = InitiatingMessage__value_PR_E2setupRequest;
177 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
179 initmsg->procedureCode = ProcedureCode_id_E2setup;
180 initmsg->criticality = Criticality_reject;
181 initmsg->value.present = pres4;
182 initmsg->value.choice.E2setupRequest = *e2setupreq;
185 pres5 = E2AP_PDU_PR_initiatingMessage;
188 e2ap_pdu->present = pres5;
189 e2ap_pdu->choice.initiatingMessage = initmsg;
194 void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
196 // uint8_t *buf = (uint8_t *)"gnb1"
198 BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
199 gnb_bstring->buf = (uint8_t*)calloc(1,4);
200 gnb_bstring->size = 4;
201 gnb_bstring->buf[0] = 0xB5;
202 gnb_bstring->buf[1] = 0xC6;
203 gnb_bstring->buf[2] = 0x77;
204 gnb_bstring->buf[3] = 0x88;
206 gnb_bstring->bits_unused = 3;
208 uint8_t *buf2 = (uint8_t *)"747";
209 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
210 plmn->buf = (uint8_t*)calloc(1,3);
211 memcpy(plmn->buf, buf2, 3);
214 GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
215 GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
216 gnbchoice->present = pres2;
217 gnbchoice->choice.gnb_ID = *gnb_bstring;
219 GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
220 gnb->plmn_id = *plmn;
221 gnb->gnb_id = *gnbchoice;
223 GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
224 e2gnb->global_gNB_ID = *gnb;
226 GlobalE2node_ID_t *globale2nodeid = (GlobalE2node_ID_t*)calloc(1, sizeof(GlobalE2node_ID_t));
227 GlobalE2node_ID_PR pres;
228 pres = GlobalE2node_ID_PR_gNB;
229 globale2nodeid->present = pres;
230 globale2nodeid->choice.gNB = e2gnb;
232 E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
233 E2setupRequestIEs__value_PR pres3;
234 pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
236 e2setuprid->criticality = 0;
237 e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
238 e2setuprid->value.present = pres3;
241 auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
242 ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
243 ranFlistIEs->criticality = 0;
244 ranFlistIEs->id = ProtocolIE_ID_id_RANfunctionsAdded;
245 ranFlistIEs->value.present = E2setupRequestIEs__value_PR_RANfunctions_List;
247 auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
248 itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
249 itemIes->criticality = Criticality_reject;
250 itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
251 itemIes->value.choice.RANfunction_Item.ranFunctionID = 1;
253 E2SM_KPM_RANfunction_Description_t *ranfunc_desc =
254 (E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
255 encode_kpm_function_description(ranfunc_desc);
257 uint8_t e2smbuffer[8192];
258 size_t e2smbuffer_size = 8192;
260 asn_codec_ctx_t *opt_cod;
263 asn_encode_to_buffer(opt_cod,
264 ATS_ALIGNED_BASIC_PER,
265 &asn_DEF_E2SM_KPM_RANfunction_Description,
266 ranfunc_desc, e2smbuffer, e2smbuffer_size);
268 fprintf(stderr, "er encded is %d\n", er.encoded);
269 fprintf(stderr, "after encoding message\n");
271 OCTET_STRING_t *ranfuncdesc_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
272 ranfuncdesc_str->buf = (uint8_t*)calloc(1,er.encoded);
273 ranfuncdesc_str->size = er.encoded;
274 memcpy(ranfuncdesc_str->buf, e2smbuffer, er.encoded);
277 itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *ranfuncdesc_str;
278 itemIes->value.choice.RANfunction_Item.ranFunctionRevision = (long)2;
280 ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
282 E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
283 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2setuprid);
284 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
286 InitiatingMessage__value_PR pres4;
287 pres4 = InitiatingMessage__value_PR_E2setupRequest;
288 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
290 initmsg->procedureCode = ProcedureCode_id_E2setup;
291 initmsg->criticality = Criticality_reject;
292 initmsg->value.present = pres4;
293 initmsg->value.choice.E2setupRequest = *e2setupreq;
296 pres5 = E2AP_PDU_PR_initiatingMessage;
299 e2ap_pdu->present = pres5;
300 e2ap_pdu->choice.initiatingMessage = initmsg;
305 void encoding::generate_e2apv1_setup_response(E2AP_PDU_t *e2ap_pdu) {
307 E2setupResponseIEs *resp_ies1 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
308 E2setupResponseIEs *resp_ies2 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
309 E2setupResponseIEs *resp_ies3 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
311 uint8_t *buf = (uint8_t *)"gnb1";
313 BIT_STRING_t *ricid_bstring = (BIT_STRING_t*)calloc(1,sizeof(BIT_STRING_t));
314 ricid_bstring->buf = buf;
315 ricid_bstring->size = 4;
316 ricid_bstring->bits_unused = 0;
318 uint8_t *buf2 = (uint8_t *)"plmn3";
319 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
323 GlobalRIC_ID_t *globalricid = (GlobalRIC_ID_t*)calloc(1,sizeof(GlobalRIC_ID_t));
324 globalricid->pLMN_Identity = *plmn;
325 globalricid->ric_ID = *ricid_bstring;
327 E2setupResponseIEs__value_PR pres1;
328 pres1 = E2setupResponseIEs__value_PR_GlobalRIC_ID;
330 resp_ies1->id = ProtocolIE_ID_id_GlobalRIC_ID;
331 resp_ies1->criticality = 0;
332 resp_ies1->value.present = pres1;
333 resp_ies1->value.choice.GlobalRIC_ID = *globalricid;
335 E2setupResponse_t *e2setupresp = (E2setupResponse_t*)calloc(1,sizeof(E2setupResponse_t));
336 int ret = ASN_SEQUENCE_ADD(&e2setupresp->protocolIEs.list, resp_ies1);
339 SuccessfulOutcome__value_PR pres;
340 pres = SuccessfulOutcome__value_PR_E2setupResponse;
341 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
342 successoutcome->procedureCode = 1;
343 successoutcome->criticality = 0;
344 successoutcome->value.present = pres;
345 successoutcome->value.choice.E2setupResponse = *e2setupresp;
347 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
349 e2ap_pdu->present = pres5;
350 e2ap_pdu->choice.successfulOutcome = successoutcome;
355 void encoding::generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
357 fprintf(stderr, "in sub 1\n");
358 RICsubscriptionRequest_IEs_t *ricreqid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
359 fprintf(stderr, "in sub 2\n");
360 ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricreqid);
361 fprintf(stderr, "in sub 3\n");
362 auto *ricsubrid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
363 fprintf(stderr, "in sub 4\n");
364 ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricsubrid);
366 fprintf(stderr, "in generate sub\n");
367 uint8_t *buf2 = (uint8_t *)"SubscriptionTriggers";
368 fprintf(stderr, "in gen sub 1\n");
369 OCTET_STRING_t *triggerdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
370 triggerdef->buf = (uint8_t *)calloc(1,20);
371 triggerdef->size = 20;
372 memcpy(triggerdef->buf, buf2, triggerdef->size);
375 fprintf(stderr, "sub1\n");
376 ProtocolIE_ID_t proto_id= ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
378 RICaction_ToBeSetup_ItemIEs__value_PR pres6;
379 pres6 = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
383 uint8_t *buf5 = (uint8_t *)"ActionDef";
385 OCTET_STRING_t *actdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
386 actdef->buf = (uint8_t *)calloc(1,9);
388 memcpy(triggerdef->buf, buf5, 9);
390 auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
391 ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
393 sa->ricTimeToWait = RICtimeToWait_w500ms;
394 sa->ricSubsequentActionType = RICsubsequentActionType_continue;
398 RICaction_ToBeSetup_ItemIEs_t *action_item_ies = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_Item_t));
399 action_item_ies->id = proto_id;
400 action_item_ies->criticality = 0;
402 action_item_ies->value.present = pres6;
403 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionID = 5;
404 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionType = RICactionType_report;
405 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionDefinition = actdef;
406 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricSubsequentAction = sa;
412 RICsubscriptionRequest_IEs__value_PR pres3;
414 pres3 = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
415 ricsubrid->id = ProtocolIE_ID_id_RICsubscriptionDetails;
418 ricsubrid->criticality = 0;
419 ricsubrid->value.present = pres3;
422 ricsubrid->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition = *triggerdef;
425 ASN_SEQUENCE_ADD(&ricsubrid->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, action_item_ies);
430 ricreqid->id = ProtocolIE_ID_id_RICrequestID;
431 ricreqid->criticality = 0;
432 ricreqid->value.present = RICsubscriptionRequest_IEs__value_PR_RICrequestID;
433 ricreqid->value.choice.RICrequestID.ricRequestorID = 22;
434 ricreqid->value.choice.RICrequestID.ricInstanceID = 6;
436 RICsubscriptionRequest_t *ricsubreq = (RICsubscriptionRequest_t*)calloc(1, sizeof(RICsubscriptionRequest_t));
438 ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricreqid);
439 ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricsubrid);
443 InitiatingMessage__value_PR pres4;
444 pres4 = InitiatingMessage__value_PR_RICsubscriptionRequest;
445 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
446 initmsg->procedureCode = ProcedureCode_id_RICsubscription;
447 initmsg->criticality = Criticality_reject;
448 initmsg->value.present = pres4;
449 initmsg->value.choice.RICsubscriptionRequest = *ricsubreq;
452 pres5 = E2AP_PDU_PR_initiatingMessage;
455 e2ap_pdu->present = pres5;
456 e2ap_pdu->choice.initiatingMessage = initmsg;
458 char *error_buf = (char*)calloc(300, sizeof(char));;
461 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
462 printf("error length %d\n", errlen);
463 printf("error buf %s\n", error_buf);
468 void encoding::generate_e2apv1_subscription_response_success(E2AP_PDU *e2ap_pdu, long reqActionIdsAccepted[],
469 long reqActionIdsRejected[], int accept_size, int reject_size,
470 long reqRequestorId, long reqInstanceId) {
472 RICsubscriptionResponse_IEs_t *respricreqid =
473 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
475 respricreqid->id = ProtocolIE_ID_id_RICrequestID;
476 respricreqid->criticality = 0;
477 respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
478 respricreqid->value.choice.RICrequestID.ricRequestorID = reqRequestorId;
480 respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
483 RICsubscriptionResponse_IEs_t *ricactionadmitted =
484 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
485 ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
486 ricactionadmitted->criticality = 0;
487 ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
489 RICaction_Admitted_List_t* admlist =
490 (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
491 ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
494 int numAccept = accept_size;
495 int numReject = reject_size;
499 for (int i=0; i < numAccept ; i++) {
500 fprintf(stderr, "in for loop i = %d\n", i);
502 long aid = reqActionIdsAccepted[i];
504 RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
505 admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
506 admitie->criticality = 0;
507 admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
508 admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
510 ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
514 RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
515 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
516 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
521 RICsubscriptionResponse_IEs_t *ricactionrejected =
522 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
523 ricactionrejected->id = ProtocolIE_ID_id_RICactions_NotAdmitted;
524 ricactionrejected->criticality = 0;
525 ricactionrejected->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_NotAdmitted_List;
527 RICaction_NotAdmitted_List_t* rejectlist =
528 (RICaction_NotAdmitted_List_t*)calloc(1,sizeof(RICaction_NotAdmitted_List_t));
529 ricactionadmitted->value.choice.RICaction_NotAdmitted_List = *rejectlist;
531 for (int i=0; i < numReject; i++) {
532 fprintf(stderr, "in for loop i = %d\n", i);
534 long aid = reqActionIdsRejected[i];
536 RICaction_NotAdmitted_ItemIEs_t *noadmitie = (RICaction_NotAdmitted_ItemIEs_t*)calloc(1,sizeof(RICaction_NotAdmitted_ItemIEs_t));
537 noadmitie->id = ProtocolIE_ID_id_RICaction_NotAdmitted_Item;
538 noadmitie->criticality = 0;
539 noadmitie->value.present = RICaction_NotAdmitted_ItemIEs__value_PR_RICaction_NotAdmitted_Item;
540 noadmitie->value.choice.RICaction_NotAdmitted_Item.ricActionID = aid;
542 ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
543 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);
548 SuccessfulOutcome__value_PR pres2;
549 pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
550 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
551 successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
552 successoutcome->criticality = 0;
553 successoutcome->value.present = pres2;
554 successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
556 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
558 e2ap_pdu->present = pres5;
559 e2ap_pdu->choice.successfulOutcome = successoutcome;
561 char *error_buf = (char*)calloc(300, sizeof(char));
564 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
565 printf("error length %d\n", errlen);
566 printf("error buf %s\n", error_buf);
571 void encoding::generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
573 //Gather details of the request
575 RICsubscriptionRequest_t orig_req =
576 sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
578 RICsubscriptionResponse_IEs_t *ricreqid =
579 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
581 int count = orig_req.protocolIEs.list.count;
582 int size = orig_req.protocolIEs.list.size;
584 RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
586 fprintf(stderr, "count%d\n", count);
587 fprintf(stderr, "size%d\n", size);
589 RICsubscriptionRequest_IEs__value_PR pres;
591 long responseRequestorId;
592 long responseInstanceId;
593 long responseActionId;
595 std::vector<long> actionIds;
597 for (int i=0; i < count; i++) {
598 RICsubscriptionRequest_IEs_t *next_ie = ies[i];
599 pres = next_ie->value.present;
601 fprintf(stderr, "next present value %d\n", pres);
604 case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
606 RICrequestID_t reqId = next_ie->value.choice.RICrequestID;
607 long requestorId = reqId.ricRequestorID;
608 long instanceId = reqId.ricInstanceID;
609 fprintf(stderr, "requestorId %d\n", requestorId);
610 fprintf(stderr, "instanceId %d\n", instanceId);
611 responseRequestorId = requestorId;
612 responseInstanceId = instanceId;
616 case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
618 case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
620 RICsubscriptionDetails_t subDetails = next_ie->value.choice.RICsubscriptionDetails;
621 RICeventTriggerDefinition_t triggerDef = subDetails.ricEventTriggerDefinition;
622 RICactions_ToBeSetup_List_t actionList = subDetails.ricAction_ToBeSetup_List;
624 int actionCount = actionList.list.count;
625 fprintf(stderr, "action count%d\n", actionCount);
627 auto **item_array = actionList.list.array;
629 for (int i=0; i < actionCount; i++) {
630 //RICaction_ToBeSetup_Item_t
631 auto *next_item = item_array[i];
632 RICactionID_t actionId = ((RICaction_ToBeSetup_ItemIEs*)next_item)->value.choice.RICaction_ToBeSetup_Item.ricActionID;
633 fprintf(stderr, "Next Action ID %ld\n", actionId);
634 responseActionId = actionId;
635 actionIds.push_back(responseActionId);
644 fprintf(stderr, "After Processing Subscription Request\n");
646 fprintf(stderr, "requestorId %d\n", responseRequestorId);
647 fprintf(stderr, "instanceId %d\n", responseInstanceId);
650 for (int i=0; i < actionIds.size(); i++) {
651 fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
656 RICsubscriptionResponse_IEs_t *respricreqid =
657 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
659 respricreqid->id = ProtocolIE_ID_id_RICrequestID;
660 respricreqid->criticality = 0;
661 respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
662 respricreqid->value.choice.RICrequestID.ricRequestorID = responseRequestorId;
664 respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
667 RICsubscriptionResponse_IEs_t *ricactionadmitted =
668 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
669 ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
670 ricactionadmitted->criticality = 0;
671 ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
673 RICaction_Admitted_List_t* admlist =
674 (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
675 ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
677 for (int i=0; i < actionIds.size(); i++) {
678 fprintf(stderr, "in for loop i = %d\n", i);
680 long aid = actionIds.at(i);
682 RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
683 admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
684 admitie->criticality = 0;
685 admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
686 admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
688 ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
693 RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
695 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
696 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
699 SuccessfulOutcome__value_PR pres2;
700 pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
701 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
702 successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
703 successoutcome->criticality = 0;
704 successoutcome->value.present = pres2;
705 successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
707 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
709 e2ap_pdu->present = pres5;
710 e2ap_pdu->choice.successfulOutcome = successoutcome;
712 char *error_buf = (char*)calloc(300, sizeof(char));
715 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
716 printf("error length %d\n", errlen);
717 printf("error buf %s\n", error_buf);
721 void encoding::generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
727 uint8_t *ind_header_buf,
729 uint8_t *ind_message_buf,
730 int message_length) {
732 fprintf(stderr, "ind1\n");
733 RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
734 RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
735 RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
736 RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
737 RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
738 RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
739 RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
740 RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
742 RICindication_IEs__value_PR pres3;
744 pres3 = RICindication_IEs__value_PR_RICrequestID;
745 ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
746 ricind_ies->criticality = 0;
747 ricind_ies->value.present = pres3;
748 ricind_ies->value.choice.RICrequestID.ricRequestorID = requestorId;
749 ricind_ies->value.choice.RICrequestID.ricInstanceID = instanceId;
751 fprintf(stderr, "ind2\n");
753 pres3 = RICindication_IEs__value_PR_RANfunctionID;
754 ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
755 ricind_ies2->criticality = 0;
756 ricind_ies2->value.present = pres3;
757 ricind_ies2->value.choice.RANfunctionID = ranFunctionId;
760 ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
761 ricind_ies3->criticality = 0;
762 pres3 = RICindication_IEs__value_PR_RICactionID;
763 ricind_ies3->value.present = pres3;
764 ricind_ies3->value.choice.RICactionID = actionId;
767 pres3 = RICindication_IEs__value_PR_RICindicationSN;
768 ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
769 ricind_ies4->criticality = 0;
770 ricind_ies4->value.present = pres3;
771 ricind_ies4->value.choice.RICindicationSN = seqNum;
773 //Indication type is REPORT
774 pres3 = RICindication_IEs__value_PR_RICindicationType;
775 ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
776 ricind_ies5->criticality = 0;
777 ricind_ies5->value.present = pres3;
778 ricind_ies5->value.choice.RICindicationType = 0;
781 uint8_t *buf2 = (uint8_t *)"reportheader";
782 OCTET_STRING_t *hdr_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
784 hdr_str->buf = (uint8_t*)calloc(1,header_length);
785 hdr_str->size = header_length;
786 memcpy(hdr_str->buf, ind_header_buf, header_length);
788 fprintf(stderr, "ind3\n");
790 ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
792 pres3 = RICindication_IEs__value_PR_RICindicationHeader;
793 ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
794 ricind_ies6->criticality = 0;
795 ricind_ies6->value.present = pres3;
796 ricind_ies6->value.choice.RICindicationHeader.size = header_length;
797 memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, ind_header_buf, header_length);
799 ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
804 pres3 = RICindication_IEs__value_PR_RICindicationMessage;
805 ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
806 fprintf(stderr, "after encoding message 1\n");
808 ricind_ies7->criticality = 0;
809 ricind_ies7->value.present = pres3;
811 fprintf(stderr, "after encoding message 2\n");
813 fprintf(stderr, "after encoding message 3\n");
814 ricind_ies7->value.choice.RICindicationMessage.size = message_length;
816 fprintf(stderr, "after encoding message 4\n");
817 memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
819 fprintf(stderr, "after encoding message 5\n");
821 uint8_t *cpid_buf = (uint8_t *)"cpid";
822 OCTET_STRING_t cpid_str;
826 int cpid_buf_len = strlen((char*)cpid_buf);
827 pres3 = RICindication_IEs__value_PR_RICcallProcessID;
828 ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
830 ricind_ies8->criticality = 0;
831 ricind_ies8->value.present = pres3;
833 ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
834 ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
836 memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
840 RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
845 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
847 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
851 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
855 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
859 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
863 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
867 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);
869 // ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);
872 InitiatingMessage__value_PR pres4;
873 pres4 = InitiatingMessage__value_PR_RICindication;
874 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
875 initmsg->procedureCode = 5;
876 initmsg->criticality = 1;
877 initmsg->value.present = pres4;
878 initmsg->value.choice.RICindication = *ricindication;
881 pres5 = E2AP_PDU_PR_initiatingMessage;
883 e2ap_pdu->present = pres5;
884 e2ap_pdu->choice.initiatingMessage = initmsg;
886 char *error_buf = (char*)calloc(300, sizeof(char));
889 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
890 printf("error length %d\n", errlen);
891 printf("error buf %s\n", error_buf);
893 xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
898 void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
899 fprintf(stderr, "ind1\n");
900 RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
901 RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
902 RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
903 RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
904 RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
905 RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
906 RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
907 RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
909 RICindication_IEs__value_PR pres3;
911 pres3 = RICindication_IEs__value_PR_RICrequestID;
912 ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
913 ricind_ies->criticality = 0;
914 ricind_ies->value.present = pres3;
915 ricind_ies->value.choice.RICrequestID.ricRequestorID = 25;
916 ricind_ies->value.choice.RICrequestID.ricInstanceID = 3;
918 fprintf(stderr, "ind2\n");
920 pres3 = RICindication_IEs__value_PR_RANfunctionID;
921 ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
922 ricind_ies2->criticality = 0;
923 ricind_ies2->value.present = pres3;
924 ricind_ies2->value.choice.RANfunctionID = 70;
927 ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
928 ricind_ies3->criticality = 0;
929 pres3 = RICindication_IEs__value_PR_RICactionID;
930 ricind_ies3->value.present = pres3;
931 ricind_ies3->value.choice.RICactionID = 80;
934 pres3 = RICindication_IEs__value_PR_RICindicationSN;
935 ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
936 ricind_ies4->criticality = 0;
937 ricind_ies4->value.present = pres3;
938 ricind_ies4->value.choice.RICindicationSN = 45;
940 pres3 = RICindication_IEs__value_PR_RICindicationType;
941 ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
942 ricind_ies5->criticality = 0;
943 ricind_ies5->value.present = pres3;
944 ricind_ies5->value.choice.RICindicationType = 0;
947 uint8_t *buf2 = (uint8_t *)"reportheader";
948 OCTET_STRING_t *hdr_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
949 hdr_str->buf = (uint8_t*)calloc(1,12);
951 memcpy(hdr_str->buf, buf2, 12);
953 fprintf(stderr, "ind3\n");
955 ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,12);
957 pres3 = RICindication_IEs__value_PR_RICindicationHeader;
958 ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
959 ricind_ies6->criticality = 0;
960 ricind_ies6->value.present = pres3;
961 ricind_ies6->value.choice.RICindicationHeader.size = 12;
962 memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, buf2, 12);
964 ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
968 E2SM_KPM_RANfunction_Description_t *e2sm_desc =
969 (E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
971 encode_kpm_function_description(e2sm_desc);
974 uint8_t e2smbuffer[8192];
975 size_t e2smbuffer_size = 8192;
977 asn_codec_ctx_t *opt_cod;
981 asn_encode_to_buffer(opt_cod,
982 ATS_ALIGNED_BASIC_PER,
983 &asn_DEF_E2SM_KPM_RANfunction_Description,
984 e2sm_desc, e2smbuffer, e2smbuffer_size);
987 fprintf(stderr, "er encded is %d\n", er.encoded);
988 fprintf(stderr, "after encoding message\n");
990 OCTET_STRING_t *msg_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
991 msg_str->buf = (uint8_t*)calloc(1,er.encoded);
992 msg_str->size = er.encoded;
993 memcpy(msg_str->buf, e2smbuffer, er.encoded);
996 pres3 = RICindication_IEs__value_PR_RICindicationMessage;
997 ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
998 fprintf(stderr, "after encoding message 1\n");
1000 ricind_ies7->criticality = 0;
1001 ricind_ies7->value.present = pres3;
1003 fprintf(stderr, "after encoding message 2\n");
1005 fprintf(stderr, "after encoding message 3\n");
1006 ricind_ies7->value.choice.RICindicationMessage.size = er.encoded;
1008 fprintf(stderr, "after encoding message 4\n");
1009 memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, e2smbuffer, er.encoded);
1011 fprintf(stderr, "after encoding message 5\n");
1013 uint8_t *buf4 = (uint8_t *)"cpid";
1014 OCTET_STRING_t cpid_str;
1015 cpid_str.buf = buf4;
1019 pres3 = RICindication_IEs__value_PR_RICcallProcessID;
1020 ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
1022 ricind_ies8->criticality = 0;
1023 ricind_ies8->value.present = pres3;
1025 ricind_ies8->value.choice.RICcallProcessID = cpid_str;
1028 RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
1034 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
1036 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
1038 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
1039 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
1040 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
1042 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
1045 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);
1047 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);
1050 InitiatingMessage__value_PR pres4;
1051 pres4 = InitiatingMessage__value_PR_RICindication;
1052 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
1053 initmsg->procedureCode = 5;
1054 initmsg->criticality = 1;
1055 initmsg->value.present = pres4;
1056 initmsg->value.choice.RICindication = *ricindication;
1059 pres5 = E2AP_PDU_PR_initiatingMessage;
1061 e2ap_pdu->present = pres5;
1062 e2ap_pdu->choice.initiatingMessage = initmsg;
1064 char *error_buf = (char*)calloc(300, sizeof(char));;
1067 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
1068 printf("error length %d\n", errlen);
1069 printf("error buf %s\n", error_buf);
1071 xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);