make -C xpp/utils install
This file documents the Zaptel drivers for the Xorcom Channel Bank. The drivers reside in a separate subdirectory, kernel/xpp/ .
It is generally a more technical document than the Astribank User Manual
An HTML version of the latest version of this document could be found at http://docs.tzafrir.org.il/README.Astribank.html
The Xorcom Astribank is a USB-connected channel-bank. An Astribank may have up to 4 modules:
1, 2 or 4 ports of E1 or T1. Can only be the first (left-most) module of the Astribank. Note that each port has physically a pair of ports, where the top one has crossed wiring.
2, 4 or 8 ports of BRI. Can only be used as the first (left-most) module of the Astribank.
8 ports of FXO (connector to an analog PSTN line).
8 ports of FXS (connector to an analog phone). If used as the first (left-most) module, it will also have 2 output lines and 4 input lines that will appear on Zaptel like standard Zaptel ports. The input and output ports are connected from the two RJ-45 connectors on the right side of the module.
There is also a 6FXS-2FXO module that is essentially an FXS module with six lines instead of 8 (but still with the input and output ports) and an FXO module of two ports.
Apart from the standard Zaptel build requirements, you also need libusb development headers to build the fpga_load firmware loader. This is typically the package libusb-dev on Debian (and derivatives like Ubuntu) or libusb-devel on RedHat (and derivatives like CentOS/Trixbox).
On Zaptel 1.2 you will need to run the following extra step to build the user space utilities, apart from the standard make; make install:
make -C xpp/utils install
(In latest SVN version of Zaptel this patch is no longer needed. Furthermore, it does not apply. The same directory has a newer patch that applies. This section is kept in the document for the time being for the benefit of those with older versions)
In order for the BRI module (xpd_bri.ko) to build, you still need an external patch:
You need to apply it to the zaptel tarball before building:
wget http://updates.xorcom.com/astribank/bristuff/1.4/bristuff-current/patches/zaptel/bri_dchan patch -p1 <http://updates.xorcom.com/astribank/bristuff/1.4/bristuff-current/patches/zaptel/bri_dchan
Note, however, that you would still need a bristuffed Asterisk. Therefore chances are that you will still need the full BriSTUFF distribution from http://updates.xorcom.com/astribank/bristuff/1.4 .
Below are some commented sequences of commands that can be used at some common scenarios. Those scenarios begin only after you installed the software (zaptel, asterisk, etc.).
Installing Astribank on a system where there's no existing Astribank. You install the driver when the Astribank was already connected:
# If you had the hardware already connected: Load just the USB firmware /usr/share/zaptel/xpp_fxloader usb # (you could use 'load' instead of 'usb' but this is also a good test # that automatic load through firmware is also in place) zaptel_hardware -v # wait until the Astribank has a product ID of 11x2 sleep 5 # Just wait a little bit zaptel_hardware -v # now that you see that all's well: /etc/init.d/zaptel start # generate configuration: zapconf # Apply it: ztcfg # edit /etc/asterisk/zapata.conf to #include zaptel-channels.conf or # copy its content to the end of zapata.conf # # This stops existing Zaptel calls, if any, but does no other harm: asterisk -rx 'zap restart'
Upgrading is roughly the same as a new installation. But in many cases you begin with resetting the firmware.
I also assume here that the configuration is valid, and hence I don't generate it.
Also be sure to use latest /etc/init.d/zaptel from zaptel.init in the source tree. Specifically one that uses the script /usr/share/zaptel/waitfor_xpds rather than directly looking at waitfor_xpds under /proc which no longer works.
# If you need to reset the firmware: /usr/share/zaptel/xpp_fxloader reset # (you could use 'load' instead of 'usb' but this is also a good test # that automatic load through firmware is also in place) zaptel_hardware -v # wait until the Astribank has a product ID of 11x2 sleep 5 # Just wait a little bit zaptel_hardware -v # now that you see that all's well: /etc/init.d/zaptel start # # This stops existing Zaptel calls, if any, but does no other harm: asterisk -rx 'zap restart'
We generally recommend to generate the configuration by using utility zapconf or genzaptelconf (obsolete and non-optimal) which are included with Zaptel. Nevertheless, the following can serve as reference configurations for a system where Astribank devices are used.
Also refer to the general README for documentation of the other Zaptel configuration files.
The zaptel init.d script, genzaptelconf and the XPD init scripts uses the parameters located in file /etc/default/zaptel (on Debian) or /etc/sysconfig/zaptel (on RedHats). There is a number of useful parameters that may be defined there:
# Lines beginning with '#' are considered comments and ignored. # xpp_sync runs with the value of 'XPP_SYNC' as its parameter to set the # synchronization source. The default is 'auto' that selects the best # Astribank. 'ZAPTEL' gets synchronization from the Zaptel sync master # span. Or a specific XBUS number. #XPP_SYNC=ZAPTEL # Disables hot-plug firmware loading #XPP_HOTPLUG_DISABLED=yes # # genzaptelconf also reads a number of extra parameters from here. Refer # to the script itself (/usr/sbin/genzaptelconf). However it is # generally recommended to use zapconf (which reads configuration from # /etc/genconf_parameters). # Disables udev hook called when an Astribank is added and ready # or removed. Though it is disabled by default with recent configuration # anyway. #ASTRIBANK_HOOK_DISABLED=yes
/etc/xpp.conf is read by the initialization scripts of Astribank modules:
# /etc/xpp.conf # # This file is used to configure the operation # of init_card_* initialization scripts. # # Adds many more tracing messages that are sent to syslog: #debug 1 # xpd_pri: E1 or T1. The default is E1 for all the ports. # Setting T1 instead: #pri_protocol T1 # # Or if you actually want to mix E1 and T1: #pri_protocol/xbus-00/xpd-02 T1 #pri_protocol/connector:usb-0000:00:1d.7-7/xpd-03 T1 #pri_protocol/label:usb:0000183/xpd-03 T1 # If several definitions can refer to a port, the last wins. # If none applies, the default of E1 holds. # FXO: country to adjust settings to: #opermode FRANCE # Don't run power calibration on the FXS units. This can save time # but can also get you unit randomly disconnect, if badly used: #fxs_skip_calib 1
(This feature is available in latest Zaptel SVN)
On a system with multiple Astribank you would normally want to guarantee that Astribanks are registered in the same order regardless of the order in which they are connected or detected. Assuming that you register them all at the same time. In order to do that, you should list the Astribanks explicitly under /etc/xpp_order .
Astribanks that are listed there are registered first (according to the order of lines in the files). Astribanks not listed there are added last, and sorted by the USB connector string.
You can identify an Astribank in two ways:
each Astribank (except some really old ones) has a label . This identifies the actual Astribank box.
Identify the path the Astribank is connected through. E.g.: to what USB port you connected it.
Identifying an Astribank by the label seems simpler and more predictable. Though it may have some slightly surprising effects if replace one Astribank with another.
The sample configuration file:
# # This is an optional configuration file for ordering # Zaptel registration. # # It is read from /etc/xpp_order. This location # may be overriden via the environment variable XPPORDER_CONF # # Lines may contain: # - The Astribank label (verbatim) # - The Astribank connector string (prefixed with @) # Ordering number of each listed Astribank is determined # by its position in this file. # Astribanks not listed in this file, get an ordering # number of 99 (last). # # Astribanks with same ordering number are sorted by their # connectors (to preserve legacy behaviour). # # Examples: #usb:1234 #@usb-0000:06:02.2-2
In order to generate one that includes all the Astribanks in the system with the current order in which they are connected, use:
zapconf xpporder
For more technical details see the section [_registering_in_zaptel] below.
fxoks=1-14
fxoks=1-12 fxsks=13-14
fxoks=1-14 fxsks=15-22
# Assumed ports settings: # Ports 1,3: TE # Ports 2,4: NT span=1,1,1,ccs,ami span=2,0,1,ccs,ami span=3,2,1,ccs,ami span=4,0,1,ccs,ami bchan=1-2,4-5,7-8,10-11 ; if you applied the bri_dchan patch: ;dchan=3,6,9,12 hardhdlc=3,6,9,12
# Assumed ports settings: # Ports 1,3: TE (CPE) # Ports 2,4: NT (Net) span=1,1,1,ccs,hdb3,crc4 span=2,0,1,ccs,hdb3,crc4 span=3,2,1,ccs,hdb3,crc4 span=4,0,1,ccs,hdb3,crc4 bchan=1-15,17-30,31-45,47-60,61-75,77-90,91-105,107-120 dchan=16,46,76,106
# Assumed ports settings: # Ports 1,3: TE (CPE) # Ports 2,4: NT (Net) span=1,1,1,esf,b8zs span=2,0,1,esf,b8zs span=3,2,1,esf,b8zs span=4,0,1,esf,b8zs bchan=1-23,25-47,49-71,73-95 dchan=24,48,72,96
[channels] signalling=fxo_ks ; The real analog ports: context=from-internal echocancel=yes ; echocancelwhenbriged=yes ; echotraining=no channel => 1-8
; output ports: context=astbank-output channel => 9-10 ; input ports: immediate=yes context=astbank-input channel => 11-14 immediate=no
[channels] signalling=fxo_ks ; The real analog ports: context=from-internal echocancel=yes ; echocancelwhenbriged=yes ; echotraining=no channel => 1-6
; output ports: context=astbank-output channel => 7-8 ; input ports: immediate=yes context=astbank-input channel => 9-12 immediate=no
; FXO ports signalling=fxs_ks context=from-pstn callerid=asreceived channel => 13-14
[channels] signalling=fxo_ks ; The real analog ports: context=from-internal echocancel=yes ; echocancelwhenbriged=yes ; echotraining=no channel => 1-8
; output ports: context=astbank-output channel => 9-10 ; input ports: immediate=yes context=astbank-input channel => 11-14 immediate=no
; FXO ports signalling=fxs_ks context=from-pstn callerid=asreceived channel => 15-22
; Assumed ports settings: ; Ports 1,3: TE ; Ports 2,4: NT [channels] switchtype = euroisdn callerid = asreceived
; TE ports: signalling = bri_cpe_ptmp ;signalling = bri_cpe context = from-pstn group = 1,11 channel => 1,2
group = 1,13 channel => 7,8
; NT ports: signalling = bri_net_ptmp ;signalling = bri_net context = from-internal group = 2,12 channel => 4,5
group = 2,14 channel => 10,11
; Assumed ports settings: ; Ports 1,3: TE ; Ports 2,4: NT [channels] switchtype = euroisdn callerid = asreceived
; TE ports: signalling = pri_cpe context = from-pstn group = 1,11 channel => 1-15,17-30
group = 1,13 channel => 61-75,77-90
; NT ports: signalling = pri_net ;signalling = pri_net context = from-internal group = 2,12 channel => 31-45,47-60
group = 2,14 channel => 91-105,107-120
; Assumed ports settings: ; Ports 1,3: TE ; Ports 2,4: NT [channels] switchtype = national callerid = asreceived
; TE ports: signalling = pri_cpe context = from-pstn group = 1,11 channel => 1-23
group = 1,13 channel => 49-71
; NT ports: signalling = pri_cpe ;signalling = pri_net context = from-internal group = 2,12 channel => 25-47
group = 2,14 channel => 73-95
Sample dialplan (extensions.conf) for all the above:
[phones-zap] ; 6001 will dial to channel 1, 6020, to Zaptel channel 20, etc. exten => _6XXX,1,Dial(Zap/${EXTEN:1}) ; Useful for debugging trunks. Will potentially allow users to ; bypass context limitations. ;exten => _6XXX.,1,Dial(Zap/${EXTEN:1:3}/${EXTEN:4}) [trunk] ; A number that begins with 9: dial it through a trunk ; (we put FXO channels and TE channels in group 0). ; The leading 9 is stripped. exten => _9.,1,Dial(Zap/g0/${EXTEN:1}) ; dialing a number that begins with 83 will dial it through ; span 3, and so forth. The two leading digits are stripped. ; (Each digital span is also added to group 10+span number). exten => _8X.,1,Dial(Zap/g1${EXTEN:1:1}/${EXTEN:2}) [from-internal] ; The context of FXS ports: analog phones. ; They are allowed to dial to all other phones include => phones-zap ; They are also allowed to call through the trunk: include => trunk ; some simple tests: include => astbank-test [from-pstn] ; Calls from the PSTN enter here. Redirect calls to an IVR ; or a default extension in the s context here. In this case we ; redirect calls to Zaptel channel 1: exten => s,1,Dial(Zap/1) ; Alternatively, the following will redirect you to the demo IVR ; from the sample extensions.conf of Asterisk: include => demo ; An extra context with some simple tests [astbank-test] ; 200: echo test exten => 200,1,Answer exten => 200,n,Wait(1) exten => 200,n,Echo() exten => 200,n,Hangup ; 203: say extension number. Will only work if caller ID ; is properly set in zapata.conf / zapata-channels.conf exten => 203,1,Answer exten => 203,n,Wait(1) exten => 203,n,SayNumber(${CALLERID(num)}) exten => 203,n,Hangup [astbank-input] exten => s,1,Set(ZAP_CHAN=${CUT(CHANNEL,-,1)}) exten => s,n,Set(ZAP_CHAN=${CUT(ZAP_CHAN,/,2)}) ; 11 is the number of the first input port. At least in the sample ; configuration below. ;exten => s,n,Set(INPUT_NUM=$[${ZAP_CHAN}-11)]) ; The sample below just logs the signal. exten => s,n,NoOp(Got signal from Zaptel Channel ${ZAP_CHAN}) ; Alternatively: ;exten => s,n,System(run something) ; No. We did not forget the context astbank-outputs. Output ; ports only get calls from the PBX. Thus they don't need a context ; of their own. Sending them to a context of their on makes ; 'zap show channels' in the CLI provide useful display, though.
The following commands provide useful information for debugging:
Check USB level status. You can use one of the following utilities for it:
zaptel_hardware -v or lsusb | grep e4e4
Look for the USB Product ID (the second number after e4e4).
If you see 11x2 (e.g: 1152)- the FPGA firmware has been loaded. Move on. zaptel_hardware will also show you some more details if the driver is loaded while the lsusb will just list the device.
If it shows something as product ID 11x0 - the USB firmware is not loaded. Maybe you need to run fxload. Or maybe just unplug and plug again the device. Also make sure that you have fxload installed.
If lsusb shows the Product ID as 11x1 - only the USB firmware is loaded and not the FPGA firmware is loaded. If this is still the case after a while - either the firmware loading has failed or you don't have fpga_load. Make sure you have libusb-dev(el) installed when building Zaptel. After you have installed it, you may need to re-run ./configure .
It should list all of your Astribank devices. If it doesn't (for more than period of time needed for the initial firmware loading) - Check that the Astribank is connected indeed.
Check if the Astribank spans are registered with Zaptel
zt_registration
This should give useful results after the drivers have identified and your devices are initialized.
It should list all Astribank XPDs. For each of them it should write "on" or "off". If the registration status is "off", then it means that the span has not been registered in Zaptel and therefore can not be used yet.
Registration is normally done as part of /etc/init.d/zaptel start. If you want to register the spans manually, then run command: zt_registration on .
You can get some information regarding Zaptel channels by running one of the following commands:
lszaptel or cat /proc/zaptel/*
Those two are almost the same. The lszaptel produced more correctly sorted output if you have more than 10 spans, and also make the output listing looks a little bit nicer.
You can see if your Zaptel spans and channels were loaded, if they were configured by ztcfg and if they are in use (typically by Asterisk). For example: Not configured Astribank FXS channel will be displayed as:
42 FXS
When ztcfg has applied the configuration of the channel (from /etc/zaptel.conf), you will see an extra column for the signalling type of the channel. The same channel after it has been configured:
42 FXS FXOKS
If a program (which is typically Asterisk) uses it, you'll see:
42 FXS FXOKS (In use)
asterisk -rx 'zap show channels'
If you get error "Unable to connect to remote asterisk" then it means that the Asterisk is not running. It is possible that Asterisk has failed to start due to misconfigured zapata.conf or whatever reason. Check /var/log/asterisk/messages or /var/log/asterisk/full .
If you get the error that "there is no such command" then it means that chan_zap.so is not loaded. There are two reasons for such problem:
chan_zap.so is not even built. Check if the file exists:
ls -l /usr/lib/asterisk/modules/chan_zap.so
the chan_zap.so file exists but it is not loaded. Try to load it manually:
asterisk -rx 'load module chan_zap.so'
You see "pseudo" channel only. It means that you have not configured any channels. If you have configured channels in zapata.conf, you may need either to restart the Asterisk or unload/load chan_zap.so manually. You can use the following Asterisk CLI commands for it: unload chan_zap.so and load chan_zap.so
Error message:
"ERR-xpd_fxo: XBUS-00/XPD-00: Failed initializing registers (-22)"
Likewise for all XPDs.
The directory /proc/xpp exists but is empty (not even the files xbuses and sync).
The driver failed to recreate the procfs directory /proc/xpp and hence everything under it. This is because it has already existed. And it existed because a process still uses it. This is typically because you have a shell whose working directory is /proc/xpp or somewhere under it:
# lsof /proc/xpp COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME bash 2741 root cwd DIR 0,3 0 4026532684 /proc/xpp
Move that process from that directory, or close the file it uses from under /proc/xpp and reload the zaptel / xpp drivers.
An Astribank finishes initialization quickly, the /proc/XBUS-nn directory has no XPD-mm subdirectories.
Error in the kernel logs about:
NOTICE-xpp: XBUS-00: XPD at 00: type=6.0 has bad firmware revision 2.6
This is normally caused by an Astribank with an older firmware connected to a
The protocol version supported by the firmware will typically be the same one as in the device initialization scripts installed to /usr/share/zaptel . Hence if this version installed /usr/share/zaptel/init_card_3_29 it will probably include firmware of protocol version 29.
Reset the firmware:
/usr/share/zaptel/xpp_fxloader reset
Or disconnect the Astribank from the power and reocnnect. On some older versions of the USB firmware resetting the firmware (or any operation of fpga_load) would fail if the driver is loaded. Hence you would need to run rmmod xpp_usb . In the end, reload the drivers.
You see USB-related errors similar to the following whenever you shut down the drivers of the Astribank or disconnect its drivers:
ERR-xpp_usb: XBUS-00: Failed to submit a receive urb
This is a normal part of the shutdown of the USB connection.
Ignore them. Unless the USB should not have disconnected at that time.
With the BRI module only, and not in the middle of an active call, you notice that suddenly the line goes down. The LED of the port stops blinking, layer1 not listed as "active" in the bri_info file in /proc/xpp, and the span is in RED alarm in Zaptel.
You may also see an error message such as:
NOTICE-xpd_bri: XBUS-00/XPD-02: D-Chan RX Bad checksum: [2A:01=FC] (252)
from the exact time of the disconnecting.
This is expected with most european BRI PtMP providers. If they support PtMP, they are normally also expected to support ISDN phones, that get the power from the provider. And thus they shut down the line whenever there's no active call.
Sometimes the line is shut down in the middle of a layer 2 message. In the BRI driver the HDLC decoding/encoding is done in the card. In that case we may get the above error.
Normaly this is not a problem. The driver will re-establish a connection once a new call needs to be made.
The firmware fails to load. Manually running xpp_fxloader gives:
Both '/etc/default/zaptel' and '/etc/sysconfig/zaptel' exist
Alternatively: an initialization script fails and gives the error
An '/etc/default/zaptel' collides with '/etc/sysconfig/zaptel'
/etc/default/<service name> is the place used in Debian-based systems for initialization scripts. /etc/sysconfig/<service name> is used in Redhat and similar for the same purpose. For historical reasons many of our programs read configuration from there: either from /etc/default/zaptel or from /etc/sysconfig/zaptel .
The problem is what to do if both of those exist. Selecting an arbitrary one can lead to unexpected results. Likewise sourcing both of them. Therefore we prefer to fail in a noisy and expected way. In the future we will probably me to reading configuration from a file under /etc/zaptel .
Remove one of those two. There should be no reason to have both on the same system.
You fail to find an Astribank device in the output of lsusb . But you see it in lsusb | grep e4e4
The perl module Zaptel::Hardware currently relies on /proc/bus/usb/devices (from usbfs) whereas lsusb can use either that or /dev/bus/usb .
Usbfs is generally deprecated and some distributions (OpenSUSE, Ubuntu) no longer mount it by default. Try:
mount /proc/bus/usb
and if that doesn't work:
mount -t usbfs usbfs /proc/bus/usbfs
However this is generally a cosmetic issue that only affects the listing in zaptel_hardware.
After upgrading to Zaptel 1.4.12 / 1.2.25 the initialization of the Astribank times out. In the logs you see:
kernel: NOTICE-xpp: XBUS-00(00): FIRMWARE: ERROR_CODE CODE = 0x3 (Premature packet end)
When an Astribank is detected, the driver asks it what is its version and what components it has. Normally if the version of the firmware and of the driver does not match the driver gives an ugly message and fails the initialization.
However in the change of the protocol between versions 2.9 (29) and 3.0 (30), the response that the new driver recieves from a device with the old version is now considered to be an illegal packet and gets discarded. As a result, the Astribank waits till time-out for the initilization to end.
Reset the firmware of the Astribank by either:
/usr/share/zaptel/xpp_fxloader reset
or disconnecting it from the power and reconnecting it.
The Astribank has 4 global indication leds and one or two per-port leds. On some of the models the LEDs are located on the left side on the front panel. If there are no separate LEDs there, then the red LEDs of the upper left-most ports of the device are used as the indication LEDs. Don't confuse them with green port status LEDs.
The first led is the "Power" led. It is on if the unit gets power. The second led is the "Active" led, which is on when there is at least one "active" port (in a call / off-hook, though the meaning of this is different in BRI). The last led is called "Hardware OK", but is actually only is on in case of the hardware failure.
The third led is the "Sync" led. If it blinks, the device is synchronized with the driver on the computer. If the device is selected to be the synchronization source for all of the Astribank devices then it will blink a quick single blink. If the device gets synchronization from the driver, it will blink in a more steady frequency.
"Double blink" indicates that the unit has an FXO module, and still is getting synchronization from the computer, and is not the synchronization source.
The per-port green led on analog (both FXS and FXO) indicates that the port is off-hook.
On the BRI, the green led indicates a TE port whereas an orange led indicates an NT port. If the led is solid, the port is down (not even layer-1 connection is up). If it is blinking a double blink, layer 1 is up. A slower single blinking indicates that layer 2 is up as well (which means that Asterisk is driving the port).
Astribank PRI module has two RJ-45 sockets for each PRI port. The lower socket provides typical PRI CPE side wiring: Rx- pins 1,2; Tx - pins 4,5. The upper socket provides typical PRI Network side wiring: Rx- pins 4,5; Tx - pins 1,2. The both sockets are permanently active and you can use any of them regardless of any configuration parameters (Both connectors are live. And connecting both of them with a flat 8-wire ethernet cable is a simple way to do a loop test for the port).
Each port in the PRI module can be configured either as E1 or T1. The default is E1, but it can be changed in xpp.conf (See the section above).
In addition to that, a port defaults to consider itself a CPE, or rather, to accept timing from the remote party. To override that you need to set the timing value to 0 (second parameter in the span= line in zaptel.conf).
Thus the following in zaptel.conf will also set an ornage LED:
span=2,0,3,ccs,hdb3,crc4
Note that as this is only applied when ztcfg is run, the port will have the default green LED lit at the bottom until it is configured.
This section describes in great depth the initialization of the Xorcom Astribank. Normally it would not be really needed, as the standard installation of Zaptel should put everything in place. This is generally some documentation to read when things fail.
There are some technical terms that are used in this document and in the driver / zaptel.
Zaptel breaks the channels it knows about to logical units called "spans". A port in a E1/T1/ISDN card is usually a span. An whole analog card is also a "span". You can see the list of spans as the list of files under /proc/zaptel directory or in output of the dahdi_tool utility.
A funny way to call an Astribank device.
Basically this is a logical unit of the Astribank. It will be registered in Zaptel as a single span. This can be either an analog (FXS or FXO) module or a single port in case of a BRI module.
Normally this is done using the script /usr/share/zaptel/xpp_fxloader. If it works fine, you don't need to bother reading this section. Once the firmware is loaded the USB Vendor ID and Product ID of the Astribank became to be e4e4 11x2, and now the driver can pick it up.
First and foremost: the simplest and most useful tool to debug problems is lsusb. The output of lsusb should show you if the device is connected if its firmware is loaded.
The firmware files are named *.hex. They are presented in the Intel hex format. The files are copied from xpp/utils to /usr/share/zaptel folder during the Zaptel installation.
The Astribank needs a firmware loaded into it. Without the firmware, the device will appear in lsusb with Vendor ID e4e4 and Product ID 11x0 (1130, 1140, 1150 or 1160). The firmware loading process consists of two stages. In the first stage the "USB" firmware is loaded by using program fxload. When the first stage is completed the Vendor ID is e4e4 and the Product ID is 11x1. (e.g. 1151 if it were 1150 previously).
You can use the following command in order to load the "USB" firmware manually:
fxload -t fx2 -D /dev/bus/usb/MMM/NNN -I /usr/share/zaptel/USB_FW.hex
where,
A standard program that is typically part either of package fxload or hotplug-utils .
On some old systems it is missing . /proc/bus/usb (usbfs) could be used instead.
the first number (bus number)
the second number (device number) you see for the device in lsusb
If the loading process has been completed successfully, the device disconnects and then connects again itself with USB Product ID 11x1 (and a new device number).
In the second stage, the "FPGA" firmware is loaded. The second-stage firmware loading is performed by using program fpga_load, which is built in the directory xpp/utils and then copied to folder /usr/sbin during Zaptel installation.
The command syntax is similar to the syntax of fxload. You can use the following command in order to load the FPGA firmware manually:
# pick the right name according to the device ID. FPGA_1161.hex is for # 116x Astribanks: astribank_hexload -D /dev/bus/usb/MMM/NNN -F /usr/share/zaptel/FPGA_1161.hex # Note the shell expantion in this line: astribank_hexload -D /dev/bus/usb/MMM/NNN -p /usr/share/zaptel/PIC_TYPE_[1-4].hex # reenumerate (disconnect and reconnect) astribank_tool -D /dev/bus/usb/MMM/NNN -n
With older USB firmwares before the one included in DAHDI 2.2 or latest Zaptel SVN, you needed to use instead of all the above:
# pick the right name according to the device ID. FPGA_1151.hex is for # 115x Astribanks: fpga_load -D /dev/bus/usb/MMM/NNN -I /usr/share/zaptel/FPGA_1151.hex
Please note, that NNN value differs from that that was used for the fxload command due to the fact that device has "reconnected" itself with another Product ID number. So you need to run lsusb again and get the new NNN value. Usually, the new value is equal to the old value incremented by 1.
On newer systems (e.g. Centos 4) /dev/bus/usb may not be available. In that case, use /proc/bus/usb . usbfs should be mounted there.
Udev is a framework for dynamic device nodes, which is supported in kernel 2.6. if your udev rules are properly configured then the firmware should be loaded automatically and you will see product ID 11x2 (e.g.: 1152).
Udev is mostly configured by files under /etc/udev/rules.d . The installer of dahdi-linux installs drivers/dahdi/xpp/xpp.rules into that directory.
This file instructs udev to run /usr/share/dahdi/xpp_fxloader for each time an Astribank connects and needs firmware. When the Astribank loads firmware or when it resets its firmware it "reenumerates" - disconnects and reconnects as a new device.
Below are kernel log messages of an Astribank loading firmware. It firs connects without any firmware (device no. 44). Udev tells it to load the USB firmware. It disconnects and reconnects (45). This Udev gets the FPGA firmware loaded into it. It disconnects again, and when it reconnects it is now ready to talk with the driver. The last message is from the driver.
usb 7-1: configuration #1 chosen from 1 choice usb 7-1: New USB device found, idVendor=e4e4, idProduct=1150 usb 7-1: New USB device strings: Mfr=0, Product=0, SerialNumber =0 usb 7-1: USB disconnect, address 44 usb 7-1: new high speed USB device using ehci_hcd and address 45 usb 7-1: configuration #1 chosen from 1 choice usb 7-1: New USB device found, idVendor=e4e4, idProduct=1151 usb 7-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3 usb 7-1: Product: Astribank usb 7-1: Manufacturer: Xorcom LTD usb 7-1: SerialNumber: 00000123 usb 7-1: USB disconnect, address 45 usb 7-1: new high speed USB device using ehci_hcd and address 46 usb 7-1: configuration #1 chosen from 1 choice usb 7-1: reset high speed USB device using ehci_hcd and address 46 INFO-xpp_usb: XUSB: Xorcom LTD -- Astribank -- FPGA
Another useful tool for tracing UDEV-related issue is the udev monitor:
udevadm monitor
Or with some older versions of udev:
udevmonitor
Hotplug is an obsolete framework for doing some of the things done by udev today. Specifically, handling kernel hotplug events. It is used in systems with kernel < 2.6.13 (e.g. RHEL4 / Centos4 and Debian 3.1). As such Zaptel still installs support for those. However if you package Zaptel for a more recent distribution, you should probably avoid including those obsolete config files.
The relevant files installed under /etc/hotplug/usb and are xpp/xpp_fxloader.usermap and xpp_fxloader (which is a symlink to /usr/share/dahdi/xpp_fxloader). the usermap file has the same format as modules.usbmap in the main kernel modules directory: it is intended to identify a (hotplugged) device.
Here is what should happen: In short: you should plug the Astribank device(s) or have them plugged in at the boot time. Then all the modules should be loaded automatically. You will see xpp_usb, xpp, and some xpd_* modules in the modules list (the output of lsmod).
After the module xpp is loaded, you'll also be able to see the directory /proc/xpp. For any Astribank device discovered, you will see there a directory /proc/xpp/XBUS-n (where n is a number: typically 0). Once a unit have been discovered you'll see subdirectories: /proc/xpp/XBUS-n/XPD-m (where m may be another number: 0, 1 ,etc).
Now to the ugly details:
The driver of the Astribank is composed of several modules:
The basic module, that communicates with Zaptel and provides some common services to other modules.
FXS modules (analog phones). Module type 1.
FXO modules (Analog PSTN lines). Module type 2.
BRI ("ISDN") modules. Module type 3.
The module for controlling E1/T1 modules. Module type 4.
The functionality needed to connect to the USB bus.
All modules depend on xpp, and modprobing them will install xpp as well. However the xpd_* modules are installed on-demand: no need to load xpd_fxo if you have only Astribank FXS.
Once an Astribank device connected and the firmware is loaded, the Vendor-ID/Product-ID of the device will be e4e4/11x2 . The handler for that combination is listed as the kernel module xpp_usb. Therefore, the system runs modprobe xpp_usb if that module is not already loaded.
The module xpp_usb depends on the zaptel and xpp modules. Both of them are loaded before xpp_usb. As usual, parameters and rules form /etc/modprobe.conf and/or from /etc/modprobe.d/* will be applied to the module.
When command modprobe xpp_usb returns, the span type specific modules (e.g., xpd_fxs, xpd_fxo) may or may not have been loaded yet.
At this point the xpp driver "asks" the box about its software (firmware) version) and the type of telephony modules it has. According to the answers it receives, the xpp driver will "modprobe" the required xpd_* modules.
When an Astribank connects, it tells the driver what ports it has. For instance, a system with 8BRI (=type 3) ports and 3 modules of 8FXS (=type 1) ports:
INFO-xpp: XBUS-00: DESCRIPTOR: 4 cards, protocol revision 30 INFO-xpp: XBUS-00: CARD 0 type=3.0 ports=8 (2x4), port-dir=0xCC INFO-xpp: XBUS-00: CARD 1 type=1.0 ports=8 (8x1), port-dir=0xFF INFO-xpp: XBUS-00: CARD 2 type=1.0 ports=8 (8x1), port-dir=0xFF INFO-xpp: XBUS-00: CARD 3 type=1.0 ports=8 (8x1), port-dir=0xFF
If zaptel, xpp or xpp_usb is missing or defective, you'll get relatively clear error messages. However if an xpd_* module fails to load (e.g.: because it is missing), the error is less intuitive:
NOTICE-xpp: xproto_get: Failed to load module for type=3. exit status=256. NOTICE-xpp: XBUS-00: CARD 0: missing protocol table for type 3. Ignored.
In this case it was because I maliciously removed the module xpd_bri (type 3) from the system.
This can also happen if you accidentally blacklist the relevant xpd- module. blacklist some_module in modprobe.conf or modprobe.d/.conf means that a direct insmod or modprobe of their name will work, but any attempt to load a module through its aliases will fail. Recall that the cpd-* modules are loaded on-demand using the alias xpd-type-N .
The chips in the device need to be initialized. This requires sending a bunch of values to certain registers in those chips. We decided that hardwiring those values in the driver code is not a good idea. Before registering a XPD as a span in Zaptel, we run an initialization script: /usr/share/zaptel/init_card_N_MM where,
N is telephony module type: 1 for an FXS span and 2 for an FXO span, 3 for BRI and 4 for PRI.
MM - is a version number. Currently it equals 30.
Those scripts must be executable. If they are not, the initiallization will do nothing but will give no error, and the device will work in an unexpected way, if at all.
If because of some reasons this fails (the script is not in the place, or the running it produced an error), then you will get an error message in the logs and the XPD will then be removed (you won't see directory for that XPD under the corresponding /proc/xpp/XBUS-* directory) and will not be registered with Zaptel.
As the XPD is initialized, you'll see the green LEDs of the ports steadily turn on and later off ("a train of lights"). This is a bit slower than the faster "blinking" when the XPDs register as Zaptel spans. The initialization of an FXS XPD may take a few seconds.
When the Astribank has finished initialization it also notifies userspace applications. This can be used to run a custom command when an Astribank is connected (after it has finished initialization) or when it has disconnected. The hook script is installed by default to /usr/share/zaptel/astribank_hook .
The XPDs will not automatically register as Zaptel spans. This is intended to allow you to set the registration order (and hence the order of Zaptel spans and channels) among multiple Astribank devices, or between an Astribank and a different Zaptel device.
When the XPD registers with Zaptel, all the green LEDs will be lit for a short while.
Spans are normally registered with the utility zt_registration. Simply running zt_registration shows the available XPDs and whether or not they are registered. To register:
zt_registration on
For a system with several spans you'll see a "fast train of lights".
If you have multiple Astribank devices, zt_registration will register them by the ascending order of the USB connector ID. This means that as long as the same Astribank is connected to the same port, the order of plugging is not important.
You can see the USB connector ID in the verbose output of the dahdi_hardware utility when xpp drivers are loaded. See CONNECTOR value in the example below:
# dahdi_hardware -v usb:004/006 xpp_usb+ e4e4:1152 Astribank-multi FPGA-firmware LABEL=[usb:0000148] CONNECTOR=usb-0000:00:03.3-2 XBUS-00/XPD-00: E1_TE Span 1 Zaptel-SYNC XBUS-00/XPD-10: FXS Span 2 XBUS-00/XPD-20: FXS Span 3 usb:004/007 xpp_usb+ e4e4:1152 Astribank-multi FPGA-firmware LABEL=[usb:0000150] CONNECTOR=usb-0000:00:03.3-6 XBUS-01/XPD-00: FXS Span 4 XBUS-01/XPD-10: FXO Span 5
If you have multiple Astribank devices, dahdi_registration will register them by the order of the "connector" field. This means that as long as the same Astribank is connected to the same port, the order of plugging is not important. Alternatively you can set an explicit registration order using /etc/dahdi/xpp_order . See above in section about xpp_order.
The registration is performed through the sysfs interface. See below the span attribute. Also note that zt_registration also allows you to unregister spans, which will work for all spans that are not in use (That is: none of their channels is in use).
By default, the Astribank drivers don't perform automatic span registration on Zaptel. It is in contrast to the all known drivers of PCI boards. Because of that, Zaptel channels related to the PCI board spans will get lower numbers than the channels related to Astribank devices.
You may choose to register the XPDs with Zaptel automatically. This may make the startup sequence a bit simpler, but is generally not recommended on a system with more than one Astribank or an Astribank and a different Zaptel device. This behavior may be defined by setting parameter [_zap_autoreg] in the modprobe configuration file (A file under /etc/modprobe.d or /etc/modprobe.conf):
options xpp zap_autoreg=1
If there is more than one Astribank on the system, all the Astribanks keep their clock in sync. Optionally the Astribanks can synchronize their clock to the master Zaptel device (in case it is a different Zaptel device). Normally you just use the default init.d script or run explicitly:
xpp_sync auto
(For now see the man page of xpp_sync for more information)
From here you get a standard Zaptel span. The next step is to configure the span by running the ztcfg utility. You would also need to configure the channels in the Asterisk zapata.conf file. Only after that you will be able to make calls through the telephony ports.
You can use zapconf, which is included with dahdi-tools, to generate a Zaptel and Asterisk configuration for your system. For analog channels it works quite well, and likewise for BRI. For E1/T1 it will probably take some tuning.
Please refer to the general Zaptel documentation for more deatils about Zaptel and Asterisk configuration. E.g, the README file in the top-level directory, and
http://voip-info.org/wiki/view/Asterisk+config+zapata.conf[]
Alternatively, write you own configuration, based on the sample from the "Sample Configurations" section.
The Astribank drivers provide their own /proc interface under /proc/xpp. Here we review the more useful details of the procfs interface. There are many other debugging details that are exposed through the procfs interface.
Also note that those details are subject to changes. Generally the recommended stable interface are the Zaptel-perl modules and utilities from the xpp/utils/ directory.
File /proc/xpp/xbuses lists the connected Astribank devices (one line per device).
A device is normally has status "connected". The status "missing" means that the device has been disconnected, but Asterisk still holds channels from it open.
A read/write file. It contains information about current synchronization source. You can change the synchronization source by writing special command to the file. For example, command echo SYNC=01 > /proc/xpp/sync
Possible values are:
Make the Astribank XBUS-<number> the sync source for other Astribanks.
Make the Astribanks synchronize with the Zaptel timing master span. You probably need this to get faxes from a non-Astribank adapter to an Astribank.
Though you'll normally use xpp_sync(8) for that.
For each Astribank device there is folder /proc/xpp/XBUS-nn and for each device module (span in the terms of Zaptel) there is folder /proc/XBUS-nn/XPD-mm.
(Not present in current drivers. See the SysFS attirbute waitfor_xpds and generally use the script waitfor_xpds)
Reading from this file only returns when the Astribank has finished initialization of the XPDs or in case of a timeout. It prints the number of XPDs to initialize, and the number initialize. Unless something went wrong, those two numbers are the same. Once the span was initialized, reading from this file returns immediately:
XPDS_READY: XBUS-00: 3/3
(Not present in current drivers. See the SysFS attirbute <<_sys_bus_astribanks_devices_xbus-nn_nn_m_p_spanthe SysFS attirbute span and generally use the script zt_registration)
is a read/write file. Reading from it gives 0 if the span is unregistered, or the span number if it is registered.
Writing to it allows manual registration / unregistration from Zaptel: writing 1 registers a span (if it wasn't already registered) and writing 0 attempts to unregister it (if it is registered. Span unregistration will fail if some channels from the span are used (e.g: by Asterisk).
A more convenient interface to this is the command zt_registration that registers or unregisters all the spans at once with a predefined order, and this is what you should normally use.
Alternatively you can use the parameter zap_autoreg to register spans automatically. But this is only recommended on a system with a single Astribank and no other Zaptel device.
Contains detailed information about port statuses of the device module (off-hook, on-hook etc.) For example, you can run the following command in order to monitor the port statuses in the real time:
watch -n1 cat /proc/xpp/XBUS-00/XPD-00/summary
Only for FXO modules. Apart from showing the status of the LEDs, it also shows for each FXO port if it is connected to a provider: look for the value of "battery" for that specific port, and a bunch of other characteristics of the port.
In addition to the usual information about the LEDs, this file also provides useful information regarding ISDN Layer 1 and Layer 2 status. For example, you can run the following command in order to monitor the Layer 1 port statuses for all BRI devices in the real time:
watch -n1 -d 'grep "Layer 1:" /proc/xpp/XBUS-*/XPD-*/bri_info'
For the status of the D channel of the ports on all BRI spans, run:
watch -n1 -d 'grep D-Channel: /proc/xpp/XBUS-*/XPD-*/bri_info'
(In latest SVN this file is read-only. The writetable functionality moved in part (E1/T1) to pri_protocol sysfs and in part (NT/TE) to zaptel.conf settings)
In addition to the usual information about the LEDs, this file also provides useful information regarding ISDN Layer 1 and Layer 2 status. For example, you can run the following command in order to monitor the Layer 1 port statuses for all E1/T1 devices in the real time:
watch -n1 -d 'grep "Layer 1:" /proc/xpp/XBUS-*/XPD-*/pri_info'
For the status of the D channel of the ports on all PRI spans, run:
watch -n1 -d 'grep D-Channel: /proc/xpp/XBUS-*/XPD-*/pri_info'
Note: the layer 2 status is much more of a guesswork based on changes in the contents of the channel that is supposed to be the D channel.
Writing to this file can be used to change the type of the device. The device type can only be changed when the XPD is not registered as a Zaptel span. The value is a whitespace-separated list of values that can be of:
Provides 31 channels, of which channel 16 is normally the D-channel. Common in places outside of North America and Japan. This is the default setup.
T1 provides 24 channels. The last one is normally the D-Channel. Common in North America.
Use the bottom port (green LED) and don't invert any wiring. Hint to higher layers that this will be the TE side of the connection. This is the default setup.
Use the top port (orange LED) and invert wiring (this is done to allow connecting an NT port and a TE port using a standard straight 8 wires "ethernet" cable). Hint to higher layers that this will be the NT side of the connection.
Set the device into local loop mode: loops the transmitted channels directly into the received channels.
Ends local loop mode.
Normally those are set by the PRI initialization script . See the definition of XPP_PRI_SETUP in the sample Zaptel init configuration file .
There are a bunch of other status files under /proc/xpp/.
Astribanks on the system and the xpds themselves are also represented in SysFS. SysFS is a virtual file system mounted under /sys and provides information in a more structured way than ProcFS. In sysfs objects are represented as directories, simple attributes are shown as files in the directory of the object and more complex objects are subdirectories or symbolic links to other directories.
As with the procfs interface, we only document some interesting attribuets. Some attributes are writable and hence writing to them without knowing what you do is not exactly wise.
Like the procfs interface, this interface is subject to changes and should not be considered a stable interface. Please use the Zaptel-perl modules and utilities.
Each astribank is represented as a device under /sys/bus/astribanks/devices , with the name xbus-NN, where NN is its two-digit number (e.g.: 00, 01).
CLear Statistics: writing to this file clear the procfs statistics for this Astribank.
Connector string for the device. The place to which the Astribank is connected. e.g: usb-0000:00:03.3-2
The label string of the Astribank unit. E.g: usb:00000135
connected (normal operation) or disconnected (has been disconnected, some channels are still open).
Provides some statistics in case the Astribank is not the sync source. The format of this file is subject to future changes.
Reading from this file only returns when the Astribank has finished initialization of the XPDs or in case of a timeout. It prints the number of XPDs to initialize, and the number initialize. Unless something went wrong, those two numbers are the same. Once the span was initialized, reading from this file returns immediately:
XPDS_READY: XBUS-00: 3/3
Reading from it prints the name and number of the state of the Astribank. This file is also writable: you can write either stop to disconnect the specific Astribank, or start to reconnect it.
(An attribute of the generic Astribanks driver)
The synchronization source. Normally the number of the astribank that is the synchronization master, or SYNC=ZAPTEL if Astribanks are synchronized from a different Zaptel device. Normally you should just use xpp_sync, though.
Under the Astribank you'll find a subdirectory for each of its XPDs ("spans"). The name of the directory is composed of three numbers:
<astribank>:<module>:<subunit>
Two-digit name of the Astribank in which this XPD is in. If it is xbus-03, you will see there 03.
The number of the Astribank module: from 0 (left-most) to 3 (right-most).
In a module that has several spans: the number of the span. In practice this is only for BRI and PRI and hence the module number will always be 0 in this case.
The two-digit number of the XPD in the procfs interface is in fact <module><subunit>.
Under this you see several attributes.
You can write here a number which will be considered to be a bitmask of the ports that should blink (0 - no blinking). Reading from here shows that bitmask. If you think that this is complicated, just use xpp_blink.
Provides direct read/write interface to the registers of each chip. Reading from the file shows the result of the last read request. To make either a read request or a write request you need to write to that file.
It is mainly used by the initialization scripts (init_card_*).
Incorrect usage of this file is one possible way of damaging the Astribank.
(Only on FXO) - shows ports that have (+) or don't have (-) battery current. That is: which ones are connected to an active FXS on the other side.
current. That is: which ones are connected to an active FXS on the other side.
Shows ports that are (1) or are not (0) off-hook. When a channel is not off-hook. For BRI and E1/T1 the value is 1 if the span is in use. This value can also be used to get the number of lines (channels) in this XPD: the count of items in this list.
is a read/write file. Reading from it gives 0 if the span is unregistered, or the span number if it is registered.
Writing to it allows manual registration / unregistration from Zaptel: writing 1 registers a span (if it wasn't already registered) and writing 0 attempts to unregister it (if it is registered. Span unregistration will fail if some channels from the span are used (e.g: by Asterisk).
A more convenient interface to this is the command zt_registration that registers or unregisters all the spans at once with a predefined order, and this is what you should normally use.
Alternatively you can use the parameter zap_autoreg to register spans automatically. But this is only recommended on a system with a single Astribank and no other Zaptel device.
This is a standard sysfs feature: from the directory of the device you have a link called "driver" to the directory of the driver that handles it. One specific interesting thing is that this allows you to easily see all the XPDs of the same type, as they are linked again from the driver's directory.
Can have either of those two:
Provides 31 channels, of which channel 16 is normally the D-channel. Common in places outside of North America and Japan. This is the default setup.
T1 provides 24 channels. The last one is normally the D-Channel. Common in North America.
This can also be set by writing the strings explicitly to the file. But can only be done when an XPD is not a registered span.
This writing is normally done by the device initialization script, based on the pri_protocol settings in /etc/xpp.conf .
Compilation-time defaults for the all modules can be shown as part of the description line for the parameter in the "modinfo" command output.
(xpp)
Register spans automatically (1) or not (0). Default: 0. Setting it simplifies operations with a single Astribank and no other Zaptel hardware. However if you have such systems, automatic registration can cause the order of spans to be unpredictable. The standard startup scripts use zt_registration on instead of this.
(xpp)
This is the directory containing the initialization scripts. The default is /usr/share/zaptel . Setting this value could be useful if that location is inconvenient for you.
(xpp)
Enable (1) or disable (0) doing most of the packets processing in separate tasklets. This should probably help on higher-end systems with multiple Astribanks.
(all modules)
It will make the driver to print tons of debugging messages. You can set/unset the parameter at run-time. The parameter value is a bitmask of several values. The different bits meaning as it defined in xpp/zap_debug.h:
0 - Disable debug messages
1 - GENERAL - General debug comments.
2 - PCM - PCM-related messages. Tends to flood logs.
4 - LEDS - Anything related to the LEDs status control. The driver produces a lot of messages when the option is enabled.
8 - SYNC - Synchronization related messages.
16 - SIGNAL - Zaptel signalling related messages.
32 - PROC - Messages related to the procfs interface.
64 - REGS - Reading and writing to chip registers. Tends to flood logs.
128 - DEVICES - Device instantiation, destruction and such.
256 - COMMANDS - Protocol commands. Tends to flood logs.
For example,
echo 33 >/sys/modules/xpp/parameters/debug
forces module xpp to print general debugging messages (1) and procfs debugging messages (32).
(xpd_fxs)
Enable (1) or disable (0) sending the voicemail message waiting indication signal to phones equipped with the Message Waiting neon lamp. It is disabled by default because the feature requires extra work of the driver even when such a phone is not used and also may cause some unusual side effects with some phone models.
(xpp_usb)
Enable (1) or disable (0) support of USB1 devices. Disabled by default.
USB1 devices are not well-tested. It seems that they don't work at all for Astribank BRI. Generally they should work with the current code, but we expect the voice quality issues. Hence we would like to make it very clear that you if you have a USB1 port (rather than a USB2 one, as recommended) you will have to take an action to enable the device.
(various)
There are various values which the driver occasionally polls the device for. For instance, the parameter poll_battery_interval for xpd_fxo to poll the battery, in order to know if the telco line is actually connected.
The value of those parameters is typically a number in milliseconds. 0 is used to disable polling. Under normal operation there should be no reason to play with those parameters.
(xpd_fxs)
Enable (1) or disable (0) support of hardware DTMF detection by the Astribank.
(fxo)
Various types of caller ID signalling styles require knowing the PCM even when the line is on-hook (which is usually a waste of CPU and bandwidth). This parameter allows fine-tuning the behaviour here:
0 (default) - Don't pass extra PCM when on-hook.
1 ETSI-FSK: Wait for polarity reversal to come before a ring and then start passing PCM until the caller ID has been passed.
2 Always: Always pass PCM.
This parameter is read-only. It cannot be changed at run-time.
Note
|
XPP here does not stand for X Printing Panel, XML Pull Parser, X-Windows Phase Plane or XML Professional Publisher. It is simply the Xorcom Peripheral Protocol, which connects a computer to a XPD (Xorcom Peripheral Device). An XBUS (originally XPP Bus) is actually a single Astribank device and the XPDs have become the single modules in it. |