fix ifname in network state for pppoe and pptp, add a workaround for isps sending...
authorFelix Fietkau <nbd@openwrt.org>
Thu, 30 Aug 2007 16:53:22 +0000 (16:53 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Thu, 30 Aug 2007 16:53:22 +0000 (16:53 +0000)
SVN-Revision: 8552

package/ppp/files/pppoe.sh
package/pptp/files/pptp.sh

index 86bdddd..ba6a876 100644 (file)
@@ -12,6 +12,11 @@ setup_interface_pppoe() {
                /sbin/insmod $module 2>&- >&-
        done
 
+       # make sure the network state references the correct ifname
+       scan_ppp "$config"
+       config_get ifname "$config" ifname
+       uci set "/var/state/network.$config.ifname=$ifname"
+
        config_get mtu "$cfg" mtu
        mtu=${mtu:-1492}
        start_pppd "$config" \
index 4d03af0..f1c46c9 100644 (file)
@@ -3,8 +3,8 @@ scan_pptp() {
 }
 
 setup_interface_pptp() {
-       local iface="$1"
        local config="$2"
+       local ifname
        
        config_get device "$config" device
        config_get ipproto "$config" ipproto
@@ -12,7 +12,18 @@ setup_interface_pptp() {
        for module in slhc ppp_generic ppp_async ip_gre; do
                /sbin/insmod $module 2>&- >&-
        done
-       setup_interface "$iface" "$config" "${ipproto:-dhcp}"
+       sleep 1
+
+       setup_interface "$device" "$config" "${ipproto:-dhcp}"
+
+       # fix up the netmask
+       config_get netmask "$config" netmask
+       [ -z "$netmask" -o -z "$device" ] || ifconfig $device netmask $netmask
+
+       # make sure the network state references the correct ifname
+       scan_ppp "$config"
+       config_get ifname "$config" ifname
+       uci set "/var/state/network.$config.ifname=$ifname"
 
        config_get mtu "$cfg" mtu
        config_get server "$cfg" server