From 3c5d6ed787231fed7b7cbe8534521f31bd4b8053 Mon Sep 17 00:00:00 2001
From: Lionel Gauthier <lionel.gauthier@eurecom.fr>
Date: Wed, 6 Aug 2014 09:49:07 +0000
Subject: [PATCH] git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5666
 818b1a75-f10b-46b9-bf7c-635c3b92a50f

---
 .../CENTOS-LTE-EPC-INTEGRATION/start_enb.bash | 208 ++++++++----------
 1 file changed, 96 insertions(+), 112 deletions(-)

diff --git a/targets/PROJECTS/CENTOS-LTE-EPC-INTEGRATION/start_enb.bash b/targets/PROJECTS/CENTOS-LTE-EPC-INTEGRATION/start_enb.bash
index db1e5d1fc7..a70e71bf96 100755
--- a/targets/PROJECTS/CENTOS-LTE-EPC-INTEGRATION/start_enb.bash
+++ b/targets/PROJECTS/CENTOS-LTE-EPC-INTEGRATION/start_enb.bash
@@ -33,25 +33,52 @@
 # company Eurecom
 # email: lionel.gauthier@eurecom.fr
 ###########################################
-# INPUT PARAMETER FOR THIS SCRIPT: 'rebuild', 'build' or implicit 'start'
+# INPUT OF THIS SCRIPT:
+# THE DIRECTORY WHERE ARE LOCATED THE CONFIGURATION FILES
 #########################################
-# This script start a ENB  
-# The MME is provided to EURECOM by external partner, and should be started by your own.
-
+# This script start  ENB  
+# Depending on configuration files, it can be instanciated a virtual switch 
+# setting or a VLAN setting for the networking between eNB and MME.
+# MME+SP-GW executable have to be launched on the same host by your own (start_epc.bash) before this script is invoked.
+# UE executable have to be launched on another host by your own (start_ue.bash) after this script is invoked.
+#
 
 ###########################################################
 # Parameters
 ###########################################################
-declare MAKE_LTE_ACCESS_STRATUM_TARGET_RT="lte-softmodem HARD_RT=1 ENABLE_ITTI=1 USE_MME=R10 LINK_PDCP_TO_GTPV1U=1 DISABLE_XER_PRINT=1 SECU=1 RRC_MSG_PRINT=1 "
+declare EMULATION_DEV_INTERFACE="eth1"
+declare EMULATION_MULTICAST_GROUP=1
+
+declare MAKE_LTE_ACCESS_STRATUM_TARGET="oaisim DEBUG=1 ENABLE_ITTI=1 USE_MME=R10 LINK_PDCP_TO_GTPV1U=1 NAS=1 Rel10=1 SECU=1 RRC_MSG_PRINT=1"
+declare MAKE_LTE_ACCESS_STRATUM_TARGET_RT="lte-softmodem DEBUG=1  RTAI=1 HARD_RT=1 ENABLE_ITTI=1 USE_MME=R10 LINK_PDCP_TO_GTPV1U=1 DISABLE_XER_PRINT=1 SECU=1 RRC_MSG_PRINT=1 "
+
 
 ###########################################################
 THIS_SCRIPT_PATH=$(dirname $(readlink -f $0))
-source $THIS_SCRIPT_PATH/utils.bash
+. $THIS_SCRIPT_PATH/utils.bash
+. $THIS_SCRIPT_PATH/interfaces.bash
+. $THIS_SCRIPT_PATH/networks.bash
 ###########################################################
