[svn-commits] trunk r980 - /trunk/wcte11xp.c

svn-commits at lists.digium.com svn-commits at lists.digium.com
Sun Mar 12 18:03:11 MST 2006


Author: markster
Date: Sun Mar 12 19:03:10 2006
New Revision: 980

URL: http://svn.digium.com/view/zaptel?rev=980&view=rev
Log:
Add support for unchannelized mode

Modified:
    trunk/wcte11xp.c

Modified: trunk/wcte11xp.c
URL: http://svn.digium.com/view/zaptel/trunk/wcte11xp.c?rev=980&r1=979&r2=980&view=diff
==============================================================================
--- trunk/wcte11xp.c (original)
+++ trunk/wcte11xp.c Sun Mar 12 19:03:10 2006
@@ -125,6 +125,17 @@
   27,26,25,24,
   31,30,29,28 };
 
+static int chanmap_e1uc[] =
+{ 3,2,1,0,
+  7,6,5,4,
+  11,10,9,8,
+  15,14,13,12,
+  19,18,17,16,
+  23,22,21,20,
+  27,26,25,24,
+  31,30,29,28 };
+
+
 #ifdef FANCY_ALARM
 static int altab[] = {
 0, 0, 0, 1, 2, 3, 4, 6, 8, 9, 11, 13, 16, 18, 20, 22, 24, 25, 27, 28, 29, 30, 31, 31, 32, 31, 31, 30, 29, 28, 27, 25, 23, 22, 20, 18, 16, 13, 11, 9, 8, 6, 4, 3, 2, 1, 0, 0, 
@@ -168,11 +179,11 @@
 	dma_addr_t	writedma;
 	volatile unsigned char *writechunk;					/* Double-word aligned write memory */
 	volatile unsigned char *readchunk;					/* Double-word aligned read memory */
-	unsigned char ec_chunk1[31][ZT_CHUNKSIZE];
-	unsigned char ec_chunk2[31][ZT_CHUNKSIZE];
-	unsigned char tempo[32];
+	unsigned char ec_chunk1[32][ZT_CHUNKSIZE];
+	unsigned char ec_chunk2[32][ZT_CHUNKSIZE];
+	unsigned char tempo[33];
 	struct zt_span span;						/* Span */
-	struct zt_chan chans[31];					/* Channels */
+	struct zt_chan chans[32];					/* Channels */
 };
 
 #define CANARY 0xca1e
@@ -183,6 +194,7 @@
 static int loopback = 0;
 static int clockextra = 0;
 static int t1e1override = -1;
+static int unchannelized = 0;
 
 static struct t1 *cards[WC_MAX_CARDS];
 
