Compare commits
17 Commits
ns-o-ran-x
...
ns-o-ran-d
Author | SHA1 | Date | |
---|---|---|---|
7287471c93 | |||
08e1fb839a | |||
8f3f20cfa3 | |||
cf8cd37685 | |||
f2e465c33e | |||
178ec65486 | |||
a09d784d52 | |||
45fa45ee2c | |||
887f0d180a | |||
93d45e3c58 | |||
a34e83b524 | |||
290e030071 | |||
|
e3161c1f4c | ||
|
54fee7c1d0 | ||
|
4f46bbf4b1 | ||
|
b65e2a4a1f | ||
|
edf7fe9e8d |
@@ -14,17 +14,6 @@ do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
# get RIC interface from cli arguments
|
|
||||||
if [ $# -eq 0 ] || [ "$import" = false ] ; then
|
|
||||||
RIC_INTERFACE="col0"
|
|
||||||
else
|
|
||||||
if [ "$arena" = true ]; then
|
|
||||||
RIC_INTERFACE="brric"
|
|
||||||
else
|
|
||||||
RIC_INTERFACE=$1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
export SRC=`dirname $0`
|
export SRC=`dirname $0`
|
||||||
. $SRC/setup-lib.sh
|
. $SRC/setup-lib.sh
|
||||||
|
|
||||||
@@ -175,9 +164,6 @@ EOF
|
|||||||
fi
|
fi
|
||||||
E2TERM_CONFIG_BIND="--mount type=bind,source=$E2TERMCONFFILE,destination=/opt/e2/config/config.conf,ro"
|
E2TERM_CONFIG_BIND="--mount type=bind,source=$E2TERMCONFFILE,destination=/opt/e2/config/config.conf,ro"
|
||||||
|
|
||||||
export RIC_IP=`ifconfig ${RIC_INTERFACE} | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*'`
|
|
||||||
|
|
||||||
|
|
||||||
if [ "$arena" = true ]; then
|
if [ "$arena" = true ]; then
|
||||||
echo 'Starting local setup'
|
echo 'Starting local setup'
|
||||||
# if both RIC and DU are executed on the same machine, do not set Docker NAT rules
|
# if both RIC and DU are executed on the same machine, do not set Docker NAT rules
|
||||||
|
@@ -36,7 +36,7 @@ if [ ! $? -eq 0 ]; then
|
|||||||
$SUDO docker build \
|
$SUDO docker build \
|
||||||
--build-arg DBAAS_SERVICE_HOST=$DBAAS_IP \
|
--build-arg DBAAS_SERVICE_HOST=$DBAAS_IP \
|
||||||
--build-arg DBAAS_SERVICE_PORT=$DBAAS_PORT \
|
--build-arg DBAAS_SERVICE_PORT=$DBAAS_PORT \
|
||||||
-f ${DOCKER_FILE}_${IMAGE_NAME} -t ${IMAGE_NAME}:$tagvers .
|
-f ${DOCKER_FILE}_${IMAGE_NAME}_c -t ${IMAGE_NAME}:$tagvers .
|
||||||
|
|
||||||
# remove copied Dockerfile
|
# remove copied Dockerfile
|
||||||
rm ${DOCKER_FILE}_${IMAGE_NAME}
|
rm ${DOCKER_FILE}_${IMAGE_NAME}
|
||||||
|
129
setup/Dockerfile_sample-xapp_c
Normal file
129
setup/Dockerfile_sample-xapp_c
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
##-----------------------------------
|
||||||
|
# BS Connector
|
||||||
|
#------------------------------------
|
||||||
|
ARG SCHEMA_PATH=schemas
|
||||||
|
ARG XAPP_DIR=sample-xapp
|
||||||
|
ARG CONNECTOR_DIR=xapp-sm-connector
|
||||||
|
ARG STAGE_DIR=/home/${CONNECTOR_DIR}
|
||||||
|
ARG DBAAS_SERVICE_HOST=10.0.2.12
|
||||||
|
ARG DBAAS_SERVICE_PORT="6379"
|
||||||
|
|
||||||
|
#==================================================================================
|
||||||
|
FROM ubuntu:18.04 as ricbuild1
|
||||||
|
|
||||||
|
# to override repo base, pass in repo argument when running docker build:
|
||||||
|
# docker build --build-arg REPOBASE=http://abc.def.org . ....
|
||||||
|
ARG REPOBASE=https://gerrit.oran-osc.org/r
|
||||||
|
ARG SCHEMA_FILE
|
||||||
|
ARG SCHEMA_PATH
|
||||||
|
ARG XAPP_DIR
|
||||||
|
ARG CONNECTOR_DIR
|
||||||
|
ARG STAGE_DIR
|
||||||
|
|
||||||
|
ARG MDC_VER=0.0.4-1
|
||||||
|
ARG RMR_VER=4.0.5
|
||||||
|
ARG RNIB_VER=1.0.0
|
||||||
|
|
||||||
|
ENV RMR_RTG_SVC="9999" \
|
||||||
|
RMR_SEED_RT="/home/${CONNECTOR_DIR}/init/routes.txt" \
|
||||||
|
LD_LIBRARY_PATH="/usr/local/lib:/usr/local/libexec" \
|
||||||
|
VERBOSE=0 \
|
||||||
|
CONFIG_FILE=/opt/ric/config/config-file.json \
|
||||||
|
DBAAS_SERVICE_HOST=${DBAAS_SERVICE_HOST} \
|
||||||
|
DBAAS_SERVICE_PORT=${DBAAS_SERVICE_PORT}
|
||||||
|
|
||||||
|
COPY ${CONNECTOR_DIR} ${STAGE_DIR}
|
||||||
|
COPY ${XAPP_DIR} /home/${XAPP_DIR}
|
||||||
|
|
||||||
|
WORKDIR ${STAGE_DIR}
|
||||||
|
|
||||||
|
# Install necessary packages
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y \
|
||||||
|
cmake \
|
||||||
|
git \
|
||||||
|
build-essential \
|
||||||
|
automake \
|
||||||
|
autoconf-archive \
|
||||||
|
autoconf \
|
||||||
|
pkg-config \
|
||||||
|
gawk \
|
||||||
|
libtool \
|
||||||
|
wget \
|
||||||
|
zlib1g-dev \
|
||||||
|
libffi-dev \
|
||||||
|
libcurl4-openssl-dev \
|
||||||
|
vim \
|
||||||
|
cpputest \
|
||||||
|
libboost-all-dev \
|
||||||
|
libhiredis-dev \
|
||||||
|
&& apt-get remove -y --purge python* \
|
||||||
|
&& apt-get install -y \
|
||||||
|
python3 \
|
||||||
|
python3-pip \
|
||||||
|
# Install mdclog using debian package hosted at packagecloud.io
|
||||||
|
&& wget -nv --content-disposition https://packagecloud.io/o-ran-sc/release/packages/debian/stretch/mdclog_${MDC_VER}_amd64.deb/download.deb \
|
||||||
|
&& wget -nv --content-disposition https://packagecloud.io/o-ran-sc/release/packages/debian/stretch/mdclog-dev_${MDC_VER}_amd64.deb/download.deb \
|
||||||
|
&& dpkg -i mdclog_${MDC_VER}_amd64.deb \
|
||||||
|
&& dpkg -i mdclog-dev_${MDC_VER}_amd64.deb \
|
||||||
|
&& rm mdclog_${MDC_VER}_amd64.deb mdclog-dev_${MDC_VER}_amd64.deb \
|
||||||
|
# Install RMR using debian package hosted at packagecloud.io
|
||||||
|
&& wget -nv --content-disposition https://packagecloud.io/o-ran-sc/release/packages/debian/stretch/rmr_${RMR_VER}_amd64.deb/download.deb \
|
||||||
|
&& wget -nv --content-disposition https://packagecloud.io/o-ran-sc/release/packages/debian/stretch/rmr-dev_${RMR_VER}_amd64.deb/download.deb \
|
||||||
|
&& dpkg -i rmr_${RMR_VER}_amd64.deb \
|
||||||
|
&& dpkg -i rmr-dev_${RMR_VER}_amd64.deb \
|
||||||
|
&& rm rmr_${RMR_VER}_amd64.deb rmr-dev_${RMR_VER}_amd64.deb \
|
||||||
|
# Install RNIB libraries
|
||||||
|
&& wget -nv --content-disposition https://packagecloud.io/o-ran-sc/release/packages/debian/stretch/rnib_${RNIB_VER}_all.deb/download.deb \
|
||||||
|
&& dpkg -i rnib_${RNIB_VER}_all.deb \
|
||||||
|
&& rm rnib_${RNIB_VER}_all.deb \
|
||||||
|
# Install dbaas
|
||||||
|
&& cd ${STAGE_DIR} \
|
||||||
|
&& git clone https://gerrit.o-ran-sc.org/r/ric-plt/dbaas \
|
||||||
|
&& cd dbaas/redismodule \
|
||||||
|
&& ./autogen.sh \
|
||||||
|
&& ./configure \
|
||||||
|
&& make -j ${nproc} all \
|
||||||
|
&& make install \
|
||||||
|
&& rm -Rf ${STAGE_DIR}/dbaas \
|
||||||
|
# Install sdl
|
||||||
|
&& cd ${STAGE_DIR} \
|
||||||
|
&& git clone https://gerrit.o-ran-sc.org/r/ric-plt/sdl \
|
||||||
|
&& cd sdl \
|
||||||
|
&& ./autogen.sh \
|
||||||
|
&& ./configure \
|
||||||
|
&& make -j ${nproc} all \
|
||||||
|
&& make install \
|
||||||
|
&& rm -Rf ${STAGE_DIR}/sdl \
|
||||||
|
# Install rapidjson
|
||||||
|
&& cd ${STAGE_DIR} \
|
||||||
|
&& git clone https://github.com/Tencent/rapidjson \
|
||||||
|
&& cd rapidjson \
|
||||||
|
&& mkdir build \
|
||||||
|
&& cd build \
|
||||||
|
&& cmake -DCMAKE_INSTALL_PREFIX=/usr/local .. \
|
||||||
|
&& make -j ${nproc} \
|
||||||
|
&& make install \
|
||||||
|
&& cd ${STAGE_DIR} \
|
||||||
|
&& rm -rf rapidjson
|
||||||
|
FROM ricbuild1
|
||||||
|
##-----------------------------------
|
||||||
|
# Now install the program
|
||||||
|
#------------------------------------
|
||||||
|
# build connector
|
||||||
|
RUN export CPATH=$CPATH:/usr/local/include \
|
||||||
|
&& cd src \
|
||||||
|
&& make clean \
|
||||||
|
&& make -j ${nproc} \
|
||||||
|
&& make install \
|
||||||
|
&& ldconfig \
|
||||||
|
&& sysctl -w net.ipv6.conf.lo.disable_ipv6=1 \
|
||||||
|
###-----------------------------------
|
||||||
|
## DRL Agent
|
||||||
|
##------------------------------------
|
||||||
|
## install packages and pip requirements
|
||||||
|
# && pip3 --no-cache-dir install -U pip \
|
||||||
|
# && pip3 --no-cache-dir install -r /home/${XAPP_DIR}/requirements.txt \
|
||||||
|
&& apt-get autoremove -y \
|
||||||
|
&& apt-get clean \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
@@ -104,7 +104,7 @@ std::string find_agent_ip_from_gnb(unsigned char* gnb_id_trans) {
|
|||||||
|
|
||||||
|
|
||||||
// send through socket
|
// send through socket
|
||||||
int send_socket(char* buf, std::string dest_ip) {
|
int send_socket(char* buf, size_t payload_size, std::string dest_ip) {
|
||||||
|
|
||||||
int control_sckfd = -1;
|
int control_sckfd = -1;
|
||||||
|
|
||||||
@@ -126,8 +126,7 @@ int send_socket(char* buf, std::string dest_ip) {
|
|||||||
|
|
||||||
// const size_t max_size = 512;
|
// const size_t max_size = 512;
|
||||||
// char buf[max_size] = "Hello, Server!"; // store the data in a buffer
|
// char buf[max_size] = "Hello, Server!"; // store the data in a buffer
|
||||||
size_t data_size = strlen(buf);
|
int sent_size = send(control_sckfd, buf, payload_size, 0);
|
||||||
int sent_size = send(control_sckfd ,buf, data_size, 0);
|
|
||||||
|
|
||||||
if(sent_size < 0) { // the send returns a size of -1 in case of errors
|
if(sent_size < 0) { // the send returns a size of -1 in case of errors
|
||||||
std::cout << "ERROR: SEND to agent " << dest_ip << std::endl;
|
std::cout << "ERROR: SEND to agent " << dest_ip << std::endl;
|
||||||
|
@@ -27,6 +27,6 @@ extern std::map<std::string, std::string> agentIp_gnbId;
|
|||||||
int open_control_socket_agent(const char* dest_ip, const int dest_port);
|
int open_control_socket_agent(const char* dest_ip, const int dest_port);
|
||||||
void close_control_socket_agent(void);
|
void close_control_socket_agent(void);
|
||||||
std::string find_agent_ip_from_gnb(unsigned char* gnb_id);
|
std::string find_agent_ip_from_gnb(unsigned char* gnb_id);
|
||||||
int send_socket(char* buf, std::string dest_ip);
|
int send_socket(char* buf, size_t payload_size, std::string dest_ip);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -30,6 +30,7 @@ void signalHandler( int signum ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]){
|
int main(int argc, char *argv[]){
|
||||||
|
std::cout << "hw_xapp_main Running";
|
||||||
|
|
||||||
// Get the thread id
|
// Get the thread id
|
||||||
std::thread::id my_id = std::this_thread::get_id();
|
std::thread::id my_id = std::this_thread::get_id();
|
||||||
@@ -71,7 +72,9 @@ int main(int argc, char *argv[]){
|
|||||||
|
|
||||||
sleep(1);
|
sleep(1);
|
||||||
//Startup E2 subscription and A1 policy
|
//Startup E2 subscription and A1 policy
|
||||||
//hw_xapp->startup(std::ref(*sub_handler));
|
std::cout << "Startup E2 subscription and A1 policy";
|
||||||
|
|
||||||
|
hw_xapp->startup(std::ref(*sub_handler));
|
||||||
|
|
||||||
//start listener threads and register message handlers.
|
//start listener threads and register message handlers.
|
||||||
int num_threads = std::stoi(config[XappSettings::SettingName::THREADS]);
|
int num_threads = std::stoi(config[XappSettings::SettingName::THREADS]);
|
||||||
|
@@ -271,7 +271,7 @@ uint8_t procRicIndication(E2AP_PDU_t *e2apMsg, transaction_identifier gnb_id)
|
|||||||
}
|
}
|
||||||
case 26: // RIC indication message
|
case 26: // RIC indication message
|
||||||
{
|
{
|
||||||
int payload_size = ricIndication->protocolIEs.list.array[idx]-> \
|
size_t payload_size = ricIndication->protocolIEs.list.array[idx]-> \
|
||||||
value.choice.RICindicationMessage.size;
|
value.choice.RICindicationMessage.size;
|
||||||
|
|
||||||
|
|
||||||
@@ -283,7 +283,7 @@ uint8_t procRicIndication(E2AP_PDU_t *e2apMsg, transaction_identifier gnb_id)
|
|||||||
|
|
||||||
// send payload to agent
|
// send payload to agent
|
||||||
std::string agent_ip = find_agent_ip_from_gnb(gnb_id);
|
std::string agent_ip = find_agent_ip_from_gnb(gnb_id);
|
||||||
send_socket(payload, agent_ip);
|
send_socket(payload, payload_size, agent_ip);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -87,6 +87,8 @@ void Xapp::stop(void){
|
|||||||
|
|
||||||
void Xapp::startup(SubscriptionHandler &sub_ref) {
|
void Xapp::startup(SubscriptionHandler &sub_ref) {
|
||||||
|
|
||||||
|
std::cout << "Startup beeing called";
|
||||||
|
|
||||||
subhandler_ref = &sub_ref;
|
subhandler_ref = &sub_ref;
|
||||||
|
|
||||||
if (GNB_ID == "") {
|
if (GNB_ID == "") {
|
||||||
@@ -118,7 +120,15 @@ void Xapp::startup(SubscriptionHandler &sub_ref) {
|
|||||||
std::cout << "Querying target gNB" << std::endl;
|
std::cout << "Querying target gNB" << std::endl;
|
||||||
rnib_gnblist.push_back(GNB_ID);
|
rnib_gnblist.push_back(GNB_ID);
|
||||||
}
|
}
|
||||||
|
while (
|
||||||
|
true
|
||||||
|
)
|
||||||
|
{
|
||||||
|
std::cout << "Send sub. req.";
|
||||||
|
std::cout << "yeet";
|
||||||
|
|
||||||
|
startup_subscribe_requests();
|
||||||
|
}
|
||||||
// open external control socket in thread and wait for message
|
// open external control socket in thread and wait for message
|
||||||
ext_control_thr_rx = std::unique_ptr<std::thread>(new std::thread{&Xapp::handle_external_control_message, this, SOCKET_PORT_EXT});
|
ext_control_thr_rx = std::unique_ptr<std::thread>(new std::thread{&Xapp::handle_external_control_message, this, SOCKET_PORT_EXT});
|
||||||
|
|
||||||
@@ -135,7 +145,16 @@ void Xapp::startup(SubscriptionHandler &sub_ref) {
|
|||||||
// send_socket("Hello, Server!", AGENT_1);
|
// send_socket("Hello, Server!", AGENT_1);
|
||||||
|
|
||||||
//send subscriptions.
|
//send subscriptions.
|
||||||
startup_subscribe_requests();
|
while (
|
||||||
|
true
|
||||||
|
)
|
||||||
|
{
|
||||||
|
std::cout << "Send sub. req.";
|
||||||
|
std::cout << "yeet";
|
||||||
|
|
||||||
|
startup_subscribe_requests();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//read A1 policies
|
//read A1 policies
|
||||||
// startup_get_policies();
|
// startup_get_policies();
|
||||||
@@ -417,7 +436,7 @@ void Xapp::send_ric_control_request(char* payload, std::string gnb_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Xapp::startup_subscribe_requests(void ){
|
void Xapp::startup_subscribe_requests(void ){
|
||||||
|
std::cout << "Startup subscribe request \n";
|
||||||
bool res;
|
bool res;
|
||||||
size_t data_size = ASN_BUFF_MAX_SIZE;
|
size_t data_size = ASN_BUFF_MAX_SIZE;
|
||||||
unsigned char data[data_size];
|
unsigned char data[data_size];
|
||||||
@@ -432,11 +451,12 @@ void Xapp::startup_subscribe_requests(void ){
|
|||||||
|
|
||||||
if(sz <= 0)
|
if(sz <= 0)
|
||||||
mdclog_write(MDCLOG_INFO,"Subscriptions cannot be sent as GNBList in RNIB is NULL");
|
mdclog_write(MDCLOG_INFO,"Subscriptions cannot be sent as GNBList in RNIB is NULL");
|
||||||
|
std::cout << "pre for loop \n";
|
||||||
for(int i = 0; i<sz; i++){
|
for(int i = 0; i<sz; i++){
|
||||||
std::cout << "Sending subscriptions to: " << gnblist[i] << std::endl;
|
std::cout << "Sending subscriptions to: " << gnblist[i] << std::endl;
|
||||||
|
|
||||||
// give the message to subscription handler, along with the transmitter.
|
// give the message to subscription handler, along with the transmitter.
|
||||||
|
|
||||||
strcpy((char*)meid,gnblist[i].c_str());
|
strcpy((char*)meid,gnblist[i].c_str());
|
||||||
|
|
||||||
// char *strMsg = "Subscription Request from HelloWorld XApp\0";
|
// char *strMsg = "Subscription Request from HelloWorld XApp\0";
|
||||||
@@ -483,6 +503,7 @@ void Xapp::startup_subscribe_requests(void ){
|
|||||||
mdclog_write(MDCLOG_INFO,"Subscription SUCCESSFUL in file= %s, line=%d for MEID %s",__FILE__,__LINE__, meid);
|
mdclog_write(MDCLOG_INFO,"Subscription SUCCESSFUL in file= %s, line=%d for MEID %s",__FILE__,__LINE__, meid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
std::cout << "Finisched subscribe request \n";
|
||||||
}
|
}
|
||||||
|
|
||||||
void Xapp::startup_get_policies(void){
|
void Xapp::startup_get_policies(void){
|
||||||
|
Reference in New Issue
Block a user