Running stock RH5.2, kernel 2.2.2, using the script provided to get a
ppp connection going using a standard 28.8 modem . . . it will take
anywhere from 5 sec to 45 sec for the dialing to start after you execute
the script . . .  command line is:

. /etc/sysconfig/network-scripts/ifup-ppp daemon ifcfg-ppp0 &

pppd comes up right away w/options, but chat takes a long time to start
. . .

attached are ifup-ppp, ifcfg-ppp0, chat-ppp0

anyone know where the delay is coming from?  thanks :-)

jacko
DEVICE="ppp0"
ONBOOT="no"
USERCTL="no"
MODEMPORT="/dev/ttyS1"
LINESPEED="115200"
PERSIST="no"
DEFABORT="yes"
DEBUG="yes"
INITSTRING="ATZ"
DEFROUTE="yes"
HARDFLOWCTL="yes"
ESCAPECHARS="no"
PPPOPTIONS=""
PAPNAME=""
REMIP=""
NETMASK=""
IPADDR=""
MRU=""
MTU=""
DISCONNECTTIMEOUT=""
RETRYTIMEOUT="5"
BOOTPROTO="none"
#!/bin/sh
PATH=/sbin:/usr/sbin:/bin:/usr/bin

# ifup-post for PPP is handled through /etc/ppp/ip-up

if [ "$1" != daemon ] ; then
  # disconnect stdin, out, err to disassociate from controlling tty
  # so that no HUPs will get through.
  $0 daemon $*& </dev/null >/dev/null 2>/dev/null
  exit 0
fi
shift

cd /etc/sysconfig/network-scripts
. network-functions

CONFIG=$1
source_config

if [ -z "$DISCONNECTTIMEOUT" ]; then
  DISCONNECTTIMEOUT=2
fi

if [ -z "$RETRYTIMEOUT" ]; then
  RETRYTIMEOUT=5
fi

if [ "$2" = "boot" -a "${ONBOOT}" = "no" ]; then
  exit
fi

[ -x /usr/sbin/pppd ] || {
  echo "/usr/sbin/pppd does not exist or is not executable"
  echo "ifup-ppp for $DEVICE exiting"
  logger -p daemon.info -t ifup-ppp \
    "/usr/sbin/pppd does not exist or is not executable for $DEVICE"
  exit 1
}

[ -f /etc/sysconfig/network-scripts/chat-$DEVICE ] || {
  echo "/etc/sysconfig/network-scripts/chat-$DEVICE does not exist"
  echo "ifup-ppp for $DEVICE exiting"
  logger -p daemon.info -t ifup-ppp \
    "/etc/sysconfig/network-scripts/chat-$DEVICE does not exist for $DEVICE"
  exit 1
}

opts="lock"
if [ "${HARDFLOWCTL}" = yes ] ; then
  opts="$opts modem crtscts"
fi
if [ "${ESCAPECHARS}" = yes ] ; then
  opts="$opts asyncmap FFFFFFFF"
fi
if [ "${DEFROUTE}" = yes ] ; then
  opts="$opts defaultroute"
fi
if [ -n "${MRU}" ] ; then
  opts="$opts mru ${MRU}"
fi
if [ -n "${MTU}" ] ; then
  opts="$opts mtu ${MTU}"
fi
if [ -n "${IPADDR}${REMIP}" ] ; then
  # if either IP address is set, the following will work.
  opts="$opts ${IPADDR}:${REMIP}"
fi
if [ -n "${PAPNAME}" ] ; then
  opts="$opts name ${PAPNAME}"
fi
if [ "${DEBUG}" = yes ] ; then
  opts="$opts debug"
  chatdbg="-v"
fi

CHATSCRIPT=/etc/sysconfig/network-scripts/chat-$DEVNAME
[ -f $CHATSCRIPT ] || {
  CHATSCRIPT=/etc/sysconfig/network-scripts/chat-$PARENTDEVNAME
}

while : ; do
  (logger -p daemon.info -t ifup-ppp \
    "pppd started for $DEVICE on $MODEMPORT at $LINESPEED" &)&

  > /var/run/ppp-$DEVICE.dev
  /usr/sbin/pppd -detach $opts $MODEMPORT $LINESPEED \
    remotename $DEVICE ipparam $DEVICE \
    ${PPPOPTIONS} \
    connect "/usr/sbin/chat $chatdbg -f $CHATSCRIPT"

  # exit if we're not supposed to persist or our lock file has disappeared 
  if [ "$PERSIST" != "yes" -o ! -f /var/run/ppp-$DEVICE.dev ]; then
    rm -f /var/run/ppp-$DEVICE.dev
    exit 0
  fi

  size=`wc -c < /var/run/ppp-$DEVICE.dev`

  if [ $size = 0 ]; then
    # pppd never connected
    timeout=$RETRYTIMEOUT
  else
    # pppd connected and then disconnected
    timeout=$DISCONNECTTIMEOUT
  fi

#comments by jacko
#  [ -z "$timeout" ] && {
#    timeout=30
#  }

  sleep $timeout || {
    # sleep was killed
    rm -f /var/run/ppp-$DEVICE.dev
    exit 0
  }

  # exit if our lock file disappeared while we slept
  if [ ! -f /var/run/ppp-$DEVICE.dev ]; then
    exit 0
  fi
done


# logging ifup-ppp exit by jacko
logger -p daemon.info -t ifup-ppp "ifup-ppp exiting script"
'' 'ATZ'
'OK' 'ATDT6471000'
'CONNECT' ''
'ogin:' 'XXXXXXXXXXXXXXXXX'
'ord:' 'XXXXXXXXXXXXXXXXX'
'TIMEOUT' '5'
'~--' ''

Reply via email to