ad1848var.h revision 1.5 1 /* $NetBSD: ad1848var.h,v 1.5 1995/05/08 22:01:59 brezak Exp $ */
2
3 /*
4 * Copyright (c) 1994 John Brezak
5 * Copyright (c) 1991-1993 Regents of the University of California.
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * 3. All advertising materials mentioning features or use of this software
17 * must display the following acknowledgement:
18 * This product includes software developed by the Computer Systems
19 * Engineering Group at Lawrence Berkeley Laboratory.
20 * 4. Neither the name of the University nor of the Laboratory may be used
21 * to endorse or promote products derived from this software without
22 * specific prior written permission.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 * SUCH DAMAGE.
35 *
36 */
37
38 #define AD1848_NPORT 8
39
40 struct ad1848_volume {
41 u_char left;
42 u_char right;
43 };
44
45 struct ad1848_softc {
46 struct device sc_dev; /* base device */
47 struct isadev sc_id; /* ISA device */
48 void *sc_ih; /* interrupt vectoring */
49
50 void *parent;
51
52 u_short sc_locked; /* true when doing HS DMA */
53 u_int sc_lastcc; /* size of last DMA xfer */
54 int sc_mode; /* half-duplex record/play */
55
56 #ifndef NEWCONFIG
57 int sc_dma_flags;
58 void *sc_dma_bp;
59 u_int sc_dma_cnt;
60 #endif
61
62 u_short sc_iobase; /* I/O port base address */
63 u_short sc_irq; /* interrupt */
64 u_short sc_drq; /* DMA */
65
66 u_long sc_irate; /* Sample rate for input */
67 u_long sc_orate; /* ...and output */
68
69 /* We keep track of these */
70 struct ad1848_volume rec_gain, aux1_gain, aux2_gain, out_gain, mon_gain;
71
72 u_int encoding; /* ulaw/linear -- keep track */
73 u_int precision; /* 8/16 bits */
74
75 int rec_port; /* recording port */
76
77 int channels;
78
79 /* ad1848 */
80 u_char MCE_bit;
81 char *chip_name;
82 int rev;
83 int mode;
84
85 int speed;
86 u_char speed_bits;
87 u_char format_bits;
88
89 u_long sc_interrupts; /* number of interrupts taken */
90 void (*sc_intr)(void *); /* dma completion intr handler */
91 void *sc_arg; /* arg for sc_intr() */
92 };
93
94 /*
95 * Ad1848 ports
96 */
97 #define MIC_IN_PORT 0
98 #define LINE_IN_PORT 1
99 #define AUX1_IN_PORT 2
100 #define DAC_IN_PORT 3
101
102 #ifdef _KERNEL
103 int ad1848_probe __P((struct ad1848_softc *));
104 void ad1848_attach __P((struct ad1848_softc *));
105
106 int ad1848_open __P((struct ad1848_softc *, dev_t, int));
107 void ad1848_close __P((void *));
108
109 void ad1848_forceintr __P((struct ad1848_softc *));
110
111 int ad1848_set_in_sr __P((void *, u_long));
112 u_long ad1848_get_in_sr __P((void *));
113 int ad1848_set_out_sr __P((void *, u_long));
114 u_long ad1848_get_out_sr __P((void *));
115 int ad1848_query_encoding __P((void *, struct audio_encoding *));
116 int ad1848_set_encoding __P((void *, u_int));
117 int ad1848_get_encoding __P((void *));
118 int ad1848_set_precision __P((void *, u_int));
119 int ad1848_get_precision __P((void *));
120 int ad1848_set_channels __P((void *, int));
121 int ad1848_get_channels __P((void *));
122
123 int ad1848_round_blocksize __P((void *, int));
124
125 int ad1848_dma_output __P((void *, void *, int, void (*)(), void*));
126 int ad1848_dma_input __P((void *, void *, int, void (*)(), void*));
127
128 int ad1848_commit_settings __P((void *));
129
130 u_int ad1848_get_silence __P((int));
131
132 int ad1848_halt_in_dma __P((void *));
133 int ad1848_halt_out_dma __P((void *));
134 int ad1848_cont_in_dma __P((void *));
135 int ad1848_cont_out_dma __P((void *));
136
137 int ad1848_intr __P((void *));
138
139 int ad1848_set_rec_port __P((struct ad1848_softc *, int));
140 int ad1848_get_rec_port __P((struct ad1848_softc *));
141
142 int ad1848_set_aux1_gain __P((struct ad1848_softc *, struct ad1848_volume *));
143 int ad1848_get_aux1_gain __P((struct ad1848_softc *, struct ad1848_volume *));
144 int ad1848_set_aux2_gain __P((struct ad1848_softc *, struct ad1848_volume *));
145 int ad1848_get_aux2_gain __P((struct ad1848_softc *, struct ad1848_volume *));
146 int ad1848_set_out_gain __P((struct ad1848_softc *, struct ad1848_volume *));
147 int ad1848_get_out_gain __P((struct ad1848_softc *, struct ad1848_volume *));
148 int ad1848_set_rec_gain __P((struct ad1848_softc *, struct ad1848_volume *));
149 int ad1848_get_rec_gain __P((struct ad1848_softc *, struct ad1848_volume *));
150 int ad1848_set_mon_gain __P((struct ad1848_softc *, struct ad1848_volume *));
151 int ad1848_get_mon_gain __P((struct ad1848_softc *, struct ad1848_volume *));
152 #endif
153