-declare -x CONFIG_FILE_DIR=./CONF
+if [ $# -eq 1 ]; then
+    declare -x CONFIG_FILE_DIR=$1
+    if [ ! -d $CONFIG_FILE_DIR ]; then
+        echo_error "ERROR while invoking this script, as first argument to this script you have to provide the path to a directory (./CONF/VLAN.VIRTUAL.$HOSTNAME for example) containing valid epc and enb config files"
+        exit 1
+    fi
+else
+    echo_error "ERROR while invoking this script, as first argument to this script you have to provide the path to a directory  (./CONF/VLAN.VIRTUAL.$HOSTNAME for example) containing valid epc and enb config files"
+    exit 1
+fi
+
+
+#check_install_epc_software
+
+
 
 cd $THIS_SCRIPT_PATH
 
+EMULATION_DEV_ADDRESS=`ifconfig $EMULATION_DEV_INTERFACE | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}'`
+
 #######################################################
 # FIND CONFIG FILE
 #######################################################
@@ -86,93 +113,38 @@ declare ENB_IPV4_NETMASK_FOR_S1U=$(          echo $ENB_IPV4_ADDRESS_FOR_S1U
 ENB_IPV4_ADDRESS_FOR_S1_MME=$(               echo $ENB_IPV4_ADDRESS_FOR_S1_MME        | cut -f1 -d '/')
 ENB_IPV4_ADDRESS_FOR_S1U=$(                  echo $ENB_IPV4_ADDRESS_FOR_S1U           | cut -f1 -d '/')
 
-is_openvswitch_interface $ENB_INTERFACE_NAME_FOR_S1_MME  \
-                               $ENB_INTERFACE_NAME_FOR_S1U
-
-if [ $? -eq 1 ]; then
-   echo_success "Found open-vswitch network configuration"
-else
-    is_vlan_interface $ENB_INTERFACE_NAME_FOR_S1_MME \
-                      $ENB_INTERFACE_NAME_FOR_S1U
-    if [ $? -eq 1 ]; then
-        echo_success "Found VLAN network configuration"
-        clean_enb_vlan_network
-        build_enb_vlan_network
-        test_enb_vlan_network
-    else
-        is_real_interface  $ENB_INTERFACE_NAME_FOR_S1_MME \
-                      $ENB_INTERFACE_NAME_FOR_S1U
-        if [ $? -eq 1 ]; then
-            echo_success "Found standart network configuration"
-        else
-            echo_error "Cannot find open-vswitch network configuration or VLAN network configuration or standard network configuration"
-            exit 1
-        fi
-    fi 
-fi
-
-clean() {
-    cd $OPENAIR_TARGETS/ARCH/EXMIMO/DRIVER/eurecom && make clean           || exit 1
-    cd $OPENAIR_TARGETS/ARCH/EXMIMO/USERSPACE/OAI_FW_INIT && make clean    || exit 1
-    make --directory=$OPENAIR_TARGETS/RTAI/USER clean                      || exit 1
-    find $OPENAIR_TARGETS/RTAI/USER -name *.a -delete
-    find $OPENAIR_TARGETS/RTAI/USER -name *.d -delete
-    find $OPENAIR_TARGETS/RTAI/USER -name *.o -delete
-    find $OPENAIR_TARGETS/RTAI/USER -name *.ko -delete
-}
-
-build() {
-    cd $OPENAIR_TARGETS/ARCH/EXMIMO/DRIVER/eurecom && make -j`grep -c ^processor /proc/cpuinfo ` || exit 1
-    cd $OPENAIR_TARGETS/ARCH/EXMIMO/USERSPACE/OAI_FW_INIT && make -j`grep -c ^processor /proc/cpuinfo ` || exit 1
-    make --directory=$OPENAIR_TARGETS/RTAI/USER $MAKE_LTE_ACCESS_STRATUM_TARGET_RT -j`grep -c ^processor /proc/cpuinfo ` || exit 1
-    make --directory=$OPENAIR_TARGETS/RTAI/USER $MAKE_LTE_ACCESS_STRATUM_TARGET_RT  || exit 1
-}
-
-##################################################
-# process script parameters
-##################################################
-for arg in "$@"
-do
-    case "$arg" in
-    rebuild)  clean;build
-            ;;
-
-    rebuildonly)  clean;build; exit 0
-            ;;
-
-    build)   build
-            ;;
-            
-    buildonly)   build; exit 0 
-            ;;
-            
-    *)      
-            ;;
-    esac
-done
-
-
 
 ##################################################
