make pppoe work automatically
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sat, 26 Mar 2005 01:14:33 +0000 (01:14 +0000)
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Sat, 26 Mar 2005 01:14:33 +0000 (01:14 +0000)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk/openwrt@459 3c298f89-4303-0410-b956-a3cf2f4a3e73

package/ppp/Makefile
package/ppp/control/ppp-pppoe-plugin.control
package/ppp/ipkg/ppp-pppoe-plugin/etc/init.d/S50pppoe [new file with mode: 0755]
target/default/target_skeleton/sbin/ifup

index f929f00..dd1dbd2 100644 (file)
@@ -95,6 +95,8 @@ $(PKG_PPP): $(PKG_BUILD_DIR)/pppd/pppd
        mkdir -p $(I_PPP)
        cp -af ./ipkg/ppp/* $(I_PPP)
        $(SCRIPT_DIR)/make-ipkg-dir.sh $(I_PPP) control/ppp.control $(PKG_VERSION)-$(PKG_RELEASE) $(ARCH) 
+       mkdir -p $(I_PPP)/etc/ppp
+       ln -s /tmp/resolv.conf $(I_PPP)/etc/ppp/resolv.conf
        mkdir -p $(I_PPP)/usr/sbin
        cp -af $(PKG_BUILD_DIR)/pppd/pppd $(I_PPP)/usr/sbin/
        $(STRIP) $(I_PPP)/usr/sbin/*
@@ -113,6 +115,7 @@ $(IPKG_STATE_DIR)/info/ppp.list: $(PKG_PPP)
 
 $(PKG_PPP_PPPOE_PLUGIN): $(PKG_PPP)
        $(SCRIPT_DIR)/make-ipkg-dir.sh $(I_PPP_PPPOE_PLUGIN) control/ppp-pppoe-plugin.control $(PKG_VERSION)-$(PKG_RELEASE) $(ARCH)
+       cp -af ./ipkg/ppp-pppoe-plugin/* $(I_PPP_PPPOE_PLUGIN)
        mkdir -p $(I_PPP_PPPOE_PLUGIN)/usr/lib/pppd/rp-pppoe
        cp -af $(PKG_BUILD_DIR)/pppd/plugins/rp-pppoe/rp-pppoe.so \
                $(I_PPP_PPPOE_PLUGIN)/usr/lib/pppd/rp-pppoe
index 33e6a32..8bbd861 100644 (file)
@@ -6,4 +6,4 @@ Architecture: mipsel
 Maintainer: Felix Fietkau <nbd@vd-s.ath.cx>
 Source: buildroot internal
 Description: a PPPoE (PPP over Ethernet) plugin for PPP
-Depends: ppp
+Depends: ppp, kmod-pppoe
diff --git a/package/ppp/ipkg/ppp-pppoe-plugin/etc/init.d/S50pppoe b/package/ppp/ipkg/ppp-pppoe-plugin/etc/init.d/S50pppoe
new file mode 100755 (executable)
index 0000000..52e1d79
--- /dev/null
@@ -0,0 +1,23 @@
+#!/bin/sh
+
+. /etc/functions.sh
+
+WAN_PROTO=$(nvram get wan_proto)
+[ "$WAN_PROTO" = "pppoe" ] || exit 0
+
+for module in slhc ppp_generic pppox pppoe; do
+       insmod $module 2>/dev/null >/dev/null
+done
+
+IFNAME=$(nvram get pppoe_ifname)
+USERNAME=$(nvram get ppp_username)
+PASSWORD=$(nvram get ppp_passwd)
+REDIAL=$(nvram get ppp_redialperiod)
+REDIAL=${REDIAL:+holdoff $REDIAL}
+IDLETIME=$(nvram get ppp_idletime)
+IDLETIME=${IDLETIME:+idle $IDLETIME}
+MTU=$(nvram get ppp_mtu)
+
+ifconfig $IFNAME up
+echo -e "plugin /usr/lib/pppd/rp-pppoe/rp-pppoe.so\nconnect /bin/true\nusepeerdns\ndefaultroute\nuser \"$USERNAME\"\npassword \"$PASSWORD\"\nmtu $MTU\n$IDLETIME\n$REDIAL" > /tmp/.pppoe-data
+/usr/sbin/pppd file /tmp/.pppoe-data $IFNAME
index 6b4a774..f8e41ce 100755 (executable)
       idletime=$(nvram get ppp_idletime)
       mtu=$(nvram get wan_mtu)
 
-      $DEBUG ifconfig $if 0.0.0.0 up
+#      handled by /etc/init.d/S50pppoe
+#      $DEBUG ifconfig $if 0.0.0.0 up
 
-      $DEBUG /sbin/pppoecd $if -u $username -p $password \
-        -i 0 -I $redial -T $idletime -t $mtu -k
+#      $DEBUG /sbin/pppoecd $if -u $username -p $password \
+#        -i 0 -I $redial -T $idletime -t $mtu -k
     ;;
     none)
     ;;