OProfile: Fix buffer synchronization for IBS
[linux-2.6] / drivers / telephony / ixj.h
1 /******************************************************************************
2  *    ixj.h
3  *
4  *
5  * Device Driver for Quicknet Technologies, Inc.'s Telephony cards
6  * including the Internet PhoneJACK, Internet PhoneJACK Lite,
7  * Internet PhoneJACK PCI, Internet LineJACK, Internet PhoneCARD and
8  * SmartCABLE
9  *
10  *    (c) Copyright 1999-2001  Quicknet Technologies, Inc.
11  *
12  *    This program is free software; you can redistribute it and/or
13  *    modify it under the terms of the GNU General Public License
14  *    as published by the Free Software Foundation; either version
15  *    2 of the License, or (at your option) any later version.
16  *
17  * Author:          Ed Okerson, <eokerson@quicknet.net>
18  *    
19  * Contributors:    Greg Herlein, <gherlein@quicknet.net>
20  *                  David W. Erhart, <derhart@quicknet.net>
21  *                  John Sellers, <jsellers@quicknet.net>
22  *                  Mike Preston, <mpreston@quicknet.net>
23  *
24  * More information about the hardware related to this driver can be found
25  * at our website:    http://www.quicknet.net
26  *
27  * Fixes:
28  *
29  * IN NO EVENT SHALL QUICKNET TECHNOLOGIES, INC. BE LIABLE TO ANY PARTY FOR
30  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
31  * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF QUICKNET
32  * TECHNOLOGIES, INC.HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33  *
34  * QUICKNET TECHNOLOGIES, INC. SPECIFICALLY DISCLAIMS ANY WARRANTIES,
35  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
36  * AND FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
37  * ON AN "AS IS" BASIS, AND QUICKNET TECHNOLOGIES, INC. HAS NO OBLIGATION 
38  * TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
39  *
40  *****************************************************************************/
41 #define IXJ_VERSION 3031
42
43 #include <linux/types.h>
44
45 #include <linux/ixjuser.h>
46 #include <linux/phonedev.h>
47
48 typedef __u16 WORD;
49 typedef __u32 DWORD;
50 typedef __u8 BYTE;
51
52 #ifndef IXJMAX
53 #define IXJMAX 16
54 #endif
55
56 /******************************************************************************
57 *
58 *  This structure when unioned with the structures below makes simple byte
59 *  access to the registers easier.
60 *
61 ******************************************************************************/
62 typedef struct {
63         unsigned char low;
64         unsigned char high;
65 } BYTES;
66
67 typedef union {
68         BYTES bytes;
69         short word;
70 } IXJ_WORD;
71
72 typedef struct{
73         unsigned int b0:1;
74         unsigned int b1:1;
75         unsigned int b2:1;
76         unsigned int b3:1;
77         unsigned int b4:1;
78         unsigned int b5:1;
79         unsigned int b6:1;
80         unsigned int b7:1;
81 } IXJ_CBITS;
82
83 typedef union{
84         IXJ_CBITS cbits;
85           char  cbyte;
86 } IXJ_CBYTE;
87
88 /******************************************************************************
89 *
90 *  This structure represents the Hardware Control Register of the CT8020/8021
91 *  The CT8020 is used in the Internet PhoneJACK, and the 8021 in the
92 *  Internet LineJACK
93 *
94 ******************************************************************************/
95 typedef struct {
96         unsigned int rxrdy:1;
97         unsigned int txrdy:1;
98         unsigned int status:1;
99         unsigned int auxstatus:1;
100         unsigned int rxdma:1;
101         unsigned int txdma:1;
102         unsigned int rxburst:1;
103         unsigned int txburst:1;
104         unsigned int dmadir:1;
105         unsigned int cont:1;
106         unsigned int irqn:1;
107         unsigned int t:5;
108 } HCRBIT;
109
110 typedef union {
111         HCRBIT bits;
112         BYTES bytes;
113 } HCR;
114
115 /******************************************************************************
116 *
117 *  This structure represents the Hardware Status Register of the CT8020/8021
118 *  The CT8020 is used in the Internet PhoneJACK, and the 8021 in the
119 *  Internet LineJACK
120 *
121 ******************************************************************************/
122 typedef struct {
123         unsigned int controlrdy:1;
124         unsigned int auxctlrdy:1;
125         unsigned int statusrdy:1;
126         unsigned int auxstatusrdy:1;
127         unsigned int rxrdy:1;
128         unsigned int txrdy:1;
129         unsigned int restart:1;
130         unsigned int irqn:1;
131         unsigned int rxdma:1;
132         unsigned int txdma:1;
133         unsigned int cohostshutdown:1;
134         unsigned int t:5;
135 } HSRBIT;
136
137 typedef union {
138         HSRBIT bits;
139         BYTES bytes;
140 } HSR;
141
142 /******************************************************************************
143 *
144 *  This structure represents the General Purpose IO Register of the CT8020/8021
145 *  The CT8020 is used in the Internet PhoneJACK, and the 8021 in the
146 *  Internet LineJACK
147 *
148 ******************************************************************************/
149 typedef struct {
150         unsigned int x:1;
151         unsigned int gpio1:1;
152         unsigned int gpio2:1;
153         unsigned int gpio3:1;
154         unsigned int gpio4:1;
155         unsigned int gpio5:1;
156         unsigned int gpio6:1;
157         unsigned int gpio7:1;
158         unsigned int xread:1;
159         unsigned int gpio1read:1;
160         unsigned int gpio2read:1;
161         unsigned int gpio3read:1;
162         unsigned int gpio4read:1;
163         unsigned int gpio5read:1;
164         unsigned int gpio6read:1;
165         unsigned int gpio7read:1;
166 } GPIOBIT;
167
168 typedef union {
169         GPIOBIT bits;
170         BYTES bytes;
171         unsigned short word;
172 } GPIO;
173
174 /******************************************************************************
175 *
176 *  This structure represents the Line Monitor status response
177 *
178 ******************************************************************************/
179 typedef struct {
180         unsigned int digit:4;
181         unsigned int cpf_valid:1;
182         unsigned int dtmf_valid:1;
183         unsigned int peak:1;
184         unsigned int z:1;
185         unsigned int f0:1;
186         unsigned int f1:1;
187         unsigned int f2:1;
188         unsigned int f3:1;
189         unsigned int frame:4;
190 } LMON;
191
192 typedef union {
193         LMON bits;
194         BYTES bytes;
195 } DTMF;
196
197 typedef struct {
198         unsigned int z:7;
199         unsigned int dtmf_en:1;
200         unsigned int y:4;
201         unsigned int F3:1;
202         unsigned int F2:1;
203         unsigned int F1:1;
204         unsigned int F0:1;
205 } CP;
206
207 typedef union {
208         CP bits;
209         BYTES bytes;
210 } CPTF;
211
212 /******************************************************************************
213 *
214 *  This structure represents the Status Control Register on the Internet
215 *  LineJACK
216 *
217 ******************************************************************************/
218 typedef struct {
219         unsigned int c0:1;
220         unsigned int c1:1;
221         unsigned int stereo:1;
222         unsigned int daafsyncen:1;
223         unsigned int led1:1;
224         unsigned int led2:1;
225         unsigned int led3:1;
226         unsigned int led4:1;
227 } PSCRWI;                       /* Internet LineJACK and Internet PhoneJACK Lite */
228
229 typedef struct {
230         unsigned int eidp:1;
231         unsigned int eisd:1;
232         unsigned int x:6;
233 } PSCRWP;                       /* Internet PhoneJACK PCI */
234
235 typedef union {
236         PSCRWI bits;
237         PSCRWP pcib;
238         char byte;
239 } PLD_SCRW;
240
241 typedef struct {
242         unsigned int c0:1;
243         unsigned int c1:1;
244         unsigned int x:1;
245         unsigned int d0ee:1;
246         unsigned int mixerbusy:1;
247         unsigned int sci:1;
248         unsigned int dspflag:1;
249         unsigned int daaflag:1;
250 } PSCRRI;
251
252 typedef struct {
253         unsigned int eidp:1;
254         unsigned int eisd:1;
255         unsigned int x:4;
256         unsigned int dspflag:1;
257         unsigned int det:1;
258 } PSCRRP;
259
260 typedef union {
261         PSCRRI bits;
262         PSCRRP pcib;
263         char byte;
264 } PLD_SCRR;
265
266 /******************************************************************************
267 *
268 *  These structures represents the SLIC Control Register on the
269 *  Internet LineJACK
270 *
271 ******************************************************************************/
272 typedef struct {
273         unsigned int c1:1;
274         unsigned int c2:1;
275         unsigned int c3:1;
276         unsigned int b2en:1;
277         unsigned int spken:1;
278         unsigned int rly1:1;
279         unsigned int rly2:1;
280         unsigned int rly3:1;
281 } PSLICWRITE;
282
283 typedef struct {
284         unsigned int state:3;
285         unsigned int b2en:1;
286         unsigned int spken:1;
287         unsigned int c3:1;
288         unsigned int potspstn:1;
289         unsigned int det:1;
290 } PSLICREAD;
291
292 typedef struct {
293         unsigned int c1:1;
294         unsigned int c2:1;
295         unsigned int c3:1;
296         unsigned int b2en:1;
297         unsigned int e1:1;
298         unsigned int mic:1;
299         unsigned int spk:1;
300         unsigned int x:1;
301 } PSLICPCI;
302
303 typedef union {
304         PSLICPCI pcib;
305         PSLICWRITE bits;
306         PSLICREAD slic;
307         char byte;
308 } PLD_SLICW;
309
310 typedef union {
311         PSLICPCI pcib;
312         PSLICREAD bits;
313         char byte;
314 } PLD_SLICR;
315
316 /******************************************************************************
317 *
318 *  These structures represents the Clock Control Register on the
319 *  Internet LineJACK
320 *
321 ******************************************************************************/
322 typedef struct {
323         unsigned int clk0:1;
324         unsigned int clk1:1;
325         unsigned int clk2:1;
326         unsigned int x0:1;
327         unsigned int slic_e1:1;
328         unsigned int x1:1;
329         unsigned int x2:1;
330         unsigned int x3:1;
331 } PCLOCK;
332
333 typedef union {
334         PCLOCK bits;
335         char byte;
336 } PLD_CLOCK;
337
338 /******************************************************************************
339 *
340 *  These structures deal with the mixer on the Internet LineJACK
341 *
342 ******************************************************************************/
343
344 typedef struct {
345         unsigned short vol[10];
346         unsigned int recsrc;
347         unsigned int modcnt;
348         unsigned short micpreamp;
349 } MIX;
350
351 /******************************************************************************
352 *
353 *  These structures deal with the control logic on the Internet PhoneCARD
354 *
355 ******************************************************************************/
356 typedef struct {
357         unsigned int x0:4;      /* unused bits */
358
359         unsigned int ed:1;      /* Event Detect */
360
361         unsigned int drf:1;     /* SmartCABLE Removal Flag 1=no cable */
362
363         unsigned int dspf:1;    /* DSP Flag 1=DSP Ready */
364
365         unsigned int crr:1;     /* Control Register Ready */
366
367 } COMMAND_REG1;
368
369 typedef union {
370         COMMAND_REG1 bits;
371         unsigned char byte;
372 } PCMCIA_CR1;
373
374 typedef struct {
375         unsigned int x0:4;      /* unused bits */
376
377         unsigned int rstc:1;    /* SmartCABLE Reset */
378
379         unsigned int pwr:1;     /* SmartCABLE Power */
380
381         unsigned int x1:2;      /* unused bits */
382
383 } COMMAND_REG2;
384
385 typedef union {
386         COMMAND_REG2 bits;
387         unsigned char byte;
388 } PCMCIA_CR2;
389
390 typedef struct {
391         unsigned int addr:5;    /* R/W SmartCABLE Register Address */
392
393         unsigned int rw:1;      /* Read / Write flag */
394
395         unsigned int dev:2;     /* 2 bit SmartCABLE Device Address */
396
397 } CONTROL_REG;
398
399 typedef union {
400         CONTROL_REG bits;
401         unsigned char byte;
402 } PCMCIA_SCCR;
403
404 typedef struct {
405         unsigned int hsw:1;
406         unsigned int det:1;
407         unsigned int led2:1;
408         unsigned int led1:1;
409         unsigned int ring1:1;
410         unsigned int ring0:1;
411         unsigned int x:1;
412         unsigned int powerdown:1;
413 } PCMCIA_SLIC_REG;
414
415 typedef union {
416         PCMCIA_SLIC_REG bits;
417         unsigned char byte;
418 } PCMCIA_SLIC;
419
420 typedef struct {
421         unsigned int cpd:1;     /* Chip Power Down */
422
423         unsigned int mpd:1;     /* MIC Bias Power Down */
424
425         unsigned int hpd:1;     /* Handset Drive Power Down */
426
427         unsigned int lpd:1;     /* Line Drive Power Down */
428
429         unsigned int spd:1;     /* Speaker Drive Power Down */
430
431         unsigned int x:2;       /* unused bits */
432
433         unsigned int sr:1;      /* Software Reset */
434
435 } Si3CONTROL1;
436
437 typedef union {
438         Si3CONTROL1 bits;
439         unsigned char byte;
440 } Si3C1;
441
442 typedef struct {
443         unsigned int al:1;      /* Analog Loopback DAC analog -> ADC analog */
444
445         unsigned int dl2:1;     /* Digital Loopback DAC -> ADC one bit */
446
447         unsigned int dl1:1;     /* Digital Loopback ADC -> DAC one bit */
448
449         unsigned int pll:1;     /* 1 = div 10, 0 = div 5 */
450
451         unsigned int hpd:1;     /* HPF disable */
452
453         unsigned int x:3;       /* unused bits */
454
455 } Si3CONTROL2;
456
457 typedef union {
458         Si3CONTROL2 bits;
459         unsigned char byte;
460 } Si3C2;
461
462 typedef struct {
463         unsigned int iir:1;     /* 1 enables IIR, 0 enables FIR */
464
465         unsigned int him:1;     /* Handset Input Mute */
466
467         unsigned int mcm:1;     /* MIC In Mute */
468
469         unsigned int mcg:2;     /* MIC In Gain */
470
471         unsigned int lim:1;     /* Line In Mute */
472
473         unsigned int lig:2;     /* Line In Gain */
474
475 } Si3RXGAIN;
476
477 typedef union {
478         Si3RXGAIN bits;
479         unsigned char byte;
480 } Si3RXG;
481
482 typedef struct {
483         unsigned int hom:1;     /* Handset Out Mute */
484
485         unsigned int lom:1;     /* Line Out Mute */
486
487         unsigned int rxg:5;     /* RX PGA Gain */
488
489         unsigned int x:1;       /* unused bit */
490
491 } Si3ADCVOLUME;
492
493 typedef union {
494         Si3ADCVOLUME bits;
495         unsigned char byte;
496 } Si3ADC;
497
498 typedef struct {
499         unsigned int srm:1;     /* Speaker Right Mute */
500
501         unsigned int slm:1;     /* Speaker Left Mute */
502
503         unsigned int txg:5;     /* TX PGA Gain */
504
505         unsigned int x:1;       /* unused bit */
506
507 } Si3DACVOLUME;
508
509 typedef union {
510         Si3DACVOLUME bits;
511         unsigned char byte;
512 } Si3DAC;
513
514 typedef struct {
515         unsigned int x:5;       /* unused bit */
516
517         unsigned int losc:1;    /* Line Out Short Circuit */
518
519         unsigned int srsc:1;    /* Speaker Right Short Circuit */
520
521         unsigned int slsc:1;    /* Speaker Left Short Circuit */
522
523 } Si3STATUSREPORT;
524
525 typedef union {
526         Si3STATUSREPORT bits;
527         unsigned char byte;
528 } Si3STAT;
529
530 typedef struct {
531         unsigned int sot:2;     /* Speaker Out Attenuation */
532
533         unsigned int lot:2;     /* Line Out Attenuation */
534
535         unsigned int x:4;       /* unused bits */
536
537 } Si3ANALOGATTN;
538
539 typedef union {
540         Si3ANALOGATTN bits;
541         unsigned char byte;
542 } Si3AATT;
543
544 /******************************************************************************
545 *
546 *  These structures deal with the DAA on the Internet LineJACK
547 *
548 ******************************************************************************/
549
550 typedef struct _DAA_REGS {
551         /*----------------------------------------------- */
552         /* SOP Registers */
553         /* */
554         BYTE bySOP;
555
556         union _SOP_REGS {
557                 struct _SOP {
558                         union   /* SOP - CR0 Register */
559                          {
560                                 BYTE reg;
561                                 struct _CR0_BITREGS {
562                                         BYTE CLK_EXT:1;         /* cr0[0:0] */
563
564                                         BYTE RIP:1;     /* cr0[1:1] */
565
566                                         BYTE AR:1;      /* cr0[2:2] */
567
568                                         BYTE AX:1;      /* cr0[3:3] */
569
570                                         BYTE FRR:1;     /* cr0[4:4] */
571
572                                         BYTE FRX:1;     /* cr0[5:5] */
573
574                                         BYTE IM:1;      /* cr0[6:6] */
575
576                                         BYTE TH:1;      /* cr0[7:7] */
577
578                                 } bitreg;
579                         } cr0;
580
581                         union   /* SOP - CR1 Register */
582                          {
583                                 BYTE reg;
584                                 struct _CR1_REGS {
585                                         BYTE RM:1;      /* cr1[0:0] */
586
587                                         BYTE RMR:1;     /* cr1[1:1] */
588
589                                         BYTE No_auto:1;         /* cr1[2:2] */
590
591                                         BYTE Pulse:1;   /* cr1[3:3] */
592
593                                         BYTE P_Tone1:1;         /* cr1[4:4] */
594
595                                         BYTE P_Tone2:1;         /* cr1[5:5] */
596
597                                         BYTE E_Tone1:1;         /* cr1[6:6] */
598
599                                         BYTE E_Tone2:1;         /* cr1[7:7] */
600
601                                 } bitreg;
602                         } cr1;
603
604                         union   /* SOP - CR2 Register */
605                          {
606                                 BYTE reg;
607                                 struct _CR2_REGS {
608                                         BYTE Call_II:1;         /* CR2[0:0] */
609
610                                         BYTE Call_I:1;  /* CR2[1:1] */
611
612                                         BYTE Call_en:1;         /* CR2[2:2] */
613
614                                         BYTE Call_pon:1;        /* CR2[3:3] */
615
616                                         BYTE IDR:1;     /* CR2[4:4] */
617
618                                         BYTE COT_R:3;   /* CR2[5:7] */
619
620                                 } bitreg;
621                         } cr2;
622
623                         union   /* SOP - CR3 Register */
624                          {
625                                 BYTE reg;
626                                 struct _CR3_REGS {
627                                         BYTE DHP_X:1;   /* CR3[0:0] */
628
629                                         BYTE DHP_R:1;   /* CR3[1:1] */
630
631                                         BYTE Cal_pctl:1;        /* CR3[2:2] */
632
633                                         BYTE SEL:1;     /* CR3[3:3] */
634
635                                         BYTE TestLoops:4;       /* CR3[4:7] */
636
637                                 } bitreg;
638                         } cr3;
639
640                         union   /* SOP - CR4 Register */
641                          {
642                                 BYTE reg;
643                                 struct _CR4_REGS {
644                                         BYTE Fsc_en:1;  /* CR4[0:0] */
645
646                                         BYTE Int_en:1;  /* CR4[1:1] */
647
648                                         BYTE AGX:2;     /* CR4[2:3] */
649
650                                         BYTE AGR_R:2;   /* CR4[4:5] */
651
652                                         BYTE AGR_Z:2;   /* CR4[6:7] */
653
654                                 } bitreg;
655                         } cr4;
656
657                         union   /* SOP - CR5 Register */
658                          {
659                                 BYTE reg;
660                                 struct _CR5_REGS {
661                                         BYTE V_0:1;     /* CR5[0:0] */
662
663                                         BYTE V_1:1;     /* CR5[1:1] */
664
665                                         BYTE V_2:1;     /* CR5[2:2] */
666
667                                         BYTE V_3:1;     /* CR5[3:3] */
668
669                                         BYTE V_4:1;     /* CR5[4:4] */
670
671                                         BYTE V_5:1;     /* CR5[5:5] */
672
673                                         BYTE V_6:1;     /* CR5[6:6] */
674
675                                         BYTE V_7:1;     /* CR5[7:7] */
676
677                                 } bitreg;
678                         } cr5;
679
680                         union   /* SOP - CR6 Register */
681                          {
682                                 BYTE reg;
683                                 struct _CR6_REGS {
684                                         BYTE reserved:8;        /* CR6[0:7] */
685
686                                 } bitreg;
687                         } cr6;
688
689                         union   /* SOP - CR7 Register */
690                          {
691                                 BYTE reg;
692                                 struct _CR7_REGS {
693                                         BYTE reserved:8;        /* CR7[0:7] */
694
695                                 } bitreg;
696                         } cr7;
697                 } SOP;
698
699                 BYTE ByteRegs[sizeof(struct _SOP)];
700
701         } SOP_REGS;
702
703         /* DAA_REGS.SOP_REGS.SOP.CR5.reg */
704         /* DAA_REGS.SOP_REGS.SOP.CR5.bitreg */
705         /* DAA_REGS.SOP_REGS.SOP.CR5.bitreg.V_2 */
706         /* DAA_REGS.SOP_REGS.ByteRegs[5] */
707
708         /*----------------------------------------------- */
709         /* XOP Registers */
710         /* */
711         BYTE byXOP;
712
713         union _XOP_REGS {
714                 struct _XOP {
715                         union   XOPXR0/* XOP - XR0 Register - Read values */
716                          {
717                                 BYTE reg;
718                                 struct _XR0_BITREGS {
719                                         BYTE SI_0:1;    /* XR0[0:0] - Read */
720
721                                         BYTE SI_1:1;    /* XR0[1:1] - Read */
722
723                                         BYTE VDD_OK:1;  /* XR0[2:2] - Read */
724
725                                         BYTE Caller_ID:1;       /* XR0[3:3] - Read */
726
727                                         BYTE RING:1;    /* XR0[4:4] - Read */
728
729                                         BYTE Cadence:1;         /* XR0[5:5] - Read */
730
731                                         BYTE Wake_up:1;         /* XR0[6:6] - Read */
732
733                                         BYTE RMR:1;     /* XR0[7:7] - Read */
734
735                                 } bitreg;
736                         } xr0;
737
738                         union   /* XOP - XR1 Register */
739                          {
740                                 BYTE reg;
741                                 struct _XR1_BITREGS {
742                                         BYTE M_SI_0:1;  /* XR1[0:0] */
743
744                                         BYTE M_SI_1:1;  /* XR1[1:1] */
745
746                                         BYTE M_VDD_OK:1;        /* XR1[2:2] */
747
748                                         BYTE M_Caller_ID:1;     /* XR1[3:3] */
749
750                                         BYTE M_RING:1;  /* XR1[4:4] */
751
752                                         BYTE M_Cadence:1;       /* XR1[5:5] */
753
754                                         BYTE M_Wake_up:1;       /* XR1[6:6] */
755
756                                         BYTE unused:1;  /* XR1[7:7] */
757
758                                 } bitreg;
759                         } xr1;
760
761                         union   /* XOP - XR2 Register */
762                          {
763                                 BYTE reg;
764                                 struct _XR2_BITREGS {
765                                         BYTE CTO0:1;    /* XR2[0:0] */
766
767                                         BYTE CTO1:1;    /* XR2[1:1] */
768
769                                         BYTE CTO2:1;    /* XR2[2:2] */
770
771                                         BYTE CTO3:1;    /* XR2[3:3] */
772
773                                         BYTE CTO4:1;    /* XR2[4:4] */
774
775                                         BYTE CTO5:1;    /* XR2[5:5] */
776
777                                         BYTE CTO6:1;    /* XR2[6:6] */
778
779                                         BYTE CTO7:1;    /* XR2[7:7] */
780
781                                 } bitreg;
782                         } xr2;
783
784                         union   /* XOP - XR3 Register */
785                          {
786                                 BYTE reg;
787                                 struct _XR3_BITREGS {
788                                         BYTE DCR0:1;    /* XR3[0:0] */
789
790                                         BYTE DCR1:1;    /* XR3[1:1] */
791
792                                         BYTE DCI:1;     /* XR3[2:2] */
793
794                                         BYTE DCU0:1;    /* XR3[3:3] */
795
796                                         BYTE DCU1:1;    /* XR3[4:4] */
797
798                                         BYTE B_off:1;   /* XR3[5:5] */
799
800                                         BYTE AGB0:1;    /* XR3[6:6] */
801
802                                         BYTE AGB1:1;    /* XR3[7:7] */
803
804                                 } bitreg;
805                         } xr3;
806
807                         union   /* XOP - XR4 Register */
808                          {
809                                 BYTE reg;
810                                 struct _XR4_BITREGS {
811                                         BYTE C_0:1;     /* XR4[0:0] */
812
813                                         BYTE C_1:1;     /* XR4[1:1] */
814
815                                         BYTE C_2:1;     /* XR4[2:2] */
816
817                                         BYTE C_3:1;     /* XR4[3:3] */
818
819                                         BYTE C_4:1;     /* XR4[4:4] */
820
821                                         BYTE C_5:1;     /* XR4[5:5] */
822
823                                         BYTE C_6:1;     /* XR4[6:6] */
824
825                                         BYTE C_7:1;     /* XR4[7:7] */
826
827                                 } bitreg;
828                         } xr4;
829
830                         union   /* XOP - XR5 Register */
831                          {
832                                 BYTE reg;
833                                 struct _XR5_BITREGS {
834                                         BYTE T_0:1;     /* XR5[0:0] */
835
836                                         BYTE T_1:1;     /* XR5[1:1] */
837
838                                         BYTE T_2:1;     /* XR5[2:2] */
839
840                                         BYTE T_3:1;     /* XR5[3:3] */
841
842                                         BYTE T_4:1;     /* XR5[4:4] */
843
844                                         BYTE T_5:1;     /* XR5[5:5] */
845
846                                         BYTE T_6:1;     /* XR5[6:6] */
847
848                                         BYTE T_7:1;     /* XR5[7:7] */
849
850                                 } bitreg;
851                         } xr5;
852
853                         union   /* XOP - XR6 Register - Read Values */
854                          {
855                                 BYTE reg;
856                                 struct _XR6_BITREGS {
857                                         BYTE CPS0:1;    /* XR6[0:0] */
858
859                                         BYTE CPS1:1;    /* XR6[1:1] */
860
861                                         BYTE unused1:2;         /* XR6[2:3] */
862
863                                         BYTE CLK_OFF:1;         /* XR6[4:4] */
864
865                                         BYTE unused2:3;         /* XR6[5:7] */
866
867                                 } bitreg;
868                         } xr6;
869
870                         union   /* XOP - XR7 Register */
871                          {
872                                 BYTE reg;
873                                 struct _XR7_BITREGS {
874                                         BYTE unused1:1;         /* XR7[0:0] */
875
876                                         BYTE Vdd0:1;    /* XR7[1:1] */
877
878                                         BYTE Vdd1:1;    /* XR7[2:2] */
879
880                                         BYTE unused2:5;         /* XR7[3:7] */
881
882                                 } bitreg;
883                         } xr7;
884                 } XOP;
885
886                 BYTE ByteRegs[sizeof(struct _XOP)];
887
888         } XOP_REGS;
889
890         /* DAA_REGS.XOP_REGS.XOP.XR7.reg */
891         /* DAA_REGS.XOP_REGS.XOP.XR7.bitreg */
892         /* DAA_REGS.XOP_REGS.XOP.XR7.bitreg.Vdd0 */
893         /* DAA_REGS.XOP_REGS.ByteRegs[7] */
894
895         /*----------------------------------------------- */
896         /* COP Registers */
897         /* */
898         BYTE byCOP;
899
900         union _COP_REGS {
901                 struct _COP {
902                         BYTE THFilterCoeff_1[8];        /* COP - TH Filter Coefficients,      CODE=0, Part 1 */
903
904                         BYTE THFilterCoeff_2[8];        /* COP - TH Filter Coefficients,      CODE=1, Part 2 */
905
906                         BYTE THFilterCoeff_3[8];        /* COP - TH Filter Coefficients,      CODE=2, Part 3 */
907
908                         BYTE RingerImpendance_1[8];     /* COP - Ringer Impendance Coefficients,  CODE=3, Part 1 */
909
910                         BYTE IMFilterCoeff_1[8];        /* COP - IM Filter Coefficients,      CODE=4, Part 1 */
911
912                         BYTE IMFilterCoeff_2[8];        /* COP - IM Filter Coefficients,      CODE=5, Part 2 */
913
914                         BYTE RingerImpendance_2[8];     /* COP - Ringer Impendance Coefficients,  CODE=6, Part 2 */
915
916                         BYTE FRRFilterCoeff[8];         /* COP - FRR Filter Coefficients,      CODE=7 */
917
918                         BYTE FRXFilterCoeff[8];         /* COP - FRX Filter Coefficients,      CODE=8 */
919
920                         BYTE ARFilterCoeff[4];  /* COP - AR Filter Coefficients,      CODE=9 */
921
922                         BYTE AXFilterCoeff[4];  /* COP - AX Filter Coefficients,      CODE=10  */
923
924                         BYTE Tone1Coeff[4];     /* COP - Tone1 Coefficients,        CODE=11 */
925
926                         BYTE Tone2Coeff[4];     /* COP - Tone2 Coefficients,        CODE=12 */
927
928                         BYTE LevelmeteringRinging[4];   /* COP - Levelmetering Ringing,        CODE=13 */
929
930                         BYTE CallerID1stTone[8];        /* COP - Caller ID 1st Tone,        CODE=14 */
931
932                         BYTE CallerID2ndTone[8];        /* COP - Caller ID 2nd Tone,        CODE=15 */
933
934                 } COP;
935
936                 BYTE ByteRegs[sizeof(struct _COP)];
937
938         } COP_REGS;
939
940         /* DAA_REGS.COP_REGS.COP.XR7.Tone1Coeff[3] */
941         /* DAA_REGS.COP_REGS.COP.XR7.bitreg */
942         /* DAA_REGS.COP_REGS.COP.XR7.bitreg.Vdd0 */
943         /* DAA_REGS.COP_REGS.ByteRegs[57] */
944
945         /*----------------------------------------------- */
946         /* CAO Registers */
947         /* */
948         BYTE byCAO;
949
950         union _CAO_REGS {
951                 struct _CAO {
952                         BYTE CallerID[512];     /* CAO - Caller ID Bytes */
953
954                 } CAO;
955
956                 BYTE ByteRegs[sizeof(struct _CAO)];
957         } CAO_REGS;
958
959         union                   /* XOP - XR0 Register - Write values */
960          {
961                 BYTE reg;
962                 struct _XR0_BITREGSW {
963                         BYTE SO_0:1;    /* XR1[0:0] - Write */
964
965                         BYTE SO_1:1;    /* XR1[1:1] - Write */
966
967                         BYTE SO_2:1;    /* XR1[2:2] - Write */
968
969                         BYTE unused:5;  /* XR1[3:7] - Write */
970
971                 } bitreg;
972         } XOP_xr0_W;
973
974         union                   /* XOP - XR6 Register - Write values */
975          {
976                 BYTE reg;
977                 struct _XR6_BITREGSW {
978                         BYTE unused1:4;         /* XR6[0:3] */
979
980                         BYTE CLK_OFF:1;         /* XR6[4:4] */
981
982                         BYTE unused2:3;         /* XR6[5:7] */
983
984                 } bitreg;
985         } XOP_xr6_W;
986
987 } DAA_REGS;
988
989 #define ALISDAA_ID_BYTE      0x81
990 #define ALISDAA_CALLERID_SIZE  512
991
992 /*------------------------------ */
993 /* */
994 /*  Misc definitions */
995 /* */
996
997 /* Power Up Operation */
998 #define SOP_PU_SLEEP    0
999 #define SOP_PU_RINGING    1
1000 #define SOP_PU_CONVERSATION  2
1001 #define SOP_PU_PULSEDIALING  3
1002 #define SOP_PU_RESET    4
1003
1004 #define ALISDAA_CALLERID_SIZE 512
1005
1006 #define PLAYBACK_MODE_COMPRESSED        0       /*        Selects: Compressed modes, TrueSpeech 8.5-4.1, G.723.1, G.722, G.728, G.729 */
1007 #define PLAYBACK_MODE_TRUESPEECH_V40    0       /*        Selects: TrueSpeech 8.5, 6.3, 5.3, 4.8 or 4.1 Kbps */
1008 #define PLAYBACK_MODE_TRUESPEECH        8       /*        Selects: TrueSpeech 8.5, 6.3, 5.3, 4.8 or 4.1 Kbps Version 5.1 */
1009 #define PLAYBACK_MODE_ULAW              2       /*        Selects: 64 Kbit/sec MuA-law PCM */
1010 #define PLAYBACK_MODE_ALAW              10      /*        Selects: 64 Kbit/sec A-law PCM */
1011 #define PLAYBACK_MODE_16LINEAR          6       /*        Selects: 128 Kbit/sec 16-bit linear */
1012 #define PLAYBACK_MODE_8LINEAR           4       /*        Selects: 64 Kbit/sec 8-bit signed linear */
1013 #define PLAYBACK_MODE_8LINEAR_WSS       5       /*        Selects: 64 Kbit/sec WSS 8-bit unsigned linear */
1014
1015 #define RECORD_MODE_COMPRESSED          0       /*        Selects: Compressed modes, TrueSpeech 8.5-4.1, G.723.1, G.722, G.728, G.729 */
1016 #define RECORD_MODE_TRUESPEECH          0       /*        Selects: TrueSpeech 8.5, 6.3, 5.3, 4.8 or 4.1 Kbps */
1017 #define RECORD_MODE_ULAW                4       /*        Selects: 64 Kbit/sec Mu-law PCM */
1018 #define RECORD_MODE_ALAW                12      /*        Selects: 64 Kbit/sec A-law PCM */
1019 #define RECORD_MODE_16LINEAR            5       /*        Selects: 128 Kbit/sec 16-bit linear */
1020 #define RECORD_MODE_8LINEAR             6       /*        Selects: 64 Kbit/sec 8-bit signed linear */
1021 #define RECORD_MODE_8LINEAR_WSS         7       /*        Selects: 64 Kbit/sec WSS 8-bit unsigned linear */
1022
1023 enum SLIC_STATES {
1024         PLD_SLIC_STATE_OC = 0,
1025         PLD_SLIC_STATE_RINGING,
1026         PLD_SLIC_STATE_ACTIVE,
1027         PLD_SLIC_STATE_OHT,
1028         PLD_SLIC_STATE_TIPOPEN,
1029         PLD_SLIC_STATE_STANDBY,
1030         PLD_SLIC_STATE_APR,
1031         PLD_SLIC_STATE_OHTPR
1032 };
1033
1034 enum SCI_CONTROL {
1035         SCI_End = 0,
1036         SCI_Enable_DAA,
1037         SCI_Enable_Mixer,
1038         SCI_Enable_EEPROM
1039 };
1040
1041 enum Mode {
1042         T63, T53, T48, T40
1043 };
1044 enum Dir {
1045         V3_TO_V4, V4_TO_V3, V4_TO_V5, V5_TO_V4
1046 };
1047
1048 typedef struct Proc_Info_Tag {
1049         enum Mode convert_mode;
1050         enum Dir convert_dir;
1051         int Prev_Frame_Type;
1052         int Current_Frame_Type;
1053 } Proc_Info_Type;
1054
1055 enum PREVAL {
1056         NORMAL = 0,
1057         NOPOST,
1058         POSTONLY,
1059         PREERROR
1060 };
1061
1062 enum IXJ_EXTENSIONS {
1063         G729LOADER = 0,
1064         TS85LOADER,
1065         PRE_READ,
1066         POST_READ,
1067         PRE_WRITE,
1068         POST_WRITE,
1069         PRE_IOCTL,
1070         POST_IOCTL
1071 };
1072
1073 typedef struct {
1074         char enable;
1075         char en_filter;
1076         unsigned int filter;
1077         unsigned int state;     /* State 0 when cadence has not started. */
1078
1079         unsigned int on1;       /* State 1 */
1080
1081         unsigned long on1min;   /* State 1 - 10% + jiffies */
1082         unsigned long on1dot;   /* State 1 + jiffies */
1083
1084         unsigned long on1max;   /* State 1 + 10% + jiffies */
1085
1086         unsigned int off1;      /* State 2 */
1087
1088         unsigned long off1min;
1089         unsigned long off1dot;  /* State 2 + jiffies */
1090         unsigned long off1max;
1091         unsigned int on2;       /* State 3 */
1092
1093         unsigned long on2min;
1094         unsigned long on2dot;
1095         unsigned long on2max;
1096         unsigned int off2;      /* State 4 */
1097
1098         unsigned long off2min;
1099         unsigned long off2dot;  /* State 4 + jiffies */
1100         unsigned long off2max;
1101         unsigned int on3;       /* State 5 */
1102
1103         unsigned long on3min;
1104         unsigned long on3dot;
1105         unsigned long on3max;
1106         unsigned int off3;      /* State 6 */
1107
1108         unsigned long off3min;
1109         unsigned long off3dot;  /* State 6 + jiffies */
1110         unsigned long off3max;
1111 } IXJ_CADENCE_F;
1112
1113 typedef struct {
1114         unsigned int busytone:1;
1115         unsigned int dialtone:1;
1116         unsigned int ringback:1;
1117         unsigned int ringing:1;
1118         unsigned int playing:1;
1119         unsigned int recording:1;
1120         unsigned int cringing:1;
1121         unsigned int play_first_frame:1;
1122         unsigned int pstn_present:1;
1123         unsigned int pstn_ringing:1;
1124         unsigned int pots_correct:1;
1125         unsigned int pots_pstn:1;
1126         unsigned int g729_loaded:1;
1127         unsigned int ts85_loaded:1;
1128         unsigned int dtmf_oob:1;        /* DTMF Out-Of-Band */
1129
1130         unsigned int pcmciascp:1;       /* SmartCABLE Present */
1131
1132         unsigned int pcmciasct:2;       /* SmartCABLE Type */
1133
1134         unsigned int pcmciastate:3;     /* SmartCABLE Init State */
1135
1136         unsigned int inwrite:1; /* Currently writing */
1137
1138         unsigned int inread:1;  /* Currently reading */
1139
1140         unsigned int incheck:1; /* Currently checking the SmartCABLE */
1141
1142         unsigned int cidplay:1; /* Currently playing Caller ID */
1143
1144         unsigned int cidring:1; /* This is the ring for Caller ID */
1145
1146         unsigned int cidsent:1; /* Caller ID has been sent */
1147
1148         unsigned int cidcw_ack:1; /* Caller ID CW ACK (from CPE) */
1149         unsigned int firstring:1; /* First ring cadence is complete */
1150         unsigned int pstncheck:1;       /* Currently checking the PSTN Line */
1151         unsigned int pstn_rmr:1;
1152         unsigned int x:3;       /* unsed bits */
1153
1154 } IXJ_FLAGS;
1155
1156 /******************************************************************************
1157 *
1158 *  This structure holds the state of all of the Quicknet cards
1159 *
1160 ******************************************************************************/
1161
1162 typedef struct {
1163         int elements_used;
1164         IXJ_CADENCE_TERM termination;
1165         IXJ_CADENCE_ELEMENT *ce;
1166 } ixj_cadence;
1167
1168 typedef struct {
1169         struct phone_device p;
1170         struct timer_list timer;
1171         unsigned int board;
1172         unsigned int DSPbase;
1173         unsigned int XILINXbase;
1174         unsigned int serial;
1175         atomic_t DSPWrite;
1176         struct phone_capability caplist[30];
1177         unsigned int caps;
1178         struct pnp_dev *dev;
1179         unsigned int cardtype;
1180         unsigned int rec_codec;
1181         unsigned int cid_rec_codec;
1182         unsigned int cid_rec_volume;
1183         unsigned char cid_rec_flag;
1184         signed char rec_mode;
1185         unsigned int play_codec;
1186         unsigned int cid_play_codec;
1187         unsigned int cid_play_volume;
1188         unsigned char cid_play_flag;
1189         signed char play_mode;
1190         IXJ_FLAGS flags;
1191         unsigned long busyflags;
1192         unsigned int rec_frame_size;
1193         unsigned int play_frame_size;
1194         unsigned int cid_play_frame_size;
1195         unsigned int cid_base_frame_size;
1196         unsigned long cidcw_wait;
1197         int aec_level;
1198         int cid_play_aec_level;
1199         int readers, writers;
1200         wait_queue_head_t poll_q;
1201         wait_queue_head_t read_q;
1202         char *read_buffer, *read_buffer_end;
1203         char *read_convert_buffer;
1204         size_t read_buffer_size;
1205         unsigned int read_buffer_ready;
1206         wait_queue_head_t write_q;
1207         char *write_buffer, *write_buffer_end;
1208         char *write_convert_buffer;
1209         size_t write_buffer_size;
1210         unsigned int write_buffers_empty;
1211         unsigned long drybuffer;
1212         char *write_buffer_rp, *write_buffer_wp;
1213         char dtmfbuffer[80];
1214         char dtmf_current;
1215         int dtmf_wp, dtmf_rp, dtmf_state, dtmf_proc;
1216         int tone_off_time, tone_on_time;
1217         struct fasync_struct *async_queue;
1218         unsigned long tone_start_jif;
1219         char tone_index;
1220         char tone_state;
1221         char maxrings;
1222         ixj_cadence *cadence_t;
1223         ixj_cadence *cadence_r;
1224         int tone_cadence_state;
1225         IXJ_CADENCE_F cadence_f[6];
1226         DTMF dtmf;
1227         CPTF cptf;
1228         BYTES dsp;
1229         BYTES ver;
1230         BYTES scr;
1231         BYTES ssr;
1232         BYTES baseframe;
1233         HSR hsr;
1234         GPIO gpio;
1235         PLD_SCRR pld_scrr;
1236         PLD_SCRW pld_scrw;
1237         PLD_SLICW pld_slicw;
1238         PLD_SLICR pld_slicr;
1239         PLD_CLOCK pld_clock;
1240         PCMCIA_CR1 pccr1;
1241         PCMCIA_CR2 pccr2;
1242         PCMCIA_SCCR psccr;
1243         PCMCIA_SLIC pslic;
1244         char pscdd;
1245         Si3C1 sic1;
1246         Si3C2 sic2;
1247         Si3RXG sirxg;
1248         Si3ADC siadc;
1249         Si3DAC sidac;
1250         Si3STAT sistat;
1251         Si3AATT siaatt;
1252         MIX mix;
1253         unsigned short ring_cadence;
1254         int ring_cadence_t;
1255         unsigned long ring_cadence_jif;
1256         unsigned long checkwait;
1257         int intercom;
1258         int m_hook;
1259         int r_hook;
1260         int p_hook;
1261         char pstn_envelope;
1262         char pstn_cid_intr;
1263         unsigned char fskz;
1264         unsigned char fskphase;
1265         unsigned char fskcnt;
1266         unsigned int cidsize;
1267         unsigned int cidcnt;
1268         unsigned long pstn_cid_received;
1269         PHONE_CID cid;
1270         PHONE_CID cid_send;
1271         unsigned long pstn_ring_int;
1272         unsigned long pstn_ring_start;
1273         unsigned long pstn_ring_stop;
1274         unsigned long pstn_winkstart;
1275         unsigned long pstn_last_rmr;
1276         unsigned long pstn_prev_rmr;
1277         unsigned long pots_winkstart;
1278         unsigned int winktime;
1279         unsigned long flash_end;
1280         char port;
1281         char hookstate;
1282         union telephony_exception ex;
1283         union telephony_exception ex_sig;
1284         int ixj_signals[35];
1285         IXJ_SIGDEF sigdef;
1286         char daa_mode;
1287         char daa_country;
1288         unsigned long pstn_sleeptil;
1289         DAA_REGS m_DAAShadowRegs;
1290         Proc_Info_Type Info_read;
1291         Proc_Info_Type Info_write;
1292         unsigned short frame_count;
1293         unsigned int filter_hist[4];
1294         unsigned char filter_en[6];
1295         unsigned short proc_load;
1296         unsigned long framesread;
1297         unsigned long frameswritten;
1298         unsigned long read_wait;
1299         unsigned long write_wait;
1300         unsigned long timerchecks;
1301         unsigned long txreadycheck;
1302         unsigned long rxreadycheck;
1303         unsigned long statuswait;
1304         unsigned long statuswaitfail;
1305         unsigned long pcontrolwait;
1306         unsigned long pcontrolwaitfail;
1307         unsigned long iscontrolready;
1308         unsigned long iscontrolreadyfail;
1309         unsigned long pstnstatecheck;
1310 #ifdef IXJ_DYN_ALLOC
1311         short *fskdata;
1312 #else
1313         short fskdata[8000];
1314 #endif
1315         int fsksize;
1316         int fskdcnt;
1317 } IXJ;
1318
1319 typedef int (*IXJ_REGFUNC) (IXJ * j, unsigned long arg);
1320
1321 extern IXJ *ixj_pcmcia_probe(unsigned long, unsigned long);
1322