@@ -614,7 +626,7 @@
 static void t4_serial_setup(struct t1 *wc)
 {
 	printk("TE110P: Setting up global serial parameters for %s %s\n", 
-	       wc->spantype == TYPE_E1 ? "E1" : "T1", 
+	       wc->spantype == TYPE_E1 ? (unchannelized ? "Unchannelized E1" : "E1") : "T1", 
 		   wc->spanflags & FLAG_FALC12 ? "FALC V1.2" : "FALC V2.1");
 	t1_framer_out(wc, 0x85, 0xe0);	/* GPC1: Multiplex mode enabled, FSC is output, active low, RCLK from channel 0 */
 	t1_framer_out(wc, 0x08, 0x05);	/* IPC: Interrupt push/pull active low */
@@ -780,6 +792,8 @@
 	char *framing, *line;
 	fmr1 = 0x44; /* FMR1: E1 mode, Automatic force resync, PCM30 mode, 8.192 Mhz backplane, no XAIS */
 	fmr2 = 0x03; /* FMR2: Auto transmit remote alarm, auto loss of multiframe recovery, no payload loopback */
+	if (unchannelized)
+		fmr2 |= 0x30;
 	if (loopback)
 		fmr2 |= 0x4;
 	if (lineconfig & ZT_CONFIG_CRC4) {
@@ -805,6 +819,9 @@
 		cas = 0x40;
 	}
 	__t1_framer_out(wc, 0x1c, fmr0);
+
+	if (unchannelized)
+		__t1_framer_out(wc, 0x1f, 0x40);
 
 	__t1_framer_out(wc, 0x37, 0xf0 /*| 0x6 */ );	/* LIM1: Clear data in case of LOS, Set receiver threshold (0.5V), No remote loop, no DRS */
 	__t1_framer_out(wc, 0x36, 0x08);	/* LIM0: Enable auto long haul mode, no local loop (must be after LIM1) */
@@ -831,7 +848,10 @@
 	__t1_framer_out(wc, 0x39, 0x15);	/* PCR: 22 "ones" clear LOS */
 	
 	__t1_framer_out(wc, 0x20, 0x9f);	/* XSW: Spare bits all to 1 */
-	__t1_framer_out(wc, 0x21, 0x1c|cas);	/* XSP: E-bit set when async. AXS auto, XSIF to 1 */
+	if (unchannelized)
+		__t1_framer_out(wc, 0x21, 0x3c);
+	else
+		__t1_framer_out(wc, 0x21, 0x1c|cas);	/* XSP: E-bit set when async. AXS auto, XSIF to 1 */
 	
 	
 	/* Generate pulse mask for E1 */
@@ -958,9 +978,12 @@
 	wc->span.maint = t1xxp_maint;
 	wc->span.open = t1xxp_open;
 	wc->span.close = t1xxp_close;
-	if (wc->spantype == TYPE_E1)
-		wc->span.channels = 31;
-	else
+	if (wc->spantype == TYPE_E1) {
+		if (unchannelized)
+			wc->span.channels = 32;
+		else
+			wc->span.channels = 31;
+	} else
 		wc->span.channels = 24;
 	wc->span.chans = wc->chans;
 	wc->span.flags = ZT_FLAG_RBS;
@@ -1113,7 +1136,7 @@
 					}
 				}
 			}
-		} else {
+		} else if (!unchannelized) {
 			if (!wc->clocktimeout && !wc->span.alarms) {
 				if ((rxbuf[32 * y + ((3 + WC_OFFSET + wc->offset) & 0x1f)] & 0x7f) != 0x1b) {
 					if (wc->miss) {
@@ -1218,9 +1241,10 @@
 	}
 
 	if (c & 0xa0) {
-		if (wc->alarmcount >= alarmdebounce) 
-			alarms |= ZT_ALARM_RED;
-		else
+		if (wc->alarmcount >= alarmdebounce) {
+			if (!unchannelized)
+				alarms |= ZT_ALARM_RED;
+		} else
 			wc->alarmcount++;
 	} else
 		wc->alarmcount = 0;
@@ -1260,7 +1284,7 @@
 
 	/* Re-check the timing source when we enter/leave alarm, not withstanding
 	   yellow alarm */
-	if (c & 0x10)
+	if ((c & 0x10) && !unchannelized)
 		alarms |= ZT_ALARM_YELLOW;
 	if (wc->span.mainttimer || wc->span.maintstat) 
 		alarms |= ZT_ALARM_LOOPBACK;
@@ -1408,9 +1432,12 @@
 
 	control_set_reg(wc, WC_LEDTEST, 0x00);
 
-	if (wc->spantype == TYPE_E1)
-		wc->chanmap = chanmap_e1;
-	else
+	if (wc->spantype == TYPE_E1) {
+		if (unchannelized)
+			wc->chanmap = chanmap_e1uc;
+		else
+			wc->chanmap = chanmap_e1;
+	} else
 		wc->chanmap = chanmap_t1;
 	/* Setup clock appropriately */
 	control_set_reg(wc, WC_CLOCK, 0x06 | wc->sync | clockextra);
@@ -1580,6 +1607,7 @@
 module_param(alarmdebounce, int, 0600);
 module_param(loopback, int, 0600);
 module_param(t1e1override, int, 0600);
+module_param(unchannelized, int, 0600);
 module_param(clockextra, int, 0600);
 module_param(debug, int, 0600);
 module_param(j1mode, int, 0600);
@@ -1587,6 +1615,7 @@
 MODULE_PARM(alarmdebounce, "i");
 MODULE_PARM(loopback, "i");
 MODULE_PARM(t1e1override, "i");
+MODULE_PARM(unchannelized, "i");
 MODULE_PARM(clockextra, "i");
 MODULE_PARM(debug, "i");
 MODULE_PARM(j1mode, "i");



More information about the svn-commits mailing list