X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=xenserver%2Fetc_init.d_vswitch;h=abd594ecae08605f1c5f177ae35cf2f6d206752f;hb=641a0a4ed;hp=83d84ec2a9b960102dd06d94d6e0d2d0924f1f3d;hpb=612f6d49c5137ecaf407a5f8cc0a1e5ba4b4bca7;p=openvswitch diff --git a/xenserver/etc_init.d_vswitch b/xenserver/etc_init.d_vswitch index 83d84ec2..abd594ec 100755 --- a/xenserver/etc_init.d_vswitch +++ b/xenserver/etc_init.d_vswitch @@ -34,6 +34,7 @@ VSWITCHD_CONF="${VSWITCHD_CONF:-/etc/ovs-vswitchd.conf}" VSWITCHD_PIDFILE="${VSWITCHD_PIDFILE:-/var/run/ovs-vswitchd.pid}" VSWITCHD_RUN_DIR="${VSWITCHD_RUN_DIR:-/var/xen/vswitch}" VSWITCHD_PRIORITY="${VSWITCHD_PRIORITY:--5}" +VSWITCHD_NETBACK_PRIORITY="${VSWITCHD_NETBACK_PRIORITY:-0}" VSWITCHD_LOGFILE="${VSWITCHD_LOGFILE:-/var/log/ovs-vswitchd.log}" VSWITCHD_FILE_LOGLEVEL="${VSWITCHD_FILE_LOGLEVEL:-}" VSWITCHD_SYSLOG_LOGLEVEL="${VSWITCHD_SYSLOG_LOGLEVEL:-WARN}" @@ -115,6 +116,28 @@ function reload_vswitchd { fi } +function quietly { + "$@" > /dev/null +} + +# renice_netback PRIORITY PID [PID...] +# +# Renices the netback processes given as each PID to nice level PRIORITY. +function renice_netback { + local pri=$1 + shift + + if test $# = 0; then + warning "Netback not running, nothing to renice" + return + fi + + for pid + do + action "Renicing netback (pid $pid) to priority $pri" quietly renice $pri -p $pid + done +} + function start_vswitchd { local syslog_opt="-vANY:SYSLOG:${VSWITCHD_SYSLOG_LOGLEVEL}" local logfile_file_opt="" @@ -152,6 +175,11 @@ function start_vswitchd { if [ "$ENABLE_FAKE_PROC_NET" = "y" ]; then fake_proc_net_opt="--fake-proc-net" fi + if [ "$VSWITCHD_NETBACK_PRIORITY" != default ]; then + renice_netback $VSWITCHD_NETBACK_PRIORITY $(pidof netback) + else + warning "Netback renicing disabled (see /etc/sysconfig/vswitch)" + fi if [ "$daemonize" != "y" ]; then # Start in background and force a "success" message action "Starting ovs-vswitchd ($strace_opt$valgrind_opt)" true