[dahdi-commits] sruffell: linux/trunk r8198 - in /linux/trunk: drivers/dahdi/voicebus/ driver...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Mon Mar 1 17:15:53 CST 2010
Author: sruffell
Date: Mon Mar 1 17:15:49 2010
New Revision: 8198
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8198
Log:
wctdm24xxp, wcte12xp: Add optional module parameter to set the maximum latency.
Setting the maximum latency can be useful if you have a system event that
normally causes a latency increase, but you would rather have a break in the
audio or frame slip, then let the latency grow to the current default maximum
which is 25ms. DAHDI-278.
Modified:
linux/trunk/drivers/dahdi/voicebus/voicebus.h
linux/trunk/drivers/dahdi/wctdm24xxp/base.c
linux/trunk/drivers/dahdi/wcte12xp/base.c
linux/trunk/include/dahdi/kernel.h
Modified: linux/trunk/drivers/dahdi/voicebus/voicebus.h
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/voicebus/voicebus.h?view=diff&rev=8198&r1=8197&r2=8198
==============================================================================
--- linux/trunk/drivers/dahdi/voicebus/voicebus.h (original)
+++ linux/trunk/drivers/dahdi/voicebus/voicebus.h Mon Mar 1 17:15:49 2010
@@ -37,11 +37,11 @@
#include <linux/etherdevice.h>
#endif
-#define VOICEBUS_DEFAULT_LATENCY 3
-#define VOICEBUS_DEFAULT_MAXLATENCY 25
-#define VOICEBUS_MAXLATENCY_BUMP 6
-
-#define VOICEBUS_SFRAME_SIZE 1004
+#define VOICEBUS_DEFAULT_LATENCY 3U
+#define VOICEBUS_DEFAULT_MAXLATENCY 25U
+#define VOICEBUS_MAXLATENCY_BUMP 6U
+
+#define VOICEBUS_SFRAME_SIZE 1004U
/*! The number of descriptors in both the tx and rx descriptor ring. */
#define DRING_SIZE (1 << 7) /* Must be a power of 2 */
@@ -189,4 +189,17 @@
{
set_bit(VOICEBUS_NORMAL_MODE, &vb->flags);
}
+
+/**
+ * voicebus_set_max_latency() - Set the maximum number of milliseconds the latency will be able to grow to.
+ */
+static inline void
+voicebus_set_maxlatency(struct voicebus *vb, unsigned int max_latency)
+{
+ spin_lock_bh(&vb->lock);
+ vb->max_latency = clamp(max_latency,
+ vb->min_tx_buffer_count,
+ VOICEBUS_DEFAULT_MAXLATENCY);
+ spin_unlock_bh(&vb->lock);
+}
#endif /* __VOICEBUS_H__ */
Modified: linux/trunk/drivers/dahdi/wctdm24xxp/base.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/wctdm24xxp/base.c?view=diff&rev=8198&r1=8197&r2=8198
==============================================================================
--- linux/trunk/drivers/dahdi/wctdm24xxp/base.c (original)
+++ linux/trunk/drivers/dahdi/wctdm24xxp/base.c Mon Mar 1 17:15:49 2010
@@ -237,6 +237,7 @@
static int ringdebounce = DEFAULT_RING_DEBOUNCE;
static int fwringdetect = 0;
static int latency = VOICEBUS_DEFAULT_LATENCY;
+static unsigned int max_latency = VOICEBUS_DEFAULT_MAXLATENCY;
static int forceload;
#define MS_PER_HOOKCHECK (1)
@@ -4670,6 +4671,7 @@
wc->vb.ops = &voicebus_operations;
ret = voicebus_init(&wc->vb, wc->board_name);
voicebus_set_minlatency(&wc->vb, latency);
+ voicebus_set_maxlatency(&wc->vb, max_latency);
}
if (ret) {
@@ -4716,6 +4718,7 @@
voicebus_stop(&wc->vb);
wc->vb.ops = &voicebus_operations;
voicebus_set_minlatency(&wc->vb, latency);
+ voicebus_set_maxlatency(&wc->vb, max_latency);
voicebus_set_normal_mode(&wc->vb);
if (voicebus_start(&wc->vb))
BUG_ON(1);
@@ -5036,6 +5039,7 @@
module_param(ringdebounce, int, 0600);
module_param(fwringdetect, int, 0600);
module_param(latency, int, 0400);
+module_param(max_latency, int, 0400);
module_param(neonmwi_monitor, int, 0600);
module_param(neonmwi_level, int, 0600);
module_param(neonmwi_envelope, int, 0600);
Modified: linux/trunk/drivers/dahdi/wcte12xp/base.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/wcte12xp/base.c?view=diff&rev=8198&r1=8197&r2=8198
==============================================================================
--- linux/trunk/drivers/dahdi/wcte12xp/base.c (original)
+++ linux/trunk/drivers/dahdi/wcte12xp/base.c Mon Mar 1 17:15:49 2010
@@ -40,6 +40,7 @@
#include <linux/delay.h>
#include <linux/sched.h>
+#include <stdbool.h>
#include <dahdi/kernel.h>
#include "wct4xxp/wct4xxp.h" /* For certain definitions */
@@ -64,6 +65,7 @@
static int t1e1override = -1;
static int unchannelized = 0;
static int latency = VOICEBUS_DEFAULT_LATENCY;
+static unsigned int max_latency = VOICEBUS_DEFAULT_MAXLATENCY;
static int vpmsupport = 1;
static int vpmtsisupport = 0;
@@ -1880,6 +1882,7 @@
if (VOICEBUS_DEFAULT_LATENCY != latency) {
voicebus_set_minlatency(&wc->vb, latency);
+ voicebus_set_maxlatency(&wc->vb, max_latency);
}
voicebus_lock_latency(&wc->vb);
Modified: linux/trunk/include/dahdi/kernel.h
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/include/dahdi/kernel.h?view=diff&rev=8198&r1=8197&r2=8198
==============================================================================
--- linux/trunk/include/dahdi/kernel.h (original)
+++ linux/trunk/include/dahdi/kernel.h Mon Mar 1 17:15:49 2010
@@ -1185,6 +1185,8 @@
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 31)
#define KERN_CONT ""
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 26)
+#define clamp(x, low, high) min (max (low, x), high)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 25)
/* Some distributions backported fatal_signal_pending so we'll use a macro to
@@ -1222,6 +1224,7 @@
#endif /* 2.6.14 */
#endif /* 2.6.18 */
#endif /* 2.6.25 */
+#endif /* 2.6.26 */
#endif /* 2.6.31 */
#ifndef DMA_BIT_MASK
More information about the dahdi-commits
mailing list