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