[svn-commits] rmudgett: mISDN/trunk r198 - /mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Fri Nov 30 14:43:38 CST 2012
Author: rmudgett
Date: Fri Nov 30 14:43:34 2012
New Revision: 198
URL: http://svnview.digium.com/svn/thirdparty?view=rev&rev=198
Log:
Fix mISDN B channels getting lost over time.
Sometimes messages sent by Asterisk in isdn_lib.c to the kernel driver
never reach it. In case of these stuck B channels it is always first a
SETUP which is never acted upon (no TIMEOUT/no SETUP-ACK indication
follows) and then later the DISCONNECT is also not answered with an
appropriate RELEASE.
The problem was introduced in mISDN on 2004-11-19 with a "fix" for kernel
2.6.8, which turns out to be plain wrong. Before kernel 2.6.8 it was
required to check "if (off != &file->f_pos)" and return -ESPIPE if a
device is not seekable. Since 2.6.8, this check does not work anymore.
The fix for kernel 2.6.8 is to use the new API function nonseekable_open()
to disallow seeks.
(closes issue ABE-2869)
Reported by: Guenther Kelleter
Patches:
noseek.diff (license #6372) patch uploaded by Guenther Kelleter
Modified:
mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c
Modified: mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c
URL: http://svnview.digium.com/svn/thirdparty/mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c?view=diff&rev=198&r1=197&r2=198
==============================================================================
--- mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c (original)
+++ mISDN/trunk/drivers/isdn/hardware/mISDN/udevice.c Fri Nov 30 14:43:34 2012
@@ -1569,6 +1569,9 @@
filep->private_data = dev;
if (device_debug & DEBUG_DEV_OP)
printk(KERN_DEBUG "mISDN_open out: %p %p\n", filep, filep->private_data);
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,8)
+ nonseekable_open(ino, filep);
+#endif
mISDN_inc_usage();
@@ -1619,8 +1622,10 @@
// u_long flags;
struct sk_buff *skb;
- if (*off != file->f_pos)
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,8)
+ if (off != &file->f_pos)
return(-ESPIPE);
+#endif
if (!access_ok(VERIFY_WRITE, buf, count))
return(-EFAULT);
if ((dev->minor == 0) && (count < mISDN_HEADER_LEN)) {
@@ -1708,8 +1713,10 @@
struct sk_buff *skb;
mISDN_head_t head;
- if (*off != file->f_pos)
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,8)
+ if (off != &file->f_pos)
return(-ESPIPE);
+#endif
if (device_debug & DEBUG_DEV_OP)
printk(KERN_DEBUG "mISDN_write: file(%d) %p count %ld queue(%d)\n",
dev->minor, file, (long)count, skb_queue_len(&dev->wport.queue));
More information about the svn-commits
mailing list