3 /*****************************************************************************
5 # Copyright 2020 AT&T Intellectual Property *
6 # Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved. *
8 # Licensed under the Apache License, Version 2.0 (the "License"); *
9 # you may not use this file except in compliance with the License. *
10 # You may obtain a copy of the License at *
12 # http://www.apache.org/licenses/LICENSE-2.0 *
14 # Unless required by applicable law or agreed to in writing, software *
15 # distributed under the License is distributed on an "AS IS" BASIS, *
16 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
17 # See the License for the specific language governing permissions and *
18 # limitations under the License. *
20 ******************************************************************************/
31 #include "encode_e2apv1.hpp"
36 #include "e2ap_asn1c_codec.h"
37 #include "GlobalE2node-ID.h"
38 #include "GlobalE2node-gNB-ID.h"
39 #include "GlobalgNB-ID.h"
40 #include "OCTET_STRING.h"
41 #include "asn_application.h"
42 #include "GNB-ID-Choice.h"
43 #include "ProtocolIE-Field.h"
44 #include "E2setupRequest.h"
45 #include "RICaction-ToBeSetup-Item.h"
46 #include "RICactions-ToBeSetup-List.h"
47 #include "RICeventTriggerDefinition.h"
48 #include "RICsubscriptionRequest.h"
49 #include "RICsubscriptionResponse.h"
50 #include "ProtocolIE-SingleContainer.h"
51 #include "RANfunctions-List.h"
52 #include "RICindication.h"
53 #include "RICsubsequentActionType.h"
54 #include "RICsubsequentAction.h"
55 #include "RICtimeToWait.h"
56 #include "E2nodeComponentInterfaceNG.h"
57 // #include "E2nodeComponentGNB-CU-UP-ID.h"
58 // #include "E2nodeComponentID.h"
59 // #include "E2nodeComponentConfigUpdate.h"
60 // #include "E2nodeComponentConfigUpdateGNB.h"
64 long encoding::get_function_id_from_subscription(E2AP_PDU_t *e2ap_pdu) {
66 RICsubscriptionRequest_t orig_req =
67 e2ap_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
69 int count = orig_req.protocolIEs.list.count;
70 int size = orig_req.protocolIEs.list.size;
72 RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
74 fprintf(stderr, "count%d\n", count);
75 fprintf(stderr, "size%d\n", size);
77 RICsubscriptionRequest_IEs__value_PR pres;
81 for (int i=0; i < count; i++) {
82 RICsubscriptionRequest_IEs_t *next_ie = ies[i];
83 pres = next_ie->value.present;
85 fprintf(stderr, "next present value %d\n", pres);
86 fprintf(stderr, "value of pres ranfuncid is %d\n", RICsubscriptionRequest_IEs__value_PR_RANfunctionID);
88 if (pres == RICsubscriptionRequest_IEs__value_PR_RANfunctionID) {
89 fprintf(stderr, "equal pres to ranfuncid\n");
90 func_id = next_ie->value.choice.RANfunctionID;
95 fprintf(stderr, "After loop, func_id is %d\n", func_id);
101 void encoding::generate_e2apv1_service_update(E2AP_PDU_t *e2ap_pdu, std::vector<encoding::ran_func_info> all_funcs) {
102 char* ran_function_op_type = getenv("RAN_FUNCTION_OP_TYPE");
103 LOG_D("Ran funciton : %s", ran_function_op_type);
104 ProtocolIE_ID_t prID;
105 if (ran_function_op_type != NULL)
107 if (strcmp(ran_function_op_type, "ADD") == 0)
109 prID = ProtocolIE_ID_id_RANfunctionsAdded;
111 else if (strcmp(ran_function_op_type, "DELETE"))
113 prID = ProtocolIE_ID_id_RANfunctionsDeleted;
118 prID = ProtocolIE_ID_id_RANfunctionsModified;
122 RICserviceUpdate_IEs_t *e2serviceUpdateList = (RICserviceUpdate_IEs_t *)calloc(1, sizeof(RICserviceUpdate_IEs_t));
123 e2serviceUpdateList->id = prID;
124 e2serviceUpdateList->criticality = Criticality_reject;
125 e2serviceUpdateList->value.present = RICserviceUpdate_IEs__value_PR_RANfunctions_List;
128 for (int i=0; i<all_funcs.size(); i++) {
130 encoding::ran_func_info nextRanFunc = all_funcs.at(i);
131 long nextRanFuncId = nextRanFunc.ranFunctionId;
132 OCTET_STRING_t *nextRanFuncDesc = nextRanFunc.ranFunctionDesc;
133 long nextRanFuncRev = nextRanFunc.ranFunctionRev;
135 auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
136 itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
137 itemIes->criticality = Criticality_reject;
138 itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
139 itemIes->value.choice.RANfunction_Item.ranFunctionID = 1;
141 itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
142 itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev + 1;
144 ASN_SEQUENCE_ADD(&e2serviceUpdateList->value.choice.RANfunctions_List.list, itemIes);
147 RICserviceUpdate_t *ricServiceUpdate = (RICserviceUpdate_t *)calloc(1, sizeof(RICserviceUpdate_t));
148 ASN_SEQUENCE_ADD(&ricServiceUpdate->protocolIEs.list, e2serviceUpdateList);
150 InitiatingMessage_t *initiatingMessage = (InitiatingMessage_t *)calloc(1, sizeof(InitiatingMessage_t));
151 initiatingMessage->criticality = Criticality_reject;
152 initiatingMessage->procedureCode = ProcedureCode_id_RICserviceUpdate;
153 initiatingMessage->value.present = InitiatingMessage__value_PR_RICserviceUpdate;
154 initiatingMessage->value.choice.RICserviceUpdate = *ricServiceUpdate;
156 E2AP_PDU_PR pres6 = E2AP_PDU_PR_initiatingMessage;
157 e2ap_pdu->present = pres6;
158 e2ap_pdu->choice.initiatingMessage = initiatingMessage;
161 void encoding::generate_e2apv1_setup_request_parameterized(E2AP_PDU_t *e2ap_pdu, std::vector<ran_func_info> all_funcs) {
163 BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
164 gnb_bstring->buf = (uint8_t*)calloc(1,4);
165 gnb_bstring->size = 4;
166 gnb_bstring->buf[0] = 0xB5;
167 gnb_bstring->buf[1] = 0xC6;
168 gnb_bstring->buf[2] = 0x77;
169 gnb_bstring->buf[3] = 0x88;
171 gnb_bstring->bits_unused = 3;
173 uint8_t *buf2 = (uint8_t *)"747";
174 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
175 plmn->buf = (uint8_t*)calloc(1,3);
176 memcpy(plmn->buf, buf2, 3);
179 GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
180 GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
181 gnbchoice->present = pres2;
182 gnbchoice->choice.gnb_ID = *gnb_bstring;
183 if (gnb_bstring) free(gnb_bstring);
185 GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
186 gnb->plmn_id = *plmn;
187 gnb->gnb_id = *gnbchoice;
188 if (plmn) free(plmn);
189 if (gnbchoice) free(gnbchoice);
191 GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
192 e2gnb->global_gNB_ID = *gnb;
195 GlobalE2node_ID_t *globale2nodeid = (GlobalE2node_ID_t*)calloc(1, sizeof(GlobalE2node_ID_t));
196 GlobalE2node_ID_PR pres;
197 pres = GlobalE2node_ID_PR_gNB;
198 globale2nodeid->present = pres;
199 globale2nodeid->choice.gNB = e2gnb;
201 E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
202 E2setupRequestIEs__value_PR pres3;
203 pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
205 e2setuprid->criticality = 0;
206 e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
207 e2setuprid->value.present = pres3;
208 if(globale2nodeid) free(globale2nodeid);
212 auto *e2txid = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
213 e2txid->id = ProtocolIE_ID_id_TransactionID;
214 e2txid-> criticality = 0;
215 e2txid->value.present = E2setupRequestIEs__value_PR_TransactionID;
216 e2txid->value.choice.TransactionID = 1;
218 auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
219 ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
220 ranFlistIEs->criticality = 0;
221 ranFlistIEs->id = ProtocolIE_ID_id_RANfunctionsAdded;
222 ranFlistIEs->value.present = E2setupRequestIEs__value_PR_RANfunctions_List;
225 for (int i = 0; i < all_funcs.size(); i++) {
227 ran_func_info nextRanFunc = all_funcs.at(i);
228 long nextRanFuncId = nextRanFunc.ranFunctionId;
229 OCTET_STRING_t *nextRanFuncDesc = nextRanFunc.ranFunctionDesc;
230 long nextRanFuncRev = nextRanFunc.ranFunctionRev;
232 auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
233 itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
234 itemIes->criticality = Criticality_reject;
235 itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
236 itemIes->value.choice.RANfunction_Item.ranFunctionID = nextRanFuncId;
237 itemIes->value.choice.RANfunction_Item.ranFunctionOID = RANfunctionOID_t(*(nextRanFunc.ranFunctionOId));
238 int ranFuncLength = strlen((char*)nextRanFuncDesc);
240 itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
241 itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev;
243 ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
247 auto *e2configIE = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
248 e2configIE->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition;
249 e2configIE->criticality = Criticality_reject;
250 e2configIE->value.present = E2setupRequestIEs__value_PR_E2nodeComponentConfigAddition_List;
253 auto *e2configAdditionItem = (E2nodeComponentConfigAddition_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigAddition_ItemIEs_t));
254 e2configAdditionItem->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition_Item;
255 e2configAdditionItem->criticality = Criticality_reject;
256 e2configAdditionItem->value.present = E2nodeComponentConfigAddition_ItemIEs__value_PR_E2nodeComponentConfigAddition_Item;
258 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentInterfaceType = E2nodeComponentInterfaceType_ng;
259 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.present = E2nodeComponentID_PR_e2nodeComponentInterfaceTypeNG;
261 auto *intfNG = (E2nodeComponentInterfaceNG_t *) calloc(1, sizeof(E2nodeComponentInterfaceNG_t));
263 OCTET_STRING_t nginterf;
264 nginterf.buf = (uint8_t*)calloc(1,8);
265 memcpy(nginterf.buf, (uint8_t *)"nginterf", 8);
268 intfNG->amf_name = (AMFName_t)(nginterf);
270 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.choice.e2nodeComponentInterfaceTypeNG = intfNG;
272 OCTET_STRING_t reqPart;
273 reqPart.buf = (uint8_t*)calloc(1,7);
274 memcpy(reqPart.buf, (uint8_t *)"reqpart", 7);
277 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentRequestPart = reqPart;
279 OCTET_STRING_t resPart;
280 resPart.buf = (uint8_t*)calloc(1,7);
281 memcpy(resPart.buf, (uint8_t *)"respart", 7);
283 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentResponsePart = resPart;
286 ASN_SEQUENCE_ADD(&e2configIE->value.choice.RANfunctions_List.list, e2configAdditionItem);
288 auto *e2nodeconfigupdatelistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
289 ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, e2nodeconfigupdatelistIEs);
290 e2nodeconfigupdatelistIEs->criticality = 0;
291 e2nodeconfigupdatelistIEs->id = ProtocolIE_ID_id_E2nodeComponentConfigUpdate;
292 e2nodeconfigupdatelistIEs->value.present = E2setupRequestIEs__value_PR_E2nodeComponentConfigUpdate_List;
295 OCTET_STRING_t *ngAPconfigUpdate = (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
296 ngAPconfigUpdate->buf = (uint8_t*)calloc(1,13);
297 memcpy(ngAPconfigUpdate->buf, (uint8_t *)"gnbngapupdate", 13);
298 ngAPconfigUpdate->size = 13;
300 OCTET_STRING_t *xnAPconfigUpdate = (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
301 xnAPconfigUpdate->buf = (uint8_t*)calloc(1,13);
302 memcpy(xnAPconfigUpdate->buf, (uint8_t *)"gnbxnapupdate", 13);
303 xnAPconfigUpdate->size = 13;
305 OCTET_STRING_t *e1APconfigUpdate = (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
306 e1APconfigUpdate->buf = (uint8_t*)calloc(1,13);
307 memcpy(e1APconfigUpdate->buf, (uint8_t *)"gnbe1apupdate", 13);
308 e1APconfigUpdate->size = 13;
310 OCTET_STRING_t *f1APconfigUpdate = (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
311 f1APconfigUpdate->buf = (uint8_t*)calloc(1,13);
312 memcpy(f1APconfigUpdate->buf, (uint8_t *)"gnbf1apupdate", 13);
313 f1APconfigUpdate->size = 13;
315 E2nodeComponentConfigUpdateGNB_t *e2nodecomponentconfigupdategnb = (E2nodeComponentConfigUpdateGNB_t *)calloc(1,sizeof(E2nodeComponentConfigUpdateGNB_t));
316 e2nodecomponentconfigupdategnb->ngAPconfigUpdate = ngAPconfigUpdate;
317 e2nodecomponentconfigupdategnb->xnAPconfigUpdate = xnAPconfigUpdate;
318 e2nodecomponentconfigupdategnb->e1APconfigUpdate = e1APconfigUpdate;
319 e2nodecomponentconfigupdategnb->f1APconfigUpdate = f1APconfigUpdate;
321 E2nodeComponentConfigUpdate_t e2nodecomponentconfigupdate = {};
322 e2nodecomponentconfigupdate.present = E2nodeComponentConfigUpdate_PR_gNBconfigUpdate;
323 e2nodecomponentconfigupdate.choice.gNBconfigUpdate = e2nodecomponentconfigupdategnb;
325 GNB_CU_UP_ID_t gnbcuupid = {};
326 gnbcuupid.buf = (uint8_t*)calloc(1,4);
327 memcpy(gnbcuupid.buf, (uint8_t *)"1234", 4);
330 E2nodeComponentGNB_CU_UP_ID_t *e2nodecomponentgnbcuupid = (E2nodeComponentGNB_CU_UP_ID_t *)calloc(1,sizeof(E2nodeComponentGNB_CU_UP_ID_t));
331 e2nodecomponentgnbcuupid->gNB_CU_UP_ID = gnbcuupid;
333 E2nodeComponentID_t *e2nodecomponentid = (E2nodeComponentID_t*)calloc(1, sizeof(E2nodeComponentID_t));
335 e2nodecomponentid->present = E2nodeComponentID_PR_e2nodeComponentTypeGNB_CU_UP;
336 e2nodecomponentid->choice.e2nodeComponentTypeGNB_CU_UP = e2nodecomponentgnbcuupid;
338 auto *configupdateitemIes = (E2nodeComponentConfigUpdate_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigUpdate_ItemIEs_t));
339 configupdateitemIes->id = ProtocolIE_ID_id_E2nodeComponentConfigUpdate_Item;
340 configupdateitemIes->criticality = Criticality_reject;
341 configupdateitemIes->value.present = E2nodeComponentConfigUpdate_ItemIEs__value_PR_E2nodeComponentConfigUpdate_Item;
342 configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentType = E2nodeComponentType_gNB_CU_UP;
343 configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentID = e2nodecomponentid;
344 configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentConfigUpdate = e2nodecomponentconfigupdate;
346 ASN_SEQUENCE_ADD(&e2nodeconfigupdatelistIEs->value.choice.E2nodeComponentConfigUpdate_List.list, configupdateitemIes);
348 E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
349 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2txid);
350 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2setuprid);
351 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
352 ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2configIE);
355 InitiatingMessage__value_PR pres4;
356 pres4 = InitiatingMessage__value_PR_E2setupRequest;
357 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
359 initmsg->procedureCode = ProcedureCode_id_E2setup;
360 initmsg->criticality = Criticality_reject;
361 initmsg->value.present = pres4;
362 initmsg->value.choice.E2setupRequest = *e2setupreq;
363 if (e2setupreq) free(e2setupreq);
366 pres5 = E2AP_PDU_PR_initiatingMessage;
369 e2ap_pdu->present = pres5;
370 e2ap_pdu->choice.initiatingMessage = initmsg;
374 void encoding::generate_e2apv2_config_update(E2AP_PDU_t *e2ap_pdu){
376 auto *e2txidIE = (E2nodeConfigurationUpdate_IEs_t *)calloc(1, sizeof(E2nodeConfigurationUpdate_IEs_t));
377 e2txidIE->id = ProtocolIE_ID_id_TransactionID;
378 e2txidIE-> criticality = Criticality_reject;
379 e2txidIE->value.present = E2nodeConfigurationUpdate_IEs__value_PR_TransactionID;
380 e2txidIE->value.choice.TransactionID = 1;
382 /// config update id for addtion list
383 auto *e2configIE = (E2nodeConfigurationUpdate_IEs_t *)calloc(1, sizeof(E2nodeConfigurationUpdate_IEs_t));
384 e2configIE->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition;
385 e2configIE->criticality = Criticality_reject;
386 e2configIE->value.present = E2nodeConfigurationUpdate_IEs__value_PR_E2nodeComponentConfigAddition_List;
389 auto *e2configAdditionItem = (E2nodeComponentConfigAddition_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigAddition_ItemIEs_t));
390 e2configAdditionItem->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition_Item;
391 e2configAdditionItem->criticality = Criticality_reject;
392 e2configAdditionItem->value.present = E2nodeComponentConfigAddition_ItemIEs__value_PR_E2nodeComponentConfigAddition_Item;
394 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentInterfaceType = E2nodeComponentInterfaceType_ng;
395 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.present = E2nodeComponentID_PR_e2nodeComponentInterfaceTypeNG;
397 auto *intfNG = (E2nodeComponentInterfaceNG_t *) calloc(1, sizeof(E2nodeComponentInterfaceNG_t));
399 OCTET_STRING_t nginterf;
400 nginterf.buf = (uint8_t*)calloc(1,8);
401 memcpy(nginterf.buf, (uint8_t *)"nginterf", 8);
404 intfNG->amf_name = (AMFName_t)(nginterf);
406 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.choice.e2nodeComponentInterfaceTypeNG = intfNG;
408 OCTET_STRING_t reqPart;
409 reqPart.buf = (uint8_t*)calloc(1,7);
410 memcpy(reqPart.buf, (uint8_t *)"reqpart", 7);
413 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentRequestPart = reqPart;
415 OCTET_STRING_t resPart;
416 resPart.buf = (uint8_t*)calloc(1,7);
417 memcpy(resPart.buf, (uint8_t *)"respart", 7);
419 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentResponsePart = resPart;
421 ASN_SEQUENCE_ADD(&e2configIE->value.choice.E2nodeComponentConfigAddition_List, e2configAdditionItem);
423 InitiatingMessage *inititingMsg = (InitiatingMessage *) calloc(1, sizeof(InitiatingMessage));
424 inititingMsg->procedureCode = ProcedureCode_id_E2nodeConfigurationUpdate;
425 inititingMsg->criticality = Criticality_reject;
426 inititingMsg->value.present = InitiatingMessage__value_PR_E2nodeConfigurationUpdate;
427 ASN_SEQUENCE_ADD(&inititingMsg->value.choice.E2nodeConfigurationUpdate.protocolIEs.list, e2txidIE);
428 ASN_SEQUENCE_ADD(&inititingMsg->value.choice.E2nodeConfigurationUpdate.protocolIEs.list, e2configIE);
429 e2ap_pdu->present = E2AP_PDU_PR_initiatingMessage;
430 e2ap_pdu->choice.initiatingMessage = inititingMsg;
433 void encoding::generate_e2apv1_setup_response(E2AP_PDU_t *e2ap_pdu) {
435 E2setupResponseIEs *resp_ies1 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
436 E2setupResponseIEs *resp_ies2 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
437 E2setupResponseIEs *resp_ies3 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
439 uint8_t *buf = (uint8_t *)"gnb1";
441 BIT_STRING_t *ricid_bstring = (BIT_STRING_t*)calloc(1,sizeof(BIT_STRING_t));
442 ricid_bstring->buf = buf;
443 ricid_bstring->size = 4;
444 ricid_bstring->bits_unused = 0;
446 uint8_t *buf2 = (uint8_t *)"plmn3";
447 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
451 GlobalRIC_ID_t *globalricid = (GlobalRIC_ID_t*)calloc(1,sizeof(GlobalRIC_ID_t));
452 globalricid->pLMN_Identity = *plmn;
453 globalricid->ric_ID = *ricid_bstring;
455 E2setupResponseIEs__value_PR pres1;
456 pres1 = E2setupResponseIEs__value_PR_GlobalRIC_ID;
458 resp_ies1->id = ProtocolIE_ID_id_GlobalRIC_ID;
459 resp_ies1->criticality = 0;
460 resp_ies1->value.present = pres1;
461 resp_ies1->value.choice.GlobalRIC_ID = *globalricid;
463 E2setupResponse_t *e2setupresp = (E2setupResponse_t*)calloc(1,sizeof(E2setupResponse_t));
464 int ret = ASN_SEQUENCE_ADD(&e2setupresp->protocolIEs.list, resp_ies1);
467 SuccessfulOutcome__value_PR pres;
468 pres = SuccessfulOutcome__value_PR_E2setupResponse;
469 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
470 successoutcome->procedureCode = 1;
471 successoutcome->criticality = 0;
472 successoutcome->value.present = pres;
473 successoutcome->value.choice.E2setupResponse = *e2setupresp;
475 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
477 e2ap_pdu->present = pres5;
478 e2ap_pdu->choice.successfulOutcome = successoutcome;
483 void encoding::generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
485 fprintf(stderr, "in sub 1\n");
486 RICsubscriptionRequest_IEs_t *ricreqid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
487 fprintf(stderr, "in sub 2\n");
488 ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricreqid);
489 fprintf(stderr, "in sub 3\n");
490 auto *ricsubrid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
491 fprintf(stderr, "in sub 4\n");
492 ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricsubrid);
494 fprintf(stderr, "in generate sub\n");
495 uint8_t *buf2 = (uint8_t *)"SubscriptionTriggers";
496 fprintf(stderr, "in gen sub 1\n");
497 OCTET_STRING_t *triggerdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
498 triggerdef->buf = (uint8_t *)calloc(1,20);
499 triggerdef->size = 20;
500 memcpy(triggerdef->buf, buf2, triggerdef->size);
503 fprintf(stderr, "sub1\n");
504 ProtocolIE_ID_t proto_id= ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
506 RICaction_ToBeSetup_ItemIEs__value_PR pres6;
507 pres6 = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
511 uint8_t *buf5 = (uint8_t *)"ActionDef";
513 OCTET_STRING_t *actdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
514 actdef->buf = (uint8_t *)calloc(1,9);
516 memcpy(triggerdef->buf, buf5, 9);
518 auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
519 ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
521 sa->ricTimeToWait = RICtimeToWait_w500ms;
522 sa->ricSubsequentActionType = RICsubsequentActionType_continue;
526 RICaction_ToBeSetup_ItemIEs_t *action_item_ies = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_Item_t));
527 action_item_ies->id = proto_id;
528 action_item_ies->criticality = 0;
530 action_item_ies->value.present = pres6;
531 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionID = 5;
532 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionType = RICactionType_report;
533 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionDefinition = actdef;
534 action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricSubsequentAction = sa;
540 RICsubscriptionRequest_IEs__value_PR pres3;
542 pres3 = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
543 ricsubrid->id = ProtocolIE_ID_id_RICsubscriptionDetails;
546 ricsubrid->criticality = 0;
547 ricsubrid->value.present = pres3;
550 ricsubrid->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition = *triggerdef;
553 ASN_SEQUENCE_ADD(&ricsubrid->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, action_item_ies);
558 ricreqid->id = ProtocolIE_ID_id_RICrequestID;
559 ricreqid->criticality = 0;
560 ricreqid->value.present = RICsubscriptionRequest_IEs__value_PR_RICrequestID;
561 ricreqid->value.choice.RICrequestID.ricRequestorID = 22;
562 ricreqid->value.choice.RICrequestID.ricInstanceID = 6;
564 RICsubscriptionRequest_t *ricsubreq = (RICsubscriptionRequest_t*)calloc(1, sizeof(RICsubscriptionRequest_t));
566 ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricreqid);
567 ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricsubrid);
571 InitiatingMessage__value_PR pres4;
572 pres4 = InitiatingMessage__value_PR_RICsubscriptionRequest;
573 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
574 initmsg->procedureCode = ProcedureCode_id_RICsubscription;
575 initmsg->criticality = Criticality_reject;
576 initmsg->value.present = pres4;
577 initmsg->value.choice.RICsubscriptionRequest = *ricsubreq;
580 pres5 = E2AP_PDU_PR_initiatingMessage;
583 e2ap_pdu->present = pres5;
584 e2ap_pdu->choice.initiatingMessage = initmsg;
586 char error_buf[300] = {0, };
589 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
590 printf("error length %d\n", errlen);
591 printf("error buf %s\n", error_buf);
596 void encoding::generate_e2apv1_subscription_response_success(E2AP_PDU *e2ap_pdu, long reqActionIdsAccepted[],
597 long reqActionIdsRejected[], int accept_size, int reject_size,
598 long reqRequestorId, long reqInstanceId) {
600 RICsubscriptionResponse_IEs_t *respricreqid =
601 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
603 respricreqid->id = ProtocolIE_ID_id_RICrequestID;
604 respricreqid->criticality = 0;
605 respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
606 respricreqid->value.choice.RICrequestID.ricRequestorID = reqRequestorId;
608 respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
610 RICsubscriptionResponse_IEs_t *respfuncid =
611 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
612 respfuncid->id = ProtocolIE_ID_id_RANfunctionID;
613 respfuncid->criticality = 0;
614 respfuncid->value.present = RICsubscriptionResponse_IEs__value_PR_RANfunctionID;
615 respfuncid->value.choice.RANfunctionID = (long)0;
618 RICsubscriptionResponse_IEs_t *ricactionadmitted =
619 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
620 ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
621 ricactionadmitted->criticality = 0;
622 ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
624 RICaction_Admitted_List_t* admlist =
625 (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
626 ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
627 if (admlist) free(admlist);
630 int numAccept = accept_size;
631 int numReject = reject_size;
635 for (int i=0; i < numAccept ; i++) {
636 fprintf(stderr, "in for loop i = %d\n", i);
638 long aid = reqActionIdsAccepted[i];
640 RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
641 admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
642 admitie->criticality = 0;
643 admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
644 admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
646 ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
650 RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
651 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
652 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respfuncid);
653 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
658 RICsubscriptionResponse_IEs_t *ricactionrejected =
659 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
660 ricactionrejected->id = ProtocolIE_ID_id_RICactions_NotAdmitted;
661 ricactionrejected->criticality = 0;
662 ricactionrejected->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_NotAdmitted_List;
664 RICaction_NotAdmitted_List_t* rejectlist =
665 (RICaction_NotAdmitted_List_t*)calloc(1,sizeof(RICaction_NotAdmitted_List_t));
666 ricactionadmitted->value.choice.RICaction_NotAdmitted_List = *rejectlist;
668 for (int i=0; i < numReject; i++) {
669 fprintf(stderr, "in for loop i = %d\n", i);
671 long aid = reqActionIdsRejected[i];
673 RICaction_NotAdmitted_ItemIEs_t *noadmitie = (RICaction_NotAdmitted_ItemIEs_t*)calloc(1,sizeof(RICaction_NotAdmitted_ItemIEs_t));
674 noadmitie->id = ProtocolIE_ID_id_RICaction_NotAdmitted_Item;
675 noadmitie->criticality = 0;
676 noadmitie->value.present = RICaction_NotAdmitted_ItemIEs__value_PR_RICaction_NotAdmitted_Item;
677 noadmitie->value.choice.RICaction_NotAdmitted_Item.ricActionID = aid;
679 ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
680 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);
685 SuccessfulOutcome__value_PR pres2;
686 pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
687 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
688 successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
689 successoutcome->criticality = 0;
690 successoutcome->value.present = pres2;
691 successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
692 if (ricsubresp) free(ricsubresp);
694 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
696 e2ap_pdu->present = pres5;
697 e2ap_pdu->choice.successfulOutcome = successoutcome;
699 char error_buf[300] = {0, };
702 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
703 printf("error length %d\n", errlen);
704 printf("error buf %s\n", error_buf);
706 printf("now printing xer of subscription response\n");
707 xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
708 printf("done printing xer of subscription response\n");
713 void encoding::generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
715 //Gather details of the request
717 RICsubscriptionRequest_t orig_req =
718 sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
720 RICsubscriptionResponse_IEs_t *ricreqid =
721 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
723 int count = orig_req.protocolIEs.list.count;
724 int size = orig_req.protocolIEs.list.size;
726 RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
728 fprintf(stderr, "count%d\n", count);
729 fprintf(stderr, "size%d\n", size);
731 RICsubscriptionRequest_IEs__value_PR pres;
733 long responseRequestorId;
734 long responseInstanceId;
735 long responseActionId;
737 std::vector<long> actionIds;
739 for (int i=0; i < count; i++) {
740 RICsubscriptionRequest_IEs_t *next_ie = ies[i];
741 pres = next_ie->value.present;
743 fprintf(stderr, "next present value %d\n", pres);
746 case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
748 RICrequestID_t reqId = next_ie->value.choice.RICrequestID;
749 long requestorId = reqId.ricRequestorID;
750 long instanceId = reqId.ricInstanceID;
751 fprintf(stderr, "requestorId %d\n", requestorId);
752 fprintf(stderr, "instanceId %d\n", instanceId);
753 responseRequestorId = requestorId;
754 responseInstanceId = instanceId;
758 case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
760 case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
762 RICsubscriptionDetails_t subDetails = next_ie->value.choice.RICsubscriptionDetails;
763 RICeventTriggerDefinition_t triggerDef = subDetails.ricEventTriggerDefinition;
764 RICactions_ToBeSetup_List_t actionList = subDetails.ricAction_ToBeSetup_List;
766 int actionCount = actionList.list.count;
767 fprintf(stderr, "action count%d\n", actionCount);
769 auto **item_array = actionList.list.array;
771 for (int i=0; i < actionCount; i++) {
772 //RICaction_ToBeSetup_Item_t
773 auto *next_item = item_array[i];
774 RICactionID_t actionId = ((RICaction_ToBeSetup_ItemIEs*)next_item)->value.choice.RICaction_ToBeSetup_Item.ricActionID;
775 fprintf(stderr, "Next Action ID %ld\n", actionId);
776 responseActionId = actionId;
777 actionIds.push_back(responseActionId);
786 fprintf(stderr, "After Processing Subscription Request\n");
788 fprintf(stderr, "requestorId %d\n", responseRequestorId);
789 fprintf(stderr, "instanceId %d\n", responseInstanceId);
792 for (int i=0; i < actionIds.size(); i++) {
793 fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
798 RICsubscriptionResponse_IEs_t *respricreqid =
799 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
801 respricreqid->id = ProtocolIE_ID_id_RICrequestID;
802 respricreqid->criticality = 0;
803 respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
804 respricreqid->value.choice.RICrequestID.ricRequestorID = responseRequestorId;
806 respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
809 RICsubscriptionResponse_IEs_t *ricactionadmitted =
810 (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
811 ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
812 ricactionadmitted->criticality = 0;
813 ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
815 RICaction_Admitted_List_t* admlist =
816 (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
817 ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
819 for (int i=0; i < actionIds.size(); i++) {
820 fprintf(stderr, "in for loop i = %d\n", i);
822 long aid = actionIds.at(i);
824 RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
825 admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
826 admitie->criticality = 0;
827 admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
828 admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
830 ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
835 RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
837 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
838 ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
841 SuccessfulOutcome__value_PR pres2;
842 pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
843 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
844 successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
845 successoutcome->criticality = 0;
846 successoutcome->value.present = pres2;
847 successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
849 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
851 e2ap_pdu->present = pres5;
852 e2ap_pdu->choice.successfulOutcome = successoutcome;
854 char error_buf[300] = {0, };
857 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
858 printf("error length %d\n", errlen);
859 printf("error buf %s\n", error_buf);
865 void encoding::generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
871 uint8_t *ind_header_buf,
873 uint8_t *ind_message_buf,
874 int message_length) {
876 fprintf(stderr, "ind1\n");
877 RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
878 RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
879 RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
880 RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
881 RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
882 RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
883 RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
884 RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
886 RICindication_IEs__value_PR pres3;
888 pres3 = RICindication_IEs__value_PR_RICrequestID;
889 ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
890 ricind_ies->criticality = 0;
891 ricind_ies->value.present = pres3;
892 ricind_ies->value.choice.RICrequestID.ricRequestorID = requestorId;
893 ricind_ies->value.choice.RICrequestID.ricInstanceID = instanceId;
895 fprintf(stderr, "ind2\n");
897 pres3 = RICindication_IEs__value_PR_RANfunctionID;
898 ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
899 ricind_ies2->criticality = 0;
900 ricind_ies2->value.present = pres3;
901 ricind_ies2->value.choice.RANfunctionID = ranFunctionId;
904 ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
905 ricind_ies3->criticality = 0;
906 pres3 = RICindication_IEs__value_PR_RICactionID;
907 ricind_ies3->value.present = pres3;
908 ricind_ies3->value.choice.RICactionID = actionId;
911 pres3 = RICindication_IEs__value_PR_RICindicationSN;
912 ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
913 ricind_ies4->criticality = 0;
914 ricind_ies4->value.present = pres3;
915 ricind_ies4->value.choice.RICindicationSN = seqNum;
917 //Indication type is REPORT
918 pres3 = RICindication_IEs__value_PR_RICindicationType;
919 ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
920 ricind_ies5->criticality = 0;
921 ricind_ies5->value.present = pres3;
922 ricind_ies5->value.choice.RICindicationType = 0;
924 fprintf(stderr, "ind3\n");
926 ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
928 pres3 = RICindication_IEs__value_PR_RICindicationHeader;
929 ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
930 ricind_ies6->criticality = 0;
931 ricind_ies6->value.present = pres3;
932 ricind_ies6->value.choice.RICindicationHeader.size = header_length;
933 memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, ind_header_buf, header_length);
935 ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
940 pres3 = RICindication_IEs__value_PR_RICindicationMessage;
941 ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
942 fprintf(stderr, "after encoding message 1\n");
944 ricind_ies7->criticality = 0;
945 ricind_ies7->value.present = pres3;
947 fprintf(stderr, "after encoding message 2\n");
949 fprintf(stderr, "after encoding message 3\n");
950 ricind_ies7->value.choice.RICindicationMessage.size = message_length;
952 fprintf(stderr, "after encoding message 4\n");
953 memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
955 fprintf(stderr, "after encoding message 5\n");
957 uint8_t *cpid_buf = (uint8_t *)"cpid";
958 OCTET_STRING_t cpid_str;
962 int cpid_buf_len = strlen((char*)cpid_buf);
963 pres3 = RICindication_IEs__value_PR_RICcallProcessID;
964 ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
966 ricind_ies8->criticality = 0;
967 ricind_ies8->value.present = pres3;
969 ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
970 ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
972 memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
976 RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
981 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
983 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
987 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
991 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
995 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
999 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
1003 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);
1005 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);
1008 InitiatingMessage__value_PR pres4;
1009 pres4 = InitiatingMessage__value_PR_RICindication;
1010 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
1011 initmsg->procedureCode = 5;
1012 initmsg->criticality = 1;
1013 initmsg->value.present = pres4;
1014 initmsg->value.choice.RICindication = *ricindication;
1015 if (ricindication) free(ricindication);
1018 pres5 = E2AP_PDU_PR_initiatingMessage;
1020 e2ap_pdu->present = pres5;
1021 e2ap_pdu->choice.initiatingMessage = initmsg;
1022 char error_buf[300] = {0, };
1025 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
1026 printf("error length %d\n", errlen);
1027 printf("error buf %s\n", error_buf);
1029 xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);