#!/bin/sh # rc.pcmcia 1.30 1999/10/25 18:17:36 (David Hinds) # # This is designed to work in BSD as well as SysV init setups. See # the HOWTO for customization instructions. # Tags for Red Hat init configuration tools # # chkconfig: 2345 45 96 # processname: cardmgr # pidfile: /var/run/cardmgr.pid # config: /etc/pcmcia/config # config: /etc/pcmcia/config.opts # description: PCMCIA support is usually to support things like ethernet \ # and modems in laptops. It won't get started unless \ # configured so it is safe to have it installed on machines \ # that don't need it. # Allow environment variables to override all options if [ "$PCMCIA" ] ; then readonly PCMCIA ; fi if [ "$PCIC" ] ; then readonly PCIC ; fi if [ "$PCIC_OPTS" ] ; then readonly PCIC_OPTS ; fi if [ "$CORE_OPTS" ] ; then readonly CORE_OPTS ; fi if [ "$CARDMGR_OPTS" ] ; then readonly CARDMGR_OPTS ; fi if [ "$SCHEME" ] ; then readonly SCHEME ; fi # Source PCMCIA configuration, if available if [ -f /etc/pcmcia.conf ] ; then # Debian startup option file . /etc/pcmcia.conf elif [ -f /etc/sysconfig/pcmcia ] ; then # Red Hat startup option file . /etc/sysconfig/pcmcia else # Slackware startup options go right here # Should be either i82365 or tcic PCIC=i82365 # Put socket driver timing parameters here PCIC_OPTS="irq_list=10,11,15 poll_interval=150" # Put pcmcia_core options here CORE_OPTS= # Put cardmgr options here CARDMGR_OPTS= # To set the PCMCIA scheme at startup... SCHEME= fi if [ "$PCMCIA" -a "$PCMCIA" != "yes" ] ; then exit 0 ; fi usage() { echo "Usage: $0 {start|stop|status|restart|reload}" } cleanup() { while read SN CLASS MOD INST DEV EXTRA ; do if [ "$SN" != "Socket" ] ; then /etc/pcmcia/$CLASS stop $DEV 2> /dev/null fi done } EXITCODE=1 for x in "1" ; do if [ "$PCIC" = "" ] ; then echo "PCIC not defined in rc.pcmcia!" break fi if [ $# -lt 1 ] ; then usage ; break ; fi action=$1 case "$action" in start) echo -n "Starting PCMCIA services:" if [ -d /var/state/pcmcia ] ; then SC=/var/state/pcmcia/scheme STAB=/var/state/pcmcia/stab elif [ -d /var/lib/pcmcia ] ; then SC=/var/lib/pcmcia/scheme STAB=/var/lib/pcmcia/stab else SC=/var/run/pcmcia-scheme STAB=/var/run/stab fi if [ -L $SC -o ! -O $SC ] ; then rm -f $SC ; fi if [ ! -f $SC ] ; then umask 022 ; touch $SC ; fi if [ "$SCHEME" ] ; then umask 022 ; echo $SCHEME > $SC ; fi fgrep -q pcmcia /proc/devices if [ $? -ne 0 ] ; then if [ -d /lib/modules/preferred ] ; then PC=/lib/modules/preferred/pcmcia else PC=/lib/modules/`uname -r`/pcmcia fi if [ -d $PC ] ; then echo -n " modules" /sbin/insmod $PC/pcmcia_core.o $CORE_OPTS /sbin/insmod $PC/$PCIC.o $PCIC_OPTS /sbin/insmod $PC/ds.o else echo " module directory $PC not found." break fi fi if [ -s /var/run/cardmgr.pid ] && \ kill -0 `cat /var/run/cardmgr.pid` 2>/dev/null ; then echo " cardmgr is already running." else if [ -r $STAB ] ; then cat $STAB | cleanup fi echo " cardmgr." /sbin/cardmgr $CARDMGR_OPTS fi if [ -d /var/lock/subsys ] ; then touch /var/lock/subsys/pcmcia fi ;; stop) echo -n "Shutting down PCMCIA services:" PID=`cat /var/run/cardmgr.pid` kill $PID echo -n " cardmgr" # Give cardmgr a few seconds to handle the signal kill -0 $PID 2>/dev/null && sleep 2 && \ kill -0 $PID 2>/dev/null && sleep 2 && \ kill -0 $PID 2>/dev/null && sleep 2 && \ kill -0 $PID 2>/dev/null if fgrep -q "ds " /proc/modules ; then echo -n " modules" /sbin/rmmod ds /sbin/rmmod $PCIC /sbin/rmmod pcmcia_core fi echo "." rm -f /var/lock/subsys/pcmcia EXITCODE=0 ;; status) pid=`pidof cardmgr` if [ "$pid" != "" ] ; then echo "cardmgr (pid $pid) is running..." EXITCODE=0 else echo "cardmgr is stopped" EXITCODE=3 fi ;; restart|reload) $0 stop $0 start EXITCODE=$? ;; *) usage ;; esac done # Only exit if we're in our own subshell if [ "${0##*/}" = "rc.pcmcia" ] ; then exit $EXITCODE fi