summaryrefslogtreecommitdiff
path: root/sys/dev/pci/bt8370reg.h
blob: 686be6c953e5b707fdcc090166c2b5235a48874c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
/*	$OpenBSD: bt8370reg.h,v 1.2 2005/08/13 23:52:49 claudio Exp $ */

/*
 * Copyright (c) 2004,2005  Internet Business Solutions AG, Zurich, Switzerland
 * Written by: Andre Oppermann <oppermann@accoom.net>
 *
 * Permission to use, copy, modify, and distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

/* Bt8370 Register definitions */
/* Globals */
#define	Bt8370_DID	0x000		/* Device Identification */
#define	Bt8370_CR0	0x001		/* Primary control register */
#define		CR0_RESET	0x80		/* Reset Framer */
#define		CR0_E1_FAS	0x00		/* E1 FAS only */
#define		CR0_E1_FAS_CRC	0x08		/* E1 FAS+CRC4 */
#define		CR0_T1_SF	0x09		/* T1 SF */
#define		CR0_T1_ESF	0x1A		/* T1 ESF+ForceCRC */
#define	Bt8370_JAT_CR	0x002		/* Jitter attenuator conf */
#define		JAT_CR_JEN	0x80		/* Jitter anntenuator enable */
#define		JAT_CR_JFREE	0x40		/* Free running JCLK and CLADO */
#define		JAT_CR_JDIR_TX	0x00		/* JAT in TX direction */
#define		JAT_CR_JDIR_RX	0x20		/* JAT in RC direction */
#define		JAT_CR_JAUTO	0x10		/* JCLK Acceleration */
#define		JAT_CR_CENTER	0x80		/* Force JAT to center */
#define		JAT_CR_JSIZE8	0x00		/* Elastic store size 8 bits */
#define		JAT_CR_JSIZE16	0x01		/* Elastic store size 16 bits */
#define		JAT_CR_JSIZE32	0x02		/* Elastic store size 32 bits */
#define		JAT_CR_JSIZE64	0x03		/* Elastic store size 64 bits */
#define		JAT_CR_JSIZE128	0x04		/* Elastic store size 128 bits */
#define	Bt8370_IRR	0x003		/* Interrupt request register */
/* Interrupt Status */
#define	Bt8370_ISR7	0x004		/* Alarm 1 Interrupt Status */
#define	Bt8370_ISR6	0x005		/* Alarm 2 Interrupt Status */
#define	Bt8370_ISR5	0x006		/* Error Interrupt Status */
#define	Bt8370_ISR4	0x007		/* Counter Overflow Interrupt Status */
#define	Bt8370_ISR3	0x008		/* Timer Interrupt Status */
#define	Bt8370_ISR2	0x009		/* Data Link 1 Interrupt Status */
#define	Bt8370_ISR1	0x00A		/* Data Link 2 Interrupt Status */
#define	Bt8370_ISR0	0x00B		/* Pattern Interrupt Status */
/* Interrupt Enable */
#define	Bt8370_IER7	0x00C		/* Alarm 1 Interrupt Enable register */
#define	Bt8370_IER6	0x00D		/* Alarm 2 Interrupt Enable register */
#define	Bt8370_IER5	0x00E		/* Error Interrupt Enable register */
#define	Bt8370_IER4	0x00F		/* Count Overflow Interrupt Enable register */
#define	Bt8370_IER3	0x010		/* Timer Interrupt Enable register */
#define	Bt8370_IER2	0x011		/* Data Link 1 Interrupt Enable register */
#define	Bt8370_IER1	0x012		/* Date Link 2 Interrupt Enable register */
#define	Bt8370_IER0	0x013		/* Pattern Interrupt Enable register */
/* Primary */
#define	Bt8370_LOOP	0x014		/* Loopback Configuration register */
#define		LOOP_PLOOP	0x08		/* Remote Payload Loopback */
#define		LOOP_LLOOP	0x04		/* Remote Line Loopback */
#define		LOOP_FLOOP	0x02		/* Local Framer Loopback */
#define		LOOP_ALOOP	0x01		/* Local Analog Loopback */
#define	Bt8370_DL3_TS	0x015		/* External Data Link Channel */
#define	Bt8370_DL3_BIT	0x016		/* External Data Link Bit */
#define	Bt8370_FSTAT	0x017		/* Offline Framer Status */
#define		FSTAT_INVALID	0x10		/* No candidate */
#define		FSTAT_FOUND	0x08		/* Frame Search Successful */
#define		FSTAT_TIMEOUT	0x04		/* Framer Search Timeout */
#define		FSTAT_ACTIVE	0x02		/* Framer Active */
#define		FSTAT_RXTXN	0x01		/* RX/TX Reframe Operation */
#define	Bt8370_PIO	0x018		/* Programmable Input/Output */
#define		PIO_ONESEC_IO	0x80		/*  */
#define		PIO_RDL_IO	0x40		/*  */
#define		PIO_TDL_IO	0x20		/*  */
#define		PIO_INDY_IO	0x10		/*  */
#define		PIO_RFSYNC_IO	0x08		/*  */
#define		PIO_RMSYNC_IO	0x04		/*  */
#define		PIO_TFSYNC_IO	0x02		/*  */
#define		PIO_TMSYNC_IO	0x01		/*  */
#define	Bt8370_POE	0x019		/* Programmable Output Enable */
#define		POE_TDL_OE	0x20		/*  */
#define		POE_RDL_OE	0x10		/*  */
#define		POE_INDY_OE	0x08		/*  */
#define		POE_TCKO_OE	0x04		/*  */
#define		POE_CLADO_OE	0x02		/*  */
#define		POE_RCKO_OE	0x01		/*  */
#define	Bt8370_CMUX	0x01A		/* Clock Input Mux */
#define		CMUX_RSBCKI_RSBCKI	0x00	/*  */
#define		CMUX_RSBCKI_TSBCKI	0x40	/*  */
#define		CMUX_RSBCKI_CLADI	0x80	/*  */
#define		CMUX_RSBCKI_CLADO	0xC0	/*  */
#define		CMUX_TSBCKI_TSBCKI	0x00	/*  */
#define		CMUX_TSBCKI_RSBCKI	0x10	/*  */
#define		CMUX_TSBCKI_CLADI	0x20	/*  */
#define		CMUX_TSBCKI_CLADO	0x30	/*  */
#define		CMUX_CLADI_CLADI	0x00	/*  */
#define		CMUX_CLADI_RCKO		0x04	/*  */
#define		CMUX_CLADI_TSBCKI	0x08	/*  */
#define		CMUX_CLADI_TCKI		0x0C	/*  */
#define		CMUX_TCKI_TCKI		0x00	/*  */
#define		CMUX_TCKI_RCKO		0x01	/*  */
#define		CMUX_TCKI_RSBCKI	0x02	/*  */
#define		CMUX_TCKI_CLADO		0x03	/*  */
#define	Bt8370_TMUX	0x01B		/* Test Mux Configuration */
#define	Bt8370_TEST	0x01C		/* Test Configuration */
/* Receive LIU (RLIU) */
#define	Bt8370_LIU_CR	0x020		/* LIU Configuration */
#define		LIU_CR_RST_LIU	0x80		/* Reset RLIU */
#define		LIU_CR_SQUELCH	0x40		/* Enable Squelch */
#define		LIU_CR_FORCE_VGA 0x20		/* Internal Variable Gain Amp */
#define		LIU_CR_RDIGI	0x10		/* Enable Receive Digital Inputs */
#define		LIU_CR_ATTN0	0x00		/* Bridge Attenuation 0db */
#define		LIU_CR_ATTN10	0x04		/* Bridge Attenuation -10db */
#define		LIU_CR_ATTN20	0x08		/* Bridge Attenuation -20db */
#define		LIU_CR_ATTN30	0x0C		/* Bridge Attenuation -30db */
#define		LIU_CR_MAGIC	0x01		/* This one must be enabled */
#define	Bt8370_RSTAT	0x021		/* Receive LIU Status */
#define		RSTAT_CPDERR	0x80		/* CLAD Phase detector lost lock */
#define		RSTAT_JMPTY	0x40		/* JAT Empty/Full */
#define		RSTAT_ZCSUB	0x20		/* ZCS detected */
#define		RSTAT_EXZ	0x10		/* Excessive Zeros */
#define		RSTAT_BPV	0x08		/* Bipolar Violations */
#define		RSTAT_EYEOPEN	0x02		/* Equalization State */
#define		RSTAT_PRE_EQ	0x01		/* Pre-Equalizer Status */
#define	Bt8370_RLIU_CR	0x022		/* Receive LIU Configuration */
#define		RLIU_CR_FRZ_SHORT 0x80		/* Freeze Equalizer for short lines */
#define		RLIU_CR_HI_CLICE  0x40		/* High Clock Slicer Threshold */
#define		RLIU_CR_AGC32	0x00		/* AGC Observation Window 32bit */
#define		RLIU_CR_AGC128	0x10		/* AGC Observation Window 128bit */
#define		RLIU_CR_AGC512	0x20		/* AGC Observation Window 512bit */
#define		RLIU_CR_AGC2048	0x30		/* AGC Observation Window 2048bit */
#define		RLIU_CR_EQ_FRZ	0x08		/* Freeze EQ Coefficients */
#define		RLIU_CR_OOR_BLOCK 0x04		/* Disable automatic RLBO */
#define		RLIU_CR_RLBO	0x02		/* Receiver Line Build Out */
#define		RLIU_CR_LONG_EYE  0x01		/* Eye Open Timeout 8192bit */
#define	Bt8370_LPF	0x023		/* RPLL Low Pass Filter */
#define	Bt8370_VGA_MAX	0x024		/* Variable Gain Amplifier Maximum */
#define	Bt8370_EQ_DAT	0x025		/* Equalizer Coefficient Data register */
#define	Bt8370_EQ_PTR	0x026		/* Equalizer Coefficient Table Pointer */
#define	Bt8370_DSLICE	0x027		/* Data Slicer Threshold */
#define	Bt8370_EQ_OUT	0x028		/* Equalizer Output Levels */
#define	Bt8370_VGA	0x029		/* Variable Gain Amplifier Status */
#define	Bt8370_PRE_EQ	0x02A		/* Pre-Equalizer */
#define	Bt8370_COEFF	0x030 /* -037 *//* LMS Adjusted Equalizer Coefficient Status */
#define	Bt8370_GAIN	0x038 /* -03C *//* Equalizer Gain Thresholds */
/* Digital Reveiver (RCVR) */
#define	Bt8370_RCR0	0x040		/* Receiver Configuration */
#define		RCR0_HDB3	0x00		/* */
#define		RCR0_B8ZS	0x00		/* */
#define		RCR0_AMI	0x80		/* */
#define		RCR0_RABORT	0x40		/* */
#define		RCR0_RFORCE	0x20		/* */
#define		RCR0_LFA_FAS	0x18		/* 3 consecutive FAS Errors */
#define		RCR0_LFA_FASCRC	0x08		/* 3 consecutive FAS or 915 CRC Errors */
#define		RCR0_LFA_26F	0x08		/* 2 out of 6 F bit Errors */
#define		RCR0_RZCS_BPV	0x00		/* */
#define		RCR0_RZCS_NBPV	0x01		/* */
#define	Bt8370_RPATT	0x041		/* Receive Test Pattern Configuration */
#define	Bt8370_RLB	0x042		/* Receive Loopback Code Detector Configuration */
#define	Bt8370_LBA	0x043		/* Loopback Activate Code Pattern */
#define	Bt8370_LBD	0x044		/* Loopback Deactivate Code Pattern */
#define	Bt8370_RALM	0x045		/* Receive Alarm Signal Configuration */
#define		RALM_FSNFAS	0x20		/* Include FS/NFAS in FERR and FRED */
#define	Bt8370_LATCH	0x046		/* Alarm/Error/Counter Latch Configuration */
#define		LATCH_STOPCNT	0x08		/* Stop Error Counter during RLOF,RLOS,RAIS */
#define	Bt8370_ALM1	0x047		/* Alarm 1 Status */
#define		ALM1_RMYEL	0x80		/* Receive Multifram Yellow Alarm */
#define		ALM1_RYEL	0x40		/* Receive Yellow Alarm */
#define		ALM1_RAIS	0x10		/* Reveive Alarm Indication Signal */
#define		ALM1_RALOS	0x09		/* Receive Analog Loss of Signal */
#define		ALM1_RLOS	0x04		/* Receive Loss of Signal */
#define		ALM1_RLOF	0x02		/* Receive Loss of Frame Alignment */
#define		ALM1_SIGFRZ	0x01		/* Signalling Freeze */
#define	Bt8370_ALM2	0x048		/* Alarm 2 Status */
#define		ALM2_LOOPDN	0x80		/*  */
#define		ALM2_LOOPUP	0x40		/*  */
#define		ALM2_TSHORT	0x10		/* Transmit Short Circuit */
#define		ALM2_TLOC	0x08		/* Transmit Loss of clock */
#define		ALM2_TLOF	0x02		/* Transmit Loss of Frame alignment */
#define	Bt8370_ALM3	0x049		/* Alarm 3 Status */
#define		ALM3_RMAIS	0x40		/* Receive TS16 Alarm Indication */
#define		ALM3_SEF	0x20		/* Severely Errored Frame */
#define		ALM3_SRED	0x10		/* Loss of CAS Alignment */
#define		ALM3_MRED	0x08		/* Loss of MFAS Alignment */
#define		ALM3_FRED	0x04		/* Loss of T1/FAS Alignment */
#define		ALM3_LOF1	0x02		/* Reason for Loss of Frame Alignment */
#define		ALM3_LOF0	0x01		/* Reason for Loss of Frame Alignment */
/* Error/Alarm Counters */
#define	Bt8370_FERR_LSB	0x050		/* Framing Bit Error Counter LSB */
#define	Bt8370_FERR_MSB	0x051		/* ditto MSB */
#define	Bt8370_CERR_LSB	0x052		/* CRC Error Counter LSB */
#define	Bt8370_CERR_MSB	0x053		/* ditto MSB */
#define	Bt8370_LCV_LSB	0x054		/* Line Code Violation Counter LSB*/
#define	Bt8370_LCV_MSB	0x055		/* ditto MSB */
#define	Bt8370_FEBE_LSB	0x056		/* Far End Block Error Counter LSB*/
#define	Bt8370_FEBE_MSB	0x057		/* ditto MSB */
#define	Bt8370_BERR_LSB	0x058		/* PRBS Bit Error Counter LSB */
#define	Bt8370_BERR_MSB	0x059		/* ditto MSB */
/* Receive Sa-Byte */
#define	Bt8370_RSA4	0x05B		/* Receive Sa4 Byte Buffer */
#define	Bt8370_RSA5	0x05C		/* ditto Sa5 */
#define	Bt8370_RSA6	0x05D		/* ditto Sa6 */
#define	Bt8370_RSA7	0x05E		/* ditto Sa7 */
#define	Bt8370_RSA8	0x05F		/* ditto Sa8 */
/* Transmit LIU (TLIU) */
#define	Bt8370_SHAPE	0x060 /* -067 *//* Transmit Pulse Shape Configuration */
#define	Bt8370_TLIU_CR	0x068		/* Transmit LIU Configuration */
#define		TLIU_CR_120	0x4C		/* 120 Ohms, external term */
#define		TLIU_CR_100	0x40		/* 100 Ohms, external term */
/* Digital Transmitter (XMTR) */
#define	Bt8370_TCR0	0x070		/* Transmit Framer Configuration */
#define		TCR0_FAS	0x00		/* FAS Only */
#define		TCR0_MFAS	0x04		/* FAS + MFAS*/
#define		TCR0_SF		0x04		/* SF Only */
#define		TCR0_ESF	0x01		/* ESF Only */
#define		TCR0_ESFCRC	0x0D		/* ESF + Force CRC */
#define	Bt8370_TCR1	0x071		/* Transmitter Configuration */
#define		TCR1_TABORT	0x40		/* Disable TX Offline Framer */
#define		TCR1_TFORCE	0x20		/* Force TX Reframe */
#define		TCR1_HDB3	0x01		/* Line code HDB3 */
#define		TCR1_B8ZS	0x01		/* Line code B8ZS */
#define		TCR1_AMI	0x00		/* Line code AMI */
#define		TCR1_3FAS	0x10		/* 3 consecutive FAS Errors */
#define		TCR1_26F	0x10		/* 2 out of 6 Frame Bit Errors */
#define	Bt8370_TFRM	0x072		/* Transmit Frame Format */
#define		TFRM_MYEL	0x20		/* Insert MultiFrame Yellow Alarm */
#define		TFRM_YEL	0x10		/* Insert Yellow Alarm */
#define		TFRM_MF		0x08		/* Insert MultiFrame Alignment */
#define		TFRM_FE		0x04		/* Insert FEBE */
#define		TFRM_CRC	0x02		/* Insert CRC4 */
#define		TFRM_FBIT	0x01		/* Insert F bit or FAS/NAS alignment */
#define	Bt8370_TERROR	0x073		/* Transmit Error Insert */
#define	Bt8370_TMAN	0x074		/* Transmit Manual Sa-Byte/FEBE Configuration */
#define		TMAN_MALL	0xF8		/* All Sa Bytes Manual */
#define	Bt8370_TALM	0x075		/* Transmit Alarm Signal Configuration */
#define		TALM_AMYEL	0x20		/* Automatic MultiFrame Yellow Alarm transmit */
#define		TALM_AYEL	0x10		/* Automatic Yellow Alarm transmit */
#define		TALM_AAIS	0x08		/* Automatic AIS Alarm transmit */
#define	Bt8370_TPATT	0x076		/* Transmit Test Pattern Configuration */
#define	Bt8370_TLB	0x077		/* Transmit Inband Loopback Code Configuration */
#define	Bt8370_LBP	0x078		/* Transmit Inband Loopback Code Pattern */
/* Transmit Sa-Byte */
#define	Bt8370_TSA4	0x07B		/* Transmit Sa4 Byte Buffer */
#define	Bt8370_TSA5	0x07C		/* ditto Sa5 */
#define	Bt8370_TSA6	0x07D		/* ditto Sa6 */
#define	Bt8370_TSA7	0x07E		/* ditto Sa7 */
#define	Bt8370_TSA8	0x07F		/* ditto Sa8 */
/* Clock Rate Adapter (CLAD) */
#define	Bt8370_CLAD_CR	0x090		/* Clock Rate Adapter Configuration */
#define		CLAD_CR_CEN	0x80		/* Enable CLAD phase detector */
#define		CLAD_CR_XSEL_1X	0x00		/* Line rate multiplier 1X */
#define		CLAD_CR_XSEL_2X	0x10		/* Line rate multiplier 2X */
#define		CLAD_CR_XSEL_4X	0x20		/* Line rate multiplier 4X */
#define		CLAD_CR_XSEL_8X	0x30		/* Line rate multiplier 8X */
#define		CLAD_CR_LFGAIN	0x05		/* Loop filter gain */
#define	Bt8370_CSEL	0x091		/* CLAD Frequency Select */
#define		CSEL_VSEL_1536	0x60		/* 1536kHz */
#define		CSEL_VSEL_1544	0x50		/* 1544kHz */
#define		CSEL_VSEL_2048	0x10		/* 2048kHz */
#define		CSEL_VSEL_4096	0x20		/* 4096kHz */
#define		CSEL_VSEL_8192	0x30		/* 8192kHz */
#define		CSEL_OSEL_1536	0x06		/* 1536kHz */
#define		CSEL_OSEL_1544	0x05		/* 1544kHz */
#define		CSEL_OSEL_2048	0x01		/* 2048kHz */
#define		CSEL_OSEL_4096	0x02		/* 4096kHz */
#define		CSEL_OSEL_8192	0x03		/* 8192kHz */
#define	Bt8370_CPHASE	0x092		/* CLAD Phase Detector Scale Factor */
#define	Bt8370_CTEST	0x093		/* CLAD Test */
/* Bit Oriented Protocol Transceiver (BOP) */
#define	Bt8370_BOP	0x0A0		/* Bit Oriented Protocol Transceiver */
#define	Bt8370_TBOP	0x0A1		/* Transmit BOP Code Word */
#define	Bt8370_RBOP	0x0A2		/* Receive BOP Code Word */
#define	Bt8370_BOP_STAT	0x0A3		/* BOP Status */
/* Data Link #1 */
#define	Bt8370_DL1_TS	0x0A4		/* DL1 Time Slot Enable */
#define	Bt8370_DL1_BIT	0x0A5		/* DL1 Bit Enable */
#define	Bt8370_DL1_CTL	0x0A6		/* DL1 Control */
#define	Bt8370_RDL1_FFC	0x0A7		/* RDL #1 FIFO Fill Control */
#define	Bt8370_RDL1	0x0A8		/* Receive Data Link FIFO #1 */
#define	Bt8370_RDL1_STAT 0x0A9		/* RDL #1 Status */
#define	Bt8370_PRM1	0x0AA		/* Performance Report Message */
#define	Bt8370_TDL1_FEC	0x0AB		/* TDL #1 FIFO Empty Control */
#define	Bt8370_TDL1_EOM	0x0AC		/* TDL #1 End of Message Control */
#define	Bt8370_TDL1	0x0AD		/* Transmit Data Link FIFO #1*/
#define	Bt8370_TDL1_STAT 0x0AE		/* TDL #1 Status */
/* Data Link #2 */
#define	Bt8370_DL2_TS	0x0AF		/* DL2 Time Slot Enable */
#define	Bt8370_DL2_BIT	0x0B0		/* DL2 Bit Enable */
#define	Bt8370_DL2_CTL	0x0B1		/* DL2 Control */
#define	Bt8370_RDL2_FFC	0x0B2		/* RDL #2 FIFO Fill Control */
#define	Bt8370_RDL2	0x0B3		/* Receive Data Link FIFO #2 */
#define	Bt8370_RDL2_STAT 0x0B4		/* RDL #2 Status */
#define	Bt8370_TDL2_FEC	0x0B6		/* TDL #2 FIFO Empty Control */
#define	Bt8370_TDL2_EOM	0x0B7		/* TDL #2 End of Message Control */
#define	Bt8370_TDL2	0x0B8		/* Transmit Data Link FIFO #2*/
#define	Bt8370_TDL2_STAT 0x0B9		/* TDL #2 Status */
/* Test */
#define	Bt8370_TEST1	0x0BA		/* DLINK Test Configuration */
#define	Bt8370_TEST2	0x0BB		/* DLINK Test Status */
#define	Bt8370_TEST3	0x0BC		/* DLINK Test Status */
#define	Bt8370_TEST4	0x0BD		/* DLINK Test Control #1 or Configuration #2 */
#define	Bt8370_TEST5	0x0BE		/* DLINK Test Control #2 or Configuration #2 */
/* System Bus Interface (SBI) */
#define	Bt8370_SBI_CR	0x0D0		/* System Bus Interface Configuration */
#define		SBI_CR_X2CLK	0x80		/* Times 2 clock */
#define		SBI_CR_SBI_OE	0x40		/* Enable SBI */
#define		SBI_CR_1536	0x08		/* 1536, 24TS*/
#define		SBI_CR_1544	0x07		/* 1544, 24TS + F bit */
#define		SBI_CR_2048	0x06		/* 2048, 32TS */
#define		SBI_CR_4096_A	0x04		/* 4096 Group A */
#define		SBI_CR_4096_B	0x05		/* 4096 Group B */
#define		SBI_CR_8192_A	0x00		/* 8192 Group A */
#define		SBI_CR_8192_B	0x01		/* 8192 Group B */
#define		SBI_CR_8192_C	0x02		/* 8192 Group C */
#define		SBI_CR_8192_D	0x03		/* 8192 Group D */
#define	Bt8370_RSB_CR	0x0D1		/* Receive System Bus Configuration */
#define		RSB_CR_BUS_RSB	0x80		/* Multiple devices on bus */
#define		RSB_CR_SIG_OFF	0x40		/* Inhibit RPCMO Signal reinsertion */
#define		RSB_CR_RPCM_NEG	0x20		/* RSB falling edge */
#define		RSB_CR_RSYN_NEG	0x10		/* RFSYNC falling edge */
#define		RSB_CR_BUS_FRZ	0x08		/* Multiple devices on bus */
#define		RSB_CR_RSB_CTR	0x04		/* Force RSLIP Center */
#define		RSB_CR_RSBI_NORMAL	0x00	/* Normal Slip Buffer Mode */
#define		RSB_CR_RSBI_ELASTIC	0x02	/* Receive Slip Buffer Elastic Mode */
#define		RSB_CR_RSBI_BYPASS	0x03	/* Bypass Slip Buffer */
#define	Bt8370_RSYNC_BIT 0x0D2		/* Receive System Bus Sync Bit Offset */
#define	Bt8370_RSYNC_TS	0x0D3		/* Receive System Bus Sync Time Slot Offset */
#define	Bt8370_TSB_CR	0x0D4		/* Transmit System Bus Configuration */
#define		TSB_CR_BUS_TSB	0x80		/* Bused TSB output */
#define		TSB_CR_TPCM_NEG	0x20		/* TINDO falling edge */
#define		TSB_CR_TSYN_NEG	0x10		/* TFSYNC falling edge */
#define		TSB_CR_TSB_CTR	0x04		/* Force TSLIP Center */
#define		TSB_CR_TSB_NORMAL	0x00	/* Normal Slip Buffer Mode */
#define		TSB_CR_TSB_ELASTIC	0x02	/* Send Slip Buffer Elastic Mode */
#define		TSB_CR_TSB_BYPASS	0x03	/* Bypass Slip Buffer */
#define	Bt8370_TSYNC_BIT 0x0D5		/* Transmit System Bus Sync Bit Offset */
#define	Bt8370_TSYNC_TS	0x0D6		/* Transmit System Bus Sync Time Slot Offset */
#define	Bt8370_RSIG_CR	0x0D7		/* Receive Signaling Configuration */
#define		RSIG_CR_FRZ_OFF	0x04		/* Manual Signaling Update FRZ */
#define		RSIG_CR_THRU	0x01		/* Transparent Robbed Bit Signaling */
#define	Bt8370_RSYNC_FRM 0x0D8		/* Signaling Reinsertion Frame Offset */
#define	Bt8370_SSTAT	0x0D9		/* Slip Buffer Status */
#define		SSTAT_TSDIR	0x80		/* Transmit Slip Direction */
#define		SSTAT_TFSLIP	0x40		/* Controlled Slip Event */
#define		SSTAT_TUSLIP	0x20		/* Uncontrolled Slip Event */
#define		SSTAT_RSDIR	0x08		/* Receive Slip Direction */
#define		SSTAT_RFSLIP	0x04		/* Controlled Slip Event */
#define		SSTAT_RUSLIP	0x02		/* Uncontrolled Slip Event */
#define	Bt8370_STACK	0x0DA		/* Receive Signaling Stack */
#define	Bt8370_RPHASE	0x0DB		/* RSLIP Phase Status */
#define	Bt8370_TPHASE	0x0DC		/* TSLIP Phase Status */
#define	Bt8370_PERR	0x0DD		/* RAM Parity Status */
#define	Bt8370_SBCn	0x0E0 /* -0FF *//* System Bus Per-Channel Control */
#define		SBCn_INSERT	0x40		/* Insert RX Signaling on RPCMO */
#define		SBCn_SIG_LP	0x20		/* Local Signaling Loopback */
#define		SBCn_RLOOP	0x10		/* Local Loopback */
#define		SBCn_RINDO	0x08		/* Activate RINDO time slot indicator */
#define		SBCn_TINDO	0x04		/* Activate TINDO time slot indicator */
#define		SBCn_TSIG_AB	0x02		/* AB Signaling */
#define		SBCn_ASSIGN	0x01		/* Enable System Bus Time Slot */
/* Buffer Memory */
#define	Bt8370_TPCn	0x100		/* Transmit Per-Channel Control */
#define		TPCn_CLEAR	0x00		/* Clear Channel Mode */
#define		TPCn_EMFBIT	0x80		/* TB7ZS/EMFBIT */
#define		TPCn_TLOOP	0x40		/* Remote DS0 Channel Loopback */
#define		TPCn_TIDLE	0x20		/* Transmit Idle */
#define		TPCn_TLOCAL	0x10		/* Transmit Local Signaling */
#define		TPCn_TSIGA	0x08		/* ABCD signaling value */
#define		TPCn_TSIGB	0x04		/* ABCD signaling value */
#define		TPCn_TSIGC	0x02		/* ABCD signaling value */
#define		TPCn_TSIGD	0x01		/* ABCD signaling value */
#define		TPCn_TSIGO	TPCn_TSIGA	/* Transmit Signaling Output */
#define		TPCn_RSIGO	TPCn_TSIGB	/* Receive Signaling Output */
#define	Bt8370_TSIGn	0x120		/* Transmit Signaling Buffer */
#define	Bt8370_TSLIP_LOn 0x140		/* Transmit PCM Slip Buffer */
#define	Bt8370_TSLIP_HIn 0x160		/* Transmit PCM Slip Buffer */
#define	Bt8370_RPCn	0x180		/* Receive Per-Channel Control */
#define		RPCn_CLEAR	0x00		/* Clear Channel Mode */
#define		RPCn_RSIG_AB	0x80		/* AB Signaling */
#define		RPCn_RIDLE	0x40		/* Time Slot Idle */
#define		RPCn_SIG_STK	0x20		/* Receive Signal Stack */
#define		RPCn_RLOCAL	0x10		/* Enable Local Signaling Output */
#define		RPCn_RSIGA	0x08		/* Local Receive Signaling */
#define		RPCn_RSIGB	0x04		/* Local Receive Signaling */
#define		RPCn_RSIGC	0x02		/* Local Receive Signaling */
#define		RPCn_RSIGD	0x01		/* Local Receive Signaling */
#define	Bt8370_RSIGn	0x1A0		/* Receive Signaling Buffer */
#define	Bt8370_RSLIP_LOn 0x1C0		/* Receive PCM Slip Buffer */
#define	Bt8370_RSLIP_HIn 0x1E0		/* Receive PCM Slip Buffer */