diff options
Diffstat (limited to 'tests/nsh_sfc/sfc_scripts')
-rwxr-xr-x | tests/nsh_sfc/sfc_scripts/install_sfc.sh | 114 | ||||
-rwxr-xr-x | tests/nsh_sfc/sfc_scripts/set_nsh_proxy_inbound.sh | 32 | ||||
-rwxr-xr-x | tests/nsh_sfc/sfc_scripts/set_nsh_proxy_outbound.sh | 32 | ||||
-rwxr-xr-x | tests/nsh_sfc/sfc_scripts/set_sfc_sff.sh | 32 | ||||
-rwxr-xr-x | tests/nsh_sfc/sfc_scripts/start_tcpdump.sh | 16 |
5 files changed, 226 insertions, 0 deletions
diff --git a/tests/nsh_sfc/sfc_scripts/install_sfc.sh b/tests/nsh_sfc/sfc_scripts/install_sfc.sh new file mode 100755 index 0000000000..265d4c153a --- /dev/null +++ b/tests/nsh_sfc/sfc_scripts/install_sfc.sh @@ -0,0 +1,114 @@ +#!/bin/bash + +set -x + +ROOTDIR=/tmp/openvpp-testing +PWDDIR=$(pwd) + +if_name1=$1 +if_name2=$2 + +VPP_VERSION=`cat ${ROOTDIR}/NSH_SFC_VER | grep VPP | awk -F'= ' '{print $2}'` +NSH_SFC_VERSION=`cat ${ROOTDIR}/NSH_SFC_VER | grep NSH_SFC | awk -F'= ' '{print $2}'` + +VPP_CODE_DIR=${ROOTDIR}/vpp_codes +NSH_SFC_CODE_DIR=${ROOTDIR}/nsh_sfc_codes + +#at first, we need to stop the vpp service if have +sudo service vpp stop + +#uninstall the vpp and nsh sfc plugin +#and git clone the vpp and nsh sfc plugin source codes +#then compile and install them in the dut nodes. +nsh_need_install=0 +sudo dpkg -l vpp-nsh-plugin >/dev/null 2>&1 +if [ $? -eq 0 ]; then + nsh_plugin_version=`dpkg -s vpp-nsh-plugin | grep Version | awk -F' ' '{print $2}'` + if [ "${nsh_plugin_version}" \< "${NSH_SFC_VERSION}" ]; then + sudo dpkg -P vpp-nsh-plugin vpp-nsh-plugin-dbg vpp-nsh-plugin-dev >/dev/null 2>&1 + test $? -eq 0 || exit 1 + nsh_need_install=1 + fi +else + nsh_need_install=1 +fi + +vpp_need_install=0 +sudo dpkg -l vpp >/dev/null 2>&1 +if [ $? -eq 0 ]; then + vpp_version=`dpkg -s vpp | grep Version | awk -F' ' '{print $2}'` + if [ "${vpp_version}" \< "${VPP_VERSION}" ]; then + sudo dpkg -P vpp vpp-dbg vpp-dev vpp-dpdk-dev vpp-dpdk-dkms vpp-lib \ + vpp-plugins vpp-python-api >/dev/null 2>&1 + test $? -eq 0 || exit 1 + vpp_need_install=1 + fi +else + vpp_need_install=1 +fi + +sleep 5 + +##begin to clone the vpp source code +if [ ${vpp_need_install} -eq 1 ]; then + sudo rm -rf ${VPP_CODE_DIR} + sudo mkdir -p ${VPP_CODE_DIR} + cd ${VPP_CODE_DIR} + git clone -b v${VPP_VERSION} https://gerrit.fd.io/r/vpp + + #compile the vpp code + cd ./vpp/build-root/ + make distclean + ./bootstrap.sh + make V=0 PLATFORM=vpp TAG=vpp install-deb + + #after that, install vpp + sudo dpkg -i *.deb + cd ${PWDDIR} +fi + +##begin to clone the nsh sfc source code +if [ ${nsh_need_install} -eq 1 ]; then + sudo rm -rf ${NSH_SFC_CODE_DIR} + sudo mkdir -p ${NSH_SFC_CODE_DIR} + cd ${NSH_SFC_CODE_DIR} + git clone -b v${NSH_SFC_VERSION} https://gerrit.fd.io/r/nsh_sfc + + #compile the nsh sfc code + cd ./nsh_sfc/nsh-plugin/ + sudo rm -rf build + sudo ./build.sh + + #after that, install the nsh sfc plugin + cd ./packaging/ + sudo dpkg -i *.deb + cd ${PWDDIR} +fi + +#check and setup the hugepages +SYS_HUGEPAGE=$(cat /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages) +if [ ${SYS_HUGEPAGE} -lt 1024 ]; then + MOUNT=$(mount | grep /mnt/huge) + while [ "${MOUNT}" != "" ] + do + sudo umount /mnt/huge + sleep 1 + MOUNT=$(mount | grep /mnt/huge) + done + + echo 2048 | sudo tee /sys/devices/system/node/node0/hugepages/hugepages-2048kB/nr_hugepages + echo 2048 | sudo tee /sys/devices/system/node/node1/hugepages/hugepages-2048kB/nr_hugepages + + sudo mkdir -p /mnt/huge + sudo mount -t hugetlbfs nodev /mnt/huge/ + test $? -eq 0 || exit 1 +fi + +#check and set the max map count +SYS_MAP=$(cat /proc/sys/vm/max_map_count) +if [ ${SYS_MAP} -lt 200000 ]; then + echo 200000 | sudo tee /proc/sys/vm/max_map_count +fi + +#after all, we can start the vpp service now +sudo service vpp start diff --git a/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_inbound.sh b/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_inbound.sh new file mode 100755 index 0000000000..453de3f8de --- /dev/null +++ b/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_inbound.sh @@ -0,0 +1,32 @@ +#!/bin/bash + +set -x + +sudo service vpp restart +sleep 5 + +sudo vppctl set int state $1 up +sleep 10 +sudo vppctl set int ip table $1 0 +sudo vppctl set int ip address $1 192.168.50.76/24 + +sudo vppctl create vxlan-gpe tunnel local 192.168.50.76 remote 192.168.50.72 vni 9 next-nsh encap-vrf-id 0 decap-vrf-id 0 +sudo vppctl set int l2 bridge vxlan_gpe_tunnel0 1 1 + +sudo vppctl create vxlan tunnel src 192.168.50.76 dst 192.168.50.71 vni 1 encap-vrf-id 0 decap-next node nsh-proxy +sudo vppctl set int l2 bridge vxlan_tunnel0 1 1 + +sudo vppctl create nsh entry nsp 185 nsi 255 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet +sudo vppctl create nsh entry nsp 185 nsi 254 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet + +sleep 2 +vxlan_gpe_index=`sudo vppctl sh int | grep "vxlan_gpe_tunnel0" | awk '{print $2}'` +vxlan_index=`sudo vppctl sh int | grep "vxlan_tunnel0" | awk '{print $2}'` +sudo vppctl create nsh map nsp 185 nsi 255 mapped-nsp 185 mapped-nsi 255 nsh_action pop encap-vxlan4-intf ${vxlan_index} +sudo vppctl create nsh map nsp 185 nsi 254 mapped-nsp 185 mapped-nsi 254 nsh_action push encap-vxlan-gpe-intf ${vxlan_gpe_index} + +sudo vppctl ip route add 192.168.50.72/24 via 192.168.50.76 +sudo vppctl set ip arp $1 192.168.50.71 $2 +sudo vppctl set ip arp $1 192.168.50.72 $2 + +sudo vppctl trace add dpdk-input 100 diff --git a/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_outbound.sh b/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_outbound.sh new file mode 100755 index 0000000000..304ed30cda --- /dev/null +++ b/tests/nsh_sfc/sfc_scripts/set_nsh_proxy_outbound.sh @@ -0,0 +1,32 @@ +#!/bin/bash + +set -x + +sudo service vpp restart +sleep 5 + +sudo vppctl set int state $1 up +sleep 10 +sudo vppctl set int ip table $1 0 +sudo vppctl set int ip address $1 192.168.50.76/24 + +sudo vppctl create vxlan-gpe tunnel local 192.168.50.76 remote 192.168.50.71 vni 9 next-nsh encap-vrf-id 0 decap-vrf-id 0 +sudo vppctl set int l2 bridge vxlan_gpe_tunnel0 1 1 + +sudo vppctl create vxlan tunnel src 192.168.50.76 dst 192.168.50.72 vni 1 encap-vrf-id 0 decap-next node nsh-proxy +sudo vppctl set int l2 bridge vxlan_tunnel0 1 1 + +sudo vppctl create nsh entry nsp 185 nsi 255 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet +sudo vppctl create nsh entry nsp 185 nsi 254 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet + +sleep 2 +vxlan_gpe_index=`sudo vppctl sh int | grep "vxlan_gpe_tunnel0" | awk '{print $2}'` +vxlan_index=`sudo vppctl sh int | grep "vxlan_tunnel0" | awk '{print $2}'` +sudo vppctl create nsh map nsp 185 nsi 255 mapped-nsp 185 mapped-nsi 255 nsh_action pop encap-vxlan4-intf ${vxlan_index} +sudo vppctl create nsh map nsp 185 nsi 254 mapped-nsp 185 mapped-nsi 254 nsh_action push encap-vxlan-gpe-intf ${vxlan_gpe_index} + +sudo vppctl ip route add 192.168.50.72/24 via 192.168.50.76 +sudo vppctl set ip arp $1 192.168.50.71 $2 +sudo vppctl set ip arp $1 192.168.50.72 $2 + +sudo vppctl trace add dpdk-input 100 diff --git a/tests/nsh_sfc/sfc_scripts/set_sfc_sff.sh b/tests/nsh_sfc/sfc_scripts/set_sfc_sff.sh new file mode 100755 index 0000000000..03e2f0ade7 --- /dev/null +++ b/tests/nsh_sfc/sfc_scripts/set_sfc_sff.sh @@ -0,0 +1,32 @@ +#!/bin/bash + +set -x + +sudo service vpp restart +sleep 5 + +sudo vppctl set int state $1 up +sleep 10 +sudo vppctl set int ip table $1 7 +sudo vppctl set int ip address $1 192.168.50.76/24 + +sudo vppctl create vxlan-gpe tunnel local 192.168.50.76 remote 192.168.50.71 vni 9 next-nsh encap-vrf-id 7 decap-vrf-id 7 +sudo vppctl set int l2 bridge vxlan_gpe_tunnel0 1 1 + +sudo vppctl create vxlan-gpe tunnel local 192.168.50.76 remote 192.168.50.72 vni 10 next-nsh encap-vrf-id 7 decap-vrf-id 7 +sudo vppctl set int l2 bridge vxlan_gpe_tunnel1 1 1 + +sudo vppctl create nsh entry nsp 185 nsi 255 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet +sudo vppctl create nsh entry nsp 185 nsi 254 md-type 1 c1 3232248395 c2 9 c3 3232248392 c4 50336437 next-ethernet + +sleep 2 +vxlan_gpe_index0=`sudo vppctl sh int | grep "vxlan_gpe_tunnel0" | awk '{print $2}'` +vxlan_gpe_index1=`sudo vppctl sh int | grep "vxlan_gpe_tunnel1" | awk '{print $2}'` +sudo vppctl create nsh map nsp 185 nsi 255 mapped-nsp 185 mapped-nsi 254 nsh_action swap encap-vxlan-gpe-intf ${vxlan_gpe_index0} + +sudo vppctl ip route add 192.168.50.71/32 via 192.168.50.76 $1 +sudo vppctl ip route add 192.168.50.72/32 via 192.168.50.76 $1 +sudo vppctl set ip arp fib-id 7 $1 192.168.50.71 $2 +sudo vppctl set ip arp fib-id 7 $1 192.168.50.72 $2 + +sudo vppctl trace add dpdk-input 100 diff --git a/tests/nsh_sfc/sfc_scripts/start_tcpdump.sh b/tests/nsh_sfc/sfc_scripts/start_tcpdump.sh new file mode 100755 index 0000000000..46f8217e26 --- /dev/null +++ b/tests/nsh_sfc/sfc_scripts/start_tcpdump.sh @@ -0,0 +1,16 @@ +#!/bin/bash + +ROOTDIR=/tmp/openvpp-testing +PWDDIR=$(pwd) + +cd ${ROOTDIR}/nsh_sfc_tests/sfc_scripts/ +sudo rm -f temp_packet.pcap + +sudo /usr/sbin/tcpdump -i $1 -c 1 -w temp_packet.pcap dst host $2 & + +if [ ! $? -eq 0 ]; then + echo "Start the tcpdump failed!!!" + exit 1 +fi + +cd ${PWDDIR} |