-# LAUNCH eNB 
+# LAUNCH eNB executable
 ##################################################
 pkill oaisim
 pkill tshark
 
-if [ ! -d $THIS_SCRIPT_PATH/OUTPUT ]; then
-    mkdir -m 777 -p $THIS_SCRIPT_PATH/OUTPUT
+if [ ! -d $THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME ]; then 
+    mkdir -m 777 -p $THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME
 fi
 
-
-ITTI_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/itti_enb_rf.$HOSTNAME.log
-rotate_log_file $ITTI_LOG_FILE
+if [ x$hard_real_time != "xyes" ]; then
+    ITTI_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/itti_enb_ue.$HOSTNAME.log
+    #rotate_log_file $ITTI_LOG_FILE
+    
+    STDOUT_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/stdout_enb_ue.$HOSTNAME.log
+    #rotate_log_file $STDOUT_LOG_FILE
+    #rotate_log_file $STDOUT_LOG_FILE.filtered
+    
+    PCAP_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/tshark_enb_ue.$HOSTNAME.pcap
+    #rotate_log_file $PCAP_LOG_FILE
+else 
+    ITTI_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/itti_enb_rf.$HOSTNAME.log
+    #rotate_log_file $ITTI_LOG_FILE
     
-STDOUT_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/stdout_enb_rf.$HOSTNAME.log
-rotate_log_file $STDOUT_LOG_FILE
-rotate_log_file $STDOUT_LOG_FILE.filtered
+    STDOUT_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/stdout_enb_rf.$HOSTNAME.log
+    #rotate_log_file $STDOUT_LOG_FILE
+    #rotate_log_file $STDOUT_LOG_FILE.filtered
     
-PCAP_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/tshark_enb_rf.$HOSTNAME.pcap
-rotate_log_file $PCAP_LOG_FILE
+    PCAP_LOG_FILE=$THIS_SCRIPT_PATH/OUTPUT/$HOSTNAME/tshark_enb_rf.$HOSTNAME.pcap
+    #rotate_log_file $PCAP_LOG_FILE
+fi
 
 
 cd $THIS_SCRIPT_PATH
@@ -184,36 +156,48 @@ else
 fi
 
 
-echo_warning "HARD REAL TIME MODE"
-PATH=$PATH:/usr/realtime/bin
-    
-cd $THIS_SCRIPT_PATH
-
+if [ x$hard_real_time != "xyes" ]; then
+    echo_warning "USER MODE"
+    make --directory=$OPENAIR_TARGETS/SIMU/USER $MAKE_LTE_ACCESS_STRATUM_TARGET -j`grep -c ^processor /proc/cpuinfo ` || exit 1
+    bash_exec "ip route add 239.0.0.160/28 dev $EMULATION_DEV_INTERFACE"
+    gdb --args $OPENAIR_TARGETS/SIMU/USER/oaisim -a  -l9 -u0 -b1 -M0 -p2  -g$EMULATION_MULTICAST_GROUP -D $EMULATION_DEV_ADDRESS -K $ITTI_LOG_FILE --enb-conf $CONFIG_FILE_ENB 2>&1 | tee $STDOUT_LOG_FILE 
 
-if [ ! -f /tmp/init_rt_done.tmp ]; then
-    echo_warning "STARTING REAL TIME (RTAI)"
-    insmod /usr/realtime/modules/rtai_hal.ko     > /dev/null 2>&1
-    insmod /usr/realtime/modules/rtai_sched.ko   > /dev/null 2>&1
-    insmod /usr/realtime/modules/rtai_sem.ko     > /dev/null 2>&1
-    insmod /usr/realtime/modules/rtai_fifos.ko   > /dev/null 2>&1
-    insmod /usr/realtime/modules/rtai_mbx.ko     > /dev/null 2>&1
-    touch /tmp/init_rt_done.tmp
-    chmod 666 /tmp/init_rt_done.tmp
 else
