From: Gerd von Egidy Date: Thu, 5 Mar 2015 11:07:57 +0000 (+0100) Subject: Add support for ethernet point-to-point connections configured via DHCP X-Git-Tag: 042~22^2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=refs%2Fpull%2F51%2Fhead;p=thirdparty%2Fdracut.git Add support for ethernet point-to-point connections configured via DHCP When current dracut receives an ip with netmask of 255.255.255.255 via DHCP, setting the also supplied default gateway fails (because it is obviously not within the netmask). The setup with a netmask of /32 is quite common in colocation datacenters where you don't want the machines of two different customers to directly talk to each other. At least two of the biggest colocation providers in Germany (1&1 and Strato) do it that way. NetworkManager supports this kind of setup and the dhclient-scripts of several distributions too. In this patch I have implemented a simple approach very similar to what is found in Debian. The dhclient-script from Fedora uses a more sophisticated approach, but that relies on the ipcalc utility which would introduce a dependency on Fedora-initscripts for dracut. Signed-off-by: Gerd von Egidy --- diff --git a/modules.d/40network/dhclient-script.sh b/modules.d/40network/dhclient-script.sh index 50f1985b5..98352ec7c 100755 --- a/modules.d/40network/dhclient-script.sh +++ b/modules.d/40network/dhclient-script.sh @@ -43,7 +43,13 @@ setup_interface() { valid_lft ${lease_time} preferred_lft ${lease_time} \ dev $netif - [ -n "$gw" ] && echo ip route replace default via $gw dev $netif > /tmp/net.$netif.gw + if [ -n "$gw" ] ; then + if [ "$mask" == "255.255.255.255" ] ; then + # point-to-point connection => set explicit route to gateway + echo ip route add $gw dev $netif > /tmp/net.$netif.gw + fi + echo ip route replace default via $gw dev $netif >> /tmp/net.$netif.gw + fi [ -n "${search}${domain}" ] && echo "search $search $domain" > /tmp/net.$netif.resolv.conf if [ -n "$namesrv" ] ; then