Commit e556ceae authored by wangyongshou's avatar wangyongshou

add netcard.conf

parent 3e69b6db
...@@ -73,7 +73,7 @@ function close_upf() ...@@ -73,7 +73,7 @@ function close_upf()
{ {
pid=$(pidof $VPP_PRO) pid=$(pidof $VPP_PRO)
if test -z "$pid"; then if test -z "$pid"; then
echo "vpp $pid is not startup" echo "vpp $pid is not start up"
else else
echo "kill vpp $pid" echo "kill vpp $pid"
kill -9 ${pid} kill -9 ${pid}
...@@ -81,7 +81,7 @@ function close_upf() ...@@ -81,7 +81,7 @@ function close_upf()
pid=$(pidof $N4_PRO) pid=$(pidof $N4_PRO)
if test -z "$pid"; then if test -z "$pid"; then
echo "n4 $pid is not startup" echo "n4 $pid is not start up"
else else
echo "kill n4 $pid" echo "kill n4 $pid"
kill -9 ${pid} kill -9 ${pid}
......
...@@ -43,16 +43,7 @@ UPF_INTER_PCI="" ...@@ -43,16 +43,7 @@ UPF_INTER_PCI=""
function start_vppe() function start_vppe()
{ {
#cmd="$VPPCMD"
install_dpdk_kmod
#$base/tools/interreput -i $CPUNUMBER
echo Y | sudo tee /sys/module/vfio/parameters/enable_unsafe_noiommu_mode
#$cmd >/dev/null 2>&1 &
$base/bin/vpp -c $base/etc/vppe.conf >/dev/null 2>&1 ; $base/bin/vpp -c $base/etc/vppe.conf >/dev/null 2>&1 ;
sleep 1s sleep 1s
pid=$(pidof $VPPPROCESS) pid=$(pidof $VPPPROCESS)
...@@ -65,9 +56,6 @@ function start_vppe() ...@@ -65,9 +56,6 @@ function start_vppe()
function start_n4() function start_n4()
{ {
#$N4PATH/main -c /opt/5gc/n4_config.yaml >/dev/null 2>&1 &
$base/bin/main -c $base/etc/n4_config.yaml & >/dev/null 2>&1 ; $base/bin/main -c $base/etc/n4_config.yaml & >/dev/null 2>&1 ;
sleep 1s sleep 1s
...@@ -102,7 +90,6 @@ function close_upf() ...@@ -102,7 +90,6 @@ function close_upf()
function close_vppe() function close_vppe()
{ {
pid=$(pidof $VPPPROCESS) pid=$(pidof $VPPPROCESS)
if test -z "$pid"; then if test -z "$pid"; then
echo "vpp $pid is not startup" echo "vpp $pid is not startup"
...@@ -114,7 +101,6 @@ function close_vppe() ...@@ -114,7 +101,6 @@ function close_vppe()
function close_n4() function close_n4()
{ {
pid=$(pidof $N4PROCESS) pid=$(pidof $N4PROCESS)
if test -z "$pid"; then if test -z "$pid"; then
echo "n4 $pid is not startup" echo "n4 $pid is not startup"
...@@ -125,14 +111,18 @@ function close_n4() ...@@ -125,14 +111,18 @@ function close_n4()
exit 0 exit 0
} }
function install_dpdk_kmod() function install_driver()
{ {
sudo modprobe vfio-pci; sudo modprobe vfio-pci;
insmod_result=$? insmod_result=$?
exec_result $insmod_result exec_result $insmod_result
echo Y | sudo tee /sys/module/vfio/parameters/enable_unsafe_noiommu_mode
#$base/tools/interreput -i $CPUNUMBER
return 0; return 0;
} }
...@@ -142,32 +132,28 @@ function exec_result() ...@@ -142,32 +132,28 @@ function exec_result()
echo "insmod vfio-pci.ko false" echo "insmod vfio-pci.ko false"
fi fi
echo "insmod vfio-pci.ko success!!!" echo "insmod vfio-pci.ko success"
} }
function install_deps() function net_state()
{ {
if [ ! -f $base/etc/netcard.conf ] ; then
echo "ERROR not exist $/base/etc/netcard.conf "
exit 0
fi
echo "install deps" while read line
} do
function unbind() eval "$line"
{ done < $base/etc/netcard.conf
python3 $current/dpdk-devbind.py -u 0000:$DPDK_EXPORT_PCI ;
python3 $current/dpdk-devbind.py -u 0000:$DPDK_EXPORT_PCI;
python3 $current/dpdk-devbind.py -b $DRIVE $DPDK_EXPORT_PCI ifconfig $upf_n3_name down;
sleep 1 ifconfig $upf_n6_name down;
python3 $current/dpdk-devbind.py -b $DRIVE $DPDK_EXPORT_PCI
sleep 1
ifconfig $DPDK_EXPORT down; python3 $base/scripts/dpdk-devbind.py -b vfio-pci $upf_n3_pci
sleep 1 python3 $base/scripts/dpdk-devbind.py -b vfio-pci $upf_n6_pci
ifconfig $DPDK_ENTRY down;
sleep 1
return 0
} }
function get_inter_ip() function get_inter_ip()
...@@ -183,7 +169,19 @@ function get_inter_pci() ...@@ -183,7 +169,19 @@ function get_inter_pci()
UPF_INTER_PCI=$(echo `$base/tools/ethtool -i ${INTER_NAME} | grep "bus-info" | awk '{print $2}'`) UPF_INTER_PCI=$(echo `$base/tools/ethtool -i ${INTER_NAME} | grep "bus-info" | awk '{print $2}'`)
#UPF_INTER_PCI=$(echo ` ./dpdk-devbind.py --status | grep "if=${INTER_NAME}" | awk '{print $1}'`) #UPF_INTER_PCI=$(echo ` ./dpdk-devbind.py --status | grep "if=${INTER_NAME}" | awk '{print $1}'`)
} }
function is_configured(){
result=$(echo `grep -n "@N3_GW@" $base/etc/vppe.conf | grep "@N3_GW@"`)
echo $result
if [[ $result != "" ]]; then
echo "not config"
return 0
else
echo "configured"
return 1
fi
}
function generate_instance() function generate_instance()
{ {
...@@ -195,7 +193,7 @@ function generate_instance() ...@@ -195,7 +193,7 @@ function generate_instance()
UPF_WORKERCORE="$workerc1,$workerc2" UPF_WORKERCORE="$workerc1,$workerc2"
#vpp config #vppe config
sed -i s/@MAINCORE@/${UPF_MAINCORE}/ $VPP_CONFIG > /dev/null 2>&1; sed -i s/@MAINCORE@/${UPF_MAINCORE}/ $VPP_CONFIG > /dev/null 2>&1;
sed -i s/@WORKERCORE@/${UPF_WORKERCORE}/ $VPP_CONFIG > /dev/null 2>&1; sed -i s/@WORKERCORE@/${UPF_WORKERCORE}/ $VPP_CONFIG > /dev/null 2>&1;
...@@ -212,12 +210,73 @@ function generate_instance() ...@@ -212,12 +210,73 @@ function generate_instance()
sed -i s/@upf@/${UPF_N4_UPF}/ $VPP_N4 > /dev/null 2>&1; sed -i s/@upf@/${UPF_N4_UPF}/ $VPP_N4 > /dev/null 2>&1;
sed -i s/@logSize@/${UPF_N4_LOGSIZE}/ $VPP_N4 > /dev/null 2>&1; sed -i s/@logSize@/${UPF_N4_LOGSIZE}/ $VPP_N4 > /dev/null 2>&1;
echo "" echo "config finished"
echo "/opt/5gc/vppe.conf"
echo "/opt/5gc/n4_config.yaml"
} }
function get_bus()
{
UPF_N3_DRIVER=$(echo `$base/tools/ethtool -i $UPF_N3_NAME | grep "driver" | awk '{print $2}'`)
if [[ $UPF_N3_DRIVER == "" ]]; then
echo "ERROR N3 $UPF_N3_NAME cat not bus"
exit 0
else
echo "$UPF_N3_NAME pci $UPF_N3_DRIVER"
fi
UPF_N6_DRIVER=$(echo `$base/tools/ethtool -i $UPF_N6_NAME | grep "driver" | awk '{print $2}'`)
if [[ $UPF_N6_DRIVER == "" ]]; then
echo "ERROR N6 $UPF_N6_NAME cat not bus"
exit 0
else
echo "$UPF_N6_NAME pci $UPF_N6_DRIVER"
fi
}
function get_pci()
{
UPF_N3_PCI=$(echo `$base/tools/ethtool -i $UPF_N3_NAME | grep "bus-info" | awk '{print $2}'`)
if [[ $UPF_N3_PCI == "" ]]; then
echo "ERROR N3 $UPF_N3_NAME cat not pci"
exit 0
else
echo "$UPF_N3_NAME pci $UPF_N3_PCI"
fi
UPF_N6_PCI=$(echo `$base/tools/ethtool -i $UPF_N6_NAME | grep "bus-info" | awk '{print $2}'`)
if [[ $UPF_N6_PCI == "" ]]; then
echo "ERROR N6 $UPF_N6_NAME cat not pci"
exit 0
else
echo "$UPF_N6_NAME pci $UPF_N6_PCI"
fi
}
function get_inter_info()
{
if [ -f $base/etc/netcard.conf ] ; then
return 0
fi
get_pci
get_bus
#netcard.conf
cd $base/etc
touch netcard.conf
chmod a+x netcard.conf
echo "upf_n3_name=$UPF_N3_NAME" >> netcard.conf
echo "upf_n6_name=$UPF_N6_NAME" >> netcard.conf
echo "upf_n3_pci=$UPF_N3_PCI" >> netcard.conf
echo "upf_n6_pci=$UPF_N6_PCI" >> netcard.conf
echo "upf_n3_driver=$UPF_N3_DRIVER" >> netcard.conf
echo "upf_n6_driver=$UPF_N6_DRIVER" >> netcard.conf
cd ..
}
#read upf.txt #read upf.txt
function read_config() { function read_config() {
...@@ -248,15 +307,7 @@ function read_config() { ...@@ -248,15 +307,7 @@ function read_config() {
UPF_CPU=$vpp_cpu UPF_CPU=$vpp_cpu
echo "vpp_cpu:$UPF_CPU" echo "vpp_cpu:$UPF_CPU"
get_inter_pci $UPF_N3_NAME get_inter_info
UPF_N3_PCI=$UPF_INTER_PCI
echo "UPF_N3_PCI:$UPF_N3_PCI"
UPF_INTER_PCI=""
get_inter_pci $UPF_N6_NAME
UPF_N6_PCI=$UPF_INTER_PCI
echo "UPF_N6_PCI:$UPF_N6_PCI"
echo "" echo ""
echo "n4 config" echo "n4 config"
...@@ -276,8 +327,16 @@ function read_config() { ...@@ -276,8 +327,16 @@ function read_config() {
function config_upf() function config_upf()
{ {
install_driver
read_config read_config
is_configured
result=$?
if [ $result -eq 0 ] ; then
generate_instance generate_instance
fi
net_state
} }
function help() function help()
...@@ -288,43 +347,34 @@ function help() ...@@ -288,43 +347,34 @@ function help()
echo "--close-upf close UPF(n4 and vppe)" echo "--close-upf close UPF(n4 and vppe)"
} }
function main() function main()
{ {
if [ ! -f $UPF_CONFIG ] ; then
echo "no exist $UPF_CONFIG"
return
fi
install_deps
if [ $# -eq 0 ]; if [ $# -eq 0 ];
then then
help help
exit exit
fi fi
if [ ! -f $UPF_CONFIG ] ; then
echo "no exist $UPF_CONFIG"
return
fi
until [ -z "$1" ]; do until [ -z "$1" ]; do
case "$1" in case "$1" in
--start-upf) --start-upf)
config_upf config_upf
#close vppe, n4 process
close_upf close_upf
#start vppe, n4 process
start_vppe start_vppe
sleep 20s sleep 20s
start_n4 start_n4
shift shift
;; ;;
--close-upf) --close-upf)
#close vppe, n4 process
close_vppe close_vppe
close_n4 close_n4
shift shift
;; ;;
*) *)
help help
exit 0 exit 0
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment