#! /bin/sh # # /usr/share/dahdi/dahdi_handle_device # # Called by UDEV when a dahdi device is added/removed # me=`basename $0` dir=`dirname $0` LOGGER="logger -i -t '$me'" NAME=`basename "$DEVPATH" | tr -c 'A-Za-z0-9-' '_'` # Always redirect stderr somewhere, otherwise the shell script will die # when it tries to do I/O related stuff on closed file descriptor. # Our default is to throw it down the bit-bucket. exec 2> /dev/null # If you wish to trace this script: #exec 2> "/tmp/${me}.$NAME" 1>&2 #exec 2> /dev/console # Our directory in the beginning, so we can use local lab setup PATH="$dir:/usr/sbin:/sbin:/usr/bin:/bin" export PATH set -e #echo >&2 "$0($ACTION): DEBUG($# args): '$*'" # Do we have a configuration? if [ -f /etc/dahdi/init.conf ]; then . /etc/dahdi/init.conf fi if [ "$DAHDI_UDEV_DISABLE_DEVICES" = 'yes' ]; then echo "DAHDI_UDEV_DISABLE_DEVICES=yes. Skip $DEVPATH" | $LOGGER exit 0 fi # Can we pass a different value so we can use # alternate (testing) configuration? # Meanwhile, make it hard-coded. DAHDICONFDIR='/etc/dahdi' export DAHDICONFDIR run_parts() { # Have our internal "run-parts" (adapted from Fedora), # as implementations differ for i in `LC_ALL=C; ls -d $dir/handle_device.d/*[!~,] 2>/dev/null` ; do [ -d "$i" ] && continue [ ! -x "$i" ] && continue # Don't run *.{rpmsave,rpmorig,rpmnew,swp,cfsaved} files case "$i" in *.cfsaved|*.rpmsave|*.rpmorig|*.rpmnew|*.swp|*,v) continue ;; esac echo "D: Running '$i'" "$i" done } case "$ACTION" in add) echo "$ACTION: $DEVPATH" | $LOGGER # Check if we can safely do our job if [ ! -f /sys/module/dahdi/parameters/auto_assign_spans ]; then echo "Old driver (no auto_assign_spans parameter). Skip $DEVPATH" | $LOGGER exit 0 fi if [ `cat /sys/module/dahdi/parameters/auto_assign_spans` -ne 0 ]; then echo "auto_assign_spans=1. Skip $DEVPATH" | $LOGGER exit 0 fi # Background run -- don't block udev run_parts 2>&1 < /dev/null | $LOGGER & ;; remove) echo "$ACTION: $DEVPATH" | $LOGGER # Background run -- don't block udev run_parts 2>&1 < /dev/null | $LOGGER & ;; *) echo "UNHANDLED: $ACTION: $DEVPATH" | $LOGGER ;; esac