[svn-commits] tzafrir: branch 1.2 r2275 - /branches/1.2/zaptel.init
    svn-commits at lists.digium.com 
    svn-commits at lists.digium.com
       
    Fri Mar  2 15:25:02 MST 2007
    
    
  
Author: tzafrir
Date: Fri Mar  2 16:25:01 2007
New Revision: 2275
URL: http://svn.digium.com/view/zaptel?view=rev&rev=2275
Log:
Proper initialization of the Astribank (xpp) at zaptel startup.
Modified:
    branches/1.2/zaptel.init
Modified: branches/1.2/zaptel.init
URL: http://svn.digium.com/view/zaptel/branches/1.2/zaptel.init?view=diff&rev=2275&r1=2274&r2=2275
==============================================================================
--- branches/1.2/zaptel.init (original)
+++ branches/1.2/zaptel.init Fri Mar  2 16:25:01 2007
@@ -42,6 +42,72 @@
 for x in $MODULES; do 
     RMODULES="$x $RMODULES"
 done
+
+# Wait for Astribank to initialize registers:
+wait_for_xpp() {
+	if [ -d /proc/xpp ]
+	then
+		# reading from waitfor_xpds only returns when the device
+		# has finished initilizing its regiters and is available.
+		cat /proc/xpp/XBUS-*/waitfor_xpds 2>/dev/null >/dev/null  || true
+	fi
+}
+
+# Register to zaptel Astribank spans that were not autoomatically registered
+# (useful when you have more than one Astribank)
+zap_reg_xpp() {
+	if [ ! -d /proc/xpp ]; then return; fi
+	
+	# Get a list of connected Astribank devices, sorted by the name of 
+	# the USB connector. That order is rather arbitrary, but will not 
+	# change without changes to the cabling.
+	xbusses=`sort -k 2 /proc/xpp/xbuses | awk -F: '/STATUS=connected/ {print $1}'`
+
+	# get a list of XPDs that were not yet registered as zaptel spans.
+	# this will be the case if you set the parameter zap_autoreg=0 to
+	# the module xpp
+	# Append /dev/null to provide a valid file name in case of an empty pattern.
+	xbusses_pattern=`echo $xbusses| sed -e 's|XBUS-[0-9]*|/proc/xpp/&/XPD-*/zt_registration|g'`' /dev/null'
+	xpds_to_register=`grep -l 0 $xbusses_pattern 2>/dev/null` || true
+	for file in $xpds_to_register; do
+		echo 1 >$file
+	done
+}
+
+# If the system has an Astribank, select the right one as the sync source.
+# TODO: replace the sryptic awk code with 'xpp_sync auto' once it is in.
+fix_asterisbank_sync() {
+	# do nothing if module not present
+	if [ ! -d /proc/xpp ]; then return; fi
+	
+	#if ! grep -q '^HOST' /proc/xpp/sync 2>/dev/null; then return; fi
+
+	case "$XPP_SYNC" in
+	n*|N*) return;;
+	host|HOST) sync_value="HOST";;
+	[0-9]*)sync_value="$XPP_SYNC";;
+	*) 
+		# find the number of the first bus, and sync from it:
+		fxo_pat=`awk -F: '/STATUS=connected/{print $1}' /proc/xpp/xbuses | sed -e 's|.*|/proc/xpp/&/*/fxo_info|'`
+		# find the first FXO unit, and set it as the sync master
+		bus=`ls -1 $fxo_pat 2> /dev/null | head -n1 | cut -d- -f2 | cut -d/ -f1` 
+		
+		if [ "$bus" = '' ]; then
+			# no device with FXO found. Just get the first one
+			bus=`awk -F: '/STATUS=connected/{print $1}' /proc/xpp/xbuses | head -n 1 | cut -d- -f2`
+		fi
+
+		# do nothing if there is no bus:
+		case "$bus" in [0-9]*):;; *) return;; esac
+		sync_value="SYNC=$bus"
+		;;
+	esac
+	# the built-in echo of bash fails to print a proper error on failure
+	if ! /bin/echo "$sync_value" >/proc/xpp/sync
+	then 
+		echo >&2 "Updating XPP sync source failed (tried \"$sync_value\", XPP_SYNC='$XPP_SYNC')"
+	fi
+}
 
 # Check that telephony is up.
 [ "${TELEPHONY}" = "yes" ] || exit 0
@@ -87,7 +153,12 @@
 			echo -n " $x"
 		fi
 	done
-	sleep 3
+	sleep 3 # TODO: remove it
+	
+	wait_for_xpp
+	zap_reg_xpp
+	fix_asterisbank_sync # can actually be run after ztcfg
+	
 	if [ ! -e /proc/zaptel/1 ]; then
 		echo "No functioning zap hardware found in /proc/zaptel, loading ztdummy"
 		modprobe ztdummy >& /dev/null
    
    
More information about the svn-commits
mailing list