Traffic control: fix TC filters for vlan sub-interface
Sometime after kernel 3.10.0-514.16.1.X, tc filter commands no longer match 802.1q packets when the filter protocol is set to 'ip'. This poses a problem for a consolidated (eg. infra w/ vlan over management) interface configuration. The tc filter will operate properly on the vlan interface, but all traffic will go to the default qdisc (low priority) when it arrives with a vlan tag at the sub-interface. This commit sets the filter protocol to '802.1q' in the case of a subinterface with a vlan tagged interface ontop of it. Some bashate cleanup has also been done on this file. Closes-Bug: #1807055 Change-Id: I457faa2b56bbd270c104cc0313ffe3cc1bfd4db3 Signed-off-by: Steven Webster <steven.webster@windriver.com>
This commit is contained in:
parent
d910ac0dc6
commit
01f5fdd274
@ -1,14 +1,15 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2017 Wind River Systems, Inc.
|
# Copyright (c) 2017-2018 Wind River Systems, Inc.
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
#
|
#
|
||||||
|
|
||||||
# $1 - interface
|
# $1 - interface
|
||||||
# $2 - interface type [mgmt, infra]
|
# $2 - interface type [mgmt, infra]
|
||||||
# $3 - dummy used to determine if we're backgrounded or not
|
# $3 - link capacity
|
||||||
|
# $4 - dummy used to determine if we're backgrounded or not
|
||||||
|
|
||||||
DEV=$1
|
DEV=$1
|
||||||
NETWORKTYPE=$2
|
NETWORKTYPE=$2
|
||||||
@ -42,7 +43,8 @@ function test_valid_speed {
|
|||||||
|
|
||||||
function log {
|
function log {
|
||||||
# It seems that syslog isn't yet running, so append directly to the syslog file
|
# It seems that syslog isn't yet running, so append directly to the syslog file
|
||||||
echo `date +%FT%T.%3N` `hostname` CGCS_TC_SETUP: $@ >> /var/log/platform.log
|
FILE=/var/log/platform.log
|
||||||
|
echo `date +%FT%T.%3N` `hostname` CGCS_TC_SETUP: $@ >> $FILE
|
||||||
}
|
}
|
||||||
|
|
||||||
function infra_exists {
|
function infra_exists {
|
||||||
@ -57,15 +59,18 @@ function is_consolidated {
|
|||||||
if ! infra_exists
|
if ! infra_exists
|
||||||
then
|
then
|
||||||
return 1
|
return 1
|
||||||
else
|
|
||||||
# determine whether the management interface is a parent of the
|
|
||||||
# infrastructure interface based on name.
|
|
||||||
# eg. this matches enp0s8 to enp0s8.10 but not enp0s88
|
|
||||||
if [[ $infrastructure_interface =~ $management_interface[\.][0-9]+$ ]]; then
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
return 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
local INFRA=$infrastructure_interface
|
||||||
|
local MGMT=$management_interface
|
||||||
|
|
||||||
|
# determine whether the management interface is a parent of the
|
||||||
|
# infrastructure interface based on name.
|
||||||
|
# eg. this matches enp0s8 to enp0s8.10 but not enp0s88
|
||||||
|
if [[ $INFRA =~ $MGMT[\.][0-9]+$ ]]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
function is_vlan {
|
function is_vlan {
|
||||||
@ -78,7 +83,8 @@ function is_vlan {
|
|||||||
|
|
||||||
function is_loopback {
|
function is_loopback {
|
||||||
# (from include/uapi/linux/if.h)
|
# (from include/uapi/linux/if.h)
|
||||||
IFF_LOOPBACK=$((1<<3))
|
# IFF_LOOPBACK = 1<<3 = 8. Using a left shifted syntax can confuse bashate.
|
||||||
|
IFF_LOOPBACK=8
|
||||||
|
|
||||||
# get the interface flags
|
# get the interface flags
|
||||||
FLAGS=`cat /sys/class/net/$DEV/flags`
|
FLAGS=`cat /sys/class/net/$DEV/flags`
|
||||||
@ -91,42 +97,78 @@ function is_loopback {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function get_tc_filter_ethertype {
|
||||||
|
local ETHERTYPE=$DEFAULT_ETHERTYPE
|
||||||
|
|
||||||
|
if is_consolidated
|
||||||
|
then
|
||||||
|
if ! is_vlan
|
||||||
|
then
|
||||||
|
# If we have a consolidated VLAN interface, we must set the
|
||||||
|
# protocol to '802.1q' for the underlying Ethernet interface
|
||||||
|
# to be able to match on IP packets coming from the VLAN
|
||||||
|
# interface.
|
||||||
|
ETHERTYPE=802.1q
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
echo $ETHERTYPE
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
function setup_tc_port_filter {
|
function setup_tc_port_filter {
|
||||||
local PORT=$1
|
local PORT=$1
|
||||||
local PORTMASK=$2
|
local PORTMASK=$2
|
||||||
local FLOWID=$3
|
local FLOWID=$3
|
||||||
local PROTOCOL=$4
|
local PROTOCOL=$4
|
||||||
|
local PRIORITY=$DEFAULT_PRIORITY
|
||||||
|
local ETHERTYPE=$DEFAULT_ETHERTYPE
|
||||||
|
|
||||||
if [ -z $PROTOCOL ]
|
ETHERTYPE=$(get_tc_filter_ethertype)
|
||||||
then
|
|
||||||
|
if [ -z $PROTOCOL ]; then
|
||||||
# Apply to TCP and UDP
|
# Apply to TCP and UDP
|
||||||
tc filter add dev $DEV protocol ip parent 1:0 prio 1 u32 match ip dport $PORT $PORTMASK flowid $FLOWID
|
tc filter add dev $DEV protocol $ETHERTYPE parent 1:0 prio $PRIORITY \
|
||||||
tc filter add dev $DEV protocol ip parent 1:0 prio 1 u32 match ip sport $PORT $PORTMASK flowid $FLOWID
|
u32 match ip dport $PORT $PORTMASK flowid $FLOWID
|
||||||
|
tc filter add dev $DEV protocol $ETHERTYPE parent 1:0 prio $PRIORITY \
|
||||||
|
u32 match ip sport $PORT $PORTMASK flowid $FLOWID
|
||||||
else
|
else
|
||||||
# Apply to specific protocol only
|
# Apply to specific protocol only
|
||||||
tc filter add dev $DEV protocol ip parent 1:0 prio 1 u32 match ip protocol 6 0xff match ip dport $PORT $PORTMASK flowid $FLOWID
|
tc filter add dev $DEV protocol $ETHERTYPE parent 1:0 prio $PRIORITY \
|
||||||
tc filter add dev $DEV protocol ip parent 1:0 prio 1 u32 match ip protocol 6 0xff match ip sport $PORT $PORTMASK flowid $FLOWID
|
u32 match ip protocol $PROTOCOL 0xff match \
|
||||||
|
ip dport $PORT $PORTMASK flowid $FLOWID
|
||||||
|
tc filter add dev $DEV protocol $ETHERTYPE parent 1:0 prio $PRIORITY \
|
||||||
|
u32 match ip protocol $PROTOCOL 0xff match \
|
||||||
|
ip sport $PORT $PORTMASK flowid $FLOWID
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_tc_tos_filter
|
function setup_tc_tos_filter {
|
||||||
{
|
|
||||||
local TOS=$1
|
local TOS=$1
|
||||||
local TOSMASK=$2
|
local TOSMASK=$2
|
||||||
local FLOWID=$3
|
local FLOWID=$3
|
||||||
|
local ETHERTYPE=$4
|
||||||
|
local PRIORITY=$5
|
||||||
|
|
||||||
tc filter add dev $DEV protocol ip parent 1:0 prio 1 u32 match ip tos $TOS $TOSMASK flowid $FLOWID
|
if [ -z $ETHERTYPE ]; then
|
||||||
|
ETHERTYPE=$DEFAULT_ETHERTYPE
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z $PRIORITY ]; then
|
||||||
|
PRIORITY=$DEFAULT_PRIORITY
|
||||||
|
fi
|
||||||
|
|
||||||
|
tc filter add dev $DEV protocol $ETHERTYPE parent 1:0 prio $PRIORITY \
|
||||||
|
u32 match ip tos $TOS $TOSMASK flowid $FLOWID
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_root_tc
|
function setup_root_tc {
|
||||||
{
|
|
||||||
# create new qdiscs, classes and queues
|
# create new qdiscs, classes and queues
|
||||||
tc qdisc add dev $DEV root handle 1: htb default 40
|
tc qdisc add dev $DEV root handle 1: htb default 40
|
||||||
tc class add dev $DEV parent 1: classid 1:1 htb rate ${SPEED}mbit burst 15k quantum 60000
|
tc class add dev $DEV parent 1: classid 1:1 htb rate ${SPEED}mbit \
|
||||||
|
burst 15k quantum 60000
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_default_tc
|
function setup_default_tc {
|
||||||
{
|
|
||||||
local RATE=$1
|
local RATE=$1
|
||||||
local CEIL=$2
|
local CEIL=$2
|
||||||
|
|
||||||
@ -135,29 +177,40 @@ function setup_default_tc
|
|||||||
local FLOWID=$CLASSID
|
local FLOWID=$CLASSID
|
||||||
|
|
||||||
# create default qdiscs, classes
|
# create default qdiscs, classes
|
||||||
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k ceil $((${CEIL}*${SPEED}/100))mbit prio 4 quantum 60000
|
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k \
|
||||||
|
ceil $((${CEIL}*${SPEED}/100))mbit prio 4 quantum 60000
|
||||||
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_hiprio_tc
|
function setup_hiprio_tc {
|
||||||
{
|
|
||||||
local RATE=$1
|
local RATE=$1
|
||||||
local CEIL=$2
|
local CEIL=$2
|
||||||
|
|
||||||
local FLOWQ=10
|
local FLOWQ=10
|
||||||
local CLASSID=1:$FLOWQ
|
local CLASSID=1:$FLOWQ
|
||||||
local FLOWID=$CLASSID
|
local FLOWID=$CLASSID
|
||||||
|
local ETHERTYPE=$DEFAULT_ETHERTYPE
|
||||||
|
ETHERTYPE=$(get_tc_filter_ethertype)
|
||||||
|
|
||||||
# create high priority qdiscs, classes, and queues
|
# create high priority qdiscs, classes, and queues
|
||||||
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k ceil $((${CEIL}*${SPEED}/100))mbit prio 3 quantum 60000
|
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k \
|
||||||
|
ceil $((${CEIL}*${SPEED}/100))mbit prio 3 quantum 60000
|
||||||
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
||||||
|
|
||||||
# filter for high priority traffic
|
# filter for high priority traffic
|
||||||
setup_tc_tos_filter 0x10 0xf8 $FLOWID
|
setup_tc_tos_filter 0x10 0xf8 $FLOWID $ETHERTYPE
|
||||||
|
|
||||||
|
if [ "$ETHERTYPE" != "$DEFAULT_ETHERTYPE" ]; then
|
||||||
|
# For the 'hiprio' class, a second filter at a different priority is
|
||||||
|
# needed in this case to match traffic with the default ethertype.
|
||||||
|
# (ie. high priority management traffic).
|
||||||
|
local PRIORITY
|
||||||
|
PRIORITY=$(($DEFAULT_PRIORITY + 1))
|
||||||
|
setup_tc_tos_filter 0x10 0xf8 $FLOWID $DEFAULT_ETHERTYPE $PRIORITY
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_migration_tc
|
function setup_migration_tc {
|
||||||
{
|
|
||||||
local RATE=$1
|
local RATE=$1
|
||||||
local CEIL=$2
|
local CEIL=$2
|
||||||
|
|
||||||
@ -166,7 +219,8 @@ function setup_migration_tc
|
|||||||
local FLOWID=$CLASSID
|
local FLOWID=$CLASSID
|
||||||
|
|
||||||
# create migration qdiscs, classes, and queues
|
# create migration qdiscs, classes, and queues
|
||||||
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k ceil $((${CEIL}*${SPEED}/100))mbit prio 2 quantum 60000
|
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k \
|
||||||
|
ceil $((${CEIL}*${SPEED}/100))mbit prio 2 quantum 60000
|
||||||
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
||||||
|
|
||||||
# Migration (TCP, ports 49152-49215)
|
# Migration (TCP, ports 49152-49215)
|
||||||
@ -176,8 +230,7 @@ function setup_migration_tc
|
|||||||
setup_tc_port_filter 16509 0xffff $FLOWID $TCP
|
setup_tc_port_filter 16509 0xffff $FLOWID $TCP
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_storage_tc
|
function setup_storage_tc {
|
||||||
{
|
|
||||||
local RATE=$1
|
local RATE=$1
|
||||||
local CEIL=$2
|
local CEIL=$2
|
||||||
|
|
||||||
@ -186,7 +239,8 @@ function setup_storage_tc
|
|||||||
local FLOWID=$CLASSID
|
local FLOWID=$CLASSID
|
||||||
|
|
||||||
# create storage qdiscs, classes, and queues
|
# create storage qdiscs, classes, and queues
|
||||||
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k ceil $((${CEIL}*${SPEED}/100))mbit prio 1 quantum 60000
|
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k \
|
||||||
|
ceil $((${CEIL}*${SPEED}/100))mbit prio 1 quantum 60000
|
||||||
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
||||||
|
|
||||||
# Storage, NFS (UDP/TCP, port 2049)
|
# Storage, NFS (UDP/TCP, port 2049)
|
||||||
@ -205,8 +259,7 @@ function setup_storage_tc
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_drbd_tc
|
function setup_drbd_tc {
|
||||||
{
|
|
||||||
local RATE=$1
|
local RATE=$1
|
||||||
local CEIL=$2
|
local CEIL=$2
|
||||||
|
|
||||||
@ -215,14 +268,15 @@ function setup_drbd_tc
|
|||||||
local FLOWID=$CLASSID
|
local FLOWID=$CLASSID
|
||||||
|
|
||||||
# create DRBD qdiscs, classes and queues
|
# create DRBD qdiscs, classes and queues
|
||||||
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k ceil $((${CEIL}*${SPEED}/100))mbit quantum 60000
|
$AC $CLASSID htb rate $((${RATE}*${SPEED}/100))mbit burst 15k \
|
||||||
|
ceil $((${CEIL}*${SPEED}/100))mbit quantum 60000
|
||||||
|
|
||||||
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
tc qdisc add dev $DEV parent $CLASSID handle $FLOWQ: sfq perturb 10
|
||||||
|
|
||||||
# DRDB (TCP, ports 7789,7790,7791,7799)
|
# DRDB (TCP, ports 7789,7790,7791,7799)
|
||||||
# port 7793 is used with drdb-extension
|
# port 7793 is used with drdb-extension
|
||||||
PORTS=( 7789 7790 7791 7792 7799 7793 )
|
PORTS=( 7789 7790 7791 7792 7799 7793 )
|
||||||
PORTMASKS=( 0xffff 0xffff 0xffff 0xffff 0xffff )
|
PORTMASKS=( 0xffff 0xffff 0xffff 0xffff 0xffff 0xffff)
|
||||||
for idx in "${!PORTS[@]}"; do
|
for idx in "${!PORTS[@]}"; do
|
||||||
PORT=${PORTS[$idx]}
|
PORT=${PORTS[$idx]}
|
||||||
MASK=${PORTMASKS[$idx]}
|
MASK=${PORTMASKS[$idx]}
|
||||||
@ -230,8 +284,7 @@ function setup_drbd_tc
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_mgmt_tc_individual
|
function setup_mgmt_tc_individual {
|
||||||
{
|
|
||||||
# Configure high priority and default traffic classes.
|
# Configure high priority and default traffic classes.
|
||||||
|
|
||||||
setup_root_tc
|
setup_root_tc
|
||||||
@ -251,8 +304,7 @@ function setup_mgmt_tc_individual
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function setup_mgmt_tc_vlan
|
function setup_mgmt_tc_vlan {
|
||||||
{
|
|
||||||
# Configure high priority and default traffic classes.
|
# Configure high priority and default traffic classes.
|
||||||
|
|
||||||
setup_root_tc
|
setup_root_tc
|
||||||
@ -271,8 +323,7 @@ function setup_mgmt_tc_vlan
|
|||||||
setup_default_tc $DEFAULT_BW $DEFAULT_CBW
|
setup_default_tc $DEFAULT_BW $DEFAULT_CBW
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_mgmt_tc_consolidated
|
function setup_mgmt_tc_consolidated {
|
||||||
{
|
|
||||||
# Configure management classes.
|
# Configure management classes.
|
||||||
# All traffic coming from the infra will get treated again by the
|
# All traffic coming from the infra will get treated again by the
|
||||||
# management traffic classes. We need to apply the same TCs as the
|
# management traffic classes. We need to apply the same TCs as the
|
||||||
@ -282,8 +333,7 @@ function setup_mgmt_tc_consolidated
|
|||||||
setup_tc_all
|
setup_tc_all
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_mgmt_tc_infra_exists
|
function setup_mgmt_tc_infra_exists {
|
||||||
{
|
|
||||||
if is_consolidated
|
if is_consolidated
|
||||||
then
|
then
|
||||||
# Infra over mgmt. In this case we want to reserve
|
# Infra over mgmt. In this case we want to reserve
|
||||||
@ -301,8 +351,7 @@ function setup_mgmt_tc_infra_exists
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_mgmt_tc_no_infra
|
function setup_mgmt_tc_no_infra {
|
||||||
{
|
|
||||||
# Configure traffic classes for a management interface when
|
# Configure traffic classes for a management interface when
|
||||||
# no infrastructure interface exists. Configure the full
|
# no infrastructure interface exists. Configure the full
|
||||||
# set of TCs.
|
# set of TCs.
|
||||||
@ -311,35 +360,34 @@ function setup_mgmt_tc_no_infra
|
|||||||
setup_tc_all
|
setup_tc_all
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_infra_tc_consolidated
|
function setup_infra_tc_consolidated {
|
||||||
{
|
|
||||||
# Configure the full set of traffic classes, but leave a small
|
# Configure the full set of traffic classes, but leave a small
|
||||||
# portion of bandwidth for the management interface.
|
# portion of bandwidth for the management interface.
|
||||||
|
|
||||||
# reserve 1% BW for management
|
# reserve 1% BW for management
|
||||||
local RESERVED=$((1*${SPEED}/100))
|
local RESERVED
|
||||||
|
RESERVED=$((1*${SPEED}/100))
|
||||||
SPEED=$((${SPEED}-${RESERVED}))
|
SPEED=$((${SPEED}-${RESERVED}))
|
||||||
|
|
||||||
setup_root_tc
|
setup_root_tc
|
||||||
setup_tc_all
|
setup_tc_all
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_infra_tc_individual
|
function setup_infra_tc_individual {
|
||||||
{
|
|
||||||
# Configure the full set of traffic classes.
|
# Configure the full set of traffic classes.
|
||||||
|
|
||||||
setup_root_tc
|
setup_root_tc
|
||||||
if is_vlan
|
if is_vlan
|
||||||
then
|
then
|
||||||
# reserve 1% BW for sibling vlan interfaces
|
# reserve 1% BW for sibling vlan interfaces
|
||||||
local RESERVED=$((1*${SPEED}/100))
|
local RESERVED
|
||||||
|
RESERVED=$((1*${SPEED}/100))
|
||||||
SPEED=$((${SPEED}-${RESERVED}))
|
SPEED=$((${SPEED}-${RESERVED}))
|
||||||
fi
|
fi
|
||||||
setup_tc_all
|
setup_tc_all
|
||||||
}
|
}
|
||||||
|
|
||||||
function setup_tc_all
|
function setup_tc_all {
|
||||||
{
|
|
||||||
# bandwidth percentages, in case of over-percentage, bandwidth is divided based
|
# bandwidth percentages, in case of over-percentage, bandwidth is divided based
|
||||||
# on bandwidth ratios
|
# on bandwidth ratios
|
||||||
local MIG_BW=30
|
local MIG_BW=30
|
||||||
@ -359,24 +407,18 @@ function setup_tc_all
|
|||||||
setup_storage_tc $STOR_BW $STOR_CBW
|
setup_storage_tc $STOR_BW $STOR_CBW
|
||||||
setup_migration_tc $MIG_BW $MIG_CBW
|
setup_migration_tc $MIG_BW $MIG_CBW
|
||||||
setup_default_tc $DEFAULT_BW $DEFAULT_CBW
|
setup_default_tc $DEFAULT_BW $DEFAULT_CBW
|
||||||
if [ $nodetype == "controller" ]
|
if [ $nodetype == "controller" ]; then
|
||||||
then
|
|
||||||
setup_drbd_tc $DRBD_BW $DRBD_CBW
|
setup_drbd_tc $DRBD_BW $DRBD_CBW
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_dev_speed
|
function get_dev_speed {
|
||||||
{
|
|
||||||
# If the link doesn't come up we won't go enabled, so here we can
|
# If the link doesn't come up we won't go enabled, so here we can
|
||||||
# afford to wait forever for the link.
|
# afford to wait forever for the link.
|
||||||
while true
|
while true; do
|
||||||
do
|
if [ -e /sys/class/net/$1/bonding ]; then
|
||||||
if [ -e /sys/class/net/$1/bonding ]
|
for VAL in `cat /sys/class/net/$1/lower_*/speed`; do
|
||||||
then
|
if test_valid_speed $VAL; then
|
||||||
for VAL in `cat /sys/class/net/$1/lower_*/speed`
|
|
||||||
do
|
|
||||||
if test_valid_speed $VAL
|
|
||||||
then
|
|
||||||
log slave for bond link $1 reported speed $VAL
|
log slave for bond link $1 reported speed $VAL
|
||||||
echo $VAL
|
echo $VAL
|
||||||
return 0
|
return 0
|
||||||
@ -384,38 +426,36 @@ function get_dev_speed
|
|||||||
log slave for bond link $1 reported invalid speed $VAL
|
log slave for bond link $1 reported invalid speed $VAL
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
log all slaves for bond link $1 reported invalid speeds, will sleep 30 sec and try again
|
log all slaves for bond link $1 reported invalid speeds, \
|
||||||
|
will sleep 30 sec and try again
|
||||||
else
|
else
|
||||||
VAL=`cat /sys/class/net/$1/speed`
|
VAL=`cat /sys/class/net/$1/speed`
|
||||||
if test_valid_speed $VAL
|
if test_valid_speed $VAL; then
|
||||||
then
|
|
||||||
log link $1 reported speed $VAL
|
log link $1 reported speed $VAL
|
||||||
echo $VAL
|
echo $VAL
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
log link $1 returned invalid speed $VAL, will sleep 30 sec and try again
|
log link $1 returned invalid speed $VAL, \
|
||||||
|
will sleep 30 sec and try again
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep 30
|
sleep 30
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_speed
|
function get_speed {
|
||||||
{
|
|
||||||
local dev=$1
|
local dev=$1
|
||||||
local networktype=$2
|
local networktype=$2
|
||||||
local net_speed=$NETWORKSPEED
|
local net_speed=$NETWORKSPEED
|
||||||
local dev_speed=$(get_dev_speed $DEV)
|
local dev_speed
|
||||||
|
dev_speed=$(get_dev_speed $DEV)
|
||||||
local speed=$dev_speed
|
local speed=$dev_speed
|
||||||
if [ $net_speed != $dev_speed ]
|
if [ $net_speed != $dev_speed ]; then
|
||||||
then
|
|
||||||
log WARNING: $dev has a different operational speed [$dev_speed] \
|
log WARNING: $dev has a different operational speed [$dev_speed] \
|
||||||
than configured speed [$net_speed] for network type $networktype
|
than configured speed [$net_speed] for network type $networktype
|
||||||
if test_valid_speed $net_speed
|
if test_valid_speed $net_speed; then
|
||||||
then
|
|
||||||
# Use greater of configured net speed / recorded dev speed
|
# Use greater of configured net speed / recorded dev speed
|
||||||
if [ $net_speed -gt $dev_speed ]
|
if [ $net_speed -gt $dev_speed ]; then
|
||||||
then
|
|
||||||
speed=$net_speed
|
speed=$net_speed
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -433,8 +473,7 @@ fi
|
|||||||
|
|
||||||
log running tc setup script for $DEV $NETWORKTYPE in background
|
log running tc setup script for $DEV $NETWORKTYPE in background
|
||||||
|
|
||||||
if [ -f /etc/platform/platform.conf ]
|
if [ -f /etc/platform/platform.conf ]; then
|
||||||
then
|
|
||||||
source /etc/platform/platform.conf
|
source /etc/platform/platform.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -453,11 +492,16 @@ AC="tc class add dev $DEV parent 1:1 classid"
|
|||||||
TCP=6
|
TCP=6
|
||||||
UDP=17
|
UDP=17
|
||||||
|
|
||||||
|
# default ethertype for filters
|
||||||
|
DEFAULT_ETHERTYPE=ip
|
||||||
|
|
||||||
|
# default priority for filters
|
||||||
|
DEFAULT_PRIORITY=1
|
||||||
|
|
||||||
# delete existing qdiscs
|
# delete existing qdiscs
|
||||||
tc qdisc del dev $DEV root > /dev/null 2>&1
|
tc qdisc del dev $DEV root > /dev/null 2>&1
|
||||||
|
|
||||||
if [ ${NETWORKTYPE} = "mgmt" ]
|
if [ ${NETWORKTYPE} = "mgmt" ]; then
|
||||||
then
|
|
||||||
if infra_exists
|
if infra_exists
|
||||||
then
|
then
|
||||||
setup_mgmt_tc_infra_exists
|
setup_mgmt_tc_infra_exists
|
||||||
|
Loading…
Reference in New Issue
Block a user