]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/commit
It seems that I slipped a nasty bug into the CAPI support. The message
authorhm <hm@FreeBSD.org>
Sun, 21 Oct 2001 08:51:54 +0000 (08:51 +0000)
committerhm <hm@FreeBSD.org>
Sun, 21 Oct 2001 08:51:54 +0000 (08:51 +0000)
commit03b61a1a00862269701919e39e2697ced7263f5f
treebd1ed72d2eecfa7bea4351953e69536f93031689
parentc6710f54b00521bc8ff02511a7c8e78d577d5286
It seems that I slipped a nasty bug into the CAPI support. The message
lengths for CONNECT_REQ and CONNECT_IND are incorrect, which causes
dialouts to fail after certain error situations (an invalid -- not
wrong! -- number has been dialed). Since these messages are tagged as
too short, the device reads trailing garbage as the B protocol
parameters; this is OK as long as the garbage consists of zero bytes,
which it usually does, except after the said error.

Another change we have taken into use is to send an explicit Q.850
"normal call clearing" code when a call is ignored using PRI equipment
(specifically AVM T1); the CAPI pseudo-code for ignore, 1, translates
into something at least Ericsson exchanges interpret oddly (message
"this area is not reachable from your number"). NCCLR makes the exchange
give a busy signal, which is the behaviour at least we prefer
(conceivably, the ignore code could be made a sysctl variable).

The attached patch corrects the message length issue. It also includes a
somewhat unpretty solution for the PRI ignore code (if device's number
of channels equals 30, assume PRI and send NCCLR, otherwise send CAPI
ignore). Tested using AVM B1 PCI and T1 PCI.

Submitted by: Juha-Matti Liukkonen <jml@cubical.fi>
Reviewed by: hm
MFC after: 1 month
sys/i4b/capi/capi_msgs.c