diff options
author | russell <russell@5390a7c7-147a-4af0-8ec9-7488f05a26cb> | 2005-08-02 18:13:11 +0000 |
---|---|---|
committer | russell <russell@5390a7c7-147a-4af0-8ec9-7488f05a26cb> | 2005-08-02 18:13:11 +0000 |
commit | 33a601cb706a779187946b5539317ac6353d5573 (patch) | |
tree | b57b926f97ccc7d3210f937e57ee80129673a479 /zaptel.c | |
parent | 6fb43e3d95aebe0c31534686ad309deeec740b1f (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-x | zaptel.c | 20 |
1 files changed, 11 insertions, 9 deletions
@@ -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; } |