[dahdi-commits] mattf: branch linux/sruffell/improved_ecreference r8385 - in /linux/team/sruf...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Mon Mar 22 12:27:17 CDT 2010
Author: mattf
Date: Mon Mar 22 12:27:13 2010
New Revision: 8385
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8385
Log:
Commit simple fifo mechanism for EC data buffering. Still needs to have a flush mechanism to handle hard underrun and similar situations.
Modified:
linux/team/sruffell/improved_ecreference/drivers/dahdi/dahdi-base.c
linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/base.c
linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/wctdm24xxp.h
linux/team/sruffell/improved_ecreference/include/dahdi/kernel.h
Modified: linux/team/sruffell/improved_ecreference/drivers/dahdi/dahdi-base.c
URL: http://svnview.digium.com/svn/dahdi/linux/team/sruffell/improved_ecreference/drivers/dahdi/dahdi-base.c?view=diff&rev=8385&r1=8384&r2=8385
==============================================================================
--- linux/team/sruffell/improved_ecreference/drivers/dahdi/dahdi-base.c (original)
+++ linux/team/sruffell/improved_ecreference/drivers/dahdi/dahdi-base.c Mon Mar 22 12:27:13 2010
@@ -145,6 +145,11 @@
EXPORT_SYMBOL(dahdi_set_hpec_ioctl);
+EXPORT_SYMBOL(__dahdi_fifo_put);
+EXPORT_SYMBOL(__dahdi_fifo_get);
+EXPORT_SYMBOL(dahdi_fifo_free);
+EXPORT_SYMBOL(dahdi_fifo_alloc);
+
#ifdef CONFIG_PROC_FS
static struct proc_dir_entry *proc_entries[DAHDI_MAX_SPANS];
#endif
@@ -492,6 +497,103 @@
write_unlock(&ecfactory_list_lock);
}
+
+struct dahdi_fifo {
+ unsigned int total_size;
+ unsigned int start;
+ unsigned int end;
+ unsigned char data[0];
+};
+
+unsigned int dahdi_fifo_used_space(struct dahdi_fifo *fifo)
+{
+ if (fifo->end >= fifo->start) {
+ return fifo->end - fifo->start;
+ } else {
+ return fifo->total_size - fifo->start + fifo->end;
+ }
+}
+
+unsigned int __dahdi_fifo_put(struct dahdi_fifo *fifo, unsigned char *data, unsigned int size)
+{
+ int newinsertposition;
+ int cpy_one_len, cpy_two_len;
+
+ if ((size + dahdi_fifo_used_space(fifo)) > (fifo->total_size - 1)) {
+ return -1;
+ }
+
+ if ((fifo->end + size) >= fifo->total_size) {
+ cpy_one_len = fifo->total_size - fifo->end;
+ cpy_two_len = fifo->end + size - fifo->total_size;
+ newinsertposition = cpy_two_len;
+ } else {
+ cpy_one_len = size;
+ cpy_two_len = 0;
+ newinsertposition = fifo->end + size;
+ }
+
+ memcpy(&fifo->data[fifo->end], data, cpy_one_len);
+
+ if (cpy_two_len) {
+ memcpy(&fifo->data[0], &data[cpy_one_len], cpy_two_len);
+ }
+
+ fifo->end = newinsertposition;
+
+ return size;
+}
+
+unsigned int __dahdi_fifo_get(struct dahdi_fifo *fifo, unsigned char *data, unsigned int size)
+{
+ int newbegin;
+ int cpy_one_len, cpy_two_len;
+
+ if (size > dahdi_fifo_used_space(fifo)) {
+ return 0;
+ }
+
+ if ((fifo->start + size) >= fifo->total_size) {
+ cpy_one_len = fifo->total_size - fifo->start;
+ cpy_two_len = fifo->start + size - fifo->total_size;
+ newbegin = cpy_two_len;
+ } else {
+ cpy_one_len = size;
+ cpy_two_len = 0;
+ newbegin = fifo->start + size;
+ }
+
+ memcpy(&data[0], &fifo->data[fifo->start], cpy_one_len);
+
+ if (cpy_two_len) {
+ memcpy(&data[cpy_one_len], &fifo->data[0], cpy_two_len);
+ }
+
+ fifo->start = newbegin;
+
+ return size;
+}
+
+void dahdi_fifo_free(struct dahdi_fifo *fifo)
+{
+ kfree(fifo);
+}
+
+struct dahdi_fifo * dahdi_fifo_alloc(unsigned int maxsize, int alloc_flags)
+{
+ struct dahdi_fifo *fifo;
+
+ fifo = kmalloc(maxsize + sizeof(*fifo) + 1, alloc_flags);
+
+ if (!fifo)
+ return NULL;
+
+ fifo->start = fifo->end = 0;
+ fifo->total_size = maxsize + 1;
+
+ return fifo;
+}
+
static inline void rotate_sums(void)
{
Modified: linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/base.c
URL: http://svnview.digium.com/svn/dahdi/linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/base.c?view=diff&rev=8385&r1=8384&r2=8385
==============================================================================
--- linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/base.c (original)
+++ linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/base.c Mon Mar 22 12:27:13 2010
@@ -46,7 +46,6 @@
#include <linux/workqueue.h>
#include <linux/delay.h>
#include <linux/moduleparam.h>
-#include <linux/kfifo.h>
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,26)
#include <linux/semaphore.h>
#else
@@ -838,7 +837,7 @@
dahdi_transmit(&wc->span);
for (x = 0; x < wc->desc->ports; x++) {
if (wc->cardflag & (1 << x)) {
- __kfifo_put(wc->ec_reference[x],
+ __dahdi_fifo_put(wc->ec_reference[x],
wc->chans[x]->writechunk, DAHDI_CHUNKSIZE);
}
}
@@ -1052,7 +1051,7 @@
unsigned char buffer[DAHDI_CHUNKSIZE];
for (x = 0; x < wc->desc->ports; x++) {
if (wc->cardflag & (1 << x)) {
- __kfifo_get(wc->ec_reference[x], buffer,
+ __dahdi_fifo_get(wc->ec_reference[x], buffer,
ARRAY_SIZE(buffer));
dahdi_ec_chunk(wc->chans[x],
wc->chans[x]->readchunk,
@@ -3736,7 +3735,7 @@
for (x = 0; x < ARRAY_SIZE(wc->ec_reference); ++x) {
if (wc->ec_reference[x])
- kfifo_free(wc->ec_reference[x]);
+ dahdi_fifo_free(wc->ec_reference[x]);
}
kfree(wc);
@@ -3795,9 +3794,9 @@
init_waitqueue_head(&wc->regq);
for (i = 0; i < ARRAY_SIZE(wc->ec_reference); ++i) {
- wc->ec_reference[i] = kfifo_alloc(DAHDI_CHUNKSIZE *
+ wc->ec_reference[i] = dahdi_fifo_alloc(DAHDI_CHUNKSIZE *
VOICEBUS_MAX_LATENCY,
- GFP_KERNEL, &wc->reglock);
+ GFP_KERNEL);
if (IS_ERR(wc->ec_reference[i])) {
ret = PTR_ERR(wc->ec_reference[i]);
Modified: linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/wctdm24xxp.h
URL: http://svnview.digium.com/svn/dahdi/linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/wctdm24xxp.h?view=diff&rev=8385&r1=8384&r2=8385
==============================================================================
--- linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/wctdm24xxp.h (original)
+++ linux/team/sruffell/improved_ecreference/drivers/dahdi/wctdm24xxp/wctdm24xxp.h Mon Mar 22 12:27:13 2010
@@ -230,7 +230,7 @@
struct voicebus *vb;
struct dahdi_chan *chans[NUM_CARDS];
struct dahdi_echocan_state *ec[NUM_CARDS];
- struct kfifo *ec_reference[NUM_CARDS];
+ struct dahdi_fifo *ec_reference[NUM_CARDS];
int initialized;
};
Modified: linux/team/sruffell/improved_ecreference/include/dahdi/kernel.h
URL: http://svnview.digium.com/svn/dahdi/linux/team/sruffell/improved_ecreference/include/dahdi/kernel.h?view=diff&rev=8385&r1=8384&r2=8385
==============================================================================
--- linux/team/sruffell/improved_ecreference/include/dahdi/kernel.h (original)
+++ linux/team/sruffell/improved_ecreference/include/dahdi/kernel.h Mon Mar 22 12:27:13 2010
@@ -1061,6 +1061,16 @@
extern u_char __dahdi_lin2mu[16384];
extern u_char __dahdi_lin2a[16384];
#endif
+
+struct dahdi_fifo;
+
+unsigned int __dahdi_fifo_put(struct dahdi_fifo *fifo, unsigned char *data, unsigned int size);
+
+unsigned int __dahdi_fifo_get(struct dahdi_fifo *fifo, unsigned char *data, unsigned int size);
+
+void dahdi_fifo_free(struct dahdi_fifo *fifo);
+
+struct dahdi_fifo * dahdi_fifo_alloc(unsigned int maxsize, int alloc_flags);
/*! \brief Used by dynamic DAHDI -- don't use directly */
void dahdi_set_dynamic_ioctl(int (*func)(unsigned int cmd, unsigned long data));
More information about the dahdi-commits
mailing list