summaryrefslogtreecommitdiff
path: root/zaptel.c
diff options
context:
space:
mode:
authorrussell <russell@5390a7c7-147a-4af0-8ec9-7488f05a26cb>2005-08-02 18:13:11 +0000
committerrussell <russell@5390a7c7-147a-4af0-8ec9-7488f05a26cb>2005-08-02 18:13:11 +0000
commit33a601cb706a779187946b5539317ac6353d5573 (patch)
treeb57b926f97ccc7d3210f937e57ee80129673a479 /zaptel.c
parent6fb43e3d95aebe0c31534686ad309deeec740b1f (diff)
merge dual-span card fixes from head
git-svn-id: http://svn.digium.com/svn/zaptel/branches/v1-0@714 5390a7c7-147a-4af0-8ec9-7488f05a26cb
Diffstat (limited to 'zaptel.c')
-rwxr-xr-xzaptel.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/zaptel.c b/zaptel.c
index fcfedc1..714fc66 100755
--- a/zaptel.c
+++ b/zaptel.c
@@ -470,9 +470,6 @@ static int zaptel_proc_read(char *page, char **start, off_t off, int count, int
/* In Linux 2.6, this MUST NOT EXECEED 1024 bytes in one read! */
- if (off > 0)
- return 0;
-
span = (long)data;
if (!span)
@@ -552,15 +549,20 @@ static int zaptel_proc_read(char *page, char **start, off_t off, int count, int
if (chans[x]->nextslave && chans[x]->master->channo == x)
len += sprintf(page + len, "Master ");
}
+ }
+ if ((chans[x]->flags & ZT_FLAG_OPEN)) {
+ len += sprintf(page + len, "(In use) ");
+ }
+ len += sprintf(page + len, "\n");
}
- if ((chans[x]->flags & ZT_FLAG_OPEN)) {
- len += sprintf(page + len, "(In use) ");
- }
- len += sprintf(page + len, "\n");
-
+ if ( len <= off ) /* If everything printed so far is before beginning of request */
+ {
+ off -= len;
+ len = 0;
}
}
}
+ *start = page + off;
return len;
}
#endif
@@ -2428,7 +2430,7 @@ ioctl_load_zone(unsigned long data)
next[x] = td.next;
/* Make sure the "next" one is sane */
if ((next[x] >= th.count) || (next[x] < 0)) {
- printk("Invalid 'next' pointer\n");
+ printk("Invalid 'next' pointer: %d\n", next[x]);
kfree(slab);
return -EINVAL;
}