3 #include "OCTET_STRING.h"
5 ssize_t e2sm_encode_ric_control_header(void *buffer, size_t buf_size,struct uEID *inUEID,long f1AP[],size_t f1AP_len,long e1AP[],size_t e1Ap_len,long ricControlStyleType, long ricControlActionID, void* plmnId, size_t plmnIdSize)
7 fprintf(stderr,"e2SM wrapper function Entered\n");
8 fprintf(stderr,"plmn Size = %ld and aMFRegionID Size = %ld and aMFSetID_size = %ld and aMFPointer_size = %ld \n", inUEID->pLMNIdentity_size,inUEID->aMFRegionID_size,inUEID->aMFSetID_size,inUEID->aMFPointer_size);
10 E2SM_RC_ControlHeader_t *controlHeaderIE = (E2SM_RC_ControlHeader_t *)calloc(1, sizeof(E2SM_RC_ControlHeader_t));
13 fprintf(stderr, "alloc E2SM_RC_ControlHeader failed\n");
17 controlHeaderIE->ric_controlHeader_formats.present = E2SM_RC_ControlHeader__ric_controlHeader_formats_PR_controlHeader_Format1;
18 //E2SM_RC_ControlHeader_Format1_t *controlHeader_Fmt1 = (E2SM_RC_ControlHeader_Format1_t *)calloc(1, sizeof(E2SM_RC_ControlHeader_Format1_t));
19 E2SM_RC_ControlHeader_Format1_t *controlHeader_Fmt1 = NULL;
20 controlHeaderIE->ric_controlHeader_formats.choice.controlHeader_Format1 = (E2SM_RC_ControlHeader_Format1_t *)calloc(1, sizeof(E2SM_RC_ControlHeader_Format1_t));
21 controlHeader_Fmt1 = controlHeaderIE->ric_controlHeader_formats.choice.controlHeader_Format1;
22 if(!controlHeader_Fmt1)
24 fprintf(stderr, "alloc E2SM_RC_ControlHeader failed\n");
25 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
29 controlHeader_Fmt1->ueID.present = UEID_PR_gNB_UEID;
30 controlHeader_Fmt1->ueID.choice.gNB_UEID = (UEID_GNB_t *)calloc(1,sizeof(UEID_GNB_t));
31 if(! controlHeader_Fmt1->ueID.choice.gNB_UEID)
33 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
34 fprintf(stderr, "alloc gNB_UEID failed\n");
38 asn_long2INTEGER(&controlHeader_Fmt1->ueID.choice.gNB_UEID->amf_UE_NGAP_ID,inUEID->amf_UE_NGAP_Id);
40 fprintf(stderr, "e2sm_encode_ric_control_header amf_UE_NGAP_ID encoded \n");
42 //OCTET_STRING_fromBuf(&controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.pLMNIdentity,inUEID->pLMNIdentity, inUEID->pLMNIdentity_size);
44 OCTET_STRING_fromBuf(&controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.pLMNIdentity, plmnId,plmnIdSize);
45 fprintf(stderr, "e2smrc_encode_ric_control_header pLMNIdentity encoded \n");
47 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf = (uint8_t*)calloc(1,inUEID->aMFRegionID_size);
48 if(!controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf)
50 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
51 fprintf(stderr, "alloc aMFRegionID Value failed\n");
54 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.size = 1;//inUEID->aMFRegionID_size;
55 int decimal_num= (int)strtol(inUEID->aMFRegionID, NULL, 2);
56 memcpy(controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf, (char*)&decimal_num,sizeof(unsigned int));
58 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.bits_unused=0;
59 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf[0] = inUEID->aMFRegionID && 0XFF;
60 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf[0] = *(inUEID->aMFRegionID ) & 0XFF;
61 //memcpy(controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFRegionID.buf,inUEID->aMFRegionID,inUEID->aMFRegionID_size);
63 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.buf = (uint8_t*)calloc(1, inUEID->aMFSetID_size);
64 if(!controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.buf)
66 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
67 fprintf(stderr, "alloc aMFSetID Value failed\n");
70 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.size = inUEID->aMFSetID_size;
71 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.buf[0] = (inUEID->aMFSetID && 0xFF00) >> 8;
72 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.buf[1] = inUEID->aMFSetID && 0XFF00 && 0X00FF;
73 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.buf[0] = (*(inUEID->aMFSetID) & 0xFFC0) >> 8;
74 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFSetID.bits_unused = 6;
77 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.buf = (uint8_t*)calloc(1, inUEID->aMFPointer_size);
78 if(!controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.buf)
80 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
81 fprintf(stderr, "alloc aMFPointer Value failed\n");
85 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.size = 1;//inUEID->aMFPointer_size;
86 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.buf[0] = inUEID->aMFPointer && 0XFF;
87 //controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.buf[0] = (*(inUEID->aMFPointer) & 0xFC) >> 2;
88 int decimal_num3= (int)strtol(inUEID->aMFPointer, NULL, 2);
89 decimal_num3=decimal_num3<<2;
90 memcpy(controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.buf, (char*)&decimal_num3,sizeof(unsigned int));
92 controlHeader_Fmt1->ueID.choice.gNB_UEID->guami.aMFPointer.bits_unused = 2;
95 controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_UE_F1AP_ID_List = (UEID_GNB_CU_F1AP_ID_List_t *)calloc(1,sizeof(UEID_GNB_CU_F1AP_ID_List_t));
96 if(! controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_UE_F1AP_ID_List)
98 fprintf(stderr, "alloc gNB_CU_CP_UE_E1AP_ID_list failed\n");
99 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
102 //f1AP is an array of data
103 //int n = sizeof(f1AP)/sizeof(long int);
105 for(int i =0; i < f1AP_len; i++)
107 UEID_GNB_CU_CP_F1AP_ID_Item_t *F1AP_ID_Item = (UEID_GNB_CU_CP_F1AP_ID_Item_t *)calloc (1, sizeof(UEID_GNB_CU_CP_F1AP_ID_Item_t ));
110 fprintf(stderr, "alloc UEID_GNB_CU_CP_F1AP_ID_Item failed\n");
111 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
114 F1AP_ID_Item->gNB_CU_UE_F1AP_ID = f1AP[i];
115 fprintf(stderr, "F1AP_id %d =%lu\n",i,*((unsigned long *) F1AP_id +i ));
116 ASN_SEQUENCE_ADD(&controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_UE_F1AP_ID_List->list,F1AP_ID_Item);
118 //F1AP_ID_Item->gNB_CU_UE_F1AP_ID = f1AP[0];
119 //ASN_SEQUENCE_ADD(&controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_UE_F1AP_ID_List->list,F1AP_ID_Item);
122 controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_CP_UE_E1AP_ID_List = (UEID_GNB_CU_CP_E1AP_ID_List_t *)calloc(1,sizeof(UEID_GNB_CU_CP_E1AP_ID_List_t));
124 if(! controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_CP_UE_E1AP_ID_List)
126 fprintf(stderr, "alloc gNB_CU_CP_UE_E1AP_ID_list failed\n");
127 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
132 //n = sizeof(e1AP)/sizeof(long int);
133 for(int i =0; i < e1Ap_len; i++)
135 UEID_GNB_CU_CP_E1AP_ID_Item_t *E1AP_ID_Item = (UEID_GNB_CU_CP_E1AP_ID_Item_t *)calloc (1, sizeof(UEID_GNB_CU_CP_E1AP_ID_Item_t ));
138 fprintf(stderr, "alloc UEID_GNB_CU_CP_E1AP_ID_Item failed\n");
139 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
143 E1AP_ID_Item->gNB_CU_CP_UE_E1AP_ID = e1AP[i];
144 ASN_SEQUENCE_ADD(&controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_CP_UE_E1AP_ID_List->list,E1AP_ID_Item);
145 //E1AP_ID_Item->gNB_CU_CP_UE_E1AP_ID = (*(unsigned long *) E1AP_id) ;
146 //ASN_SEQUENCE_ADD(&controlHeader_Fmt1->ueID.choice.gNB_UEID->gNB_CU_CP_UE_E1AP_ID_List->list,E1AP_ID_Item);
150 controlHeader_Fmt1->ric_Style_Type = ricControlStyleType;
151 controlHeader_Fmt1->ric_ControlAction_ID = ricControlActionID;
153 controlHeaderIE->ric_controlHeader_formats.choice.controlHeader_Format1 = controlHeader_Fmt1;
156 fprintf(stderr, "showing xer of asn_DEF_E2SM_RC_ControlHeader data\n");
157 xer_fprint(stderr, &asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
158 fprintf(stderr, "\n");
159 fprintf(stderr, "After xer of asn_DEF_E2SM_RC_ControlHeader data\n");
161 asn_enc_rval_t encode_result;
162 encode_result = aper_encode_to_buffer(&asn_DEF_E2SM_RC_ControlHeader, NULL, controlHeaderIE, buffer, buf_size);
165 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlHeader, controlHeaderIE);
166 if(encode_result.encoded == -1)
168 fprintf(stderr, "Cannot encode %s: %s\n", encode_result.failed_type->name, strerror(errno));
173 return encode_result.encoded;
177 ssize_t e2sm_encode_nrcgi(NR_CGI_t *nr_cgi, void* plmnIdValue, size_t plmnId_size,ulong lNRCellId, uint8_t* buffer, size_t buf_size)
179 nr_cgi = (NR_CGI_t*)calloc(1, sizeof(NR_CGI_t));
181 fprintf(stderr, "e2src_encode_nrcgi alloc nr_cgi failed \n");
184 OCTET_STRING_fromBuf(&nr_cgi->pLMNIdentity,plmnIdValue, plmnId_size);
185 //fprintf(stderr, "encodec Plmn Id = %s plmnIdValue %s and lNRCellId = %lu \n", nr_cgi->pLMNIdentity, plmnIdValue,lNRCellId);
186 //fprintf(stderr, "encodec Plmn Id = %s and lNRCellId = %d \n", nr_cgi->pLMNIdentity,plmnIdValue,lNRCellId);
187 BIT_STRING_t *nr_cell_id = &nr_cgi->nRCellIdentity ;
188 nr_cell_id->buf = (uint8_t*)calloc(1,5);
191 nr_cell_id->size = 5;
192 nr_cell_id->buf[0] = ((lNRCellId & 0X0FF0000000) >> 28);
193 nr_cell_id->buf[1] = ((lNRCellId & 0X000FF00000) >> 20);
194 nr_cell_id->buf[2] = ((lNRCellId & 0X00000FF000) >> 12);
195 nr_cell_id->buf[3] = ((lNRCellId & 0X0000000FF0) >> 4);
196 nr_cell_id->buf[4] = (lNRCellId & 0X000000000F) << 4;
197 nr_cell_id->bits_unused = 4;
201 fprintf(stderr, "showing xer of asn_DEF_NR_CGI NR_CGI_t data\n");
202 xer_fprint(stderr, &asn_DEF_NR_CGI, nr_cgi);
204 asn_enc_rval_t encode_result = aper_encode_to_buffer(&asn_DEF_NR_CGI, NULL, nr_cgi, buffer, buf_size);
206 if(encode_result.encoded != -1)
208 fprintf(stderr, "nr_cgi encodedi length = %zd \n", encode_result.encoded) ;
209 return encode_result.encoded;
213 fprintf(stderr, "nr_cgi encode failed =%zd \n", encode_result.encoded) ;
218 ssize_t e2sm_encode_ric_control_message(void *buffer, size_t buf_size, long targetPrimaryCell,
219 long targetCell, long nrOrEUtraCell, long nrCGIOrECGI, void* ranParameterValue,size_t ranParameterValue_size){
221 E2SM_RC_ControlMessage_t *e2smrcRcControlMsg = (E2SM_RC_ControlMessage_t*)calloc(1, sizeof(E2SM_RC_ControlMessage_t));
222 if(!e2smrcRcControlMsg) {
223 fprintf(stderr, "alloc E2SM_ControlMessage_t failed\n");
226 e2smrcRcControlMsg->ric_controlMessage_formats.present = E2SM_RC_ControlMessage__ric_controlMessage_formats_PR_controlMessage_Format1;
227 E2SM_RC_ControlMessage_Format1_t *e2smrcRcControlFormat1 = (E2SM_RC_ControlMessage_Format1_t*)calloc(1, sizeof(E2SM_RC_ControlMessage_Format1_t));
228 if(!e2smrcRcControlFormat1) {
229 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
230 fprintf(stderr, "alloc E2SM_ControlMessage_Format1_t failed\n");
233 RANParameter_ValueType_Choice_Structure_t *ranParameter_choice_Structure4 = (struct RANParameter_ValueType_Choice_Structure*)calloc(2, sizeof(struct RANParameter_ValueType_Choice_Structure));
234 //RANParameter_STRUCTURE_t* RPS4=(RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
235 //ranParameter_choice_Structure4[0]=(RANParameter_ValueType_Choice_Structure_t*)calloc(1,sizeof(RANParameter_ValueType_Choice_Structure_t));
236 //ranParameter_choice_Structure4[1]=(RANParameter_ValueType_Choice_Structure_t*)calloc(1,sizeof(RANParameter_ValueType_Choice_Structure_t));
237 //PLMN ################################
238 //void *p={"001F01"};
239 //void *nR={"12345C0010"};
242 int newSize = strlen((char*)ranParameterValue1) + strlen((char*)ranParameterValue2) + 2;
244 // Allocate new buffer
245 char * newBuffer = (char *)malloc(newSize);
246 //strcpy(newBuffer,z);
247 strcat(newBuffer,(char *)ranParameterValue1); // or strncat
248 strcat(newBuffer,(char *)ranParameterValue2);
250 //newBuffer=00001F0112345C0010;
251 printf("%s\n",newBuffer);
252 u_int64_t lol3 = (u_int64_t)strtoll(newBuffer, NULL, 16);
254 int c0=lol3 & 0X0000000000000000FF;
255 int c1=(lol3>>8) & 0X0000000000000000FF;
256 int c2=(lol3>>16) & 0X0000000000000000FF;
257 int c3=(lol3>>24) & 0X0000000000000000FF;
258 int c4=(lol3>>32) & 0X0000000000000000FF;
259 int c5=(lol3>>40) & 0X0000000000000000FF;
260 int c6=(lol3>>48) & 0X0000000000000000FF;
261 int c7=(lol3>>56) & 0X0000000000000000FF;
262 int c8=lol3 & 0X000000000000000000;
264 RANParameter_STRUCTURE_Item_t *ranParameter_structure_Item_nrcgi = (RANParameter_STRUCTURE_Item_t *)calloc(1,sizeof(RANParameter_STRUCTURE_Item_t));
265 ranParameter_structure_Item_nrcgi->ranParameter_ID=4;
266 RANParameter_ValueType_t* RPV_t_nrcgi=(RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
267 RPV_t_nrcgi->present=RANParameter_ValueType_PR_ranP_Choice_ElementFalse;
268 RANParameter_ValueType_Choice_ElementFalse_t * RPVCEF_nrcgi=(RANParameter_ValueType_Choice_ElementFalse_t *)calloc(1, sizeof(RANParameter_ValueType_Choice_ElementFalse_t));
269 RANParameter_Value_t *RPV_nrcgi=(RANParameter_Value_t *)calloc(1, sizeof(RANParameter_Value_t));
270 RPV_nrcgi->present= RANParameter_Value_PR_valueOctS;
274 OCTET_STRING_t *NRCGI=(OCTET_STRING_t *)calloc(1,sizeof(OCTET_STRING_t));
275 OCTET_STRING_fromBuf(NRCGI, ranParameterValue,ranParameterValue_size);
276 RPV_nrcgi->choice.valueOctS=*NRCGI;
277 RPVCEF_nrcgi->ranParameter_value=RPV_nrcgi;
278 RPV_t_nrcgi->choice.ranP_Choice_ElementFalse=RPVCEF_nrcgi;
279 ranParameter_structure_Item_nrcgi->ranParameter_valueType=RPV_t_nrcgi;
280 ranParameter_choice_Structure4->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
281 ranParameter_choice_Structure4->ranParameter_Structure->sequence_of_ranParameters = (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
282 int result1 = ASN_SEQUENCE_ADD(&ranParameter_choice_Structure4->ranParameter_Structure->sequence_of_ranParameters->list, ranParameter_structure_Item_nrcgi);
285 fprintf(stderr,"Unable to assign memory to add PLMN %s",strerror(errno));
290 RANParameter_STRUCTURE_Item_t* ranParameter_structure_Item3= (RANParameter_STRUCTURE_Item_t *)calloc(1,sizeof(RANParameter_STRUCTURE_Item_t));
291 ranParameter_structure_Item3->ranParameter_ID=3;
292 RANParameter_ValueType_t* RPV_t3=(RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
293 RPV_t3->present=RANParameter_ValueType_PR_ranP_Choice_Structure;
294 RPV_t3->choice.ranP_Choice_Structure=ranParameter_choice_Structure4;
295 ranParameter_structure_Item3->ranParameter_valueType=RPV_t3;
296 RANParameter_ValueType_Choice_Structure_t *ranParameter_choice_Structure3 = (struct RANParameter_ValueType_Choice_Structure*)calloc(2, sizeof(struct RANParameter_ValueType_Choice_Structure));
297 ranParameter_choice_Structure3->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
298 ranParameter_choice_Structure3->ranParameter_Structure->sequence_of_ranParameters= (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
299 int result3 = ASN_SEQUENCE_ADD(&ranParameter_choice_Structure3->ranParameter_Structure->sequence_of_ranParameters->list, ranParameter_structure_Item3);
302 fprintf(stderr,"Unable to assign memory to add ranParameter_structure_Item3 %s",strerror(errno));
305 RANParameter_STRUCTURE_Item_t * ranParameter_structure_Item2= (RANParameter_STRUCTURE_Item_t *)calloc(1,sizeof(RANParameter_STRUCTURE_Item_t));
306 ranParameter_structure_Item2->ranParameter_ID=2;
307 RANParameter_ValueType_t* RPV_t2=(RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
308 RPV_t2->present=RANParameter_ValueType_PR_ranP_Choice_Structure;
309 RPV_t2->choice.ranP_Choice_Structure=ranParameter_choice_Structure3;
310 ranParameter_structure_Item2->ranParameter_valueType=RPV_t2;
311 RANParameter_ValueType_Choice_Structure_t *ranParameter_choice_Structure2 = (struct RANParameter_ValueType_Choice_Structure*)calloc(2, sizeof(struct RANParameter_ValueType_Choice_Structure));
312 ranParameter_choice_Structure2->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
313 ranParameter_choice_Structure2->ranParameter_Structure->sequence_of_ranParameters= (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
314 int result4 = ASN_SEQUENCE_ADD(&ranParameter_choice_Structure2->ranParameter_Structure->sequence_of_ranParameters->list, ranParameter_structure_Item2);
317 fprintf(stderr,"Unable to assign memory to add ranParameter_structure_Item2 %s",strerror(errno));
320 RANParameter_ValueType_t* RPV_t1=(RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
321 RPV_t1->present=RANParameter_ValueType_PR_ranP_Choice_Structure;
322 RPV_t1->choice.ranP_Choice_Structure=ranParameter_choice_Structure2;
323 E2SM_RC_ControlMessage_Format1_Item_t *format1item = (E2SM_RC_ControlMessage_Format1_Item_t *) calloc(1,sizeof(
324 E2SM_RC_ControlMessage_Format1_Item_t));
326 fprintf(stderr, "alloc format1item failed\n");
327 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
330 format1item->ranParameter_ID=1;
331 format1item->ranParameter_valueType.present = RANParameter_ValueType_PR_ranP_Choice_Structure;
332 format1item->ranParameter_valueType=*RPV_t1;
333 int result5 = ASN_SEQUENCE_ADD(&e2smrcRcControlFormat1->ranP_List.list, format1item);
336 fprintf(stderr,"Unable to assign memory to add format1item %s",strerror(errno));
339 e2smrcRcControlMsg->ric_controlMessage_formats.choice.controlMessage_Format1=e2smrcRcControlFormat1;
340 asn_enc_rval_t encode_result;
341 encode_result = aper_encode_to_buffer(&asn_DEF_E2SM_RC_ControlMessage, NULL, e2smrcRcControlMsg, buffer,buf_size );
342 fprintf(stderr, "encoded length = %ld \n", encode_result.encoded);
343 if(encode_result.encoded == -1)
345 fprintf(stderr, "Cannot encode %s: %s\n", encode_result.failed_type->name, strerror(errno));
350 xer_fprint(stderr, &asn_DEF_E2SM_RC_ControlMessage,e2smrcRcControlMsg);
351 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
352 return encode_result.encoded;
358 ssize_t e2sm_encode_ric_control_message(void *buffer, size_t buf_size, long targetPrimaryCell,
359 long targetCell, long nrOrEUtraCell, long nrCGIOrECGI, void* ranParameterValue, size_t ranParameterValue_size)
361 fprintf(stderr, "e2sm_encode_ric_control_message \n") ;
362 //NR_CGI_t *nr_cgi = NULL;
363 //uint8_t nrcgiBuf[buf_size];
364 //ssize_t nrcgiBuf_size,nrcgiLen;
367 E2SM_RC_ControlMessage_t *e2smrcRcControlMsg = (E2SM_RC_ControlMessage_t*)calloc(1, sizeof(E2SM_RC_ControlMessage_t));
368 if(!e2smrcRcControlMsg) {
369 fprintf(stderr, "alloc E2SM_ControlMessage_t failed\n");
372 e2smrcRcControlMsg->ric_controlMessage_formats.present = E2SM_RC_ControlMessage__ric_controlMessage_formats_PR_controlMessage_Format1;
374 E2SM_RC_ControlMessage_Format1_t *e2smrcRcControlFormat1 = (E2SM_RC_ControlMessage_Format1_t*)calloc(1, sizeof(E2SM_RC_ControlMessage_Format1_t));
375 if(!e2smrcRcControlFormat1) {
376 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
377 fprintf(stderr, "alloc E2SM_ControlMessage_Format1_t failed\n");
380 // Start Target Primary Cell
381 E2SM_RC_ControlMessage_Format1_Item_t *ranParameterItem1 = (E2SM_RC_ControlMessage_Format1_Item_t *) calloc(1,sizeof(
382 E2SM_RC_ControlMessage_Format1_Item_t));
383 if(!ranParameterItem1) {
384 fprintf(stderr, "alloc RANParameter_Item_t1 failed\n");
385 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
389 ranParameterItem1->ranParameter_ID = targetPrimaryCell; // Target Primary Cell ID value = 1
390 ranParameterItem1->ranParameter_valueType.present = RANParameter_ValueType_PR_ranP_Choice_Structure;
392 RANParameter_ValueType_Choice_Structure_t *ranParameterStructure1 = (RANParameter_ValueType_Choice_Structure_t*)calloc(1, sizeof(RANParameter_ValueType_Choice_Structure_t));
393 if(!ranParameterStructure1)
395 fprintf(stderr, "alloc RANParameter_STRUCTURE_t1 failed\n");
396 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
400 fprintf(stderr, "targetPrimaryCell encoded \n");
403 RANParameter_STRUCTURE_Item_t *ranParameterItem2 = (RANParameter_STRUCTURE_Item_t *)calloc(1,sizeof(RANParameter_STRUCTURE_Item_t));
405 if(!ranParameterItem2)
408 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
409 fprintf(stderr, "alloc RANParameter_Item_t2 failed\n");
413 ranParameterItem2->ranParameter_ID = targetCell; // Target Cell ID value = 2
415 RANParameter_ValueType_Choice_Structure_t *ranParameterStructure2 = (RANParameter_ValueType_Choice_Structure_t*)calloc(1, sizeof(struct RANParameter_ValueType_Choice_Structure));
416 if(!ranParameterStructure2)
418 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
419 fprintf(stderr, "alloc RANParameter_STRUCTURE_t2 failed\n");
423 fprintf(stderr, "targetPrimaryCellId Value encoded \n");
425 // Start NR Cell (or E-UTRA Cell)
426 RANParameter_STRUCTURE_Item_t *ranParameterItem3 = (RANParameter_STRUCTURE_Item_t*)calloc(1,sizeof(RANParameter_STRUCTURE_Item_t));
427 if(!ranParameterItem3)
429 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
430 fprintf(stderr, "alloc RANParameter_Item_t3 failed\n");
434 ranParameterItem3->ranParameter_ID = nrOrEUtraCell; // NR Cell ID (or E-UTRA Cell ID) value =
436 RANParameter_ValueType_Choice_Structure_t *ranParameterStructure3 = (struct RANParameter_ValueType_Choice_Structure*)calloc(1, sizeof(struct RANParameter_ValueType_Choice_Structure));
437 if(!ranParameterStructure3)
439 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
440 fprintf(stderr, "alloc RANParameter_Item_t3 failed\n");
443 fprintf(stderr, " NR Cell ID Value encoded \n");
445 // Start NR CGI (or ECGI)
446 RANParameter_STRUCTURE_Item_t *ranParameterItem4 = (RANParameter_STRUCTURE_Item_t *) calloc(1,sizeof(
447 RANParameter_STRUCTURE_Item_t));
448 if(!ranParameterItem4)
450 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
451 fprintf(stderr, "alloc RANParameter_Item_t4 failed\n");
455 ranParameterItem4->ranParameter_ID = nrCGIOrECGI; // NR CGI ID (or ECGI ID) value =
457 ranParameterItem4->ranParameter_valueType = (RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
458 if(!ranParameterItem4->ranParameter_valueType)
460 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
461 fprintf(stderr, "alloc ranParameterItem4->ranParameter_valueType failed\n");
465 ranParameterItem4->ranParameter_valueType->present = RANParameter_ValueType_PR_ranP_Choice_ElementFalse;
466 ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse = (RANParameter_ValueType_Choice_ElementFalse_t *)calloc(1, sizeof(RANParameter_ValueType_Choice_ElementFalse_t));
467 if(!ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse)
469 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
470 fprintf(stderr, "alloc RANParameter_Item_t4 failed\n");
474 ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse->ranParameter_value = (RANParameter_Value_t *)calloc(1, sizeof(RANParameter_Value_t));
475 if(!ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse->ranParameter_value)
477 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
478 fprintf(stderr, "alloc ranParameter_value failed\n");
481 ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse->ranParameter_value->present = RANParameter_Value_PR_valueOctS;
482 OCTET_STRING_fromBuf(&ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse->ranParameter_value->choice.valueOctS,ranParameterValue, ranParameterValue_size);
485 fprintf(stderr, "Target Plmn Id = %s ranParameterValue and lNRCellId = %lu \n", ranParameterValue,lNRCellId);
486 nrcgiLen = e2sm_encode_nrcgi(nr_cgi, ranParameterValue, ranParameterValue_size, lNRCellId,nrcgiBuf,nrcgiBuf_size);
489 fprintf(stderr,"e2srmc_encode_nrcgi failed \n");
492 OCTET_STRING_fromBuf(&ranParameterItem4->ranParameter_valueType->choice.ranP_Choice_ElementFalse->ranParameter_value->choice.valueOctS,nrcgiBuf,nrcgiLen);
494 fprintf(stderr, " NR CGI encoded \n");
496 ranParameterStructure3->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
497 if(!ranParameterStructure3->ranParameter_Structure)
499 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
500 fprintf(stderr, "alloc ranParameterStructure3->ranParameter_Structure failed\n");
504 ranParameterStructure3->ranParameter_Structure->sequence_of_ranParameters = (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
505 if(!ranParameterStructure3->ranParameter_Structure->sequence_of_ranParameters)
507 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
508 fprintf(stderr, "alloc ranParameterStructure3->ranParameter_Structure->sequence_of_ranParameters failed\n");
514 ASN_SEQUENCE_ADD(&ranParameterStructure3->ranParameter_Structure->sequence_of_ranParameters->list, ranParameterItem4); // NR CGI (or ECGI)
515 ranParameterItem3->ranParameter_valueType = (RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
516 if(!ranParameterItem3->ranParameter_valueType)
518 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
519 fprintf(stderr, "alloc ranParameterItem3->ranParameter_valueType failed\n");
522 ranParameterItem3->ranParameter_valueType->present = RANParameter_ValueType_PR_ranP_Choice_Structure;
523 ranParameterItem3->ranParameter_valueType->choice.ranP_Choice_Structure = ranParameterStructure3; // NR Cell (or E-UTRA Cell)
524 fprintf(stderr, " ranParameterStructure3 encoded \n");
526 ranParameterStructure2->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
527 if(!ranParameterStructure2->ranParameter_Structure)
529 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
530 fprintf(stderr, "alloc ranParameterStructure2->ranParameter_Structure failed\n");
534 ranParameterStructure2->ranParameter_Structure->sequence_of_ranParameters = (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
535 if(!ranParameterStructure2->ranParameter_Structure->sequence_of_ranParameters)
537 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
538 fprintf(stderr, "alloc ranParameterStructure3->ranParameter_Structure->sequence_of_ranParameters failed\n");
542 ASN_SEQUENCE_ADD(&ranParameterStructure2->ranParameter_Structure->sequence_of_ranParameters->list, ranParameterItem3); // NR Cell (or E-UTRA Cell)
543 ranParameterItem2->ranParameter_valueType = (RANParameter_ValueType_t*)calloc(1,sizeof(RANParameter_ValueType_t));
544 if(!ranParameterItem2->ranParameter_valueType)
546 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
547 fprintf(stderr, "alloc ranParameterItem2->ranParameter_valueType failed\n");
550 ranParameterItem2->ranParameter_valueType->present = RANParameter_ValueType_PR_ranP_Choice_Structure;
551 ranParameterItem2->ranParameter_valueType->choice.ranP_Choice_Structure = ranParameterStructure2; // Target Cell
552 fprintf(stderr, " ranParameterStructure2 encoded \n");
554 ranParameterStructure1->ranParameter_Structure = (RANParameter_STRUCTURE_t*)calloc(1,sizeof(RANParameter_STRUCTURE_t));
555 if(!ranParameterStructure1->ranParameter_Structure)
557 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
558 fprintf(stderr, "alloc ranParameterStructure1->ranParameter_Structure failed\n");
562 ranParameterStructure1->ranParameter_Structure->sequence_of_ranParameters = (struct RANParameter_STRUCTURE__sequence_of_ranParameters*)calloc(1,sizeof(struct RANParameter_STRUCTURE__sequence_of_ranParameters));
563 if(!ranParameterStructure1->ranParameter_Structure->sequence_of_ranParameters)
565 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
566 fprintf(stderr, "alloc ranParameterStructure1->ranParameter_Structure->sequence_of_ranParameters failed\n");
569 fprintf(stderr, " ranParameterStructure1 encoded \n");
571 ASN_SEQUENCE_ADD(&ranParameterStructure1->ranParameter_Structure->sequence_of_ranParameters->list, ranParameterItem2); // Target Cell
572 ranParameterItem1->ranParameter_valueType.choice.ranP_Choice_Structure = ranParameterStructure1; // Target Primary Cell
574 ASN_SEQUENCE_ADD(&e2smrcRcControlFormat1->ranP_List.list, ranParameterItem1); // Target Primary Cell
575 e2smrcRcControlMsg->ric_controlMessage_formats.choice.controlMessage_Format1 = e2smrcRcControlFormat1;
578 fprintf(stderr, "showing xer of asn_DEF_E2SM_RC_ControlMessage data\n");
579 xer_fprint(stderr, &asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
580 fprintf(stderr, "\n");
581 fprintf(stderr, "After xer of asn_DEF_E2SM_RC_ControlMessage data\n");
583 asn_enc_rval_t encode_result;
584 encode_result = aper_encode_to_buffer(&asn_DEF_E2SM_RC_ControlMessage, NULL, e2smrcRcControlMsg, buffer, buf_size);
585 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlMessage, e2smrcRcControlMsg);
586 fprintf(stderr, "encoded length = %ld \n", encode_result.encoded);
587 if(encode_result.encoded == -1)
589 fprintf(stderr, "Cannot encode %s: %s\n", encode_result.failed_type->name, strerror(errno));
594 return encode_result.encoded;
599 E2SM_RC_ControlOutcome_t* e2sm_decode_ric_call_process_outcome(void *buffer, size_t buf_size)
601 fprintf(stderr, "e2sm_decode_ric_call_process_outcome Enter \n");
602 asn_dec_rval_t decode_result;
603 E2SM_RC_ControlOutcome_t* controlOutcome = NULL;
604 decode_result = aper_decode_complete(NULL, &asn_DEF_E2SM_RC_ControlOutcome, (void **)&controlOutcome, buffer, buf_size);
605 if(decode_result.code == RC_OK) {
606 xer_fprint(stdout, &asn_DEF_E2SM_RC_ControlOutcome, controlOutcome);
607 return controlOutcome;
610 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlOutcome, controlOutcome);
615 void e2sm_free_ric_call_process_outcome(E2SM_RC_ControlOutcome_t* controlOutcome) {
616 ASN_STRUCT_FREE(asn_DEF_E2SM_RC_ControlOutcome, controlOutcome);