2 #include "encode_e2apv1.hpp"
4 void generate_e2apv1_setup_request(E2AP_PDU_t *e2ap_pdu) {
6 uint8_t *buf = (uint8_t *)"gnb1";
8 BIT_STRING_t *gnb_bstring = (BIT_STRING_t*)calloc(1, sizeof(BIT_STRING_t));;
9 gnb_bstring->buf = buf;
10 gnb_bstring->size = 4;
11 gnb_bstring->bits_unused = 0;
13 uint8_t *buf2 = (uint8_t *)"plmn3";
14 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
18 GNB_ID_Choice_t *gnbchoice = (GNB_ID_Choice_t*)calloc(1,sizeof(GNB_ID_Choice_t));
19 GNB_ID_Choice_PR pres2 = GNB_ID_Choice_PR_gnb_ID;
20 gnbchoice->present = pres2;
21 gnbchoice->choice.gnb_ID = *gnb_bstring;
23 GlobalgNB_ID_t *gnb = (GlobalgNB_ID_t*)calloc(1, sizeof(GlobalgNB_ID_t));
25 gnb->gnb_id = *gnbchoice;
27 GlobalE2node_gNB_ID_t *e2gnb = (GlobalE2node_gNB_ID_t*)calloc(1, sizeof(GlobalE2node_gNB_ID_t));
28 e2gnb->global_gNB_ID = *gnb;
30 GlobalE2node_ID_t *globale2nodeid = (GlobalE2node_ID_t*)calloc(1, sizeof(GlobalE2node_ID_t));
31 GlobalE2node_ID_PR pres;
32 pres = GlobalE2node_ID_PR_gNB;
33 globale2nodeid->present = pres;
34 globale2nodeid->choice.gNB = e2gnb;
36 E2setupRequestIEs_t *e2setuprid = (E2setupRequestIEs_t*)calloc(1, sizeof(E2setupRequestIEs_t));;
37 E2setupRequestIEs__value_PR pres3;
38 pres3 = E2setupRequestIEs__value_PR_GlobalE2node_ID;
40 e2setuprid->criticality = 0;
41 e2setuprid->value.choice.GlobalE2node_ID = *globale2nodeid;
42 e2setuprid->value.present = pres3;
44 auto *ranFlistIEs = (E2setupRequestIEs_t *)calloc(1, sizeof(E2setupRequestIEs_t));
45 ASN_STRUCT_RESET(asn_DEF_E2setupRequestIEs, ranFlistIEs);
46 ranFlistIEs->criticality = 0;
47 ranFlistIEs->id = ProtocolIE_ID_id_RANfunctionsAdded;
48 ranFlistIEs->value.present = E2setupRequestIEs__value_PR_RANfunctions_List;
50 auto *itemIes = (RANfunction_ItemIEs_t *)calloc(1, sizeof(RANfunction_ItemIEs_t));
51 itemIes->id = ProtocolIE_ID_id_RANfunction_Item;
52 itemIes->criticality = Criticality_reject;
53 itemIes->value.present = RANfunction_ItemIEs__value_PR_RANfunction_Item;
54 itemIes->value.choice.RANfunction_Item.ranFunctionID = 1;
56 ASN_SEQUENCE_ADD(&ranFlistIEs->value.choice.RANfunctions_List.list, itemIes);
58 E2setupRequest_t *e2setupreq = (E2setupRequest_t*)calloc(1, sizeof(E2setupRequest_t));
59 e2setupreq->protocolIEs.list.size = sizeof(E2setupRequestIEs);
60 e2setupreq->protocolIEs.list.count = 1;
61 e2setupreq->protocolIEs.list.array = &e2setuprid;
63 InitiatingMessage__value_PR pres4;
64 pres4 = InitiatingMessage__value_PR_E2setupRequest;
65 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
66 initmsg->procedureCode = 1;
67 initmsg->criticality = 0;
68 initmsg->value.present = pres4;
69 initmsg->value.choice.E2setupRequest = *e2setupreq;
72 pres5 = E2AP_PDU_PR_initiatingMessage;
75 e2ap_pdu->present = pres5;
76 e2ap_pdu->choice.initiatingMessage = initmsg;
81 void generate_e2apv1_setup_response(E2AP_PDU_t *e2ap_pdu) {
83 E2setupResponseIEs *resp_ies1 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
84 E2setupResponseIEs *resp_ies2 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
85 E2setupResponseIEs *resp_ies3 = (E2setupResponseIEs_t*)calloc(1, sizeof(E2setupResponseIEs_t));
87 uint8_t *buf = (uint8_t *)"gnb1";
89 BIT_STRING_t *ricid_bstring = (BIT_STRING_t*)calloc(1,sizeof(BIT_STRING_t));
90 ricid_bstring->buf = buf;
91 ricid_bstring->size = 4;
92 ricid_bstring->bits_unused = 0;
94 uint8_t *buf2 = (uint8_t *)"plmn3";
95 OCTET_STRING_t *plmn = (OCTET_STRING_t*)calloc(1,sizeof(OCTET_STRING_t));
99 GlobalRIC_ID_t *globalricid = (GlobalRIC_ID_t*)calloc(1,sizeof(GlobalRIC_ID_t));
100 globalricid->pLMN_Identity = *plmn;
101 globalricid->ric_ID = *ricid_bstring;
103 E2setupResponseIEs__value_PR pres1;
104 pres1 = E2setupResponseIEs__value_PR_GlobalRIC_ID;
106 resp_ies1->id = ProtocolIE_ID_id_GlobalRIC_ID;
107 resp_ies1->criticality = 0;
108 resp_ies1->value.present = pres1;
109 resp_ies1->value.choice.GlobalRIC_ID = *globalricid;
111 E2setupResponse_t *e2setupresp = (E2setupResponse_t*)calloc(1,sizeof(E2setupResponse_t));
112 int ret = ASN_SEQUENCE_ADD(&e2setupresp->protocolIEs.list, resp_ies1);
115 SuccessfulOutcome__value_PR pres;
116 pres = SuccessfulOutcome__value_PR_E2setupResponse;
117 SuccessfulOutcome_t *successoutcome = (SuccessfulOutcome_t*)calloc(1, sizeof(SuccessfulOutcome_t));
118 successoutcome->procedureCode = 1;
119 successoutcome->criticality = 0;
120 successoutcome->value.present = pres;
121 successoutcome->value.choice.E2setupResponse = *e2setupresp;
123 E2AP_PDU_PR pres5 = E2AP_PDU_PR_successfulOutcome;
125 e2ap_pdu->present = pres5;
126 e2ap_pdu->choice.successfulOutcome = successoutcome;
131 void generate_e2apv1_subscription_request(E2AP_PDU *e2ap_pdu) {
133 fprintf(stderr, "in generate sub\n");
134 uint8_t *buf2 = (uint8_t *)"SubscriptionTriggers";
135 fprintf(stderr, "in gen sub 1\n");
136 OCTET_STRING_t *triggerdef = (OCTET_STRING_t*)calloc(1, sizeof(OCTET_STRING_t));
137 triggerdef->buf = buf2;
138 triggerdef->size = 20;
141 ProtocolIE_SingleContainer_1547P0_t *action_item =
142 (ProtocolIE_SingleContainer_1547P0_t *)calloc(1, sizeof(ProtocolIE_SingleContainer_1547P0_t));
143 action_item->ricActionID = 19;
144 action_item->ricActionType = 1;
146 // RICactions_ToBeSetup_List_t actionslist = asn_DEF_RICactions_ToBeSetup_List;
149 // actionslist.list.size = sizeof(RICaction_ToBeSetup_Item_t);
151 actionslist.list.size = sizeof(ProtocolIE_SingleContainer);
152 actionslist.list.count = 1;
153 actionslist.list.array = &action_item;
156 fprintf(stderr, "sub1\n");
157 ProtocolIE_ID_t proto_id= ProtocolIE_ID_id_RICaction_ToBeSetup_Item;
159 RICaction_ToBeSetup_ItemIEs__value_PR pres6;
160 pres6 = RICaction_ToBeSetup_ItemIEs__value_PR_RICaction_ToBeSetup_Item;
164 RICaction_ToBeSetup_Item_t action_item;
165 action_item.ricActionID = 5;
166 action_item.ricActionType = 9;
170 RICaction_ToBeSetup_ItemIEs_t *action_item_ies = (RICaction_ToBeSetup_ItemIEs_t *)calloc(1, sizeof(RICaction_ToBeSetup_Item_t));
171 action_item_ies->id = proto_id;
172 action_item_ies->criticality = 0;
173 action_item_ies->value.choice.RICaction_ToBeSetup_Item = action_item;
174 action_item_ies->value.present = pres6;
178 RICactions_ToBeSetup_List_t actionslist;
180 // actionslist.list.size = sizeof(ProtocolIE_SingleContainer);
181 actionslist.list.size = sizeof(RICaction_ToBeSetup_ItemIEs_t);
182 actionslist.list.count = 1;
183 actionslist.list.array = (ProtocolIE_SingleContainer**)&action_item_ies;
187 RICsubscriptionDetails_t ricsubdetails;
189 ricsubdetails.ricAction_ToBeSetup_List = actionslist;
190 ricsubdetails.ricEventTriggerDefinition = *trigger;
194 RANfunctions_List_t *rflist = (RANfunctions_List_t*)calloc(1,sizeof(RANfunctions_List_t));
198 RICsubscriptionRequest_IEs_t *ricsubrid = (RICsubscriptionRequest_IEs_t*)calloc(1, sizeof(RICsubscriptionRequest_IEs_t));;
199 RICsubscriptionRequest_IEs__value_PR pres3;
201 pres3 = RICsubscriptionRequest_IEs__value_PR_RICsubscriptionDetails;
202 ricsubrid->id = ProtocolIE_ID_id_RICsubscriptionDetails;
205 ricsubrid->criticality = 0;
206 ricsubrid->value.present = pres3;
208 // ricsubrid->value.choice.RICrequestID.ricRequestorID = 25;
209 // ricsubrid->value.choice.RICrequestID.ricInstanceID = 3;
211 // ricsubrid->value.choice.RANfunctionID = 17;
212 ricsubrid->value.choice.RICsubscriptionDetails = ricsubdetails;
216 RICsubscriptionRequest_t *ricsubreq;
217 ricsubreq->protocolIEs.list.size = sizeof(RICsubscriptionRequest_IEs_t);
218 ricsubreq->protocolIEs.list.count = 1;
219 ricsubreq->protocolIEs.list.array = &ricsubrid;
221 InitiatingMessage__value_PR pres4;
222 pres4 = InitiatingMessage__value_PR_RICsubscriptionRequest;
223 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
224 initmsg->procedureCode = 8;
225 initmsg->criticality = 0;
226 initmsg->value.present = pres4;
227 initmsg->value.choice.RICsubscriptionRequest = *ricsubreq;
230 pres5 = E2AP_PDU_PR_initiatingMessage;
233 e2ap_pdu->present = pres5;
234 e2ap_pdu->choice.initiatingMessage = initmsg;
236 char *error_buf = (char*)calloc(300, sizeof(char));;
239 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
240 printf("error length %d\n", errlen);
241 printf("error buf %s\n", error_buf);
243 xer_fprint(stderr, &asn_DEF_E2AP_PDU, e2ap_pdu);
249 void generate_e2apv1_indication_request(E2AP_PDU *e2ap_pdu) {
251 RICindication_IEs_t *ricind_ies = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
252 RICindication_IEs_t *ricind_ies2 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
253 RICindication_IEs_t *ricind_ies3 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
254 RICindication_IEs_t *ricind_ies4 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
255 RICindication_IEs_t *ricind_ies5 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
256 RICindication_IEs_t *ricind_ies6 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
257 RICindication_IEs_t *ricind_ies7 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
258 RICindication_IEs_t *ricind_ies8 = (RICindication_IEs_t*)calloc(1, sizeof(RICindication_IEs_t));
260 RICindication_IEs__value_PR pres3;
262 pres3 = RICindication_IEs__value_PR_RICrequestID;
263 ricind_ies->id = ProtocolIE_ID_id_RICrequestID;
264 ricind_ies->criticality = 0;
265 ricind_ies->value.present = pres3;
266 ricind_ies->value.choice.RICrequestID.ricRequestorID = 25;
267 ricind_ies->value.choice.RICrequestID.ricInstanceID = 3;
269 pres3 = RICindication_IEs__value_PR_RANfunctionID;
270 ricind_ies2->id = ProtocolIE_ID_id_RANfunctionID;
271 ricind_ies2->criticality = 0;
272 ricind_ies2->value.present = pres3;
273 ricind_ies2->value.choice.RANfunctionID = 70;
276 ricind_ies3->id = ProtocolIE_ID_id_RICactionID;
277 ricind_ies3->criticality = 0;
278 pres3 = RICindication_IEs__value_PR_RICactionID;
279 ricind_ies3->value.present = pres3;
280 ricind_ies3->value.choice.RICactionID = 80;
283 pres3 = RICindication_IEs__value_PR_RICindicationSN;
284 ricind_ies4->id = ProtocolIE_ID_id_RICindicationSN;
285 ricind_ies4->criticality = 0;
286 ricind_ies4->value.present = pres3;
287 ricind_ies4->value.choice.RICindicationSN = 45;
289 pres3 = RICindication_IEs__value_PR_RICindicationType;
290 ricind_ies5->id = ProtocolIE_ID_id_RICindicationType;
291 ricind_ies5->criticality = 0;
292 ricind_ies5->value.present = pres3;
293 ricind_ies5->value.choice.RICindicationType = 0;
295 uint8_t *buf2 = (uint8_t *)"reportheader";
296 OCTET_STRING_t hdr_str;
300 pres3 = RICindication_IEs__value_PR_RICindicationHeader;
301 ricind_ies6->id = ProtocolIE_ID_id_RICindicationHeader;
302 ricind_ies6->criticality = 0;
303 ricind_ies6->value.present = pres3;
304 ricind_ies6->value.choice.RICindicationHeader = hdr_str;
306 uint8_t *buf3 = (uint8_t *)"reportmessage";
307 OCTET_STRING_t msg_str;
311 pres3 = RICindication_IEs__value_PR_RICindicationMessage;
312 ricind_ies7->id = ProtocolIE_ID_id_RICindicationMessage;
314 ricind_ies7->criticality = 0;
315 ricind_ies7->value.present = pres3;
317 ricind_ies7->value.choice.RICindicationMessage = msg_str;
319 uint8_t *buf4 = (uint8_t *)"cpid";
320 OCTET_STRING_t cpid_str;
324 pres3 = RICindication_IEs__value_PR_RICcallProcessID;
325 ricind_ies8->id = ProtocolIE_ID_id_RICrequestID;
327 ricind_ies8->criticality = 0;
328 ricind_ies8->value.present = pres3;
330 ricind_ies8->value.choice.RICcallProcessID = cpid_str;
333 RICindication_t *ricindication = (RICindication_t*)calloc(1, sizeof(RICindication_t));
335 int ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies);
337 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies2);
339 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies3);
340 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies4);
341 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies5);
342 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies6);
343 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies7);
344 ret = ASN_SEQUENCE_ADD(&ricindication->protocolIEs.list, ricind_ies8);
347 InitiatingMessage__value_PR pres4;
348 pres4 = InitiatingMessage__value_PR_RICindication;
349 InitiatingMessage_t *initmsg = (InitiatingMessage_t*)calloc(1, sizeof(InitiatingMessage_t));
350 initmsg->procedureCode = 5;
351 initmsg->criticality = 1;
352 initmsg->value.present = pres4;
353 initmsg->value.choice.RICindication = *ricindication;
356 pres5 = E2AP_PDU_PR_initiatingMessage;
358 e2ap_pdu = (E2AP_PDU_t*)calloc(1, sizeof(E2AP_PDU_t));
359 e2ap_pdu->present = pres5;
360 e2ap_pdu->choice.initiatingMessage = initmsg;
362 char *error_buf = (char*)calloc(300, sizeof(char));;
365 asn_check_constraints(&asn_DEF_E2AP_PDU, e2ap_pdu, error_buf, &errlen);
366 printf("error length %d\n", errlen);
367 printf("error buf %s\n", error_buf);