diff options
author | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-05-30 19:16:45 -0400 |
---|---|---|
committer | Andrea Bastoni <bastoni@cs.unc.edu> | 2010-05-30 19:16:45 -0400 |
commit | ada47b5fe13d89735805b566185f4885f5a3f750 (patch) | |
tree | 644b88f8a71896307d71438e9b3af49126ffb22b /include/sound | |
parent | 43e98717ad40a4ae64545b5ba047c7b86aa44f4f (diff) | |
parent | 3280f21d43ee541f97f8cda5792150d2dbec20d5 (diff) |
Merge branch 'wip-2.6.34' into old-private-masterarchived-private-master
Diffstat (limited to 'include/sound')
28 files changed, 797 insertions, 51 deletions
diff --git a/include/sound/Kbuild b/include/sound/Kbuild index fd054a344324..e9dd9369ecb9 100644 --- a/include/sound/Kbuild +++ b/include/sound/Kbuild | |||
@@ -2,7 +2,6 @@ header-y += asound_fm.h | |||
2 | header-y += hdsp.h | 2 | header-y += hdsp.h |
3 | header-y += hdspm.h | 3 | header-y += hdspm.h |
4 | header-y += sfnt_info.h | 4 | header-y += sfnt_info.h |
5 | header-y += sscape_ioctl.h | ||
6 | 5 | ||
7 | unifdef-y += asequencer.h | 6 | unifdef-y += asequencer.h |
8 | unifdef-y += asound.h | 7 | unifdef-y += asound.h |
diff --git a/include/sound/ac97_codec.h b/include/sound/ac97_codec.h index 3dae3f799b9b..49400459b477 100644 --- a/include/sound/ac97_codec.h +++ b/include/sound/ac97_codec.h | |||
@@ -593,7 +593,7 @@ enum { | |||
593 | 593 | ||
594 | struct ac97_quirk { | 594 | struct ac97_quirk { |
595 | unsigned short subvendor; /* PCI subsystem vendor id */ | 595 | unsigned short subvendor; /* PCI subsystem vendor id */ |
596 | unsigned short subdevice; /* PCI sybsystem device id */ | 596 | unsigned short subdevice; /* PCI subsystem device id */ |
597 | unsigned short mask; /* device id bit mask, 0 = accept all */ | 597 | unsigned short mask; /* device id bit mask, 0 = accept all */ |
598 | unsigned int codec_id; /* codec id (if any), 0 = accept all */ | 598 | unsigned int codec_id; /* codec id (if any), 0 = accept all */ |
599 | const char *name; /* name shown as info */ | 599 | const char *name; /* name shown as info */ |
diff --git a/include/sound/aci.h b/include/sound/aci.h new file mode 100644 index 000000000000..ee639d355ef0 --- /dev/null +++ b/include/sound/aci.h | |||
@@ -0,0 +1,90 @@ | |||
1 | #ifndef _ACI_H_ | ||
2 | #define _ACI_H_ | ||
3 | |||
4 | #define ACI_REG_COMMAND 0 /* write register offset */ | ||
5 | #define ACI_REG_STATUS 1 /* read register offset */ | ||
6 | #define ACI_REG_BUSY 2 /* busy register offset */ | ||
7 | #define ACI_REG_RDS 2 /* PCM20: RDS register offset */ | ||
8 | #define ACI_MINTIME 500 /* ACI time out limit */ | ||
9 | |||
10 | #define ACI_SET_MUTE 0x0d | ||
11 | #define ACI_SET_POWERAMP 0x0f | ||
12 | #define ACI_SET_TUNERMUTE 0xa3 | ||
13 | #define ACI_SET_TUNERMONO 0xa4 | ||
14 | #define ACI_SET_IDE 0xd0 | ||
15 | #define ACI_SET_WSS 0xd1 | ||
16 | #define ACI_SET_SOLOMODE 0xd2 | ||
17 | #define ACI_SET_PREAMP 0x03 | ||
18 | #define ACI_GET_PREAMP 0x21 | ||
19 | #define ACI_WRITE_TUNE 0xa7 | ||
20 | #define ACI_READ_TUNERSTEREO 0xa8 | ||
21 | #define ACI_READ_TUNERSTATION 0xa9 | ||
22 | #define ACI_READ_VERSION 0xf1 | ||
23 | #define ACI_READ_IDCODE 0xf2 | ||
24 | #define ACI_INIT 0xff | ||
25 | #define ACI_STATUS 0xf0 | ||
26 | #define ACI_S_GENERAL 0x00 | ||
27 | #define ACI_ERROR_OP 0xdf | ||
28 | |||
29 | /* ACI Mixer */ | ||
30 | |||
31 | /* These are the values for the right channel GET registers. | ||
32 | Add an offset of 0x01 for the left channel register. | ||
33 | (left=right+0x01) */ | ||
34 | |||
35 | #define ACI_GET_MASTER 0x03 | ||
36 | #define ACI_GET_MIC 0x05 | ||
37 | #define ACI_GET_LINE 0x07 | ||
38 | #define ACI_GET_CD 0x09 | ||
39 | #define ACI_GET_SYNTH 0x0b | ||
40 | #define ACI_GET_PCM 0x0d | ||
41 | #define ACI_GET_LINE1 0x10 /* Radio on PCM20 */ | ||
42 | #define ACI_GET_LINE2 0x12 | ||
43 | |||
44 | #define ACI_GET_EQ1 0x22 /* from Bass ... */ | ||
45 | #define ACI_GET_EQ2 0x24 | ||
46 | #define ACI_GET_EQ3 0x26 | ||
47 | #define ACI_GET_EQ4 0x28 | ||
48 | #define ACI_GET_EQ5 0x2a | ||
49 | #define ACI_GET_EQ6 0x2c | ||
50 | #define ACI_GET_EQ7 0x2e /* ... to Treble */ | ||
51 | |||
52 | /* And these are the values for the right channel SET registers. | ||
53 | For left channel access you have to add an offset of 0x08. | ||
54 | MASTER is an exception, which needs an offset of 0x01 */ | ||
55 | |||
56 | #define ACI_SET_MASTER 0x00 | ||
57 | #define ACI_SET_MIC 0x30 | ||
58 | #define ACI_SET_LINE 0x31 | ||
59 | #define ACI_SET_CD 0x34 | ||
60 | #define ACI_SET_SYNTH 0x33 | ||
61 | #define ACI_SET_PCM 0x32 | ||
62 | #define ACI_SET_LINE1 0x35 /* Radio on PCM20 */ | ||
63 | #define ACI_SET_LINE2 0x36 | ||
64 | |||
65 | #define ACI_SET_EQ1 0x40 /* from Bass ... */ | ||
66 | #define ACI_SET_EQ2 0x41 | ||
67 | #define ACI_SET_EQ3 0x42 | ||
68 | #define ACI_SET_EQ4 0x43 | ||
69 | #define ACI_SET_EQ5 0x44 | ||
70 | #define ACI_SET_EQ6 0x45 | ||
71 | #define ACI_SET_EQ7 0x46 /* ... to Treble */ | ||
72 | |||
73 | struct snd_miro_aci { | ||
74 | unsigned long aci_port; | ||
75 | int aci_vendor; | ||
76 | int aci_product; | ||
77 | int aci_version; | ||
78 | int aci_amp; | ||
79 | int aci_preamp; | ||
80 | int aci_solomode; | ||
81 | |||
82 | struct mutex aci_mutex; | ||
83 | }; | ||
84 | |||
85 | int snd_aci_cmd(struct snd_miro_aci *aci, int write1, int write2, int write3); | ||
86 | |||
87 | struct snd_miro_aci *snd_aci_get_aci(void); | ||
88 | |||
89 | #endif /* _ACI_H_ */ | ||
90 | |||
diff --git a/include/sound/ak4113.h b/include/sound/ak4113.h new file mode 100644 index 000000000000..2609048c1d44 --- /dev/null +++ b/include/sound/ak4113.h | |||
@@ -0,0 +1,321 @@ | |||
1 | #ifndef __SOUND_AK4113_H | ||
2 | #define __SOUND_AK4113_H | ||
3 | |||
4 | /* | ||
5 | * Routines for Asahi Kasei AK4113 | ||
6 | * Copyright (c) by Jaroslav Kysela <perex@perex.cz>, | ||
7 | * Copyright (c) by Pavel Hofman <pavel.hofman@ivitera.com>, | ||
8 | * | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or modify | ||
11 | * it under the terms of the GNU General Public License as published by | ||
12 | * the Free Software Foundation; either version 2 of the License, or | ||
13 | * (at your option) any later version. | ||
14 | * | ||
15 | * This program is distributed in the hope that it will be useful, | ||
16 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
17 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
18 | * GNU General Public License for more details. | ||
19 | * | ||
20 | * You should have received a copy of the GNU General Public License | ||
21 | * along with this program; if not, write to the Free Software | ||
22 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
23 | * | ||
24 | */ | ||
25 | |||
26 | /* AK4113 registers */ | ||
27 | /* power down */ | ||
28 | #define AK4113_REG_PWRDN 0x00 | ||
29 | /* format control */ | ||
30 | #define AK4113_REG_FORMAT 0x01 | ||
31 | /* input/output control */ | ||
32 | #define AK4113_REG_IO0 0x02 | ||
33 | /* input/output control */ | ||
34 | #define AK4113_REG_IO1 0x03 | ||
35 | /* interrupt0 mask */ | ||
36 | #define AK4113_REG_INT0_MASK 0x04 | ||
37 | /* interrupt1 mask */ | ||
38 | #define AK4113_REG_INT1_MASK 0x05 | ||
39 | /* DAT mask & DTS select */ | ||
40 | #define AK4113_REG_DATDTS 0x06 | ||
41 | /* receiver status 0 */ | ||
42 | #define AK4113_REG_RCS0 0x07 | ||
43 | /* receiver status 1 */ | ||
44 | #define AK4113_REG_RCS1 0x08 | ||
45 | /* receiver status 2 */ | ||
46 | #define AK4113_REG_RCS2 0x09 | ||
47 | /* RX channel status byte 0 */ | ||
48 | #define AK4113_REG_RXCSB0 0x0a | ||
49 | /* RX channel status byte 1 */ | ||
50 | #define AK4113_REG_RXCSB1 0x0b | ||
51 | /* RX channel status byte 2 */ | ||
52 | #define AK4113_REG_RXCSB2 0x0c | ||
53 | /* RX channel status byte 3 */ | ||
54 | #define AK4113_REG_RXCSB3 0x0d | ||
55 | /* RX channel status byte 4 */ | ||
56 | #define AK4113_REG_RXCSB4 0x0e | ||
57 | /* burst preamble Pc byte 0 */ | ||
58 | #define AK4113_REG_Pc0 0x0f | ||
59 | /* burst preamble Pc byte 1 */ | ||
60 | #define AK4113_REG_Pc1 0x10 | ||
61 | /* burst preamble Pd byte 0 */ | ||
62 | #define AK4113_REG_Pd0 0x11 | ||
63 | /* burst preamble Pd byte 1 */ | ||
64 | #define AK4113_REG_Pd1 0x12 | ||
65 | /* Q-subcode address + control */ | ||
66 | #define AK4113_REG_QSUB_ADDR 0x13 | ||
67 | /* Q-subcode track */ | ||
68 | #define AK4113_REG_QSUB_TRACK 0x14 | ||
69 | /* Q-subcode index */ | ||
70 | #define AK4113_REG_QSUB_INDEX 0x15 | ||
71 | /* Q-subcode minute */ | ||
72 | #define AK4113_REG_QSUB_MINUTE 0x16 | ||
73 | /* Q-subcode second */ | ||
74 | #define AK4113_REG_QSUB_SECOND 0x17 | ||
75 | /* Q-subcode frame */ | ||
76 | #define AK4113_REG_QSUB_FRAME 0x18 | ||
77 | /* Q-subcode zero */ | ||
78 | #define AK4113_REG_QSUB_ZERO 0x19 | ||
79 | /* Q-subcode absolute minute */ | ||
80 | #define AK4113_REG_QSUB_ABSMIN 0x1a | ||
81 | /* Q-subcode absolute second */ | ||
82 | #define AK4113_REG_QSUB_ABSSEC 0x1b | ||
83 | /* Q-subcode absolute frame */ | ||
84 | #define AK4113_REG_QSUB_ABSFRM 0x1c | ||
85 | |||
86 | /* sizes */ | ||
87 | #define AK4113_REG_RXCSB_SIZE ((AK4113_REG_RXCSB4-AK4113_REG_RXCSB0)+1) | ||
88 | #define AK4113_REG_QSUB_SIZE ((AK4113_REG_QSUB_ABSFRM-AK4113_REG_QSUB_ADDR)\ | ||
89 | +1) | ||
90 | |||
91 | #define AK4113_WRITABLE_REGS (AK4113_REG_DATDTS + 1) | ||
92 | |||
93 | /* AK4113_REG_PWRDN bits */ | ||
94 | /* Channel Status Select */ | ||
95 | #define AK4113_CS12 (1<<7) | ||
96 | /* Block Start & C/U Output Mode */ | ||
97 | #define AK4113_BCU (1<<6) | ||
98 | /* Master Clock Operation Select */ | ||
99 | #define AK4113_CM1 (1<<5) | ||
100 | /* Master Clock Operation Select */ | ||
101 | #define AK4113_CM0 (1<<4) | ||
102 | /* Master Clock Frequency Select */ | ||
103 | #define AK4113_OCKS1 (1<<3) | ||
104 | /* Master Clock Frequency Select */ | ||
105 | #define AK4113_OCKS0 (1<<2) | ||
106 | /* 0 = power down, 1 = normal operation */ | ||
107 | #define AK4113_PWN (1<<1) | ||
108 | /* 0 = reset & initialize (except thisregister), 1 = normal operation */ | ||
109 | #define AK4113_RST (1<<0) | ||
110 | |||
111 | /* AK4113_REQ_FORMAT bits */ | ||
112 | /* V/TX Output select: 0 = Validity Flag Output, 1 = TX */ | ||
113 | #define AK4113_VTX (1<<7) | ||
114 | /* Audio Data Control */ | ||
115 | #define AK4113_DIF2 (1<<6) | ||
116 | /* Audio Data Control */ | ||
117 | #define AK4113_DIF1 (1<<5) | ||
118 | /* Audio Data Control */ | ||
119 | #define AK4113_DIF0 (1<<4) | ||
120 | /* Deemphasis Autodetect Enable (1 = enable) */ | ||
121 | #define AK4113_DEAU (1<<3) | ||
122 | /* 32kHz-48kHz Deemphasis Control */ | ||
123 | #define AK4113_DEM1 (1<<2) | ||
124 | /* 32kHz-48kHz Deemphasis Control */ | ||
125 | #define AK4113_DEM0 (1<<1) | ||
126 | #define AK4113_DEM_OFF (AK4113_DEM0) | ||
127 | #define AK4113_DEM_44KHZ (0) | ||
128 | #define AK4113_DEM_48KHZ (AK4113_DEM1) | ||
129 | #define AK4113_DEM_32KHZ (AK4113_DEM0|AK4113_DEM1) | ||
130 | /* STDO: 16-bit, right justified */ | ||
131 | #define AK4113_DIF_16R (0) | ||
132 | /* STDO: 18-bit, right justified */ | ||
133 | #define AK4113_DIF_18R (AK4113_DIF0) | ||
134 | /* STDO: 20-bit, right justified */ | ||
135 | #define AK4113_DIF_20R (AK4113_DIF1) | ||
136 | /* STDO: 24-bit, right justified */ | ||
137 | #define AK4113_DIF_24R (AK4113_DIF1|AK4113_DIF0) | ||
138 | /* STDO: 24-bit, left justified */ | ||
139 | #define AK4113_DIF_24L (AK4113_DIF2) | ||
140 | /* STDO: I2S */ | ||
141 | #define AK4113_DIF_24I2S (AK4113_DIF2|AK4113_DIF0) | ||
142 | /* STDO: 24-bit, left justified; LRCLK, BICK = Input */ | ||
143 | #define AK4113_DIF_I24L (AK4113_DIF2|AK4113_DIF1) | ||
144 | /* STDO: I2S; LRCLK, BICK = Input */ | ||
145 | #define AK4113_DIF_I24I2S (AK4113_DIF2|AK4113_DIF1|AK4113_DIF0) | ||
146 | |||
147 | /* AK4113_REG_IO0 */ | ||
148 | /* XTL1=0,XTL0=0 -> 11.2896Mhz; XTL1=0,XTL0=1 -> 12.288Mhz */ | ||
149 | #define AK4113_XTL1 (1<<6) | ||
150 | /* XTL1=1,XTL0=0 -> 24.576Mhz; XTL1=1,XTL0=1 -> use channel status */ | ||
151 | #define AK4113_XTL0 (1<<5) | ||
152 | /* Block Start Signal Output: 0 = U-bit, 1 = C-bit (req. BCU = 1) */ | ||
153 | #define AK4113_UCE (1<<4) | ||
154 | /* TX Output Enable (1 = enable) */ | ||
155 | #define AK4113_TXE (1<<3) | ||
156 | /* Output Through Data Selector for TX pin */ | ||
157 | #define AK4113_OPS2 (1<<2) | ||
158 | /* Output Through Data Selector for TX pin */ | ||
159 | #define AK4113_OPS1 (1<<1) | ||
160 | /* Output Through Data Selector for TX pin */ | ||
161 | #define AK4113_OPS0 (1<<0) | ||
162 | /* 11.2896 MHz ref. Xtal freq. */ | ||
163 | #define AK4113_XTL_11_2896M (0) | ||
164 | /* 12.288 MHz ref. Xtal freq. */ | ||
165 | #define AK4113_XTL_12_288M (AK4113_XTL0) | ||
166 | /* 24.576 MHz ref. Xtal freq. */ | ||
167 | #define AK4113_XTL_24_576M (AK4113_XTL1) | ||
168 | |||
169 | /* AK4113_REG_IO1 */ | ||
170 | /* Interrupt 0 pin Hold */ | ||
171 | #define AK4113_EFH1 (1<<7) | ||
172 | /* Interrupt 0 pin Hold */ | ||
173 | #define AK4113_EFH0 (1<<6) | ||
174 | #define AK4113_EFH_512LRCLK (0) | ||
175 | #define AK4113_EFH_1024LRCLK (AK4113_EFH0) | ||
176 | #define AK4113_EFH_2048LRCLK (AK4113_EFH1) | ||
177 | #define AK4113_EFH_4096LRCLK (AK4113_EFH1|AK4113_EFH0) | ||
178 | /* PLL Lock Time: 0 = 384/fs, 1 = 1/fs */ | ||
179 | #define AK4113_FAST (1<<5) | ||
180 | /* MCKO2 Output Select: 0 = CMx/OCKSx, 1 = Xtal */ | ||
181 | #define AK4113_XMCK (1<<4) | ||
182 | /* MCKO2 Output Freq. Select: 0 = x1, 1 = x0.5 (req. XMCK = 1) */ | ||
183 | #define AK4113_DIV (1<<3) | ||
184 | /* Input Recovery Data Select */ | ||
185 | #define AK4113_IPS2 (1<<2) | ||
186 | /* Input Recovery Data Select */ | ||
187 | #define AK4113_IPS1 (1<<1) | ||
188 | /* Input Recovery Data Select */ | ||
189 | #define AK4113_IPS0 (1<<0) | ||
190 | #define AK4113_IPS(x) ((x)&7) | ||
191 | |||
192 | /* AK4113_REG_INT0_MASK && AK4113_REG_INT1_MASK*/ | ||
193 | /* mask enable for QINT bit */ | ||
194 | #define AK4113_MQI (1<<7) | ||
195 | /* mask enable for AUTO bit */ | ||
196 | #define AK4113_MAUT (1<<6) | ||
197 | /* mask enable for CINT bit */ | ||
198 | #define AK4113_MCIT (1<<5) | ||
199 | /* mask enable for UNLOCK bit */ | ||
200 | #define AK4113_MULK (1<<4) | ||
201 | /* mask enable for V bit */ | ||
202 | #define AK4113_V (1<<3) | ||
203 | /* mask enable for STC bit */ | ||
204 | #define AK4113_STC (1<<2) | ||
205 | /* mask enable for AUDN bit */ | ||
206 | #define AK4113_MAN (1<<1) | ||
207 | /* mask enable for PAR bit */ | ||
208 | #define AK4113_MPR (1<<0) | ||
209 | |||
210 | /* AK4113_REG_DATDTS */ | ||
211 | /* DAT Start ID Counter */ | ||
212 | #define AK4113_DCNT (1<<4) | ||
213 | /* DTS-CD 16-bit Sync Word Detect */ | ||
214 | #define AK4113_DTS16 (1<<3) | ||
215 | /* DTS-CD 14-bit Sync Word Detect */ | ||
216 | #define AK4113_DTS14 (1<<2) | ||
217 | /* mask enable for DAT bit (if 1, no INT1 effect */ | ||
218 | #define AK4113_MDAT1 (1<<1) | ||
219 | /* mask enable for DAT bit (if 1, no INT0 effect */ | ||
220 | #define AK4113_MDAT0 (1<<0) | ||
221 | |||
222 | /* AK4113_REG_RCS0 */ | ||
223 | /* Q-subcode buffer interrupt, 0 = no change, 1 = changed */ | ||
224 | #define AK4113_QINT (1<<7) | ||
225 | /* Non-PCM or DTS stream auto detection, 0 = no detect, 1 = detect */ | ||
226 | #define AK4113_AUTO (1<<6) | ||
227 | /* channel status buffer interrupt, 0 = no change, 1 = change */ | ||
228 | #define AK4113_CINT (1<<5) | ||
229 | /* PLL lock status, 0 = lock, 1 = unlock */ | ||
230 | #define AK4113_UNLCK (1<<4) | ||
231 | /* Validity bit, 0 = valid, 1 = invalid */ | ||
232 | #define AK4113_V (1<<3) | ||
233 | /* sampling frequency or Pre-emphasis change, 0 = no detect, 1 = detect */ | ||
234 | #define AK4113_STC (1<<2) | ||
235 | /* audio bit output, 0 = audio, 1 = non-audio */ | ||
236 | #define AK4113_AUDION (1<<1) | ||
237 | /* parity error or biphase error status, 0 = no error, 1 = error */ | ||
238 | #define AK4113_PAR (1<<0) | ||
239 | |||
240 | /* AK4113_REG_RCS1 */ | ||
241 | /* sampling frequency detection */ | ||
242 | #define AK4113_FS3 (1<<7) | ||
243 | #define AK4113_FS2 (1<<6) | ||
244 | #define AK4113_FS1 (1<<5) | ||
245 | #define AK4113_FS0 (1<<4) | ||
246 | /* Pre-emphasis detect, 0 = OFF, 1 = ON */ | ||
247 | #define AK4113_PEM (1<<3) | ||
248 | /* DAT Start ID Detect, 0 = no detect, 1 = detect */ | ||
249 | #define AK4113_DAT (1<<2) | ||
250 | /* DTS-CD bit audio stream detect, 0 = no detect, 1 = detect */ | ||
251 | #define AK4113_DTSCD (1<<1) | ||
252 | /* Non-PCM bit stream detection, 0 = no detect, 1 = detect */ | ||
253 | #define AK4113_NPCM (1<<0) | ||
254 | #define AK4113_FS_8000HZ (AK4113_FS3|AK4113_FS0) | ||
255 | #define AK4113_FS_11025HZ (AK4113_FS2|AK4113_FS0) | ||
256 | #define AK4113_FS_16000HZ (AK4113_FS2|AK4113_FS1|AK4113_FS0) | ||
257 | #define AK4113_FS_22050HZ (AK4113_FS2) | ||
258 | #define AK4113_FS_24000HZ (AK4113_FS2|AK4113_FS1) | ||
259 | #define AK4113_FS_32000HZ (AK4113_FS1|AK4113_FS0) | ||
260 | #define AK4113_FS_44100HZ (0) | ||
261 | #define AK4113_FS_48000HZ (AK4113_FS1) | ||
262 | #define AK4113_FS_64000HZ (AK4113_FS3|AK4113_FS1|AK4113_FS0) | ||
263 | #define AK4113_FS_88200HZ (AK4113_FS3) | ||
264 | #define AK4113_FS_96000HZ (AK4113_FS3|AK4113_FS1) | ||
265 | #define AK4113_FS_176400HZ (AK4113_FS3|AK4113_FS2) | ||
266 | #define AK4113_FS_192000HZ (AK4113_FS3|AK4113_FS2|AK4113_FS1) | ||
267 | |||
268 | /* AK4113_REG_RCS2 */ | ||
269 | /* CRC for Q-subcode, 0 = no error, 1 = error */ | ||
270 | #define AK4113_QCRC (1<<1) | ||
271 | /* CRC for channel status, 0 = no error, 1 = error */ | ||
272 | #define AK4113_CCRC (1<<0) | ||
273 | |||
274 | /* flags for snd_ak4113_check_rate_and_errors() */ | ||
275 | #define AK4113_CHECK_NO_STAT (1<<0) /* no statistics */ | ||
276 | #define AK4113_CHECK_NO_RATE (1<<1) /* no rate check */ | ||
277 | |||
278 | #define AK4113_CONTROLS 13 | ||
279 | |||
280 | typedef void (ak4113_write_t)(void *private_data, unsigned char addr, | ||
281 | unsigned char data); | ||
282 | typedef unsigned char (ak4113_read_t)(void *private_data, unsigned char addr); | ||
283 | |||
284 | struct ak4113 { | ||
285 | struct snd_card *card; | ||
286 | ak4113_write_t *write; | ||
287 | ak4113_read_t *read; | ||
288 | void *private_data; | ||
289 | unsigned int init:1; | ||
290 | spinlock_t lock; | ||
291 | unsigned char regmap[AK4113_WRITABLE_REGS]; | ||
292 | struct snd_kcontrol *kctls[AK4113_CONTROLS]; | ||
293 | struct snd_pcm_substream *substream; | ||
294 | unsigned long parity_errors; | ||
295 | unsigned long v_bit_errors; | ||
296 | unsigned long qcrc_errors; | ||
297 | unsigned long ccrc_errors; | ||
298 | unsigned char rcs0; | ||
299 | unsigned char rcs1; | ||
300 | unsigned char rcs2; | ||
301 | struct delayed_work work; | ||
302 | unsigned int check_flags; | ||
303 | void *change_callback_private; | ||
304 | void (*change_callback)(struct ak4113 *ak4113, unsigned char c0, | ||
305 | unsigned char c1); | ||
306 | }; | ||
307 | |||
308 | int snd_ak4113_create(struct snd_card *card, ak4113_read_t *read, | ||
309 | ak4113_write_t *write, | ||
310 | const unsigned char *pgm, | ||
311 | void *private_data, struct ak4113 **r_ak4113); | ||
312 | void snd_ak4113_reg_write(struct ak4113 *ak4113, unsigned char reg, | ||
313 | unsigned char mask, unsigned char val); | ||
314 | void snd_ak4113_reinit(struct ak4113 *ak4113); | ||
315 | int snd_ak4113_build(struct ak4113 *ak4113, | ||
316 | struct snd_pcm_substream *capture_substream); | ||
317 | int snd_ak4113_external_rate(struct ak4113 *ak4113); | ||
318 | int snd_ak4113_check_rate_and_errors(struct ak4113 *ak4113, unsigned int flags); | ||
319 | |||
320 | #endif /* __SOUND_AK4113_H */ | ||
321 | |||
diff --git a/include/sound/ak4114.h b/include/sound/ak4114.h index d293d36a66b8..3ce69fd92523 100644 --- a/include/sound/ak4114.h +++ b/include/sound/ak4114.h | |||
@@ -95,13 +95,13 @@ | |||
95 | 95 | ||
96 | /* AK4114_REG_IO0 */ | 96 | /* AK4114_REG_IO0 */ |
97 | #define AK4114_TX1E (1<<7) /* TX1 Output Enable (1 = enable) */ | 97 | #define AK4114_TX1E (1<<7) /* TX1 Output Enable (1 = enable) */ |
98 | #define AK4114_OPS12 (1<<2) /* Output Though Data Selector for TX1 pin */ | 98 | #define AK4114_OPS12 (1<<6) /* Output Data Selector for TX1 pin */ |
99 | #define AK4114_OPS11 (1<<1) /* Output Though Data Selector for TX1 pin */ | 99 | #define AK4114_OPS11 (1<<5) /* Output Data Selector for TX1 pin */ |
100 | #define AK4114_OPS10 (1<<0) /* Output Though Data Selector for TX1 pin */ | 100 | #define AK4114_OPS10 (1<<4) /* Output Data Selector for TX1 pin */ |
101 | #define AK4114_TX0E (1<<3) /* TX0 Output Enable (1 = enable) */ | 101 | #define AK4114_TX0E (1<<3) /* TX0 Output Enable (1 = enable) */ |
102 | #define AK4114_OPS02 (1<<2) /* Output Though Data Selector for TX0 pin */ | 102 | #define AK4114_OPS02 (1<<2) /* Output Data Selector for TX0 pin */ |
103 | #define AK4114_OPS01 (1<<1) /* Output Though Data Selector for TX0 pin */ | 103 | #define AK4114_OPS01 (1<<1) /* Output Data Selector for TX0 pin */ |
104 | #define AK4114_OPS00 (1<<0) /* Output Though Data Selector for TX0 pin */ | 104 | #define AK4114_OPS00 (1<<0) /* Output Data Selector for TX0 pin */ |
105 | 105 | ||
106 | /* AK4114_REG_IO1 */ | 106 | /* AK4114_REG_IO1 */ |
107 | #define AK4114_EFH1 (1<<7) /* Interrupt 0 pin Hold */ | 107 | #define AK4114_EFH1 (1<<7) /* Interrupt 0 pin Hold */ |
diff --git a/include/sound/ak4xxx-adda.h b/include/sound/ak4xxx-adda.h index 891cf1aea8b1..030b87c2f6d4 100644 --- a/include/sound/ak4xxx-adda.h +++ b/include/sound/ak4xxx-adda.h | |||
@@ -68,7 +68,7 @@ struct snd_akm4xxx { | |||
68 | enum { | 68 | enum { |
69 | SND_AK4524, SND_AK4528, SND_AK4529, | 69 | SND_AK4524, SND_AK4528, SND_AK4529, |
70 | SND_AK4355, SND_AK4358, SND_AK4381, | 70 | SND_AK4355, SND_AK4358, SND_AK4381, |
71 | SND_AK5365 | 71 | SND_AK5365, SND_AK4620, |
72 | } type; | 72 | } type; |
73 | 73 | ||
74 | /* (array) information of combined codecs */ | 74 | /* (array) information of combined codecs */ |
@@ -76,6 +76,9 @@ struct snd_akm4xxx { | |||
76 | const struct snd_akm4xxx_adc_channel *adc_info; | 76 | const struct snd_akm4xxx_adc_channel *adc_info; |
77 | 77 | ||
78 | struct snd_ak4xxx_ops ops; | 78 | struct snd_ak4xxx_ops ops; |
79 | unsigned int num_chips; | ||
80 | unsigned int total_regs; | ||
81 | const char *name; | ||
79 | }; | 82 | }; |
80 | 83 | ||
81 | void snd_akm4xxx_write(struct snd_akm4xxx *ak, int chip, unsigned char reg, | 84 | void snd_akm4xxx_write(struct snd_akm4xxx *ak, int chip, unsigned char reg, |
diff --git a/include/sound/asound.h b/include/sound/asound.h index 1f57bb92eb5a..098595500632 100644 --- a/include/sound/asound.h +++ b/include/sound/asound.h | |||
@@ -544,7 +544,7 @@ struct snd_rawmidi_status { | |||
544 | * Timer section - /dev/snd/timer | 544 | * Timer section - /dev/snd/timer |
545 | */ | 545 | */ |
546 | 546 | ||
547 | #define SNDRV_TIMER_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 5) | 547 | #define SNDRV_TIMER_VERSION SNDRV_PROTOCOL_VERSION(2, 0, 6) |
548 | 548 | ||
549 | enum { | 549 | enum { |
550 | SNDRV_TIMER_CLASS_NONE = -1, | 550 | SNDRV_TIMER_CLASS_NONE = -1, |
diff --git a/include/sound/control.h b/include/sound/control.h index ef96f07aa03b..112374dc0c58 100644 --- a/include/sound/control.h +++ b/include/sound/control.h | |||
@@ -56,7 +56,6 @@ struct snd_kcontrol_new { | |||
56 | 56 | ||
57 | struct snd_kcontrol_volatile { | 57 | struct snd_kcontrol_volatile { |
58 | struct snd_ctl_file *owner; /* locked */ | 58 | struct snd_ctl_file *owner; /* locked */ |
59 | pid_t owner_pid; | ||
60 | unsigned int access; /* access rights */ | 59 | unsigned int access; /* access rights */ |
61 | }; | 60 | }; |
62 | 61 | ||
@@ -87,10 +86,12 @@ struct snd_kctl_event { | |||
87 | 86 | ||
88 | #define snd_kctl_event(n) list_entry(n, struct snd_kctl_event, list) | 87 | #define snd_kctl_event(n) list_entry(n, struct snd_kctl_event, list) |
89 | 88 | ||
89 | struct pid; | ||
90 | |||
90 | struct snd_ctl_file { | 91 | struct snd_ctl_file { |
91 | struct list_head list; /* list of all control files */ | 92 | struct list_head list; /* list of all control files */ |
92 | struct snd_card *card; | 93 | struct snd_card *card; |
93 | pid_t pid; | 94 | struct pid *pid; |
94 | int prefer_pcm_subdevice; | 95 | int prefer_pcm_subdevice; |
95 | int prefer_rawmidi_subdevice; | 96 | int prefer_rawmidi_subdevice; |
96 | wait_queue_head_t change_sleep; | 97 | wait_queue_head_t change_sleep; |
diff --git a/include/sound/core.h b/include/sound/core.h index a61499c22b0b..89e0ac17f44a 100644 --- a/include/sound/core.h +++ b/include/sound/core.h | |||
@@ -458,5 +458,8 @@ struct snd_pci_quirk { | |||
458 | const struct snd_pci_quirk * | 458 | const struct snd_pci_quirk * |
459 | snd_pci_quirk_lookup(struct pci_dev *pci, const struct snd_pci_quirk *list); | 459 | snd_pci_quirk_lookup(struct pci_dev *pci, const struct snd_pci_quirk *list); |
460 | 460 | ||
461 | const struct snd_pci_quirk * | ||
462 | snd_pci_quirk_lookup_id(u16 vendor, u16 device, | ||
463 | const struct snd_pci_quirk *list); | ||
461 | 464 | ||
462 | #endif /* __SOUND_CORE_H */ | 465 | #endif /* __SOUND_CORE_H */ |
diff --git a/include/sound/cs4231-regs.h b/include/sound/cs4231-regs.h index 92647532c454..66d28c2cb53d 100644 --- a/include/sound/cs4231-regs.h +++ b/include/sound/cs4231-regs.h | |||
@@ -70,7 +70,6 @@ | |||
70 | #define AD1845_PWR_DOWN 0x1b /* power down control */ | 70 | #define AD1845_PWR_DOWN 0x1b /* power down control */ |
71 | #define CS4235_LEFT_MASTER 0x1b /* left master output control */ | 71 | #define CS4235_LEFT_MASTER 0x1b /* left master output control */ |
72 | #define CS4231_REC_FORMAT 0x1c /* clock and data format - record - bits 7-0 MCE */ | 72 | #define CS4231_REC_FORMAT 0x1c /* clock and data format - record - bits 7-0 MCE */ |
73 | #define CS4231_PLY_VAR_FREQ 0x1d /* playback variable frequency */ | ||
74 | #define AD1845_CLOCK 0x1d /* crystal clock select and total power down */ | 73 | #define AD1845_CLOCK 0x1d /* crystal clock select and total power down */ |
75 | #define CS4235_RIGHT_MASTER 0x1d /* right master output control */ | 74 | #define CS4235_RIGHT_MASTER 0x1d /* right master output control */ |
76 | #define CS4231_REC_UPR_CNT 0x1e /* record upper count */ | 75 | #define CS4231_REC_UPR_CNT 0x1e /* record upper count */ |
diff --git a/include/sound/cs46xx_dsp_spos.h b/include/sound/cs46xx_dsp_spos.h index 7c44667e79a6..49b03c9e5e55 100644 --- a/include/sound/cs46xx_dsp_spos.h +++ b/include/sound/cs46xx_dsp_spos.h | |||
@@ -118,9 +118,11 @@ struct dsp_scb_descriptor { | |||
118 | 118 | ||
119 | struct snd_info_entry *proc_info; | 119 | struct snd_info_entry *proc_info; |
120 | int ref_count; | 120 | int ref_count; |
121 | spinlock_t lock; | ||
122 | 121 | ||
123 | int deleted; | 122 | u16 volume[2]; |
123 | unsigned int deleted :1; | ||
124 | unsigned int updated :1; | ||
125 | unsigned int volume_set :1; | ||
124 | }; | 126 | }; |
125 | 127 | ||
126 | struct dsp_task_descriptor { | 128 | struct dsp_task_descriptor { |
diff --git a/include/sound/pcm.h b/include/sound/pcm.h index de6d981de5d6..8b611a561985 100644 --- a/include/sound/pcm.h +++ b/include/sound/pcm.h | |||
@@ -262,6 +262,8 @@ struct snd_pcm_hw_constraint_list { | |||
262 | unsigned int mask; | 262 | unsigned int mask; |
263 | }; | 263 | }; |
264 | 264 | ||
265 | struct snd_pcm_hwptr_log; | ||
266 | |||
265 | struct snd_pcm_runtime { | 267 | struct snd_pcm_runtime { |
266 | /* -- Status -- */ | 268 | /* -- Status -- */ |
267 | struct snd_pcm_substream *trigger_master; | 269 | struct snd_pcm_substream *trigger_master; |
@@ -310,7 +312,9 @@ struct snd_pcm_runtime { | |||
310 | struct snd_pcm_mmap_control *control; | 312 | struct snd_pcm_mmap_control *control; |
311 | 313 | ||
312 | /* -- locking / scheduling -- */ | 314 | /* -- locking / scheduling -- */ |
313 | wait_queue_head_t sleep; | 315 | unsigned int twake: 1; /* do transfer (!poll) wakeup */ |
316 | wait_queue_head_t sleep; /* poll sleep */ | ||
317 | wait_queue_head_t tsleep; /* transfer sleep */ | ||
314 | struct fasync_struct *fasync; | 318 | struct fasync_struct *fasync; |
315 | 319 | ||
316 | /* -- private section -- */ | 320 | /* -- private section -- */ |
@@ -340,6 +344,10 @@ struct snd_pcm_runtime { | |||
340 | /* -- OSS things -- */ | 344 | /* -- OSS things -- */ |
341 | struct snd_pcm_oss_runtime oss; | 345 | struct snd_pcm_oss_runtime oss; |
342 | #endif | 346 | #endif |
347 | |||
348 | #ifdef CONFIG_SND_PCM_XRUN_DEBUG | ||
349 | struct snd_pcm_hwptr_log *hwptr_log; | ||
350 | #endif | ||
343 | }; | 351 | }; |
344 | 352 | ||
345 | struct snd_pcm_group { /* keep linked substreams */ | 353 | struct snd_pcm_group { /* keep linked substreams */ |
@@ -348,6 +356,8 @@ struct snd_pcm_group { /* keep linked substreams */ | |||
348 | int count; | 356 | int count; |
349 | }; | 357 | }; |
350 | 358 | ||
359 | struct pid; | ||
360 | |||
351 | struct snd_pcm_substream { | 361 | struct snd_pcm_substream { |
352 | struct snd_pcm *pcm; | 362 | struct snd_pcm *pcm; |
353 | struct snd_pcm_str *pstr; | 363 | struct snd_pcm_str *pstr; |
@@ -379,6 +389,7 @@ struct snd_pcm_substream { | |||
379 | atomic_t mmap_count; | 389 | atomic_t mmap_count; |
380 | unsigned int f_flags; | 390 | unsigned int f_flags; |
381 | void (*pcm_release)(struct snd_pcm_substream *); | 391 | void (*pcm_release)(struct snd_pcm_substream *); |
392 | struct pid *pid; | ||
382 | #if defined(CONFIG_SND_PCM_OSS) || defined(CONFIG_SND_PCM_OSS_MODULE) | 393 | #if defined(CONFIG_SND_PCM_OSS) || defined(CONFIG_SND_PCM_OSS_MODULE) |
383 | /* -- OSS things -- */ | 394 | /* -- OSS things -- */ |
384 | struct snd_pcm_oss_substream oss; | 395 | struct snd_pcm_oss_substream oss; |
@@ -831,6 +842,8 @@ void snd_pcm_set_sync(struct snd_pcm_substream *substream); | |||
831 | int snd_pcm_lib_interleave_len(struct snd_pcm_substream *substream); | 842 | int snd_pcm_lib_interleave_len(struct snd_pcm_substream *substream); |
832 | int snd_pcm_lib_ioctl(struct snd_pcm_substream *substream, | 843 | int snd_pcm_lib_ioctl(struct snd_pcm_substream *substream, |
833 | unsigned int cmd, void *arg); | 844 | unsigned int cmd, void *arg); |
845 | int snd_pcm_update_state(struct snd_pcm_substream *substream, | ||
846 | struct snd_pcm_runtime *runtime); | ||
834 | int snd_pcm_update_hw_ptr(struct snd_pcm_substream *substream); | 847 | int snd_pcm_update_hw_ptr(struct snd_pcm_substream *substream); |
835 | int snd_pcm_playback_xrun_check(struct snd_pcm_substream *substream); | 848 | int snd_pcm_playback_xrun_check(struct snd_pcm_substream *substream); |
836 | int snd_pcm_capture_xrun_check(struct snd_pcm_substream *substream); | 849 | int snd_pcm_capture_xrun_check(struct snd_pcm_substream *substream); |
@@ -902,6 +915,44 @@ int snd_pcm_lib_preallocate_pages_for_all(struct snd_pcm *pcm, | |||
902 | int snd_pcm_lib_malloc_pages(struct snd_pcm_substream *substream, size_t size); | 915 | int snd_pcm_lib_malloc_pages(struct snd_pcm_substream *substream, size_t size); |
903 | int snd_pcm_lib_free_pages(struct snd_pcm_substream *substream); | 916 | int snd_pcm_lib_free_pages(struct snd_pcm_substream *substream); |
904 | 917 | ||
918 | int _snd_pcm_lib_alloc_vmalloc_buffer(struct snd_pcm_substream *substream, | ||
919 | size_t size, gfp_t gfp_flags); | ||
920 | int snd_pcm_lib_free_vmalloc_buffer(struct snd_pcm_substream *substream); | ||
921 | struct page *snd_pcm_lib_get_vmalloc_page(struct snd_pcm_substream *substream, | ||
922 | unsigned long offset); | ||
923 | #if 0 /* for kernel-doc */ | ||
924 | /** | ||
925 | * snd_pcm_lib_alloc_vmalloc_buffer - allocate virtual DMA buffer | ||
926 | * @substream: the substream to allocate the buffer to | ||
927 | * @size: the requested buffer size, in bytes | ||
928 | * | ||
929 | * Allocates the PCM substream buffer using vmalloc(), i.e., the memory is | ||
930 | * contiguous in kernel virtual space, but not in physical memory. Use this | ||
931 | * if the buffer is accessed by kernel code but not by device DMA. | ||
932 | * | ||
933 | * Returns 1 if the buffer was changed, 0 if not changed, or a negative error | ||
934 | * code. | ||
935 | */ | ||
936 | static int snd_pcm_lib_alloc_vmalloc_buffer | ||
937 | (struct snd_pcm_substream *substream, size_t size); | ||
938 | /** | ||
939 | * snd_pcm_lib_alloc_vmalloc_32_buffer - allocate 32-bit-addressable buffer | ||
940 | * @substream: the substream to allocate the buffer to | ||
941 | * @size: the requested buffer size, in bytes | ||
942 | * | ||
943 | * This function works like snd_pcm_lib_alloc_vmalloc_buffer(), but uses | ||
944 | * vmalloc_32(), i.e., the pages are allocated from 32-bit-addressable memory. | ||
945 | */ | ||
946 | static int snd_pcm_lib_alloc_vmalloc_32_buffer | ||
947 | (struct snd_pcm_substream *substream, size_t size); | ||
948 | #endif | ||
949 | #define snd_pcm_lib_alloc_vmalloc_buffer(subs, size) \ | ||
950 | _snd_pcm_lib_alloc_vmalloc_buffer \ | ||
951 | (subs, size, GFP_KERNEL | __GFP_HIGHMEM | __GFP_ZERO) | ||
952 | #define snd_pcm_lib_alloc_vmalloc_32_buffer(subs, size) \ | ||
953 | _snd_pcm_lib_alloc_vmalloc_buffer \ | ||
954 | (subs, size, GFP_KERNEL | GFP_DMA32 | __GFP_ZERO) | ||
955 | |||
905 | #ifdef CONFIG_SND_DMA_SGBUF | 956 | #ifdef CONFIG_SND_DMA_SGBUF |
906 | /* | 957 | /* |
907 | * SG-buffer handling | 958 | * SG-buffer handling |
@@ -972,6 +1023,10 @@ int snd_pcm_lib_mmap_iomem(struct snd_pcm_substream *substream, struct vm_area_s | |||
972 | #define snd_pcm_lib_mmap_iomem NULL | 1023 | #define snd_pcm_lib_mmap_iomem NULL |
973 | #endif | 1024 | #endif |
974 | 1025 | ||
1026 | int snd_pcm_lib_mmap_noncached(struct snd_pcm_substream *substream, | ||
1027 | struct vm_area_struct *area); | ||
1028 | #define snd_pcm_lib_mmap_vmalloc snd_pcm_lib_mmap_noncached | ||
1029 | |||
975 | static inline void snd_pcm_limit_isa_dma_size(int dma, size_t *max) | 1030 | static inline void snd_pcm_limit_isa_dma_size(int dma, size_t *max) |
976 | { | 1031 | { |
977 | *max = dma < 4 ? 64 * 1024 : 128 * 1024; | 1032 | *max = dma < 4 ? 64 * 1024 : 128 * 1024; |
diff --git a/include/sound/pcm_oss.h b/include/sound/pcm_oss.h index cc4e226f35fd..760c969d885d 100644 --- a/include/sound/pcm_oss.h +++ b/include/sound/pcm_oss.h | |||
@@ -61,7 +61,7 @@ struct snd_pcm_oss_runtime { | |||
61 | struct snd_pcm_plugin *plugin_first; | 61 | struct snd_pcm_plugin *plugin_first; |
62 | struct snd_pcm_plugin *plugin_last; | 62 | struct snd_pcm_plugin *plugin_last; |
63 | #endif | 63 | #endif |
64 | unsigned int prev_hw_ptr_interrupt; | 64 | unsigned int prev_hw_ptr_period; |
65 | }; | 65 | }; |
66 | 66 | ||
67 | struct snd_pcm_oss_file { | 67 | struct snd_pcm_oss_file { |
diff --git a/include/sound/rawmidi.h b/include/sound/rawmidi.h index c23c26585700..2480e7d10dcf 100644 --- a/include/sound/rawmidi.h +++ b/include/sound/rawmidi.h | |||
@@ -46,6 +46,7 @@ | |||
46 | struct snd_rawmidi; | 46 | struct snd_rawmidi; |
47 | struct snd_rawmidi_substream; | 47 | struct snd_rawmidi_substream; |
48 | struct snd_seq_port_info; | 48 | struct snd_seq_port_info; |
49 | struct pid; | ||
49 | 50 | ||
50 | struct snd_rawmidi_ops { | 51 | struct snd_rawmidi_ops { |
51 | int (*open) (struct snd_rawmidi_substream * substream); | 52 | int (*open) (struct snd_rawmidi_substream * substream); |
@@ -97,6 +98,7 @@ struct snd_rawmidi_substream { | |||
97 | struct snd_rawmidi_str *pstr; | 98 | struct snd_rawmidi_str *pstr; |
98 | char name[32]; | 99 | char name[32]; |
99 | struct snd_rawmidi_runtime *runtime; | 100 | struct snd_rawmidi_runtime *runtime; |
101 | struct pid *pid; | ||
100 | /* hardware layer */ | 102 | /* hardware layer */ |
101 | struct snd_rawmidi_ops *ops; | 103 | struct snd_rawmidi_ops *ops; |
102 | }; | 104 | }; |
diff --git a/include/sound/sb.h b/include/sound/sb.h index 4e62ee1e4115..95353542256a 100644 --- a/include/sound/sb.h +++ b/include/sound/sb.h | |||
@@ -33,6 +33,7 @@ enum sb_hw_type { | |||
33 | SB_HW_20, | 33 | SB_HW_20, |
34 | SB_HW_201, | 34 | SB_HW_201, |
35 | SB_HW_PRO, | 35 | SB_HW_PRO, |
36 | SB_HW_JAZZ16, /* Media Vision Jazz16 */ | ||
36 | SB_HW_16, | 37 | SB_HW_16, |
37 | SB_HW_16CSP, /* SB16 with CSP chip */ | 38 | SB_HW_16CSP, /* SB16 with CSP chip */ |
38 | SB_HW_ALS100, /* Avance Logic ALS100 chip */ | 39 | SB_HW_ALS100, /* Avance Logic ALS100 chip */ |
diff --git a/include/sound/sh_dac_audio.h b/include/sound/sh_dac_audio.h new file mode 100644 index 000000000000..f5deaf1ddb9f --- /dev/null +++ b/include/sound/sh_dac_audio.h | |||
@@ -0,0 +1,21 @@ | |||
1 | /* | ||
2 | * SH_DAC specific configuration, for the dac_audio platform_device | ||
3 | * | ||
4 | * Copyright (C) 2009 Rafael Ignacio Zurita <rizurita@yahoo.com> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify it | ||
7 | * under the terms of the GNU General Public License version 2 as published | ||
8 | * by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __INCLUDE_SH_DAC_AUDIO_H | ||
12 | #define __INCLUDE_SH_DAC_AUDIO_H | ||
13 | |||
14 | struct dac_audio_pdata { | ||
15 | int buffer_size; | ||
16 | int channel; | ||
17 | void (*start)(struct dac_audio_pdata *pd); | ||
18 | void (*stop)(struct dac_audio_pdata *pd); | ||
19 | }; | ||
20 | |||
21 | #endif /* __INCLUDE_SH_DAC_AUDIO_H */ | ||
diff --git a/include/sound/soc-dai.h b/include/sound/soc-dai.h index 97ca9af414dc..0a0b019d41ad 100644 --- a/include/sound/soc-dai.h +++ b/include/sound/soc-dai.h | |||
@@ -16,6 +16,8 @@ | |||
16 | 16 | ||
17 | #include <linux/list.h> | 17 | #include <linux/list.h> |
18 | 18 | ||
19 | #include <sound/soc.h> | ||
20 | |||
19 | struct snd_pcm_substream; | 21 | struct snd_pcm_substream; |
20 | 22 | ||
21 | /* | 23 | /* |
@@ -30,6 +32,7 @@ struct snd_pcm_substream; | |||
30 | #define SND_SOC_DAIFMT_DSP_A 3 /* L data MSB after FRM LRC */ | 32 | #define SND_SOC_DAIFMT_DSP_A 3 /* L data MSB after FRM LRC */ |
31 | #define SND_SOC_DAIFMT_DSP_B 4 /* L data MSB during FRM LRC */ | 33 | #define SND_SOC_DAIFMT_DSP_B 4 /* L data MSB during FRM LRC */ |
32 | #define SND_SOC_DAIFMT_AC97 5 /* AC97 */ | 34 | #define SND_SOC_DAIFMT_AC97 5 /* AC97 */ |
35 | #define SND_SOC_DAIFMT_PDM 6 /* Pulse density modulation */ | ||
33 | 36 | ||
34 | /* left and right justified also known as MSB and LSB respectively */ | 37 | /* left and right justified also known as MSB and LSB respectively */ |
35 | #define SND_SOC_DAIFMT_MSB SND_SOC_DAIFMT_LEFT_J | 38 | #define SND_SOC_DAIFMT_MSB SND_SOC_DAIFMT_LEFT_J |
@@ -106,7 +109,7 @@ int snd_soc_dai_set_clkdiv(struct snd_soc_dai *dai, | |||
106 | int div_id, int div); | 109 | int div_id, int div); |
107 | 110 | ||
108 | int snd_soc_dai_set_pll(struct snd_soc_dai *dai, | 111 | int snd_soc_dai_set_pll(struct snd_soc_dai *dai, |
109 | int pll_id, unsigned int freq_in, unsigned int freq_out); | 112 | int pll_id, int source, unsigned int freq_in, unsigned int freq_out); |
110 | 113 | ||
111 | /* Digital Audio interface formatting */ | 114 | /* Digital Audio interface formatting */ |
112 | int snd_soc_dai_set_fmt(struct snd_soc_dai *dai, unsigned int fmt); | 115 | int snd_soc_dai_set_fmt(struct snd_soc_dai *dai, unsigned int fmt); |
@@ -114,6 +117,10 @@ int snd_soc_dai_set_fmt(struct snd_soc_dai *dai, unsigned int fmt); | |||
114 | int snd_soc_dai_set_tdm_slot(struct snd_soc_dai *dai, | 117 | int snd_soc_dai_set_tdm_slot(struct snd_soc_dai *dai, |
115 | unsigned int tx_mask, unsigned int rx_mask, int slots, int slot_width); | 118 | unsigned int tx_mask, unsigned int rx_mask, int slots, int slot_width); |
116 | 119 | ||
120 | int snd_soc_dai_set_channel_map(struct snd_soc_dai *dai, | ||
121 | unsigned int tx_num, unsigned int *tx_slot, | ||
122 | unsigned int rx_num, unsigned int *rx_slot); | ||
123 | |||
117 | int snd_soc_dai_set_tristate(struct snd_soc_dai *dai, int tristate); | 124 | int snd_soc_dai_set_tristate(struct snd_soc_dai *dai, int tristate); |
118 | 125 | ||
119 | /* Digital Audio Interface mute */ | 126 | /* Digital Audio Interface mute */ |
@@ -136,8 +143,8 @@ struct snd_soc_dai_ops { | |||
136 | */ | 143 | */ |
137 | int (*set_sysclk)(struct snd_soc_dai *dai, | 144 | int (*set_sysclk)(struct snd_soc_dai *dai, |
138 | int clk_id, unsigned int freq, int dir); | 145 | int clk_id, unsigned int freq, int dir); |
139 | int (*set_pll)(struct snd_soc_dai *dai, | 146 | int (*set_pll)(struct snd_soc_dai *dai, int pll_id, int source, |
140 | int pll_id, unsigned int freq_in, unsigned int freq_out); | 147 | unsigned int freq_in, unsigned int freq_out); |
141 | int (*set_clkdiv)(struct snd_soc_dai *dai, int div_id, int div); | 148 | int (*set_clkdiv)(struct snd_soc_dai *dai, int div_id, int div); |
142 | 149 | ||
143 | /* | 150 | /* |
@@ -148,6 +155,9 @@ struct snd_soc_dai_ops { | |||
148 | int (*set_tdm_slot)(struct snd_soc_dai *dai, | 155 | int (*set_tdm_slot)(struct snd_soc_dai *dai, |
149 | unsigned int tx_mask, unsigned int rx_mask, | 156 | unsigned int tx_mask, unsigned int rx_mask, |
150 | int slots, int slot_width); | 157 | int slots, int slot_width); |
158 | int (*set_channel_map)(struct snd_soc_dai *dai, | ||
159 | unsigned int tx_num, unsigned int *tx_slot, | ||
160 | unsigned int rx_num, unsigned int *rx_slot); | ||
151 | int (*set_tristate)(struct snd_soc_dai *dai, int tristate); | 161 | int (*set_tristate)(struct snd_soc_dai *dai, int tristate); |
152 | 162 | ||
153 | /* | 163 | /* |
@@ -209,7 +219,6 @@ struct snd_soc_dai { | |||
209 | struct snd_soc_codec *codec; | 219 | struct snd_soc_codec *codec; |
210 | unsigned int active; | 220 | unsigned int active; |
211 | unsigned char pop_wait:1; | 221 | unsigned char pop_wait:1; |
212 | void *dma_data; | ||
213 | 222 | ||
214 | /* DAI private data */ | 223 | /* DAI private data */ |
215 | void *private_data; | 224 | void *private_data; |
@@ -220,4 +229,21 @@ struct snd_soc_dai { | |||
220 | struct list_head list; | 229 | struct list_head list; |
221 | }; | 230 | }; |
222 | 231 | ||
232 | static inline void *snd_soc_dai_get_dma_data(const struct snd_soc_dai *dai, | ||
233 | const struct snd_pcm_substream *ss) | ||
234 | { | ||
235 | return (ss->stream == SNDRV_PCM_STREAM_PLAYBACK) ? | ||
236 | dai->playback.dma_data : dai->capture.dma_data; | ||
237 | } | ||
238 | |||
239 | static inline void snd_soc_dai_set_dma_data(struct snd_soc_dai *dai, | ||
240 | const struct snd_pcm_substream *ss, | ||
241 | void *data) | ||
242 | { | ||
243 | if (ss->stream == SNDRV_PCM_STREAM_PLAYBACK) | ||
244 | dai->playback.dma_data = data; | ||
245 | else | ||
246 | dai->capture.dma_data = data; | ||
247 | } | ||
248 | |||
223 | #endif | 249 | #endif |
diff --git a/include/sound/soc-dapm.h b/include/sound/soc-dapm.h index c1410e3191e3..c0922a034223 100644 --- a/include/sound/soc-dapm.h +++ b/include/sound/soc-dapm.h | |||
@@ -95,6 +95,21 @@ | |||
95 | .shift = wshift, .invert = winvert, .kcontrols = wcontrols, \ | 95 | .shift = wshift, .invert = winvert, .kcontrols = wcontrols, \ |
96 | .num_kcontrols = 1} | 96 | .num_kcontrols = 1} |
97 | 97 | ||
98 | /* Simplified versions of above macros, assuming wncontrols = ARRAY_SIZE(wcontrols) */ | ||
99 | #define SOC_PGA_ARRAY(wname, wreg, wshift, winvert,\ | ||
100 | wcontrols) \ | ||
101 | { .id = snd_soc_dapm_pga, .name = wname, .reg = wreg, .shift = wshift, \ | ||
102 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = ARRAY_SIZE(wcontrols)} | ||
103 | #define SOC_MIXER_ARRAY(wname, wreg, wshift, winvert, \ | ||
104 | wcontrols)\ | ||
105 | { .id = snd_soc_dapm_mixer, .name = wname, .reg = wreg, .shift = wshift, \ | ||
106 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = ARRAY_SIZE(wcontrols)} | ||
107 | #define SOC_MIXER_NAMED_CTL_ARRAY(wname, wreg, wshift, winvert, \ | ||
108 | wcontrols)\ | ||
109 | { .id = snd_soc_dapm_mixer_named_ctl, .name = wname, .reg = wreg, \ | ||
110 | .shift = wshift, .invert = winvert, .kcontrols = wcontrols, \ | ||
111 | .num_kcontrols = ARRAY_SIZE(wcontrols)} | ||
112 | |||
98 | /* path domain with event - event handler must return 0 for success */ | 113 | /* path domain with event - event handler must return 0 for success */ |
99 | #define SND_SOC_DAPM_PGA_E(wname, wreg, wshift, winvert, wcontrols, \ | 114 | #define SND_SOC_DAPM_PGA_E(wname, wreg, wshift, winvert, wcontrols, \ |
100 | wncontrols, wevent, wflags) \ | 115 | wncontrols, wevent, wflags) \ |
@@ -126,6 +141,23 @@ | |||
126 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = 1, \ | 141 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = 1, \ |
127 | .event = wevent, .event_flags = wflags} | 142 | .event = wevent, .event_flags = wflags} |
128 | 143 | ||
144 | /* Simplified versions of above macros, assuming wncontrols = ARRAY_SIZE(wcontrols) */ | ||
145 | #define SOC_PGA_E_ARRAY(wname, wreg, wshift, winvert, wcontrols, \ | ||
146 | wevent, wflags) \ | ||
147 | { .id = snd_soc_dapm_pga, .name = wname, .reg = wreg, .shift = wshift, \ | ||
148 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = ARRAY_SIZE(wcontrols), \ | ||
149 | .event = wevent, .event_flags = wflags} | ||
150 | #define SOC_MIXER_E_ARRAY(wname, wreg, wshift, winvert, wcontrols, \ | ||
151 | wevent, wflags) \ | ||
152 | { .id = snd_soc_dapm_mixer, .name = wname, .reg = wreg, .shift = wshift, \ | ||
153 | .invert = winvert, .kcontrols = wcontrols, .num_kcontrols = ARRAY_SIZE(wcontrols), \ | ||
154 | .event = wevent, .event_flags = wflags} | ||
155 | #define SOC_MIXER_NAMED_CTL_E_ARRAY(wname, wreg, wshift, winvert, \ | ||
156 | wcontrols, wevent, wflags) \ | ||
157 | { .id = snd_soc_dapm_mixer, .name = wname, .reg = wreg, .shift = wshift, \ | ||
158 | .invert = winvert, .kcontrols = wcontrols, \ | ||
159 | .num_kcontrols = ARRAY_SIZE(wcontrols), .event = wevent, .event_flags = wflags} | ||
160 | |||
129 | /* events that are pre and post DAPM */ | 161 | /* events that are pre and post DAPM */ |
130 | #define SND_SOC_DAPM_PRE(wname, wevent) \ | 162 | #define SND_SOC_DAPM_PRE(wname, wevent) \ |
131 | { .id = snd_soc_dapm_pre, .name = wname, .kcontrols = NULL, \ | 163 | { .id = snd_soc_dapm_pre, .name = wname, .kcontrols = NULL, \ |
@@ -206,6 +238,12 @@ | |||
206 | .get = snd_soc_dapm_get_enum_double, \ | 238 | .get = snd_soc_dapm_get_enum_double, \ |
207 | .put = snd_soc_dapm_put_enum_double, \ | 239 | .put = snd_soc_dapm_put_enum_double, \ |
208 | .private_value = (unsigned long)&xenum } | 240 | .private_value = (unsigned long)&xenum } |
241 | #define SOC_DAPM_ENUM_VIRT(xname, xenum) \ | ||
242 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ | ||
243 | .info = snd_soc_info_enum_double, \ | ||
244 | .get = snd_soc_dapm_get_enum_virt, \ | ||
245 | .put = snd_soc_dapm_put_enum_virt, \ | ||
246 | .private_value = (unsigned long)&xenum } | ||
209 | #define SOC_DAPM_VALUE_ENUM(xname, xenum) \ | 247 | #define SOC_DAPM_VALUE_ENUM(xname, xenum) \ |
210 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ | 248 | { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ |
211 | .info = snd_soc_info_enum_double, \ | 249 | .info = snd_soc_info_enum_double, \ |
@@ -260,6 +298,10 @@ int snd_soc_dapm_get_enum_double(struct snd_kcontrol *kcontrol, | |||
260 | struct snd_ctl_elem_value *ucontrol); | 298 | struct snd_ctl_elem_value *ucontrol); |
261 | int snd_soc_dapm_put_enum_double(struct snd_kcontrol *kcontrol, | 299 | int snd_soc_dapm_put_enum_double(struct snd_kcontrol *kcontrol, |
262 | struct snd_ctl_elem_value *ucontrol); | 300 | struct snd_ctl_elem_value *ucontrol); |
301 | int snd_soc_dapm_get_enum_virt(struct snd_kcontrol *kcontrol, | ||
302 | struct snd_ctl_elem_value *ucontrol); | ||
303 | int snd_soc_dapm_put_enum_virt(struct snd_kcontrol *kcontrol, | ||
304 | struct snd_ctl_elem_value *ucontrol); | ||
263 | int snd_soc_dapm_get_value_enum_double(struct snd_kcontrol *kcontrol, | 305 | int snd_soc_dapm_get_value_enum_double(struct snd_kcontrol *kcontrol, |
264 | struct snd_ctl_elem_value *ucontrol); | 306 | struct snd_ctl_elem_value *ucontrol); |
265 | int snd_soc_dapm_put_value_enum_double(struct snd_kcontrol *kcontrol, | 307 | int snd_soc_dapm_put_value_enum_double(struct snd_kcontrol *kcontrol, |
@@ -333,6 +375,10 @@ struct snd_soc_dapm_route { | |||
333 | const char *sink; | 375 | const char *sink; |
334 | const char *control; | 376 | const char *control; |
335 | const char *source; | 377 | const char *source; |
378 | |||
379 | /* Note: currently only supported for links where source is a supply */ | ||
380 | int (*connected)(struct snd_soc_dapm_widget *source, | ||
381 | struct snd_soc_dapm_widget *sink); | ||
336 | }; | 382 | }; |
337 | 383 | ||
338 | /* dapm audio path between two widgets */ | 384 | /* dapm audio path between two widgets */ |
@@ -349,6 +395,9 @@ struct snd_soc_dapm_path { | |||
349 | u32 connect:1; /* source and sink widgets are connected */ | 395 | u32 connect:1; /* source and sink widgets are connected */ |
350 | u32 walked:1; /* path has been walked */ | 396 | u32 walked:1; /* path has been walked */ |
351 | 397 | ||
398 | int (*connected)(struct snd_soc_dapm_widget *source, | ||
399 | struct snd_soc_dapm_widget *sink); | ||
400 | |||
352 | struct list_head list_source; | 401 | struct list_head list_source; |
353 | struct list_head list_sink; | 402 | struct list_head list_sink; |
354 | struct list_head list; | 403 | struct list_head list; |
diff --git a/include/sound/soc.h b/include/sound/soc.h index 475cb7ed6bec..a57fbfcd4c8f 100644 --- a/include/sound/soc.h +++ b/include/sound/soc.h | |||
@@ -169,6 +169,23 @@ | |||
169 | .private_value = (unsigned long)&xenum } | 169 | .private_value = (unsigned long)&xenum } |
170 | 170 | ||
171 | /* | 171 | /* |
172 | * Simplified versions of above macros, declaring a struct and calculating | ||
173 | * ARRAY_SIZE internally | ||
174 | */ | ||
175 | #define SOC_ENUM_DOUBLE_DECL(name, xreg, xshift_l, xshift_r, xtexts) \ | ||
176 | struct soc_enum name = SOC_ENUM_DOUBLE(xreg, xshift_l, xshift_r, \ | ||
177 | ARRAY_SIZE(xtexts), xtexts) | ||
178 | #define SOC_ENUM_SINGLE_DECL(name, xreg, xshift, xtexts) \ | ||
179 | SOC_ENUM_DOUBLE_DECL(name, xreg, xshift, xshift, xtexts) | ||
180 | #define SOC_ENUM_SINGLE_EXT_DECL(name, xtexts) \ | ||
181 | struct soc_enum name = SOC_ENUM_SINGLE_EXT(ARRAY_SIZE(xtexts), xtexts) | ||
182 | #define SOC_VALUE_ENUM_DOUBLE_DECL(name, xreg, xshift_l, xshift_r, xmask, xtexts, xvalues) \ | ||
183 | struct soc_enum name = SOC_VALUE_ENUM_DOUBLE(xreg, xshift_l, xshift_r, xmask, \ | ||
184 | ARRAY_SIZE(xtexts), xtexts, xvalues) | ||
185 | #define SOC_VALUE_ENUM_SINGLE_DECL(name, xreg, xshift, xmask, xtexts, xvalues) \ | ||
186 | SOC_VALUE_ENUM_DOUBLE_DECL(name, xreg, xshift, xshift, xmask, xtexts, xvalues) | ||
187 | |||
188 | /* | ||
172 | * Bias levels | 189 | * Bias levels |
173 | * | 190 | * |
174 | * @ON: Bias is fully on for audio playback and capture operations. | 191 | * @ON: Bias is fully on for audio playback and capture operations. |
@@ -223,15 +240,15 @@ int snd_soc_codec_set_cache_io(struct snd_soc_codec *codec, | |||
223 | int addr_bits, int data_bits, | 240 | int addr_bits, int data_bits, |
224 | enum snd_soc_control_type control); | 241 | enum snd_soc_control_type control); |
225 | 242 | ||
226 | #ifdef CONFIG_PM | ||
227 | int snd_soc_suspend_device(struct device *dev); | ||
228 | int snd_soc_resume_device(struct device *dev); | ||
229 | #endif | ||
230 | |||
231 | /* pcm <-> DAI connect */ | 243 | /* pcm <-> DAI connect */ |
232 | void snd_soc_free_pcms(struct snd_soc_device *socdev); | 244 | void snd_soc_free_pcms(struct snd_soc_device *socdev); |
233 | int snd_soc_new_pcms(struct snd_soc_device *socdev, int idx, const char *xid); | 245 | int snd_soc_new_pcms(struct snd_soc_device *socdev, int idx, const char *xid); |
234 | int snd_soc_init_card(struct snd_soc_device *socdev); | 246 | |
247 | /* Utility functions to get clock rates from various things */ | ||
248 | int snd_soc_calc_frame_size(int sample_size, int channels, int tdm_slots); | ||
249 | int snd_soc_params_to_frame_size(struct snd_pcm_hw_params *params); | ||
250 | int snd_soc_calc_bclk(int fs, int sample_size, int channels, int tdm_slots); | ||
251 | int snd_soc_params_to_bclk(struct snd_pcm_hw_params *parms); | ||
235 | 252 | ||
236 | /* set runtime hw params */ | 253 | /* set runtime hw params */ |
237 | int snd_soc_set_runtime_hwparams(struct snd_pcm_substream *substream, | 254 | int snd_soc_set_runtime_hwparams(struct snd_pcm_substream *substream, |
@@ -253,6 +270,9 @@ void snd_soc_jack_free_gpios(struct snd_soc_jack *jack, int count, | |||
253 | /* codec register bit access */ | 270 | /* codec register bit access */ |
254 | int snd_soc_update_bits(struct snd_soc_codec *codec, unsigned short reg, | 271 | int snd_soc_update_bits(struct snd_soc_codec *codec, unsigned short reg, |
255 | unsigned int mask, unsigned int value); | 272 | unsigned int mask, unsigned int value); |
273 | int snd_soc_update_bits_locked(struct snd_soc_codec *codec, | ||
274 | unsigned short reg, unsigned int mask, | ||
275 | unsigned int value); | ||
256 | int snd_soc_test_bits(struct snd_soc_codec *codec, unsigned short reg, | 276 | int snd_soc_test_bits(struct snd_soc_codec *codec, unsigned short reg, |
257 | unsigned int mask, unsigned int value); | 277 | unsigned int mask, unsigned int value); |
258 | 278 | ||
@@ -333,6 +353,8 @@ struct snd_soc_jack_gpio { | |||
333 | int debounce_time; | 353 | int debounce_time; |
334 | struct snd_soc_jack *jack; | 354 | struct snd_soc_jack *jack; |
335 | struct work_struct work; | 355 | struct work_struct work; |
356 | |||
357 | int (*jack_status_check)(void); | ||
336 | }; | 358 | }; |
337 | #endif | 359 | #endif |
338 | 360 | ||
@@ -353,6 +375,7 @@ struct snd_soc_pcm_stream { | |||
353 | unsigned int channels_min; /* min channels */ | 375 | unsigned int channels_min; /* min channels */ |
354 | unsigned int channels_max; /* max channels */ | 376 | unsigned int channels_max; /* max channels */ |
355 | unsigned int active:1; /* stream is in use */ | 377 | unsigned int active:1; /* stream is in use */ |
378 | void *dma_data; /* used by platform code */ | ||
356 | }; | 379 | }; |
357 | 380 | ||
358 | /* SoC audio ops */ | 381 | /* SoC audio ops */ |
@@ -400,6 +423,10 @@ struct snd_soc_codec { | |||
400 | short reg_cache_size; | 423 | short reg_cache_size; |
401 | short reg_cache_step; | 424 | short reg_cache_step; |
402 | 425 | ||
426 | unsigned int idle_bias_off:1; /* Use BIAS_OFF instead of STANDBY */ | ||
427 | unsigned int cache_only:1; /* Suppress writes to hardware */ | ||
428 | unsigned int cache_sync:1; /* Cache needs to be synced to hardware */ | ||
429 | |||
403 | /* dapm */ | 430 | /* dapm */ |
404 | u32 pop_time; | 431 | u32 pop_time; |
405 | struct list_head dapm_widgets; | 432 | struct list_head dapm_widgets; |
@@ -413,6 +440,7 @@ struct snd_soc_codec { | |||
413 | unsigned int num_dai; | 440 | unsigned int num_dai; |
414 | 441 | ||
415 | #ifdef CONFIG_DEBUG_FS | 442 | #ifdef CONFIG_DEBUG_FS |
443 | struct dentry *debugfs_codec_root; | ||
416 | struct dentry *debugfs_reg; | 444 | struct dentry *debugfs_reg; |
417 | struct dentry *debugfs_pop_time; | 445 | struct dentry *debugfs_pop_time; |
418 | struct dentry *debugfs_dapm; | 446 | struct dentry *debugfs_dapm; |
@@ -494,6 +522,8 @@ struct snd_soc_card { | |||
494 | int (*set_bias_level)(struct snd_soc_card *, | 522 | int (*set_bias_level)(struct snd_soc_card *, |
495 | enum snd_soc_bias_level level); | 523 | enum snd_soc_bias_level level); |
496 | 524 | ||
525 | long pmdown_time; | ||
526 | |||
497 | /* CPU <--> Codec DAI links */ | 527 | /* CPU <--> Codec DAI links */ |
498 | struct snd_soc_dai_link *dai_link; | 528 | struct snd_soc_dai_link *dai_link; |
499 | int num_links; | 529 | int num_links; |
diff --git a/include/sound/sscape_ioctl.h b/include/sound/sscape_ioctl.h deleted file mode 100644 index 0d8885969c64..000000000000 --- a/include/sound/sscape_ioctl.h +++ /dev/null | |||
@@ -1,21 +0,0 @@ | |||
1 | #ifndef SSCAPE_IOCTL_H | ||
2 | #define SSCAPE_IOCTL_H | ||
3 | |||
4 | |||
5 | struct sscape_bootblock | ||
6 | { | ||
7 | unsigned char code[256]; | ||
8 | unsigned version; | ||
9 | }; | ||
10 | |||
11 | #define SSCAPE_MICROCODE_SIZE 65536 | ||
12 | |||
13 | struct sscape_microcode | ||
14 | { | ||
15 | unsigned char __user *code; | ||
16 | }; | ||
17 | |||
18 | #define SND_SSCAPE_LOAD_BOOTB _IOWR('P', 100, struct sscape_bootblock) | ||
19 | #define SND_SSCAPE_LOAD_MCODE _IOW ('P', 101, struct sscape_microcode) | ||
20 | |||
21 | #endif | ||
diff --git a/include/sound/tlv320dac33-plat.h b/include/sound/tlv320dac33-plat.h new file mode 100644 index 000000000000..ac0665264bdf --- /dev/null +++ b/include/sound/tlv320dac33-plat.h | |||
@@ -0,0 +1,21 @@ | |||
1 | /* | ||
2 | * Platform header for Texas Instruments TLV320DAC33 codec driver | ||
3 | * | ||
4 | * Author: Peter Ujfalusi <peter.ujfalusi@nokia.com> | ||
5 | * | ||
6 | * Copyright: (C) 2009 Nokia Corporation | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __TLV320DAC33_PLAT_H | ||
14 | #define __TLV320DAC33_PLAT_H | ||
15 | |||
16 | struct tlv320dac33_platform_data { | ||
17 | int power_gpio; | ||
18 | u8 burst_bclkdiv; | ||
19 | }; | ||
20 | |||
21 | #endif /* __TLV320DAC33_PLAT_H */ | ||
diff --git a/include/sound/tpa6130a2-plat.h b/include/sound/tpa6130a2-plat.h new file mode 100644 index 000000000000..e29fde6b5cbe --- /dev/null +++ b/include/sound/tpa6130a2-plat.h | |||
@@ -0,0 +1,36 @@ | |||
1 | /* | ||
2 | * TPA6130A2 driver platform header | ||
3 | * | ||
4 | * Copyright (C) Nokia Corporation | ||
5 | * | ||
6 | * Written by Peter Ujfalusi <peter.ujfalusi@nokia.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or | ||
9 | * modify it under the terms of the GNU General Public License | ||
10 | * version 2 as published by the Free Software Foundation. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, but | ||
13 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
15 | * General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
20 | * 02110-1301 USA | ||
21 | */ | ||
22 | |||
23 | #ifndef TPA6130A2_PLAT_H | ||
24 | #define TPA6130A2_PLAT_H | ||
25 | |||
26 | enum tpa_model { | ||
27 | TPA6130A2, | ||
28 | TPA6140A2, | ||
29 | }; | ||
30 | |||
31 | struct tpa6130a2_platform_data { | ||
32 | enum tpa_model id; | ||
33 | int power_gpio; | ||
34 | }; | ||
35 | |||
36 | #endif | ||
diff --git a/include/sound/version.h b/include/sound/version.h index 22939142dd23..7fed23442db8 100644 --- a/include/sound/version.h +++ b/include/sound/version.h | |||
@@ -1,3 +1,3 @@ | |||
1 | /* include/version.h */ | 1 | /* include/version.h */ |
2 | #define CONFIG_SND_VERSION "1.0.21" | 2 | #define CONFIG_SND_VERSION "1.0.22.1" |
3 | #define CONFIG_SND_DATE "" | 3 | #define CONFIG_SND_DATE "" |
diff --git a/include/sound/wm2000.h b/include/sound/wm2000.h new file mode 100644 index 000000000000..aa388ca9ec64 --- /dev/null +++ b/include/sound/wm2000.h | |||
@@ -0,0 +1,26 @@ | |||
1 | /* | ||
2 | * linux/sound/wm2000.h -- Platform data for WM2000 | ||
3 | * | ||
4 | * Copyright 2010 Wolfson Microelectronics. PLC. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __LINUX_SND_WM2000_H | ||
12 | #define __LINUX_SND_WM2000_H | ||
13 | |||
14 | struct wm2000_platform_data { | ||
15 | /** Filename for system-specific image to download to device. */ | ||
16 | const char *download_file; | ||
17 | |||
18 | /** Divide MCLK by 2 for system clock? */ | ||
19 | unsigned int mclkdiv2:1; | ||
20 | |||
21 | /** Disable speech clarity enhancement, for use when an | ||
22 | * external algorithm is used. */ | ||
23 | unsigned int speech_enh_disable:1; | ||
24 | }; | ||
25 | |||
26 | #endif | ||
diff --git a/include/sound/wm8904.h b/include/sound/wm8904.h new file mode 100644 index 000000000000..d66575a601be --- /dev/null +++ b/include/sound/wm8904.h | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * Platform data for WM8904 | ||
3 | * | ||
4 | * Copyright 2009 Wolfson Microelectronics PLC. | ||
5 | * | ||
6 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify it | ||
9 | * under the terms of the GNU General Public License as published by the | ||
10 | * Free Software Foundation; either version 2 of the License, or (at your | ||
11 | * option) any later version. | ||
12 | * | ||
13 | */ | ||
14 | |||
15 | #ifndef __MFD_WM8994_PDATA_H__ | ||
16 | #define __MFD_WM8994_PDATA_H__ | ||
17 | |||
18 | #define WM8904_DRC_REGS 4 | ||
19 | #define WM8904_EQ_REGS 25 | ||
20 | |||
21 | /** | ||
22 | * DRC configurations are specified with a label and a set of register | ||
23 | * values to write (the enable bits will be ignored). At runtime an | ||
24 | * enumerated control will be presented for each DRC block allowing | ||
25 | * the user to choose the configration to use. | ||
26 | * | ||
27 | * Configurations may be generated by hand or by using the DRC control | ||
28 | * panel provided by the WISCE - see http://www.wolfsonmicro.com/wisce/ | ||
29 | * for details. | ||
30 | */ | ||
31 | struct wm8904_drc_cfg { | ||
32 | const char *name; | ||
33 | u16 regs[WM8904_DRC_REGS]; | ||
34 | }; | ||
35 | |||
36 | /** | ||
37 | * ReTune Mobile configurations are specified with a label, sample | ||
38 | * rate and set of values to write (the enable bits will be ignored). | ||
39 | * | ||
40 | * Configurations are expected to be generated using the ReTune Mobile | ||
41 | * control panel in WISCE - see http://www.wolfsonmicro.com/wisce/ | ||
42 | */ | ||
43 | struct wm8904_retune_mobile_cfg { | ||
44 | const char *name; | ||
45 | unsigned int rate; | ||
46 | u16 regs[WM8904_EQ_REGS]; | ||
47 | }; | ||
48 | |||
49 | struct wm8904_pdata { | ||
50 | int num_drc_cfgs; | ||
51 | struct wm8904_drc_cfg *drc_cfgs; | ||
52 | |||
53 | int num_retune_mobile_cfgs; | ||
54 | struct wm8904_retune_mobile_cfg *retune_mobile_cfgs; | ||
55 | }; | ||
56 | |||
57 | #endif | ||
diff --git a/include/sound/wm8955.h b/include/sound/wm8955.h new file mode 100644 index 000000000000..5074ef499f40 --- /dev/null +++ b/include/sound/wm8955.h | |||
@@ -0,0 +1,26 @@ | |||
1 | /* | ||
2 | * Platform data for WM8955 | ||
3 | * | ||
4 | * Copyright 2009 Wolfson Microelectronics PLC. | ||
5 | * | ||
6 | * Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify it | ||
9 | * under the terms of the GNU General Public License as published by the | ||
10 | * Free Software Foundation; either version 2 of the License, or (at your | ||
11 | * option) any later version. | ||
12 | * | ||
13 | */ | ||
14 | |||
15 | #ifndef __WM8955_PDATA_H__ | ||
16 | #define __WM8955_PDATA_H__ | ||
17 | |||
18 | struct wm8955_pdata { | ||
19 | /* Configure LOUT2/ROUT2 to drive a speaker */ | ||
20 | unsigned int out2_speaker:1; | ||
21 | |||
22 | /* Configure MONOIN+/- in differential mode */ | ||
23 | unsigned int monoin_diff:1; | ||
24 | }; | ||
25 | |||
26 | #endif | ||
diff --git a/include/sound/wm8993.h b/include/sound/wm8993.h index 9c661f2f8cda..eee19f63c0d8 100644 --- a/include/sound/wm8993.h +++ b/include/sound/wm8993.h | |||
@@ -36,7 +36,7 @@ struct wm8993_platform_data { | |||
36 | unsigned int micbias1_lvl:1; | 36 | unsigned int micbias1_lvl:1; |
37 | unsigned int micbias2_lvl:1; | 37 | unsigned int micbias2_lvl:1; |
38 | 38 | ||
39 | /* Jack detect threashold levels, see datasheet for values */ | 39 | /* Jack detect threshold levels, see datasheet for values */ |
40 | unsigned int jd_scthr:2; | 40 | unsigned int jd_scthr:2; |
41 | unsigned int jd_thr:2; | 41 | unsigned int jd_thr:2; |
42 | }; | 42 | }; |
diff --git a/include/sound/wss.h b/include/sound/wss.h index 6d65f322f1d5..fd01f22825cd 100644 --- a/include/sound/wss.h +++ b/include/sound/wss.h | |||
@@ -154,7 +154,6 @@ int snd_wss_create(struct snd_card *card, | |||
154 | unsigned short hardware, | 154 | unsigned short hardware, |
155 | unsigned short hwshare, | 155 | unsigned short hwshare, |
156 | struct snd_wss **rchip); | 156 | struct snd_wss **rchip); |
157 | int snd_wss_free(struct snd_wss *chip); | ||
158 | int snd_wss_pcm(struct snd_wss *chip, int device, struct snd_pcm **rpcm); | 157 | int snd_wss_pcm(struct snd_wss *chip, int device, struct snd_pcm **rpcm); |
159 | int snd_wss_timer(struct snd_wss *chip, int device, struct snd_timer **rtimer); | 158 | int snd_wss_timer(struct snd_wss *chip, int device, struct snd_timer **rtimer); |
160 | int snd_wss_mixer(struct snd_wss *chip); | 159 | int snd_wss_mixer(struct snd_wss *chip); |