Disable TCP-Offloading {completely, generically and easily}
I want to disable tcp-offloading ("TOE") on my debian servers.
ethtool -K .....
I have some wishes, though:
Integrate it cleanly into debian
This reads: no rc.local, I would also like to avoid pseudo-rc-scripting...
I would guess, it's installing ethtool and using the pre-up.d/-Hook which deconfigures TOE using options from /etc/network/interfaces.
I would like to deconfigure all my (future) servers in a generic fashion using FAI. (since fai is already in place - and wanted!) What about toe-options that are not supported on some hardware? Will networking fail if a non-existing-option should be disabled? I guess it should be robust not to do so, but this does not seem to be my wanted solution, either.
It clutters the config very much, since atm there are 11 options! Using multiple NICs this smells error-prone to me.
Isn't there a more generic solution? I have a sysctl in mind, but did not find one yet. My wish was:
echo 0 > /proc/sys/net/core/enable_tcp_offloading
PS: I'm quite surprised to find my "newer hardwares" to have TOE enabled by default, because of this: http://www.linuxfoundation.org/collaborate/workgroups/networking/toe
On Debian, the ethtool
package now provides an if-up.d
script that implements options for offloading (and other ethtool
settings).
You just have to install this package and add lines like these to the interface in/etc/network/interfaces
.
auto eth0
iface eth0 inet static
address 10.0.3.1/255.255.248.0
gateway 10.0.2.10
offload-tx off
offload-sg off
offload-tso off
Eureka! Found "my" solution!
I'm simply placing my own disable-toe Script in /etc/network/if-up.d/ which disables tcp-offloading completely.
As bonus I've added an /etc/network/interfaces-Option, that disables this.
#!/bin/bash
RUN=true
case "${IF_NO_TOE,,}" in
no|off|false|disable|disabled)
RUN=false
;;
esac
if [ "$MODE" = start -a "$RUN" = true ]; then
TOE_OPTIONS="rx tx sg tso ufo gso gro lro rxvlan txvlan rxhash"
for TOE_OPTION in $TOE_OPTIONS; do
/sbin/ethtool --offload "$IFACE" "$TOE_OPTION" off &>/dev/null || true
done
fi
Off topic (sort of) but I ended up here when trying to figure out how to do the same thing for some RHEL6 servers. So if anyone is looking for the same thing for RHEL/CentOS/Fedora like distributions, you'll find the answer here.