X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/85fa7a0ac5527d54fe742e5df002d11d3a83699a..eb4ff95812295c9ae621f46b9acad57aa0d8cfc9:/package/ppp/files/ifup.pppoa diff --git a/package/ppp/files/ifup.pppoa b/package/ppp/files/ifup.pppoa index ee88e4b9e..5f42a39d0 100644 --- a/package/ppp/files/ifup.pppoa +++ b/package/ppp/files/ifup.pppoa @@ -10,36 +10,40 @@ type=$1 exit } -for module in slhc ppp_generic pppox pppoatm; do +for module in slhc ppp_generic pppoatm; do /sbin/insmod $module 2>&- >&- done while :; do - VPI=$(nvram get atm_vpi) - VCI=$(nvram get atm_vci) - USERNAME=$(nvram get ppp_username) - PASSWORD=$(nvram get ppp_passwd) - REDIAL=$(nvram get ppp_redialperiod) - REDIAL=${REDIAL:+lcp-echo-interval $REDIAL} - IDLETIME=$(nvram get ppp_idletime) - IDLETIME=${IDLETIME:+lcp-echo-failure $IDLETIME} - MTU=$(nvram get ppp_mtu) - MTU=${MTU:-1492} - MTU=${MTU:+ mtu $MTU mru $MTU} + VPI=$(nvram get atm_vpi) + VCI=$(nvram get atm_vci) + USERNAME=$(nvram get ppp_username) + PASSWORD=$(nvram get ppp_passwd) + KEEPALIVE=$(nvram get ppp_redialperiod) + KEEPALIVE=${KEEPALIVE:+lcp-echo-interval 10 lcp-echo-failure $KEEPALIVE} + DEMAND=$(nvram get ppp_demand) + case "$DEMAND" in + on|1|enabled) + DEMAND=$(nvram get ppp_idletime) + DEMAND=${IDLETIME:+demand idle $IDLETIME} + ;; + *) DEMAND="";; + esac + MTU=$(nvram get ppp_mtu) + MTU=${MTU:-1500} - ifconfig $IFNAME up - /usr/sbin/pppd nodetach \ + /usr/sbin/pppd nodetach \ plugin pppoatm.so ${VPI:-8}.${VCI:-35} \ - connect /bin/true \ - usepeerdns \ - defaultroute \ - linkname $type \ - user "$USERNAME" \ - password "$PASSWORD" \ - $MTU \ - $IDLETIME \ - $REDIAL - - # Read settings again (might have changed) - [ -e /etc/config/network ] && . /etc/config/network + usepeerdns \ + defaultroute \ + linkname $type \ + ipparam $type \ + user "$USERNAME" \ + password "$PASSWORD" \ + mtu $MTU mru $MTU \ + $DEMAND \ + $KEEPALIVE + + # Read settings again (might have changed) + [ -e /etc/config/network ] && . /etc/config/network done &