X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?p=sim%2Fe2-interface.git;a=blobdiff_plain;f=e2sim%2Fe2apv1sim%2Fe2sim.cpp;fp=e2sim%2Fe2apv1sim%2Fe2sim.cpp;h=6f768b01e86fca2da40a3538510cefcb4075dac7;hp=0000000000000000000000000000000000000000;hb=0eba05c4ff0c99974d3f3a63b65cbe2adb209e51;hpb=c380e183231711cf9f8bc72d0eb52e532dd07085 diff --git a/e2sim/e2apv1sim/e2sim.cpp b/e2sim/e2apv1sim/e2sim.cpp new file mode 100644 index 0000000..6f768b0 --- /dev/null +++ b/e2sim/e2apv1sim/e2sim.cpp @@ -0,0 +1,107 @@ +/***************************************************************************** +# * +# Copyright 2019 AT&T Intellectual Property * +# Copyright 2019 Nokia * +# * +# Licensed under the Apache License, Version 2.0 (the "License"); * +# you may not use this file except in compliance with the License. * +# You may obtain a copy of the License at * +# * +# http://www.apache.org/licenses/LICENSE-2.0 * +# * +# Unless required by applicable law or agreed to in writing, software * +# distributed under the License is distributed on an "AS IS" BASIS, * +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * +# See the License for the specific language governing permissions and * +# limitations under the License. * +# * +******************************************************************************/ + +#include +#include +#include +#include + + +#include "e2sim_defs.h" +#include "e2sim_sctp.hpp" +#include "e2ap_message_handler.hpp" +#include "encode_e2apv1.hpp" + +using namespace std; + +void encode_and_send_sctp_data(E2AP_PDU_t* pdu, int client_fd) +{ + uint8_t *buf; + sctp_buffer_t data; + + data.len = e2ap_asn1c_encode_pdu(pdu, &buf); + memcpy(data.buffer, buf, min(data.len, MAX_SCTP_BUFFER)); + + sctp_send_data(client_fd, data); +} + +void wait_for_sctp_data(int client_fd) +{ + sctp_buffer_t recv_buf; + if(sctp_receive_data(client_fd, recv_buf) > 0) + { + LOG_I("[SCTP] Received new data of size %d", recv_buf.len); + e2ap_handle_sctp_data(client_fd, recv_buf, false); + } +} + + +int main(int argc, char* argv[]){ + LOG_I("Start E2 Agent (E2 Simulator)"); + + bool xmlenc = true; + + options_t ops = read_input_options(argc, argv); + + //E2 Agent will automatically restart upon sctp disconnection + // int server_fd = sctp_start_server(ops.server_ip, ops.server_port); + int client_fd = sctp_start_client(ops.server_ip, ops.server_port); + E2AP_PDU_t* pdu_setup = (E2AP_PDU_t*)calloc(1,sizeof(E2AP_PDU)); + + // generate_e2apv1_subscription_request(pdu_setup); + generate_e2apv1_setup_request(pdu_setup); + + xer_fprint(stderr, &asn_DEF_E2AP_PDU, pdu_setup); + + auto buffer_size = MAX_SCTP_BUFFER; + unsigned char buffer[MAX_SCTP_BUFFER]; + + sctp_buffer_t data; + + // auto er = asn_encode_to_buffer(nullptr, ATS_ALIGNED_BASIC_PER, &asn_DEF_E2AP_PDU, pdu_setup, buffer, buffer_size); + auto er = asn_encode_to_buffer(nullptr, ATS_BASIC_XER, &asn_DEF_E2AP_PDU, pdu_setup, buffer, buffer_size); + data.len = er.encoded; + + fprintf(stderr, "er encded is %d\n", er.encoded); + + memcpy(data.buffer, buffer, er.encoded); + + if(sctp_send_data(client_fd, data) > 0) { + LOG_I("[SCTP] Sent E2-SETUP-REQUEST"); + } else { + LOG_E("[SCTP] Unable to send E2-SETUP-REQUEST to peer"); + } + + sctp_buffer_t recv_buf; + + LOG_I("[SCTP] Waiting for SCTP data"); + + while(1) //constantly looking for data on SCTP interface + { + if(sctp_receive_data(client_fd, recv_buf) <= 0) + break; + + LOG_I("[SCTP] Received new data of size %d", recv_buf.len); + + e2ap_handle_sctp_data(client_fd, recv_buf, xmlenc); + if (xmlenc) xmlenc = false; + } + + return 0; +}