5c33fefce0497f56571cd35c67bc2d0cb21338ad
[sim/e2-interface.git] / e2sim / src / encoding / encode_e2apv1.cpp
1
2
3 /*****************************************************************************
4 #                                                                            *
5 # Copyright 2020 AT&T Intellectual Property                                  *
6 #                                                                            *
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                                    *
10 #                                                                            *
11 #      http://www.apache.org/licenses/LICENSE-2.0                            *
12 #                                                                            *
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.                                             *
18 #                                                                            *
19 ******************************************************************************/
20
21 #include <stdio.h>
22 #include <string.h>
23 #include <iostream>
24 #include <unistd.h>
25
26 #include <iterator>
27 #include <vector>
28
29
30 #include "encode_e2apv1.hpp"
31
32 extern "C" {
33   //#include "E2SM-KPM-RANfunction-Description.h"
34
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"
55   
56 }
57
58 long encoding::get_function_id_from_subscription(E2AP_PDU_t *e2ap_pdu) {
59
60   RICsubscriptionRequest_t orig_req =
61     e2ap_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
62   
63   RICsubscriptionResponse_IEs_t *ricreqid =
64     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
65                                            
66   int count = orig_req.protocolIEs.list.count;
67   int size = orig_req.protocolIEs.list.size;
68   
69   RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
70
71   fprintf(stderr, "count%d\n", count);
72   fprintf(stderr, "size%d\n", size);
73
74   RICsubscriptionRequest_IEs__value_PR pres;
75
76   long func_id;
77
78   for (int i=0; i < count; i++) {
79     RICsubscriptionRequest_IEs_t *next_ie = ies[i];
80     pres = next_ie->value.present;
81     
82     fprintf(stderr, "next present value %d\n", pres);
83
84     if (pres == RICsubscriptionRequest_IEs__value_PR_RANfunctionID) {
85       func_id = next_ie->value.choice.RANfunctionID;
86     }
87     
88   }
89
90   return func_id;  
91
92 }
93
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) {
96
97   //  uint8_t *buf = (uint8_t *)"gnb1"
98
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;
106
107   gnb_bstring->bits_unused = 3;
108
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);
113   plmn->size = 3;
114
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;
119
120   GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
121   gnb->plmn_id = *plmn;
122   gnb->gnb_id = *gnbchoice;
123
124   GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
125   e2gnb->global_gNB_ID = *gnb;
126
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;
132   
133   E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
134   E2setupRequestIEs__value_PR pres3;
135   pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
136   e2setuprid->id = 3;
137   e2setuprid->criticality = 0;
138   e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
139   e2setuprid->value.present = pres3;
140
141
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;
147
148
149   for (int i = 0; i < all_funcs.size(); i++) {
150
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;
155
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;
161
162     int ranFuncLength = strlen((char*)nextRanFuncDesc);
163
164     itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *nextRanFuncDesc;
165     itemIes->value.choice.RANfunction_Item.ranFunctionRevision = nextRanFuncRev;
166     
167     ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
168
169   }
170
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);
174
175   InitiatingMessage__value_PR pres4;
176   pres4 = InitiatingMessage__value_PR_E2setupRequest;
177   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
178
179   initmsg->procedureCode = ProcedureCode_id_E2setup;
180   initmsg->criticality = Criticality_reject;
181   initmsg->value.present = pres4;
182   initmsg->value.choice.E2setupRequest = *e2setupreq;
183
184   E2AP_PDU_PR pres5;
185   pres5 = E2AP_PDU_PR_initiatingMessage;
186   
187
188   e2ap_pdu->present = pres5;
189   e2ap_pdu->choice.initiatingMessage = initmsg;  
190
191 }
192
193 /*
194 void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
195   
196   //  uint8_t *buf = (uint8_t *)"gnb1"
197
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;
205
206   gnb_bstring->bits_unused = 3;
207
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);
212   plmn->size = 3;
213
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;
218
219   GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
220   gnb->plmn_id = *plmn;
221   gnb->gnb_id = *gnbchoice;
222
223   GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
224   e2gnb->global_gNB_ID = *gnb;
225
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;
231   
232   E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));
233   E2setupRequestIEs__value_PR pres3;
234   pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
235   e2setuprid->id = 3;
236   e2setuprid->criticality = 0;
237   e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
238   e2setuprid->value.present = pres3;
239
240
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;
246
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;
252
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);
256
257   uint8_t e2smbuffer[8192];
258   size_t e2smbuffer_size = 8192;
259
260   asn_codec_ctx_t *opt_cod;  
261
262   asn_enc_rval_t er =
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);
267   
268   fprintf(stderr, "er encded is %d\n", er.encoded);
269   fprintf(stderr, "after encoding message\n");
270
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);
275   
276
277   itemIes->value.choice.RANfunction_Item.ranFunctionDefinition = *ranfuncdesc_str;
278   itemIes->value.choice.RANfunction_Item.ranFunctionRevision = (long)2;
279
280   ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
281
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);
285
286   InitiatingMessage__value_PR pres4;
287   pres4 = InitiatingMessage__value_PR_E2setupRequest;
288   InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
289
290   initmsg->procedureCode = ProcedureCode_id_E2setup;
291   initmsg->criticality = Criticality_reject;
292   initmsg->value.present = pres4;
293   initmsg->value.choice.E2setupRequest = *e2setupreq;
294
295   E2AP_PDU_PR pres5;
296   pres5 = E2AP_PDU_PR_initiatingMessage;
297   
298
299   e2ap_pdu->present = pres5;
300   e2ap_pdu->choice.initiatingMessage = initmsg;
301
302 }
303 */
304
305 void encoding::generate_e2apv1_setup_response(E2AP_PDU_t *e2ap_pdu) {
306
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));
310
311   uint8_t *buf = (uint8_t *)"gnb1";
312
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;
317
318   uint8_t *buf2 = (uint8_t *)"plmn3";
319   OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
320   plmn->buf = buf2;
321   plmn->size = 5;
322
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;
326
327   E2setupResponseIEs__value_PR pres1;
328   pres1 = E2setupResponseIEs__value_PR_GlobalRIC_ID;
329   
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;
334
335   E2setupResponse_t *e2setupresp = (E2setupResponse_t*)calloc(1,sizeof(E2setupResponse_t));
336   int ret = ASN_SEQUENCE_ADD(&e2setupresp->protocolIEs.list, resp_ies1);
337
338
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;
346
347   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
348   
349   e2ap_pdu->present = pres5;
350   e2ap_pdu->choice.successfulOutcome = successoutcome;
351   
352 }
353
354
355 void encoding::generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
356
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);
365   
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);
373
374
375   fprintf(stderr, "sub1\n");
376   ProtocolIE_ID_t proto_id= ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
377
378   RICaction_ToBeSetup_ItemIEs__value_PR pres6;
379   pres6 = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
380
381   printf("sub2\n");
382
383   uint8_t *buf5 = (uint8_t *)"ActionDef";
384
385   OCTET_STRING_t *actdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
386   actdef->buf = (uint8_t *)calloc(1,9);
387   actdef->size = 9;  
388   memcpy(triggerdef->buf, buf5, 9);
389
390   auto *sa = (RICsubsequentAction_t *) calloc(1, sizeof(RICsubsequentAction_t));
391   ASN_STRUCT_RESET(asn_DEF_RICsubsequentAction, sa);
392   
393   sa->ricTimeToWait = RICtimeToWait_w500ms;
394   sa->ricSubsequentActionType = RICsubsequentActionType_continue;
395     
396   printf("sub3\n");
397
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;
401
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;
407
408
409   printf("sub5\n");
410   
411
412   RICsubscriptionRequest_IEs__value_PR pres3;
413   printf("sub6.1\n");
414   pres3 = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
415   ricsubrid->id = ProtocolIE_ID_id_RICsubscriptionDetails;
416   printf("sub6.2\n");
417   
418   ricsubrid->criticality = 0;
419   ricsubrid->value.present = pres3;
420   printf("sub6.3\n");
421
422   ricsubrid->value.choice.RICsubscriptionDetails.ricEventTriggerDefinition = *triggerdef;
423   printf("sub6.4\n");
424   
425   ASN_SEQUENCE_ADD(&ricsubrid->value.choice.RICsubscriptionDetails.ricAction_ToBeSetup_List.list, action_item_ies);
426
427   printf("sub7\n");
428
429
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;
435
436   RICsubscriptionRequest_t *ricsubreq = (RICsubscriptionRequest_t*)calloc(1, sizeof(RICsubscriptionRequest_t));
437
438   ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricreqid);
439   ASN_SEQUENCE_ADD(&ricsubreq->protocolIEs.list,ricsubrid);
440
441
442
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;
450
451   E2AP_PDU_PR pres5;
452   pres5 = E2AP_PDU_PR_initiatingMessage;
453   
454
455   e2ap_pdu->present = pres5;
456   e2ap_pdu->choice.initiatingMessage = initmsg;
457
458   char *error_buf = (char*)calloc(300, sizeof(char));;
459   size_t errlen;
460                                                                           
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);
464
465
466 }
467
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) {
471
472   RICsubscriptionResponse_IEs_t *respricreqid =
473     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
474   
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;
479   
480   respricreqid->value.choice.RICrequestID.ricInstanceID = reqInstanceId;
481
482
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;
488
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;
492
493
494   int numAccept = accept_size;
495   int numReject = reject_size;
496
497
498   
499   for (int i=0; i < numAccept ; i++) {
500     fprintf(stderr, "in for loop i = %d\n", i);
501
502     long aid = reqActionIdsAccepted[i];
503
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;
509     
510     ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
511
512   }
513
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);
517   
518
519   if (numReject > 0) {
520
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;
526     
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;
530     
531     for (int i=0; i < numReject; i++) {
532       fprintf(stderr, "in for loop i = %d\n", i);
533       
534       long aid = reqActionIdsRejected[i];
535       
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;
541       
542       ASN_SEQUENCE_ADD(&ricactionrejected->value.choice.RICaction_NotAdmitted_List.list, noadmitie);
543       ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionrejected);      
544     }
545   }
546
547
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;
555
556   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
557   
558   e2ap_pdu->present = pres5;
559   e2ap_pdu->choice.successfulOutcome = successoutcome;
560
561   char *error_buf = (char*)calloc(300, sizeof(char));
562   size_t errlen;
563
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);
567
568   
569 }
570
571 void encoding::generate_e2apv1_subscription_response(E2AP_PDU *e2ap_pdu, E2AP_PDU *sub_req_pdu) {
572
573   //Gather details of the request
574
575   RICsubscriptionRequest_t orig_req =
576     sub_req_pdu->choice.initiatingMessage->value.choice.RICsubscriptionRequest;
577   
578   RICsubscriptionResponse_IEs_t *ricreqid =
579     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
580                                            
581   int count = orig_req.protocolIEs.list.count;
582   int size = orig_req.protocolIEs.list.size;
583   
584   RICsubscriptionRequest_IEs_t **ies = (RICsubscriptionRequest_IEs_t**)orig_req.protocolIEs.list.array;
585
586   fprintf(stderr, "count%d\n", count);
587   fprintf(stderr, "size%d\n", size);
588
589   RICsubscriptionRequest_IEs__value_PR pres;
590
591   long responseRequestorId;
592   long responseInstanceId;
593   long responseActionId;
594
595   std::vector<long> actionIds;
596
597   for (int i=0; i < count; i++) {
598     RICsubscriptionRequest_IEs_t *next_ie = ies[i];
599     pres = next_ie->value.present;
600     
601     fprintf(stderr, "next present value %d\n", pres);
602
603     switch(pres) {
604     case RICsubscriptionRequest_IEs__value_PR_RICrequestID:
605       {
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;
613                 
614         break;
615       }
616     case RICsubscriptionRequest_IEs__value_PR_RANfunctionID:
617       break;
618     case RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails:
619       {
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;
623         
624         int actionCount = actionList.list.count;
625         fprintf(stderr, "action count%d\n", actionCount);
626
627         auto **item_array = actionList.list.array;
628
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);
636         }
637         
638         break;
639       }
640     }
641     
642   }
643
644   fprintf(stderr, "After Processing Subscription Request\n");
645
646   fprintf(stderr, "requestorId %d\n", responseRequestorId);
647   fprintf(stderr, "instanceId %d\n", responseInstanceId);
648
649
650   for (int i=0; i < actionIds.size(); i++) {
651     fprintf(stderr, "Action ID %d %ld\n", i, actionIds.at(i));
652     
653   }
654
655
656   RICsubscriptionResponse_IEs_t *respricreqid =
657     (RICsubscriptionResponse_IEs_t*)calloc(1, sizeof(RICsubscriptionResponse_IEs_t));
658   
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;
663   
664   respricreqid->value.choice.RICrequestID.ricInstanceID = responseInstanceId;
665
666
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;
672
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;
676
677   for (int i=0; i < actionIds.size(); i++) {
678     fprintf(stderr, "in for loop i = %d\n", i);
679
680     long aid = actionIds.at(i);
681
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;
687     
688     ASN_SEQUENCE_ADD(&ricactionadmitted->value.choice.RICaction_Admitted_List.list, admitie);
689
690   }
691
692
693   RICsubscriptionResponse_t *ricsubresp = (RICsubscriptionResponse_t*)calloc(1,sizeof(RICsubscriptionResponse_t));
694   
695   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, respricreqid);
696   ASN_SEQUENCE_ADD(&ricsubresp->protocolIEs.list, ricactionadmitted);
697
698
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;
706
707   E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
708   
709   e2ap_pdu->present = pres5;
710   e2ap_pdu->choice.successfulOutcome = successoutcome;
711
712   char *error_buf = (char*)calloc(300, sizeof(char));
713   size_t errlen;
714
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);
718   
719 }
720
721 void encoding::generate_e2apv1_indication_request_parameterized(E2AP_PDU *e2ap_pdu,
722                                                                 long requestorId,
723                                                                 long instanceId,
724                                                                 long ranFunctionId,
725                                                                 long actionId,
726                                                                 long seqNum,
727                                                                 uint8_t *ind_header_buf,
728                                                                 int header_length,
729                                                                 uint8_t *ind_message_buf,
730                                                                 int message_length) {
731   
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));
741
742   RICindication_IEs__value_PR pres3;
743
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;
750
751   fprintf(stderr, "ind2\n");
752
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;
758
759   
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;
765
766
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;
772
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;
779
780
781   uint8_t *buf2 = (uint8_t *)"reportheader";
782   OCTET_STRING_t *hdr_str = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
783
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);
787
788   fprintf(stderr, "ind3\n");
789
790   ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,header_length);
791
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);
798   
799   ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
800
801
802   
803
804   pres3 = RICindication_IEs__value_PR_RICindicationMessage;
805   ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
806   fprintf(stderr, "after encoding message 1\n");
807
808   ricind_ies7->criticality = 0;
809   ricind_ies7->value.present = pres3;
810
811   fprintf(stderr, "after encoding message 2\n");
812
813   fprintf(stderr, "after encoding message 3\n");      
814   ricind_ies7->value.choice.RICindicationMessage.size = message_length;
815
816   fprintf(stderr, "after encoding message 4\n");
817   memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, ind_message_buf, message_length);
818
819   fprintf(stderr, "after encoding message 5\n");      
820
821   uint8_t *cpid_buf = (uint8_t *)"cpid";
822   OCTET_STRING_t cpid_str;
823
824   printf("5.1\n");
825
826   int cpid_buf_len = strlen((char*)cpid_buf);
827   pres3 = RICindication_IEs__value_PR_RICcallProcessID;
828   ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
829
830   ricind_ies8->criticality = 0;
831   ricind_ies8->value.present = pres3;
832
833   ricind_ies8->value.choice.RICcallProcessID.buf = (uint8_t*)calloc(1,cpid_buf_len);
834   ricind_ies8->value.choice.RICcallProcessID.size = cpid_buf_len;
835
836   memcpy(ricind_ies8->value.choice.RICcallProcessID.buf, cpid_buf, cpid_buf_len);
837
838   printf("5.2\n");
839
840   RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
841
842   
843   int ret;
844
845   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
846   
847   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
848
849   printf("5.3\n");
850
851   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
852
853   printf("5.35\n");
854   
855   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
856
857   printf("5.36\n");
858   
859   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
860
861   printf("5.4\n");
862   
863   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
864
865   printf("5.5\n");
866
867   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);  
868   
869   //  ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);    
870
871
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;
879
880   E2AP_PDU_PR pres5;
881   pres5 = E2AP_PDU_PR_initiatingMessage;
882   
883   e2ap_pdu->present = pres5;
884   e2ap_pdu->choice.initiatingMessage = initmsg;
885
886   char *error_buf = (char*)calloc(300, sizeof(char));
887   size_t errlen;
888
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);
892
893   xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);  
894
895 }
896
897 /*
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));
908
909   RICindication_IEs__value_PR pres3;
910
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;
917
918   fprintf(stderr, "ind2\n");  
919
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;
925
926   
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;
932
933
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;
939
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;
945
946
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);
950   hdr_str->size = 12;
951   memcpy(hdr_str->buf, buf2, 12);
952
953   fprintf(stderr, "ind3\n");
954
955   ricind_ies6->value.choice.RICindicationHeader.buf = (uint8_t*)calloc(1,12);
956
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);
963   
964   ricind_ies7->value.choice.RICindicationMessage.buf = (uint8_t*)calloc(1,8192);
965
966
967
968   E2SM_KPM_RANfunction_Description_t *e2sm_desc =
969     (E2SM_KPM_RANfunction_Description_t*)calloc(1,sizeof(E2SM_KPM_RANfunction_Description_t));
970
971   encode_kpm_function_description(e2sm_desc);
972   
973   
974   uint8_t e2smbuffer[8192];
975   size_t e2smbuffer_size = 8192;
976
977   asn_codec_ctx_t *opt_cod;
978
979   
980   asn_enc_rval_t er =
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);
985     
986   
987   fprintf(stderr, "er encded is %d\n", er.encoded);
988   fprintf(stderr, "after encoding message\n");
989   
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);
994   
995
996   pres3 = RICindication_IEs__value_PR_RICindicationMessage;
997   ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
998   fprintf(stderr, "after encoding message 1\n");
999
1000   ricind_ies7->criticality = 0;
1001   ricind_ies7->value.present = pres3;
1002
1003   fprintf(stderr, "after encoding message 2\n");
1004
1005   fprintf(stderr, "after encoding message 3\n");      
1006   ricind_ies7->value.choice.RICindicationMessage.size = er.encoded;
1007
1008   fprintf(stderr, "after encoding message 4\n");      
1009   memcpy(ricind_ies7->value.choice.RICindicationMessage.buf, e2smbuffer, er.encoded);
1010
1011   fprintf(stderr, "after encoding message 5\n");      
1012
1013   uint8_t *buf4 = (uint8_t *)"cpid";
1014   OCTET_STRING_t cpid_str;
1015   cpid_str.buf = buf4;
1016   cpid_str.size = 4;      
1017
1018
1019   pres3 = RICindication_IEs__value_PR_RICcallProcessID;
1020   ricind_ies8->id = ProtocolIE_ID_id_RICcallProcessID;
1021
1022   ricind_ies8->criticality = 0;
1023   ricind_ies8->value.present = pres3;
1024
1025   ricind_ies8->value.choice.RICcallProcessID = cpid_str;
1026
1027
1028   RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
1029
1030   
1031   int ret;
1032 */
1033   /*
1034     ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
1035
1036     ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
1037
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);  
1041
1042     ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
1043   */
1044 /*
1045     ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);  
1046
1047   ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);    
1048
1049
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;
1057
1058   E2AP_PDU_PR pres5;
1059   pres5 = E2AP_PDU_PR_initiatingMessage;
1060   
1061   e2ap_pdu->present = pres5;
1062   e2ap_pdu->choice.initiatingMessage = initmsg;
1063
1064   char *error_buf = (char*)calloc(300, sizeof(char));;
1065   size_t errlen;  
1066
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);
1070
1071   xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
1072 }
1073 */
1074