make pppoe work automatically
authorFelix Fietkau <nbd@openwrt.org>
Sat, 26 Mar 2005 01:14:33 +0000 (01:14 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Sat, 26 Mar 2005 01:14:33 +0000 (01:14 +0000)
SVN-Revision: 459

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

index f929f00f74c921ef3711e7a6559ad7e7814ccf9e..dd1dbd220bb189d031c0f8d9b64d536a26653965 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 33e6a321991e040a151a62c86055b95b7a123136..8bbd8610f122a1c9ffbbfbd2ac9d9d9de055bcd8 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/openwrt/package/ppp/ipkg/ppp-pppoe-plugin/etc/init.d/S50pppoe b/openwrt/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 6b4a7740be4e689690880f3898c9498461cd6c78..f8e41ce8ce28943a6243f058af08ff6cc7578dd7 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)
     ;;