47da01a2cd93aa249aa8cb786ef849dcb6cf6947
[sim/e2-interface.git] / e2sim / src / encoding / encode_e2apv1.cpp
1
2
3 /*****************************************************************************
4 #                                                                            *
5 # Copyright 2020 AT&T Intellectual Property                                  *
6 # Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved.      *
7 #                                                                            *
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                                    *
11 #                                                                            *
12 #      http://www.apache.org/licenses/LICENSE-2.0                            *
13 #                                                                            *
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.                                             *
19 #                                                                            *
20 ******************************************************************************/
21
22 #include <stdio.h>
23 #include <string.h>
24 #include <iostream>
25 #include <unistd.h>
26
27 #include <iterator>
28 #include <vector>
29
30
31 #include "encode_e2apv1.hpp"
32
33 extern "C" {
34
35
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"
61   
62 }
63
64 long encoding::get_function_id_from_subscription(E2AP_PDU_t *e2ap_pdu) {
65
66   RICsubscriptionRequest_t orig_req =
67     e2ap_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
68
69   int count = orig_req.protocolIEs.list.count;
70   int size = orig_req.protocolIEs.list.size;
71   
72   RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
73
74   fprintf(stderr, "count%d\n", count);
75   fprintf(stderr, "size%d\n", size);
76
77   RICsubscriptionRequest_IEs__value_PR pres;
78
79   long func_id;
80
81   for (int i=0; i < count; i++) {
82     RICsubscriptionRequest_IEs_t *next_ie = ies[i];
83     pres = next_ie->value.present;
84     
85     fprintf(stderr, "next present value %d\n", pres);
86     fprintf(stderr, "value of pres ranfuncid is %d\n", RICsubscriptionRequest_IEs__value_PR_RANfunctionID);
87
88     if (pres == RICsubscriptionRequest_IEs__value_PR_RANfunctionID) {
89       fprintf(stderr, "equal pres to ranfuncid\n");
90       func_id = next_ie->value.choice.RANfunctionID;
91     }
92     
93   }
94
95   fprintf(stderr, "After loop, func_id is %d\n", func_id);
96
97   return func_id;  
98
99 }
100
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)
106   {
107     if (strcmp(ran_function_op_type, "ADD") == 0)
108     {
109       prID = ProtocolIE_ID_id_RANfunctionsAdded;
110     }
111     else if (strcmp(ran_function_op_type, "DELETE"))
112     {
113       prID = ProtocolIE_ID_id_RANfunctionsDeleted;
114     }
115   }
116   else
117   {
118     prID = ProtocolIE_ID_id_RANfunctionsModified;
119   }
120
121
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;
126
127
128   for (int i=0; i<all_funcs.size(); i++) {
129
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;
134
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;
140
141     itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
142     itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev + 1;
143
144     ASN_SEQUENCE_ADD(&e2serviceUpdateList->value.choice.RANfunctions_List.list, itemIes);
145   }
146
147   RICserviceUpdate_t *ricServiceUpdate = (RICserviceUpdate_t *)calloc(1, sizeof(RICserviceUpdate_t));
148   ASN_SEQUENCE_ADD(&ricServiceUpdate->protocolIEs.list, e2serviceUpdateList);
149
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;
155
156   E2AP_PDU_PR pres6 = E2AP_PDU_PR_initiatingMessage;
157   e2ap_pdu->present = pres6;
158   e2ap_pdu->choice.initiatingMessage = initiatingMessage;
159 }
160
161 void encoding::generate_e2apv1_setup_request_parameterized(E2AP_PDU_t *e2ap_pdu, std::vector<ran_func_info> all_funcs) {
162   //                                             long ranFunctionId, uint8_t *ranFuncDescEncoded, int ranFuncLength) {
163
164   //  uint8_t *buf = (uint8_t *)"gnb1"
165
166   BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
167   gnb_bstring->buf = (uint8_t*)calloc(1,4);
168   gnb_bstring->size = 4;
169   gnb_bstring->buf[0] = 0xB5;
170   gnb_bstring->buf[1] = 0xC6;
171   gnb_bstring->buf[2] = 0x77;
172   gnb_bstring->buf[3] = 0x88;
173
174   gnb_bstring->bits_unused = 3;
175
176   uint8_t *buf2 = (uint8_t *)"747";
177   OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
178   plmn->buf = (uint8_t*)calloc(1,3);
179   memcpy(plmn->buf, buf2, 3);
180   plmn->size = 3;
181
182   GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
183   GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
184   gnbchoice->present = pres2;
185   gnbchoice->choice.gnb_ID = *gnb_bstring;
186   if (gnb_bstring) free(gnb_bstring);
187
188   GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
189   gnb->plmn_id = *plmn;
190   gnb->gnb_id = *gnbchoice;
191   if (plmn) free(plmn);
192   if (gnbchoice) free(gnbchoice);
193
194   GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
195   e2gnb->global_gNB_ID = *gnb;
196   if (gnb) free(gnb);
197
198   GlobalE2node_ID_t *globale2nodeid = (GlobalE2node_ID_t*)calloc(1, sizeof(GlobalE2node_ID_t));
199   GlobalE2node_ID_PR pres;
200   pres = GlobalE2node_ID_PR_gNB;
201   globale2nodeid->present = pres;
202   globale2nodeid->choice.gNB = e2gnb;
203   
204   E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
205   E2setupRequestIEs__value_PR pres3;
206   pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
207   e2setuprid->id = 3;
208   e2setuprid->criticality = 0;
209   e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
210   e2setuprid->value.present = pres3;
211   if(globale2nodeid) free(globale2nodeid);
212
213
214   printf("seting up the tx id");
215   auto *e2txid = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
216   e2txid->id = ProtocolIE_ID_id_TransactionID;
217   e2txid-> criticality = 0;
218   e2txid->value.present = E2setupRequestIEs__value_PR_TransactionID;
219   e2txid->value.choice.TransactionID = 1;
220
221   printf("seting done the tx id");
222
223   auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
224   ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
225   ranFlistIEs->criticality = 0;
226   ranFlistIEs->id = ProtocolIE_ID_id_RANfunctionsAdded;
227   ranFlistIEs->value.present = E2setupRequestIEs__value_PR_RANfunctions_List;
228
229
230   for (int i = 0; i < all_funcs.size(); i++) {
231
232     ran_func_info nextRanFunc = all_funcs.at(i);
233     long nextRanFuncId = nextRanFunc.ranFunctionId;
234     OCTET_STRING_t *nextRanFuncDesc = nextRanFunc.ranFunctionDesc;
235     long nextRanFuncRev = nextRanFunc.ranFunctionRev;
236
237     auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
238     itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
239     itemIes->criticality = Criticality_reject;
240     itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
241     itemIes->value.choice.RANfunction_Item.ranFunctionID = nextRanFuncId;
242     itemIes->value.choice.RANfunction_Item.ranFunctionOID = RANfunctionOID_t(*(nextRanFunc.ranFunctionOId));
243     int ranFuncLength = strlen((char*)nextRanFuncDesc);
244
245     itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
246     itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev;
247     
248     ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
249
250   }
251
252 auto *e2configIE = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
253 e2configIE->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition;
254 e2configIE->criticality = Criticality_reject;
255 e2configIE->value.present = E2setupRequestIEs__value_PR_E2nodeComponentConfigAddition_List;
256
257
258 auto *e2configAdditionItem = (E2nodeComponentConfigAddition_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigAddition_ItemIEs_t));
259 e2configAdditionItem->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition_Item;
260 e2configAdditionItem->criticality = Criticality_reject;
261 e2configAdditionItem->value.present = E2nodeComponentConfigAddition_ItemIEs__value_PR_E2nodeComponentConfigAddition_Item;
262
263 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentInterfaceType = E2nodeComponentInterfaceType_ng;
264 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.present = E2nodeComponentID_PR_e2nodeComponentInterfaceTypeNG;
265
266 // E2nodeComponentInterfaceNG_t intfNG;
267 auto *intfNG = (E2nodeComponentInterfaceNG_t *) calloc(1, sizeof(E2nodeComponentInterfaceNG_t));
268   
269 OCTET_STRING_t nginterf;
270 nginterf.buf = (uint8_t*)calloc(1,8);
271 memcpy(nginterf.buf, (uint8_t *)"nginterf", 8);
272
273 nginterf.size = 8;
274 intfNG->amf_name = (AMFName_t)(nginterf);
275
276 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.choice.e2nodeComponentInterfaceTypeNG = intfNG;
277
278 OCTET_STRING_t reqPart;
279 reqPart.buf = (uint8_t*)calloc(1,7);
280 memcpy(reqPart.buf, (uint8_t *)"reqpart", 7);
281 reqPart.size = 7;
282
283 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentRequestPart = reqPart;
284
285 OCTET_STRING_t resPart;
286 resPart.buf = (uint8_t*)calloc(1,7);
287 memcpy(resPart.buf, (uint8_t *)"respart", 7);
288 resPart.size = 7;
289 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentResponsePart = resPart;
290
291
292 ASN_SEQUENCE_ADD(&e2configIE->value.choice.RANfunctions_List.list, e2configAdditionItem);
293 /*
294     auto *e2nodeconfigupdatelistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
295   ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, e2nodeconfigupdatelistIEs);
296   e2nodeconfigupdatelistIEs->criticality = 0;
297   e2nodeconfigupdatelistIEs->id = ProtocolIE_ID_id_E2nodeComponentConfigUpdate;
298   e2nodeconfigupdatelistIEs->value.present = E2setupRequestIEs__value_PR_E2nodeComponentConfigUpdate_List;
299
300
301   OCTET_STRING_t *ngAPconfigUpdate =  (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
302   ngAPconfigUpdate->buf = (uint8_t*)calloc(1,13);
303   memcpy(ngAPconfigUpdate->buf, (uint8_t *)"gnbngapupdate", 13);
304   ngAPconfigUpdate->size = 13;
305
306   OCTET_STRING_t *xnAPconfigUpdate =  (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
307   xnAPconfigUpdate->buf = (uint8_t*)calloc(1,13);
308   memcpy(xnAPconfigUpdate->buf, (uint8_t *)"gnbxnapupdate", 13);
309   xnAPconfigUpdate->size = 13;
310
311   OCTET_STRING_t *e1APconfigUpdate =  (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
312   e1APconfigUpdate->buf = (uint8_t*)calloc(1,13);
313   memcpy(e1APconfigUpdate->buf, (uint8_t *)"gnbe1apupdate", 13);
314   e1APconfigUpdate->size = 13;
315
316   OCTET_STRING_t *f1APconfigUpdate =  (OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
317   f1APconfigUpdate->buf = (uint8_t*)calloc(1,13);
318   memcpy(f1APconfigUpdate->buf, (uint8_t *)"gnbf1apupdate", 13);
319   f1APconfigUpdate->size = 13;
320
321   E2nodeComponentConfigUpdateGNB_t *e2nodecomponentconfigupdategnb = (E2nodeComponentConfigUpdateGNB_t *)calloc(1,sizeof(E2nodeComponentConfigUpdateGNB_t));
322   e2nodecomponentconfigupdategnb->ngAPconfigUpdate = ngAPconfigUpdate;
323   e2nodecomponentconfigupdategnb->xnAPconfigUpdate = xnAPconfigUpdate;
324   e2nodecomponentconfigupdategnb->e1APconfigUpdate = e1APconfigUpdate;
325   e2nodecomponentconfigupdategnb->f1APconfigUpdate = f1APconfigUpdate;
326
327   E2nodeComponentConfigUpdate_t e2nodecomponentconfigupdate = {};
328   e2nodecomponentconfigupdate.present = E2nodeComponentConfigUpdate_PR_gNBconfigUpdate;
329   e2nodecomponentconfigupdate.choice.gNBconfigUpdate = e2nodecomponentconfigupdategnb;
330
331   GNB_CU_UP_ID_t gnbcuupid = {};
332   gnbcuupid.buf = (uint8_t*)calloc(1,4);
333   memcpy(gnbcuupid.buf, (uint8_t *)"1234", 4);
334   gnbcuupid.size = 4;
335
336   E2nodeComponentGNB_CU_UP_ID_t *e2nodecomponentgnbcuupid = (E2nodeComponentGNB_CU_UP_ID_t *)calloc(1,sizeof(E2nodeComponentGNB_CU_UP_ID_t));
337   e2nodecomponentgnbcuupid->gNB_CU_UP_ID = gnbcuupid;
338
339   E2nodeComponentID_t *e2nodecomponentid = (E2nodeComponentID_t*)calloc(1, sizeof(E2nodeComponentID_t));
340
341   e2nodecomponentid->present = E2nodeComponentID_PR_e2nodeComponentTypeGNB_CU_UP;
342   e2nodecomponentid->choice.e2nodeComponentTypeGNB_CU_UP = e2nodecomponentgnbcuupid;
343
344   auto *configupdateitemIes = (E2nodeComponentConfigUpdate_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigUpdate_ItemIEs_t));
345   configupdateitemIes->id = ProtocolIE_ID_id_E2nodeComponentConfigUpdate_Item;
346   configupdateitemIes->criticality = Criticality_reject;
347   configupdateitemIes->value.present = E2nodeComponentConfigUpdate_ItemIEs__value_PR_E2nodeComponentConfigUpdate_Item;
348   configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentType = E2nodeComponentType_gNB_CU_UP;
349   configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentID = e2nodecomponentid;
350   configupdateitemIes->value.choice.E2nodeComponentConfigUpdate_Item.e2nodeComponentConfigUpdate = e2nodecomponentconfigupdate;
351
352   ASN_SEQUENCE_ADD(&e2nodeconfigupdatelistIEs->value.choice.E2nodeComponentConfigUpdate_List.list, configupdateitemIes);
353 */
354   E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
355   ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2txid);
356   ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2setuprid);
357   ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, ranFlistIEs);
358   ASN_SEQUENCE_ADD(&e2setupreq->protocolIEs.list, e2configIE);
359
360
361   InitiatingMessage__value_PR pres4;
362   pres4 = InitiatingMessage__value_PR_E2setupRequest;
363   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
364
365   initmsg->procedureCode = ProcedureCode_id_E2setup;
366   initmsg->criticality = Criticality_reject;
367   initmsg->value.present = pres4;
368   initmsg->value.choice.E2setupRequest = *e2setupreq;
369   if (e2setupreq) free(e2setupreq);
370
371   E2AP_PDU_PR pres5;
372   pres5 = E2AP_PDU_PR_initiatingMessage;
373   
374
375   e2ap_pdu->present = pres5;
376   e2ap_pdu->choice.initiatingMessage = initmsg;  
377
378 }
379
380 void encoding::generate_e2apv2_config_update(E2AP_PDU_t *e2ap_pdu){
381  
382   
383
384 /// config update id for addtion list  
385 auto *e2configIE = (E2nodeConfigurationUpdate_IEs_t *)calloc(1, sizeof(E2nodeConfigurationUpdate_IEs_t));
386 e2configIE->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition;
387 e2configIE->criticality = Criticality_reject;
388 e2configIE->value.present = E2nodeConfigurationUpdate_IEs__value_PR_E2nodeComponentConfigAddition_List;
389
390
391 auto *e2configAdditionItem = (E2nodeComponentConfigAddition_ItemIEs_t *)calloc(1, sizeof(E2nodeComponentConfigAddition_ItemIEs_t));
392 e2configAdditionItem->id = ProtocolIE_ID_id_E2nodeComponentConfigAddition_Item;
393 e2configAdditionItem->criticality = Criticality_reject;
394 e2configAdditionItem->value.present = E2nodeComponentConfigAddition_ItemIEs__value_PR_E2nodeComponentConfigAddition_Item;
395
396 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentInterfaceType = E2nodeComponentInterfaceType_ng;
397 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.present = E2nodeComponentID_PR_e2nodeComponentInterfaceTypeNG;
398
399 auto *intfNG = (E2nodeComponentInterfaceNG_t *) calloc(1, sizeof(E2nodeComponentInterfaceNG_t));
400   
401 OCTET_STRING_t nginterf;
402 nginterf.buf = (uint8_t*)calloc(1,8);
403 memcpy(nginterf.buf, (uint8_t *)"nginterf", 8);
404
405 nginterf.size = 8;
406 intfNG->amf_name = (AMFName_t)(nginterf);
407
408 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentID.choice.e2nodeComponentInterfaceTypeNG = intfNG;
409
410 OCTET_STRING_t reqPart;
411 reqPart.buf = (uint8_t*)calloc(1,7);
412 memcpy(reqPart.buf, (uint8_t *)"reqpart", 7);
413 reqPart.size = 7;
414
415 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentRequestPart = reqPart;
416
417 OCTET_STRING_t resPart;
418 resPart.buf = (uint8_t*)calloc(1,7);
419 memcpy(resPart.buf, (uint8_t *)"respart", 7);
420 resPart.size = 7;
421 e2configAdditionItem->value.choice.E2nodeComponentConfigAddition_Item.e2nodeComponentConfiguration.e2nodeComponentResponsePart = resPart;
422
423
424
425
426
427 ASN_SEQUENCE_ADD(&e2configIE->value.choice.E2nodeComponentConfigAddition_List, e2configAdditionItem);
428
429   InitiatingMessage *inititingMsg = (InitiatingMessage *) calloc(1, sizeof(InitiatingMessage));
430   inititingMsg->procedureCode = InitiatingMessage__value_PR_E2nodeConfigurationUpdate;
431   inititingMsg->criticality = Criticality_reject;
432   inititingMsg->value.present = InitiatingMessage__value_PR_E2nodeConfigurationUpdate;
433   ASN_SEQUENCE_ADD(&inititingMsg->value.choice.E2nodeConfigurationUpdate.protocolIEs.list, e2configIE);
434   e2ap_pdu->present = E2AP_PDU_PR_initiatingMessage;
435   e2ap_pdu->choice.initiatingMessage = inititingMsg;
436 }
437
438 void encoding::generate_e2apv1_setup_response(E2AP_PDU_t *e2ap_pdu) {
439
440   E2setupResponseIEs *resp_ies1 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
441   E2setupResponseIEs *resp_ies2 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
442   E2setupResponseIEs *resp_ies3 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
443
444   uint8_t *buf = (uint8_t *)"gnb1";
445
446   BIT_STRING_t *ricid_bstring = (BIT_STRING_t*)calloc(1,sizeof(BIT_STRING_t));
447   ricid_bstring->buf = buf;
448   ricid_bstring->size = 4;
449   ricid_bstring->bits_unused = 0;
450
451   uint8_t *buf2 = (uint8_t *)"plmn3";
452   OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
453   plmn->buf = buf2;
454   plmn->size = 5;
455
456   GlobalRIC_ID_t *globalricid = (GlobalRIC_ID_t*)calloc(1,sizeof(GlobalRIC_ID_t));
457   globalricid->pLMN_Identity = *plmn;
458   globalricid->ric_ID = *ricid_bstring;
459
460   E2setupResponseIEs__value_PR pres1;
461   pres1 = E2setupResponseIEs__value_PR_GlobalRIC_ID;
462   
463   resp_ies1->id = ProtocolIE_ID_id_GlobalRIC_ID;
464   resp_ies1->criticality = 0;
465   resp_ies1->value.present = pres1;
466   resp_ies1->value.choice.GlobalRIC_ID = *globalricid;
467
468   E2setupResponse_t *e2setupresp = (E2setupResponse_t*)calloc(1,sizeof(E2setupResponse_t));
469   int ret = ASN_SEQUENCE_ADD(&e2setupresp->protocolIEs.list, resp_ies1);
470
471
472   SuccessfulOutcome__value_PR pres;
473   pres = SuccessfulOutcome__value_PR_E2setupResponse;
474   SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
475   successoutcome->procedureCode = 1;
476   successoutcome->criticality = 0;
477   successoutcome->value.present = pres;
478   successoutcome->value.choice.E2setupResponse = *e2setupresp;
479
480   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
481   
482   e2ap_pdu->present = pres5;
483   e2ap_pdu->choice.successfulOutcome = successoutcome;
484   
485 }
486
487
488 void encoding::generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
489
490   fprintf(stderr, "in sub 1\n");
491   RICsubscriptionRequest_IEs_t *ricreqid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
492   fprintf(stderr, "in sub 2\n");  
493   ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricreqid);
494   fprintf(stderr, "in sub 3\n");  
495   auto *ricsubrid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));
496   fprintf(stderr, "in sub 4\n");  
497   ASN_STRUCT_RESET(asn_DEF_RICsubscriptionRequest_IEs, ricsubrid);
498   
499   fprintf(stderr, "in generate sub\n");
500   uint8_t *buf2 = (uint8_t *)"SubscriptionTriggers";
501   fprintf(stderr, "in gen sub 1\n");
502   OCTET_STRING_t *triggerdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
503   triggerdef->buf = (uint8_t *)calloc(1,20);
504   triggerdef->size = 20;  
505   memcpy(triggerdef->buf, buf2, triggerdef->size);
506
507
508   fprintf(stderr, "sub1\n");
509   ProtocolIE_ID_t proto_id= ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
510
511   RICaction_ToBeSetup_ItemIEs__value_PR pres6;
512   pres6 = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
513
514   printf("sub2\n");
515
516   uint8_t *buf5 = (uint8_t *)"ActionDef";
517
518   OCTET_STRING_t *actdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
519   actdef->buf = (uint8_t *)calloc(1,9);
520   actdef->size = 9;  
521   memcpy(triggerdef->buf, buf5, 9);
522
523   auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
524   ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
525   
526   sa->ricTimeToWait = RICtimeToWait_w500ms;
527   sa->ricSubsequentActionType = RICsubsequentActionType_continue;
528     
529   printf("sub3\n");
530
531   RICaction_ToBeSetup_ItemIEs_t *action_item_ies = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_Item_t));
532   action_item_ies->id = proto_id;
533   action_item_ies->criticality = 0;
534
535   action_item_ies->value.present = pres6;
536   action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionID = 5;
537   action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionType = RICactionType_report;
538   action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricActionDefinition = actdef;
539   action_item_ies->value.choice.RICaction_ToBeSetup_Item.ricSubsequentAction = sa;
540
541
542   printf("sub5\n");
543   
544
545   RICsubscriptionRequest_IEs__value_PR pres3;
546   printf("sub6.1\n");
547   pres3 = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
548   ricsubrid->id = ProtocolIE_ID_id_RICsubscriptionDetails;
549   printf("sub6.2\n");
550   
551   ricsubrid->criticality = 0;
552   ricsubrid->value.present = pres3;
553   printf("sub6.3\n");
554
555   ricsubrid->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition = *triggerdef;
556   printf("sub6.4\n");
557   
558   ASN_SEQUENCE_ADD(&ricsubrid->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, action_item_ies);
559
560   printf("sub7\n");
561
562
563   ricreqid->id = ProtocolIE_ID_id_RICrequestID;
564   ricreqid->criticality = 0;
565   ricreqid->value.present = RICsubscriptionRequest_IEs__value_PR_RICrequestID;
566   ricreqid->value.choice.RICrequestID.ricRequestorID = 22;
567   ricreqid->value.choice.RICrequestID.ricInstanceID = 6;
568
569   RICsubscriptionRequest_t *ricsubreq = (RICsubscriptionRequest_t*)calloc(1, sizeof(RICsubscriptionRequest_t));
570
571   ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricreqid);
572   ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricsubrid);
573
574
575
576   InitiatingMessage__value_PR pres4;
577   pres4 = InitiatingMessage__value_PR_RICsubscriptionRequest;
578   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
579   initmsg->procedureCode = ProcedureCode_id_RICsubscription;
580   initmsg->criticality = Criticality_reject;
581   initmsg->value.present = pres4;
582   initmsg->value.choice.RICsubscriptionRequest = *ricsubreq;
583
584   E2AP_PDU_PR pres5;
585   pres5 = E2AP_PDU_PR_initiatingMessage;
586   
587
588   e2ap_pdu->present = pres5;
589   e2ap_pdu->choice.initiatingMessage = initmsg;
590
591   char error_buf[300] = {0, };
592   size_t errlen = 0;
593                                                                           
594   asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
595   printf("error length %d\n", errlen);
596   printf("error buf %s\n", error_buf);
597
598
599 }
600
601 void encoding::generate_e2apv1_subscription_response_success(E2AP_PDU *e2ap_pdu, long reqActionIdsAccepted[],
602                                                    long reqActionIdsRejected[], int accept_size, int reject_size,
603                                                    long reqRequestorId, long reqInstanceId) {
604
605   RICsubscriptionResponse_IEs_t *respricreqid =
606     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
607   
608   respricreqid->id = ProtocolIE_ID_id_RICrequestID;
609   respricreqid->criticality = 0;
610   respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
611   respricreqid->value.choice.RICrequestID.ricRequestorID = reqRequestorId;
612   
613   respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
614
615   RICsubscriptionResponse_IEs_t *respfuncid =
616     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
617   respfuncid->id = ProtocolIE_ID_id_RANfunctionID;
618   respfuncid->criticality = 0;
619   respfuncid->value.present = RICsubscriptionResponse_IEs__value_PR_RANfunctionID;
620   respfuncid->value.choice.RANfunctionID = (long)0;
621   
622
623   RICsubscriptionResponse_IEs_t *ricactionadmitted =
624     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
625   ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
626   ricactionadmitted->criticality = 0;
627   ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
628
629   RICaction_Admitted_List_t* admlist = 
630     (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
631   ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
632   if (admlist) free(admlist);
633
634
635   int numAccept = accept_size;
636   int numReject = reject_size;
637
638
639   
640   for (int i=0; i < numAccept ; i++) {
641     fprintf(stderr, "in for loop i = %d\n", i);
642
643     long aid = reqActionIdsAccepted[i];
644
645     RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
646     admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
647     admitie->criticality = 0;
648     admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
649     admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
650     
651     ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
652
653   }
654
655   RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
656   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
657   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respfuncid);
658   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
659   
660
661   if (numReject > 0) {
662
663     RICsubscriptionResponse_IEs_t *ricactionrejected =
664       (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
665     ricactionrejected->id = ProtocolIE_ID_id_RICactions_NotAdmitted;
666     ricactionrejected->criticality = 0;
667     ricactionrejected->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_NotAdmitted_List;
668     
669     RICaction_NotAdmitted_List_t* rejectlist = 
670       (RICaction_NotAdmitted_List_t*)calloc(1,sizeof(RICaction_NotAdmitted_List_t));
671     ricactionadmitted->value.choice.RICaction_NotAdmitted_List = *rejectlist;
672     
673     for (int i=0; i < numReject; i++) {
674       fprintf(stderr, "in for loop i = %d\n", i);
675       
676       long aid = reqActionIdsRejected[i];
677       
678       RICaction_NotAdmitted_ItemIEs_t *noadmitie = (RICaction_NotAdmitted_ItemIEs_t*)calloc(1,sizeof(RICaction_NotAdmitted_ItemIEs_t));
679       noadmitie->id = ProtocolIE_ID_id_RICaction_NotAdmitted_Item;
680       noadmitie->criticality = 0;
681       noadmitie->value.present = RICaction_NotAdmitted_ItemIEs__value_PR_RICaction_NotAdmitted_Item;
682       noadmitie->value.choice.RICaction_NotAdmitted_Item.ricActionID = aid;
683       
684       ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
685       ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);      
686     }
687   }
688
689
690   SuccessfulOutcome__value_PR pres2;
691   pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
692   SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
693   successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
694   successoutcome->criticality = 0;
695   successoutcome->value.present = pres2;
696   successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
697   if (ricsubresp) free(ricsubresp);
698
699   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
700   
701   e2ap_pdu->present = pres5;
702   e2ap_pdu->choice.successfulOutcome = successoutcome;
703
704   char error_buf[300] = {0, };
705   size_t errlen = 0;
706
707   asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
708   printf("error length %d\n", errlen);
709   printf("error buf %s\n", error_buf);
710
711   printf("now printing xer of subscription response\n");
712   xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
713   printf("done printing xer of subscription response\n");  
714
715   
716 }
717
718 void encoding::generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
719
720   //Gather details of the request
721
722   RICsubscriptionRequest_t orig_req =
723     sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
724   
725   RICsubscriptionResponse_IEs_t *ricreqid =
726     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
727                                            
728   int count = orig_req.protocolIEs.list.count;
729   int size = orig_req.protocolIEs.list.size;
730   
731   RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
732
733   fprintf(stderr, "count%d\n", count);
734   fprintf(stderr, "size%d\n", size);
735
736   RICsubscriptionRequest_IEs__value_PR pres;
737
738   long responseRequestorId;
739   long responseInstanceId;
740   long responseActionId;
741
742   std::vector<long> actionIds;
743
744   for (int i=0; i < count; i++) {
745     RICsubscriptionRequest_IEs_t *next_ie = ies[i];
746     pres = next_ie->value.present;
747     
748     fprintf(stderr, "next present value %d\n", pres);
749
750     switch(pres) {
751     case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
752       {
753         RICrequestID_t reqId = next_ie->value.choice.RICrequestID;
754         long requestorId = reqId.ricRequestorID;
755         long instanceId = reqId.ricInstanceID;
756         fprintf(stderr, "requestorId %d\n", requestorId);
757         fprintf(stderr, "instanceId %d\n", instanceId);
758         responseRequestorId = requestorId;
759         responseInstanceId = instanceId;
760                 
761         break;
762       }
763     case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
764       break;
765     case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
766       {
767         RICsubscriptionDetails_t subDetails = next_ie->value.choice.RICsubscriptionDetails; 
768         RICeventTriggerDefinition_t triggerDef = subDetails.ricEventTriggerDefinition;
769         RICactions_ToBeSetup_List_t actionList = subDetails.ricAction_ToBeSetup_List;
770         
771         int actionCount = actionList.list.count;
772         fprintf(stderr, "action count%d\n", actionCount);
773
774         auto **item_array = actionList.list.array;
775
776         for (int i=0; i < actionCount; i++) {
777           //RICaction_ToBeSetup_Item_t
778           auto *next_item = item_array[i];
779           RICactionID_t actionId = ((RICaction_ToBeSetup_ItemIEs*)next_item)->value.choice.RICaction_ToBeSetup_Item.ricActionID;
780           fprintf(stderr, "Next Action ID %ld\n", actionId);
781           responseActionId = actionId;
782           actionIds.push_back(responseActionId);
783         }
784         
785         break;
786       }
787     }
788     
789   }
790
791   fprintf(stderr, "After Processing Subscription Request\n");
792
793   fprintf(stderr, "requestorId %d\n", responseRequestorId);
794   fprintf(stderr, "instanceId %d\n", responseInstanceId);
795
796
797   for (int i=0; i < actionIds.size(); i++) {
798     fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
799     
800   }
801
802
803   RICsubscriptionResponse_IEs_t *respricreqid =
804     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
805   
806   respricreqid->id = ProtocolIE_ID_id_RICrequestID;
807   respricreqid->criticality = 0;
808   respricreqid->value.present = RICsubscriptionResponse_IEs__value_PR_RICrequestID;
809   respricreqid->value.choice.RICrequestID.ricRequestorID = responseRequestorId;
810   
811   respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
812
813
814   RICsubscriptionResponse_IEs_t *ricactionadmitted =
815     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
816   ricactionadmitted->id = ProtocolIE_ID_id_RICactions_Admitted;
817   ricactionadmitted->criticality = 0;
818   ricactionadmitted->value.present = RICsubscriptionResponse_IEs__value_PR_RICaction_Admitted_List;
819
820   RICaction_Admitted_List_t* admlist = 
821     (RICaction_Admitted_List_t*)calloc(1,sizeof(RICaction_Admitted_List_t));
822   ricactionadmitted->value.choice.RICaction_Admitted_List = *admlist;
823
824   for (int i=0; i < actionIds.size(); i++) {
825     fprintf(stderr, "in for loop i = %d\n", i);
826
827     long aid = actionIds.at(i);
828
829     RICaction_Admitted_ItemIEs_t *admitie = (RICaction_Admitted_ItemIEs_t*)calloc(1,sizeof(RICaction_Admitted_ItemIEs_t));
830     admitie->id = ProtocolIE_ID_id_RICaction_Admitted_Item;
831     admitie->criticality = 0;
832     admitie->value.present = RICaction_Admitted_ItemIEs__value_PR_RICaction_Admitted_Item;
833     admitie->value.choice.RICaction_Admitted_Item.ricActionID = aid;
834     
835     ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
836
837   }
838
839
840   RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
841   
842   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
843   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
844
845
846   SuccessfulOutcome__value_PR pres2;
847   pres2 = SuccessfulOutcome__value_PR_RICsubscriptionResponse;
848   SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
849   successoutcome->procedureCode = ProcedureCode_id_RICsubscription;
850   successoutcome->criticality = 0;
851   successoutcome->value.present = pres2;
852   successoutcome->value.choice.RICsubscriptionResponse = *ricsubresp;
853
854   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
855   
856   e2ap_pdu->present = pres5;
857   e2ap_pdu->choice.successfulOutcome = successoutcome;
858
859   char error_buf[300] = {0, };
860   size_t errlen = 0;
861
862   asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
863   printf("error length %d\n", errlen);
864   printf("error buf %s\n", error_buf);
865
866
867   
868 }
869
870 void encoding::generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
871                                                                 long requestorId,
872                                                                 long instanceId,
873                                                                 long ranFunctionId,
874                                                                 long actionId,
875                                                                 long seqNum,
876                                                                 uint8_t *ind_header_buf,
877                                                                 int header_length,
878                                                                 uint8_t *ind_message_buf,
879                                                                 int message_length) {
880   
881   fprintf(stderr, "ind1\n");
882   RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
883   RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
884   RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
885   RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
886   RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
887   RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
888   RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
889   RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
890
891   RICindication_IEs__value_PR pres3;
892
893   pres3 = RICindication_IEs__value_PR_RICrequestID;
894   ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
895   ricind_ies->criticality = 0;
896   ricind_ies->value.present = pres3;
897   ricind_ies->value.choice.RICrequestID.ricRequestorID = requestorId;
898   ricind_ies->value.choice.RICrequestID.ricInstanceID = instanceId;
899
900   fprintf(stderr, "ind2\n");
901
902   pres3 = RICindication_IEs__value_PR_RANfunctionID;
903   ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
904   ricind_ies2->criticality = 0;
905   ricind_ies2->value.present = pres3;
906   ricind_ies2->value.choice.RANfunctionID = ranFunctionId;
907
908   
909   ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
910   ricind_ies3->criticality = 0;
911   pres3 =  RICindication_IEs__value_PR_RICactionID;
912   ricind_ies3->value.present = pres3;
913   ricind_ies3->value.choice.RICactionID = actionId;
914
915
916   pres3 = RICindication_IEs__value_PR_RICindicationSN;
917   ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
918   ricind_ies4->criticality = 0;
919   ricind_ies4->value.present = pres3;
920   ricind_ies4->value.choice.RICindicationSN = seqNum;
921
922   //Indication type is REPORT
923   pres3 = RICindication_IEs__value_PR_RICindicationType;
924   ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
925   ricind_ies5->criticality = 0;
926   ricind_ies5->value.present = pres3;
927   ricind_ies5->value.choice.RICindicationType = 0;
928
929   fprintf(stderr, "ind3\n");
930
931   ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
932
933   pres3 = RICindication_IEs__value_PR_RICindicationHeader;
934   ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
935   ricind_ies6->criticality = 0;
936   ricind_ies6->value.present = pres3;
937   ricind_ies6->value.choice.RICindicationHeader.size = header_length;
938   memcpy(ricind_ies6->value.choice.RICindicationHeader.buf, ind_header_buf, header_length);
939   
940   ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
941
942
943   
944
945   pres3 = RICindication_IEs__value_PR_RICindicationMessage;
946   ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
947   fprintf(stderr, "after encoding message 1\n");
948
949   ricind_ies7->criticality = 0;
950   ricind_ies7->value.present = pres3;
951
952   fprintf(stderr, "after encoding message 2\n");
953
954   fprintf(stderr, "after encoding message 3\n");      
955   ricind_ies7->value.choice.RICindicationMessage.size = message_length;
956
957   fprintf(stderr, "after encoding message 4\n");
958   memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
959
960   fprintf(stderr, "after encoding message 5\n");
961
962   uint8_t *cpid_buf = (uint8_t *)"cpid";
963   OCTET_STRING_t cpid_str;
964
965   printf("5.1\n");
966
967   int cpid_buf_len = strlen((char*)cpid_buf);
968   pres3 = RICindication_IEs__value_PR_RICcallProcessID;
969   ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
970
971   ricind_ies8->criticality = 0;
972   ricind_ies8->value.present = pres3;
973
974   ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
975   ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
976
977   memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
978
979   printf("5.2\n");
980
981   RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
982
983   
984   int ret;
985
986   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
987   
988   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
989
990   printf("5.3\n");
991
992   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
993
994   printf("5.35\n");
995   
996   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
997
998   printf("5.36\n");
999   
1000   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
1001
1002   printf("5.4\n");
1003   
1004   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
1005
1006   printf("5.5\n");
1007
1008   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);  
1009   
1010   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);    
1011
1012
1013   InitiatingMessage__value_PR pres4;
1014   pres4 = InitiatingMessage__value_PR_RICindication;
1015   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
1016   initmsg->procedureCode = 5;
1017   initmsg->criticality = 1;
1018   initmsg->value.present = pres4;
1019   initmsg->value.choice.RICindication = *ricindication;
1020   if (ricindication) free(ricindication);
1021
1022   E2AP_PDU_PR pres5;
1023   pres5 = E2AP_PDU_PR_initiatingMessage;
1024   
1025   e2ap_pdu->present = pres5;
1026   e2ap_pdu->choice.initiatingMessage = initmsg;
1027   char error_buf[300] = {0, };
1028   size_t errlen = 0;
1029
1030   asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
1031   printf("error length %d\n", errlen);
1032   printf("error buf %s\n", error_buf);
1033
1034   xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);  
1035
1036 }
1037
1038