-    echo_warning "REAL TIME FOUND STARTED (RTAI)"
+    echo_warning "HARD REAL TIME MODE"
+    PATH=$PATH:/usr/realtime/bin
+    
+    #make --directory=$OPENAIR_TARGETS/RT/USER drivers  || exit 1
+    # 2 lines below replace the line above
+    cd $OPENAIR_TARGETS/ARCH/EXMIMO/DRIVER/eurecom && make clean && make   || exit 1
+    cd $OPENAIR_TARGETS/ARCH/EXMIMO/USERSPACE/OAI_FW_INIT && make clean && make   || exit 1
+    cd $THIS_SCRIPT_PATH
+    
+    make --directory=$OPENAIR_TARGETS/RT/USER $MAKE_LTE_ACCESS_STRATUM_TARGET_RT -j`grep -c ^processor /proc/cpuinfo ` || exit 1
+    
+    if [ ! -f /tmp/init_rt_done.tmp ]; then
+        echo_warning "STARTING REAL TIME (RTAI)"
+        insmod /usr/realtime/modules/rtai_hal.ko     > /dev/null 2>&1
+        insmod /usr/realtime/modules/rtai_sched.ko   > /dev/null 2>&1
+        insmod /usr/realtime/modules/rtai_sem.ko     > /dev/null 2>&1
+        insmod /usr/realtime/modules/rtai_fifos.ko   > /dev/null 2>&1
+        insmod /usr/realtime/modules/rtai_mbx.ko     > /dev/null 2>&1
+        touch /tmp/init_rt_done.tmp
+        chmod 666 /tmp/init_rt_done.tmp
+    else
+        echo_warning "REAL TIME FOUND STARTED (RTAI)"
+    fi
+    
+    cd $OPENAIR_TARGETS/RT/USER
+    bash ./init_exmimo2.sh
+    echo_warning "STARTING SOFTMODEM..."
+    #cat /dev/rtf62 > $STDOUT_LOG_FILE &
+    gdb --args ./lte-softmodem -K $ITTI_LOG_FILE -V  -O $CONFIG_FILE_ENB  2>&1
+    cd $THIS_SCRIPT_PATH
 fi
 
-cd $OPENAIR_TARGETS/RTAI/USER
-bash ./init_exmimo2.sh
-echo_warning "STARTING SOFTMODEM..."
-#cat /dev/rtf62 > $STDOUT_LOG_FILE &
-./lte-softmodem -K $ITTI_LOG_FILE -O $CONFIG_FILE_ENB --ulsch-max-errors=20 2>&1
-cd $THIS_SCRIPT_PATH
-sync
 pkill tshark
-pkill cat
-sync
-#cat $STDOUT_LOG_FILE |  grep -v '[PHY]' | grep -v '[MAC]' | grep -v '[EMU]' | \
-#                        grep -v '[OCM]' | grep -v '[OMG]' | \
-#                        grep -v 'RLC not configured' | grep -v 'check if serving becomes' | \
-#                        grep -v 'mac_rrc_data_req'   | grep -v 'BCCH request =>' > $STDOUT_LOG_FILE.filtered
+
+cat $STDOUT_LOG_FILE |  grep -v '[PHY]' | grep -v '[MAC]' | grep -v '[EMU]' | \
+                        grep -v '[OCM]' | grep -v '[OMG]' | \
+                        grep -v 'RLC not configured' | grep -v 'check if serving becomes' | \
+                        grep -v 'mac_rrc_data_req'   | grep -v 'BCCH request =>' > $STDOUT_LOG_FILE.filtered
-- 
GitLab