[svn-commits] mattf: branch 1.2 r3243 - in /branches/1.2/wctdm24xxp: base.c wctdm24xxp.h
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Wed Nov 21 17:51:49 CST 2007
Author: mattf
Date: Wed Nov 21 17:51:48 2007
New Revision: 3243
URL: http://svn.digium.com/view/zaptel?view=rev&rev=3243
Log:
Add new product support
Modified:
branches/1.2/wctdm24xxp/base.c
branches/1.2/wctdm24xxp/wctdm24xxp.h
Modified: branches/1.2/wctdm24xxp/base.c
URL: http://svn.digium.com/view/zaptel/branches/1.2/wctdm24xxp/base.c?view=diff&rev=3243&r1=3242&r2=3243
==============================================================================
--- branches/1.2/wctdm24xxp/base.c (original)
+++ branches/1.2/wctdm24xxp/base.c Wed Nov 21 17:51:48 2007
@@ -246,6 +246,7 @@
static struct wctdm_desc wctdm2400 = { "Wildcard TDM2400P", 0, 24 };
static struct wctdm_desc wctdm800 = { "Wildcard TDM800P", 0, 8 };
+static struct wctdm_desc wctdm410 = { "Wildcard TDM410P", 0, 4 };
static struct wctdm_desc wcaex2400 = { "Wildcard AEX2400", 0, 24 };
static struct wctdm_desc wcaex800 = { "Wildcard AEX800", 0, 8 };
@@ -279,6 +280,23 @@
#endif
static int wctdm_init_proslic(struct wctdm *wc, int card, int fast , int manual, int sane);
+
+static inline int CMD_BYTE(int card, int bit, int altcs)
+{
+ /* Let's add some trickery to make the TDM410 work */
+ if (altcs == 3) {
+ if (card == 2) {
+ card = 4;
+ altcs = 0;
+ } else if (card == 3) {
+ card = 5;
+ altcs = 2;
+ }
+ }
+
+ return (((((card) & 0x3) * 3 + (bit)) * 7) \
+ + ((card) >> 2) + (altcs) + ((altcs) ? -21 : 0));
+}
/* sleep in user space until woken up. Equivilant of tsleep() in BSD */
int schluffen(wait_queue_head_t *q)
@@ -719,6 +737,16 @@
if (x < ZT_CHUNKSIZE - 1) {
writechunk[EFRAME_SIZE] = wc->ctlreg;
writechunk[EFRAME_SIZE + 1] = wc->txident++;
+#if 1
+ if ((wc->type == 4) && ((wc->ctlreg & 0x10) || (wc->modtype[NUM_CARDS] == MOD_TYPE_NONE))) {
+ writechunk[EFRAME_SIZE + 2] = 0;
+ for (y = 0; y < 4; y++) {
+ if (wc->modtype[y] == MOD_TYPE_NONE)
+ writechunk[EFRAME_SIZE + 2] |= (1 << y);
+ }
+ } else
+ writechunk[EFRAME_SIZE + 2] = 0xf;
+#endif
}
writechunk += (EFRAME_SIZE + EFRAME_GAP);
}
@@ -3318,11 +3346,17 @@
wc->cardflag |= (1 << x);
printk("Port %d: Installed -- AUTO FXO (%s mode)\n",x + 1, fxo_modes[_opermode].name);
} else {
- if ((wc->type == 8) && ((x & 0x3) == 1) && !wc->altcs[x]) {
+ if ((wc->type != 24) && ((x & 0x3) == 1) && !wc->altcs[x]) {
spin_lock_irqsave(&wc->reglock, flags);
+ wc->altcs[x] = 2;
+ if (wc->type == 4) {
+ wc->altcs[x+1] = 3;
+ wc->altcs[x+2] = 3;
+ }
wc->modtype[x] = MOD_TYPE_FXSINIT;
- wc->altcs[x] = 2;
spin_unlock_irqrestore(&wc->reglock, flags);
+
+ schluffen(&wc->regq);
schluffen(&wc->regq);
spin_lock_irqsave(&wc->reglock, flags);
wc->modtype[x] = MOD_TYPE_FXS;
@@ -3330,7 +3364,7 @@
if (debug & DEBUG_CARD)
printk("Trying port %d with alternate chip select\n", x + 1);
goto retry;
- } else {
+ } else {
printk("Port %d: Not installed\n", x + 1);
wc->modtype[x] = MOD_TYPE_NONE;
wc->cardflag |= (1 << x);
@@ -3345,7 +3379,7 @@
wc->ctlreg |= 0x10;
} else {
spin_lock_irqsave(&wc->reglock, flags);
- for (x = wc->cards; x < wc->cards+NUM_EC; x++)
+ for (x = NUM_CARDS; x < NUM_CARDS + NUM_EC; x++)
wc->modtype[x] = MOD_TYPE_NONE;
spin_unlock_irqrestore(&wc->reglock, flags);
wctdm_vpm150m_init(wc);
@@ -3551,6 +3585,7 @@
{ 0xd161, 0x0800, PCI_ANY_ID, PCI_ANY_ID, 0, 0, (unsigned long) &wctdm800 },
{ 0xd161, 0x8002, PCI_ANY_ID, PCI_ANY_ID, 0, 0, (unsigned long) &wcaex800 },
{ 0xd161, 0x8003, PCI_ANY_ID, PCI_ANY_ID, 0, 0, (unsigned long) &wcaex2400 },
+ { 0xd161, 0x8005, PCI_ANY_ID, PCI_ANY_ID, 0, 0, (unsigned long) &wctdm410 },
{ 0 }
};
Modified: branches/1.2/wctdm24xxp/wctdm24xxp.h
URL: http://svn.digium.com/view/zaptel/branches/1.2/wctdm24xxp/wctdm24xxp.h?view=diff&rev=3243&r1=3242&r2=3243
==============================================================================
--- branches/1.2/wctdm24xxp/wctdm24xxp.h (original)
+++ branches/1.2/wctdm24xxp/wctdm24xxp.h Wed Nov 21 17:51:48 2007
@@ -50,8 +50,10 @@
#define CMD_WR(a,b) (((a) << 8) | (b) | __CMD_WR)
#define CMD_RD(a) (((a) << 8) | __CMD_RD)
+#if 0
#define CMD_BYTE(card,bit,altcs) (((((card) & 0x3) * 3 + (bit)) * 7) \
+ ((card) >> 2) + (altcs) + ((altcs) ? -21 : 0))
+#endif
#define NUM_CARDS 24
#define NUM_EC 4
#define NUM_SLOTS 6
More information about the svn-commits
mailing list