Merge branch 'for-3.18-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj...
[linux/fpc-iii.git] / sound / pci / rme9652 / hdsp.c
blob7646ba1664eb5147881b0c6b5eb6cda0545fe71d
1 /*
2 * ALSA driver for RME Hammerfall DSP audio interface(s)
4 * Copyright (c) 2002 Paul Davis
5 * Marcus Andersson
6 * Thomas Charbonnel
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 #include <linux/init.h>
25 #include <linux/delay.h>
26 #include <linux/interrupt.h>
27 #include <linux/pci.h>
28 #include <linux/firmware.h>
29 #include <linux/module.h>
30 #include <linux/math64.h>
31 #include <linux/vmalloc.h>
33 #include <sound/core.h>
34 #include <sound/control.h>
35 #include <sound/pcm.h>
36 #include <sound/info.h>
37 #include <sound/asoundef.h>
38 #include <sound/rawmidi.h>
39 #include <sound/hwdep.h>
40 #include <sound/initval.h>
41 #include <sound/hdsp.h>
43 #include <asm/byteorder.h>
44 #include <asm/current.h>
45 #include <asm/io.h>
47 static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; /* Index 0-MAX */
48 static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */
49 static bool enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP; /* Enable this card */
51 module_param_array(index, int, NULL, 0444);
52 MODULE_PARM_DESC(index, "Index value for RME Hammerfall DSP interface.");
53 module_param_array(id, charp, NULL, 0444);
54 MODULE_PARM_DESC(id, "ID string for RME Hammerfall DSP interface.");
55 module_param_array(enable, bool, NULL, 0444);
56 MODULE_PARM_DESC(enable, "Enable/disable specific Hammerfall DSP soundcards.");
57 MODULE_AUTHOR("Paul Davis <paul@linuxaudiosystems.com>, Marcus Andersson, Thomas Charbonnel <thomas@undata.org>");
58 MODULE_DESCRIPTION("RME Hammerfall DSP");
59 MODULE_LICENSE("GPL");
60 MODULE_SUPPORTED_DEVICE("{{RME Hammerfall-DSP},"
61 "{RME HDSP-9652},"
62 "{RME HDSP-9632}}");
63 MODULE_FIRMWARE("rpm_firmware.bin");
64 MODULE_FIRMWARE("multiface_firmware.bin");
65 MODULE_FIRMWARE("multiface_firmware_rev11.bin");
66 MODULE_FIRMWARE("digiface_firmware.bin");
67 MODULE_FIRMWARE("digiface_firmware_rev11.bin");
69 #define HDSP_MAX_CHANNELS 26
70 #define HDSP_MAX_DS_CHANNELS 14
71 #define HDSP_MAX_QS_CHANNELS 8
72 #define DIGIFACE_SS_CHANNELS 26
73 #define DIGIFACE_DS_CHANNELS 14
74 #define MULTIFACE_SS_CHANNELS 18
75 #define MULTIFACE_DS_CHANNELS 14
76 #define H9652_SS_CHANNELS 26
77 #define H9652_DS_CHANNELS 14
78 /* This does not include possible Analog Extension Boards
79 AEBs are detected at card initialization
81 #define H9632_SS_CHANNELS 12
82 #define H9632_DS_CHANNELS 8
83 #define H9632_QS_CHANNELS 4
84 #define RPM_CHANNELS 6
86 /* Write registers. These are defined as byte-offsets from the iobase value.
88 #define HDSP_resetPointer 0
89 #define HDSP_freqReg 0
90 #define HDSP_outputBufferAddress 32
91 #define HDSP_inputBufferAddress 36
92 #define HDSP_controlRegister 64
93 #define HDSP_interruptConfirmation 96
94 #define HDSP_outputEnable 128
95 #define HDSP_control2Reg 256
96 #define HDSP_midiDataOut0 352
97 #define HDSP_midiDataOut1 356
98 #define HDSP_fifoData 368
99 #define HDSP_inputEnable 384
101 /* Read registers. These are defined as byte-offsets from the iobase value
104 #define HDSP_statusRegister 0
105 #define HDSP_timecode 128
106 #define HDSP_status2Register 192
107 #define HDSP_midiDataIn0 360
108 #define HDSP_midiDataIn1 364
109 #define HDSP_midiStatusOut0 384
110 #define HDSP_midiStatusOut1 388
111 #define HDSP_midiStatusIn0 392
112 #define HDSP_midiStatusIn1 396
113 #define HDSP_fifoStatus 400
115 /* the meters are regular i/o-mapped registers, but offset
116 considerably from the rest. the peak registers are reset
117 when read; the least-significant 4 bits are full-scale counters;
118 the actual peak value is in the most-significant 24 bits.
121 #define HDSP_playbackPeakLevel 4096 /* 26 * 32 bit values */
122 #define HDSP_inputPeakLevel 4224 /* 26 * 32 bit values */
123 #define HDSP_outputPeakLevel 4352 /* (26+2) * 32 bit values */
124 #define HDSP_playbackRmsLevel 4612 /* 26 * 64 bit values */
125 #define HDSP_inputRmsLevel 4868 /* 26 * 64 bit values */
128 /* This is for H9652 cards
129 Peak values are read downward from the base
130 Rms values are read upward
131 There are rms values for the outputs too
132 26*3 values are read in ss mode
133 14*3 in ds mode, with no gap between values
135 #define HDSP_9652_peakBase 7164
136 #define HDSP_9652_rmsBase 4096
138 /* c.f. the hdsp_9632_meters_t struct */
139 #define HDSP_9632_metersBase 4096
141 #define HDSP_IO_EXTENT 7168
143 /* control2 register bits */
145 #define HDSP_TMS 0x01
146 #define HDSP_TCK 0x02
147 #define HDSP_TDI 0x04
148 #define HDSP_JTAG 0x08
149 #define HDSP_PWDN 0x10
150 #define HDSP_PROGRAM 0x020
151 #define HDSP_CONFIG_MODE_0 0x040
152 #define HDSP_CONFIG_MODE_1 0x080
153 #define HDSP_VERSION_BIT (0x100 | HDSP_S_LOAD)
154 #define HDSP_BIGENDIAN_MODE 0x200
155 #define HDSP_RD_MULTIPLE 0x400
156 #define HDSP_9652_ENABLE_MIXER 0x800
157 #define HDSP_S200 0x800
158 #define HDSP_S300 (0x100 | HDSP_S200) /* dummy, purpose of 0x100 unknown */
159 #define HDSP_CYCLIC_MODE 0x1000
160 #define HDSP_TDO 0x10000000
162 #define HDSP_S_PROGRAM (HDSP_CYCLIC_MODE|HDSP_PROGRAM|HDSP_CONFIG_MODE_0)
163 #define HDSP_S_LOAD (HDSP_CYCLIC_MODE|HDSP_PROGRAM|HDSP_CONFIG_MODE_1)
165 /* Control Register bits */
167 #define HDSP_Start (1<<0) /* start engine */
168 #define HDSP_Latency0 (1<<1) /* buffer size = 2^n where n is defined by Latency{2,1,0} */
169 #define HDSP_Latency1 (1<<2) /* [ see above ] */
170 #define HDSP_Latency2 (1<<3) /* [ see above ] */
171 #define HDSP_ClockModeMaster (1<<4) /* 1=Master, 0=Slave/Autosync */
172 #define HDSP_AudioInterruptEnable (1<<5) /* what do you think ? */
173 #define HDSP_Frequency0 (1<<6) /* 0=44.1kHz/88.2kHz/176.4kHz 1=48kHz/96kHz/192kHz */
174 #define HDSP_Frequency1 (1<<7) /* 0=32kHz/64kHz/128kHz */
175 #define HDSP_DoubleSpeed (1<<8) /* 0=normal speed, 1=double speed */
176 #define HDSP_SPDIFProfessional (1<<9) /* 0=consumer, 1=professional */
177 #define HDSP_SPDIFEmphasis (1<<10) /* 0=none, 1=on */
178 #define HDSP_SPDIFNonAudio (1<<11) /* 0=off, 1=on */
179 #define HDSP_SPDIFOpticalOut (1<<12) /* 1=use 1st ADAT connector for SPDIF, 0=do not */
180 #define HDSP_SyncRef2 (1<<13)
181 #define HDSP_SPDIFInputSelect0 (1<<14)
182 #define HDSP_SPDIFInputSelect1 (1<<15)
183 #define HDSP_SyncRef0 (1<<16)
184 #define HDSP_SyncRef1 (1<<17)
185 #define HDSP_AnalogExtensionBoard (1<<18) /* For H9632 cards */
186 #define HDSP_XLRBreakoutCable (1<<20) /* For H9632 cards */
187 #define HDSP_Midi0InterruptEnable (1<<22)
188 #define HDSP_Midi1InterruptEnable (1<<23)
189 #define HDSP_LineOut (1<<24)
190 #define HDSP_ADGain0 (1<<25) /* From here : H9632 specific */
191 #define HDSP_ADGain1 (1<<26)
192 #define HDSP_DAGain0 (1<<27)
193 #define HDSP_DAGain1 (1<<28)
194 #define HDSP_PhoneGain0 (1<<29)
195 #define HDSP_PhoneGain1 (1<<30)
196 #define HDSP_QuadSpeed (1<<31)
198 /* RPM uses some of the registers for special purposes */
199 #define HDSP_RPM_Inp12 0x04A00
200 #define HDSP_RPM_Inp12_Phon_6dB 0x00800 /* Dolby */
201 #define HDSP_RPM_Inp12_Phon_0dB 0x00000 /* .. */
202 #define HDSP_RPM_Inp12_Phon_n6dB 0x04000 /* inp_0 */
203 #define HDSP_RPM_Inp12_Line_0dB 0x04200 /* Dolby+PRO */
204 #define HDSP_RPM_Inp12_Line_n6dB 0x00200 /* PRO */
206 #define HDSP_RPM_Inp34 0x32000
207 #define HDSP_RPM_Inp34_Phon_6dB 0x20000 /* SyncRef1 */
208 #define HDSP_RPM_Inp34_Phon_0dB 0x00000 /* .. */
209 #define HDSP_RPM_Inp34_Phon_n6dB 0x02000 /* SyncRef2 */
210 #define HDSP_RPM_Inp34_Line_0dB 0x30000 /* SyncRef1+SyncRef0 */
211 #define HDSP_RPM_Inp34_Line_n6dB 0x10000 /* SyncRef0 */
213 #define HDSP_RPM_Bypass 0x01000
215 #define HDSP_RPM_Disconnect 0x00001
217 #define HDSP_ADGainMask (HDSP_ADGain0|HDSP_ADGain1)
218 #define HDSP_ADGainMinus10dBV HDSP_ADGainMask
219 #define HDSP_ADGainPlus4dBu (HDSP_ADGain0)
220 #define HDSP_ADGainLowGain 0
222 #define HDSP_DAGainMask (HDSP_DAGain0|HDSP_DAGain1)
223 #define HDSP_DAGainHighGain HDSP_DAGainMask
224 #define HDSP_DAGainPlus4dBu (HDSP_DAGain0)
225 #define HDSP_DAGainMinus10dBV 0
227 #define HDSP_PhoneGainMask (HDSP_PhoneGain0|HDSP_PhoneGain1)
228 #define HDSP_PhoneGain0dB HDSP_PhoneGainMask
229 #define HDSP_PhoneGainMinus6dB (HDSP_PhoneGain0)
230 #define HDSP_PhoneGainMinus12dB 0
232 #define HDSP_LatencyMask (HDSP_Latency0|HDSP_Latency1|HDSP_Latency2)
233 #define HDSP_FrequencyMask (HDSP_Frequency0|HDSP_Frequency1|HDSP_DoubleSpeed|HDSP_QuadSpeed)
235 #define HDSP_SPDIFInputMask (HDSP_SPDIFInputSelect0|HDSP_SPDIFInputSelect1)
236 #define HDSP_SPDIFInputADAT1 0
237 #define HDSP_SPDIFInputCoaxial (HDSP_SPDIFInputSelect0)
238 #define HDSP_SPDIFInputCdrom (HDSP_SPDIFInputSelect1)
239 #define HDSP_SPDIFInputAES (HDSP_SPDIFInputSelect0|HDSP_SPDIFInputSelect1)
241 #define HDSP_SyncRefMask (HDSP_SyncRef0|HDSP_SyncRef1|HDSP_SyncRef2)
242 #define HDSP_SyncRef_ADAT1 0
243 #define HDSP_SyncRef_ADAT2 (HDSP_SyncRef0)
244 #define HDSP_SyncRef_ADAT3 (HDSP_SyncRef1)
245 #define HDSP_SyncRef_SPDIF (HDSP_SyncRef0|HDSP_SyncRef1)
246 #define HDSP_SyncRef_WORD (HDSP_SyncRef2)
247 #define HDSP_SyncRef_ADAT_SYNC (HDSP_SyncRef0|HDSP_SyncRef2)
249 /* Sample Clock Sources */
251 #define HDSP_CLOCK_SOURCE_AUTOSYNC 0
252 #define HDSP_CLOCK_SOURCE_INTERNAL_32KHZ 1
253 #define HDSP_CLOCK_SOURCE_INTERNAL_44_1KHZ 2
254 #define HDSP_CLOCK_SOURCE_INTERNAL_48KHZ 3
255 #define HDSP_CLOCK_SOURCE_INTERNAL_64KHZ 4
256 #define HDSP_CLOCK_SOURCE_INTERNAL_88_2KHZ 5
257 #define HDSP_CLOCK_SOURCE_INTERNAL_96KHZ 6
258 #define HDSP_CLOCK_SOURCE_INTERNAL_128KHZ 7
259 #define HDSP_CLOCK_SOURCE_INTERNAL_176_4KHZ 8
260 #define HDSP_CLOCK_SOURCE_INTERNAL_192KHZ 9
262 /* Preferred sync reference choices - used by "pref_sync_ref" control switch */
264 #define HDSP_SYNC_FROM_WORD 0
265 #define HDSP_SYNC_FROM_SPDIF 1
266 #define HDSP_SYNC_FROM_ADAT1 2
267 #define HDSP_SYNC_FROM_ADAT_SYNC 3
268 #define HDSP_SYNC_FROM_ADAT2 4
269 #define HDSP_SYNC_FROM_ADAT3 5
271 /* SyncCheck status */
273 #define HDSP_SYNC_CHECK_NO_LOCK 0
274 #define HDSP_SYNC_CHECK_LOCK 1
275 #define HDSP_SYNC_CHECK_SYNC 2
277 /* AutoSync references - used by "autosync_ref" control switch */
279 #define HDSP_AUTOSYNC_FROM_WORD 0
280 #define HDSP_AUTOSYNC_FROM_ADAT_SYNC 1
281 #define HDSP_AUTOSYNC_FROM_SPDIF 2
282 #define HDSP_AUTOSYNC_FROM_NONE 3
283 #define HDSP_AUTOSYNC_FROM_ADAT1 4
284 #define HDSP_AUTOSYNC_FROM_ADAT2 5
285 #define HDSP_AUTOSYNC_FROM_ADAT3 6
287 /* Possible sources of S/PDIF input */
289 #define HDSP_SPDIFIN_OPTICAL 0 /* optical (ADAT1) */
290 #define HDSP_SPDIFIN_COAXIAL 1 /* coaxial (RCA) */
291 #define HDSP_SPDIFIN_INTERNAL 2 /* internal (CDROM) */
292 #define HDSP_SPDIFIN_AES 3 /* xlr for H9632 (AES)*/
294 #define HDSP_Frequency32KHz HDSP_Frequency0
295 #define HDSP_Frequency44_1KHz HDSP_Frequency1
296 #define HDSP_Frequency48KHz (HDSP_Frequency1|HDSP_Frequency0)
297 #define HDSP_Frequency64KHz (HDSP_DoubleSpeed|HDSP_Frequency0)
298 #define HDSP_Frequency88_2KHz (HDSP_DoubleSpeed|HDSP_Frequency1)
299 #define HDSP_Frequency96KHz (HDSP_DoubleSpeed|HDSP_Frequency1|HDSP_Frequency0)
300 /* For H9632 cards */
301 #define HDSP_Frequency128KHz (HDSP_QuadSpeed|HDSP_DoubleSpeed|HDSP_Frequency0)
302 #define HDSP_Frequency176_4KHz (HDSP_QuadSpeed|HDSP_DoubleSpeed|HDSP_Frequency1)
303 #define HDSP_Frequency192KHz (HDSP_QuadSpeed|HDSP_DoubleSpeed|HDSP_Frequency1|HDSP_Frequency0)
304 /* RME says n = 104857600000000, but in the windows MADI driver, I see:
305 return 104857600000000 / rate; // 100 MHz
306 return 110100480000000 / rate; // 105 MHz
308 #define DDS_NUMERATOR 104857600000000ULL; /* = 2^20 * 10^8 */
310 #define hdsp_encode_latency(x) (((x)<<1) & HDSP_LatencyMask)
311 #define hdsp_decode_latency(x) (((x) & HDSP_LatencyMask)>>1)
313 #define hdsp_encode_spdif_in(x) (((x)&0x3)<<14)
314 #define hdsp_decode_spdif_in(x) (((x)>>14)&0x3)
316 /* Status Register bits */
318 #define HDSP_audioIRQPending (1<<0)
319 #define HDSP_Lock2 (1<<1) /* this is for Digiface and H9652 */
320 #define HDSP_spdifFrequency3 HDSP_Lock2 /* this is for H9632 only */
321 #define HDSP_Lock1 (1<<2)
322 #define HDSP_Lock0 (1<<3)
323 #define HDSP_SPDIFSync (1<<4)
324 #define HDSP_TimecodeLock (1<<5)
325 #define HDSP_BufferPositionMask 0x000FFC0 /* Bit 6..15 : h/w buffer pointer */
326 #define HDSP_Sync2 (1<<16)
327 #define HDSP_Sync1 (1<<17)
328 #define HDSP_Sync0 (1<<18)
329 #define HDSP_DoubleSpeedStatus (1<<19)
330 #define HDSP_ConfigError (1<<20)
331 #define HDSP_DllError (1<<21)
332 #define HDSP_spdifFrequency0 (1<<22)
333 #define HDSP_spdifFrequency1 (1<<23)
334 #define HDSP_spdifFrequency2 (1<<24)
335 #define HDSP_SPDIFErrorFlag (1<<25)
336 #define HDSP_BufferID (1<<26)
337 #define HDSP_TimecodeSync (1<<27)
338 #define HDSP_AEBO (1<<28) /* H9632 specific Analog Extension Boards */
339 #define HDSP_AEBI (1<<29) /* 0 = present, 1 = absent */
340 #define HDSP_midi0IRQPending (1<<30)
341 #define HDSP_midi1IRQPending (1<<31)
343 #define HDSP_spdifFrequencyMask (HDSP_spdifFrequency0|HDSP_spdifFrequency1|HDSP_spdifFrequency2)
344 #define HDSP_spdifFrequencyMask_9632 (HDSP_spdifFrequency0|\
345 HDSP_spdifFrequency1|\
346 HDSP_spdifFrequency2|\
347 HDSP_spdifFrequency3)
349 #define HDSP_spdifFrequency32KHz (HDSP_spdifFrequency0)
350 #define HDSP_spdifFrequency44_1KHz (HDSP_spdifFrequency1)
351 #define HDSP_spdifFrequency48KHz (HDSP_spdifFrequency0|HDSP_spdifFrequency1)
353 #define HDSP_spdifFrequency64KHz (HDSP_spdifFrequency2)
354 #define HDSP_spdifFrequency88_2KHz (HDSP_spdifFrequency0|HDSP_spdifFrequency2)
355 #define HDSP_spdifFrequency96KHz (HDSP_spdifFrequency2|HDSP_spdifFrequency1)
357 /* This is for H9632 cards */
358 #define HDSP_spdifFrequency128KHz (HDSP_spdifFrequency0|\
359 HDSP_spdifFrequency1|\
360 HDSP_spdifFrequency2)
361 #define HDSP_spdifFrequency176_4KHz HDSP_spdifFrequency3
362 #define HDSP_spdifFrequency192KHz (HDSP_spdifFrequency3|HDSP_spdifFrequency0)
364 /* Status2 Register bits */
366 #define HDSP_version0 (1<<0)
367 #define HDSP_version1 (1<<1)
368 #define HDSP_version2 (1<<2)
369 #define HDSP_wc_lock (1<<3)
370 #define HDSP_wc_sync (1<<4)
371 #define HDSP_inp_freq0 (1<<5)
372 #define HDSP_inp_freq1 (1<<6)
373 #define HDSP_inp_freq2 (1<<7)
374 #define HDSP_SelSyncRef0 (1<<8)
375 #define HDSP_SelSyncRef1 (1<<9)
376 #define HDSP_SelSyncRef2 (1<<10)
378 #define HDSP_wc_valid (HDSP_wc_lock|HDSP_wc_sync)
380 #define HDSP_systemFrequencyMask (HDSP_inp_freq0|HDSP_inp_freq1|HDSP_inp_freq2)
381 #define HDSP_systemFrequency32 (HDSP_inp_freq0)
382 #define HDSP_systemFrequency44_1 (HDSP_inp_freq1)
383 #define HDSP_systemFrequency48 (HDSP_inp_freq0|HDSP_inp_freq1)
384 #define HDSP_systemFrequency64 (HDSP_inp_freq2)
385 #define HDSP_systemFrequency88_2 (HDSP_inp_freq0|HDSP_inp_freq2)
386 #define HDSP_systemFrequency96 (HDSP_inp_freq1|HDSP_inp_freq2)
387 /* FIXME : more values for 9632 cards ? */
389 #define HDSP_SelSyncRefMask (HDSP_SelSyncRef0|HDSP_SelSyncRef1|HDSP_SelSyncRef2)
390 #define HDSP_SelSyncRef_ADAT1 0
391 #define HDSP_SelSyncRef_ADAT2 (HDSP_SelSyncRef0)
392 #define HDSP_SelSyncRef_ADAT3 (HDSP_SelSyncRef1)
393 #define HDSP_SelSyncRef_SPDIF (HDSP_SelSyncRef0|HDSP_SelSyncRef1)
394 #define HDSP_SelSyncRef_WORD (HDSP_SelSyncRef2)
395 #define HDSP_SelSyncRef_ADAT_SYNC (HDSP_SelSyncRef0|HDSP_SelSyncRef2)
397 /* Card state flags */
399 #define HDSP_InitializationComplete (1<<0)
400 #define HDSP_FirmwareLoaded (1<<1)
401 #define HDSP_FirmwareCached (1<<2)
403 /* FIFO wait times, defined in terms of 1/10ths of msecs */
405 #define HDSP_LONG_WAIT 5000
406 #define HDSP_SHORT_WAIT 30
408 #define UNITY_GAIN 32768
409 #define MINUS_INFINITY_GAIN 0
411 /* the size of a substream (1 mono data stream) */
413 #define HDSP_CHANNEL_BUFFER_SAMPLES (16*1024)
414 #define HDSP_CHANNEL_BUFFER_BYTES (4*HDSP_CHANNEL_BUFFER_SAMPLES)
416 /* the size of the area we need to allocate for DMA transfers. the
417 size is the same regardless of the number of channels - the
418 Multiface still uses the same memory area.
420 Note that we allocate 1 more channel than is apparently needed
421 because the h/w seems to write 1 byte beyond the end of the last
422 page. Sigh.
425 #define HDSP_DMA_AREA_BYTES ((HDSP_MAX_CHANNELS+1) * HDSP_CHANNEL_BUFFER_BYTES)
426 #define HDSP_DMA_AREA_KILOBYTES (HDSP_DMA_AREA_BYTES/1024)
428 #define HDSP_FIRMWARE_SIZE (24413 * 4)
430 struct hdsp_9632_meters {
431 u32 input_peak[16];
432 u32 playback_peak[16];
433 u32 output_peak[16];
434 u32 xxx_peak[16];
435 u32 padding[64];
436 u32 input_rms_low[16];
437 u32 playback_rms_low[16];
438 u32 output_rms_low[16];
439 u32 xxx_rms_low[16];
440 u32 input_rms_high[16];
441 u32 playback_rms_high[16];
442 u32 output_rms_high[16];
443 u32 xxx_rms_high[16];
446 struct hdsp_midi {
447 struct hdsp *hdsp;
448 int id;
449 struct snd_rawmidi *rmidi;
450 struct snd_rawmidi_substream *input;
451 struct snd_rawmidi_substream *output;
452 char istimer; /* timer in use */
453 struct timer_list timer;
454 spinlock_t lock;
455 int pending;
458 struct hdsp {
459 spinlock_t lock;
460 struct snd_pcm_substream *capture_substream;
461 struct snd_pcm_substream *playback_substream;
462 struct hdsp_midi midi[2];
463 struct tasklet_struct midi_tasklet;
464 int use_midi_tasklet;
465 int precise_ptr;
466 u32 control_register; /* cached value */
467 u32 control2_register; /* cached value */
468 u32 creg_spdif;
469 u32 creg_spdif_stream;
470 int clock_source_locked;
471 char *card_name; /* digiface/multiface/rpm */
472 enum HDSP_IO_Type io_type; /* ditto, but for code use */
473 unsigned short firmware_rev;
474 unsigned short state; /* stores state bits */
475 const struct firmware *firmware;
476 u32 *fw_uploaded;
477 size_t period_bytes; /* guess what this is */
478 unsigned char max_channels;
479 unsigned char qs_in_channels; /* quad speed mode for H9632 */
480 unsigned char ds_in_channels;
481 unsigned char ss_in_channels; /* different for multiface/digiface */
482 unsigned char qs_out_channels;
483 unsigned char ds_out_channels;
484 unsigned char ss_out_channels;
486 struct snd_dma_buffer capture_dma_buf;
487 struct snd_dma_buffer playback_dma_buf;
488 unsigned char *capture_buffer; /* suitably aligned address */
489 unsigned char *playback_buffer; /* suitably aligned address */
491 pid_t capture_pid;
492 pid_t playback_pid;
493 int running;
494 int system_sample_rate;
495 char *channel_map;
496 int dev;
497 int irq;
498 unsigned long port;
499 void __iomem *iobase;
500 struct snd_card *card;
501 struct snd_pcm *pcm;
502 struct snd_hwdep *hwdep;
503 struct pci_dev *pci;
504 struct snd_kcontrol *spdif_ctl;
505 unsigned short mixer_matrix[HDSP_MATRIX_MIXER_SIZE];
506 unsigned int dds_value; /* last value written to freq register */
509 /* These tables map the ALSA channels 1..N to the channels that we
510 need to use in order to find the relevant channel buffer. RME
511 refer to this kind of mapping as between "the ADAT channel and
512 the DMA channel." We index it using the logical audio channel,
513 and the value is the DMA channel (i.e. channel buffer number)
514 where the data for that channel can be read/written from/to.
517 static char channel_map_df_ss[HDSP_MAX_CHANNELS] = {
518 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17,
519 18, 19, 20, 21, 22, 23, 24, 25
522 static char channel_map_mf_ss[HDSP_MAX_CHANNELS] = { /* Multiface */
523 /* Analog */
524 0, 1, 2, 3, 4, 5, 6, 7,
525 /* ADAT 2 */
526 16, 17, 18, 19, 20, 21, 22, 23,
527 /* SPDIF */
528 24, 25,
529 -1, -1, -1, -1, -1, -1, -1, -1
532 static char channel_map_ds[HDSP_MAX_CHANNELS] = {
533 /* ADAT channels are remapped */
534 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23,
535 /* channels 12 and 13 are S/PDIF */
536 24, 25,
537 /* others don't exist */
538 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1
541 static char channel_map_H9632_ss[HDSP_MAX_CHANNELS] = {
542 /* ADAT channels */
543 0, 1, 2, 3, 4, 5, 6, 7,
544 /* SPDIF */
545 8, 9,
546 /* Analog */
547 10, 11,
548 /* AO4S-192 and AI4S-192 extension boards */
549 12, 13, 14, 15,
550 /* others don't exist */
551 -1, -1, -1, -1, -1, -1, -1, -1,
552 -1, -1
555 static char channel_map_H9632_ds[HDSP_MAX_CHANNELS] = {
556 /* ADAT */
557 1, 3, 5, 7,
558 /* SPDIF */
559 8, 9,
560 /* Analog */
561 10, 11,
562 /* AO4S-192 and AI4S-192 extension boards */
563 12, 13, 14, 15,
564 /* others don't exist */
565 -1, -1, -1, -1, -1, -1, -1, -1,
566 -1, -1, -1, -1, -1, -1
569 static char channel_map_H9632_qs[HDSP_MAX_CHANNELS] = {
570 /* ADAT is disabled in this mode */
571 /* SPDIF */
572 8, 9,
573 /* Analog */
574 10, 11,
575 /* AO4S-192 and AI4S-192 extension boards */
576 12, 13, 14, 15,
577 /* others don't exist */
578 -1, -1, -1, -1, -1, -1, -1, -1,
579 -1, -1, -1, -1, -1, -1, -1, -1,
580 -1, -1
583 static int snd_hammerfall_get_buffer(struct pci_dev *pci, struct snd_dma_buffer *dmab, size_t size)
585 dmab->dev.type = SNDRV_DMA_TYPE_DEV;
586 dmab->dev.dev = snd_dma_pci_data(pci);
587 if (snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV, snd_dma_pci_data(pci),
588 size, dmab) < 0)
589 return -ENOMEM;
590 return 0;
593 static void snd_hammerfall_free_buffer(struct snd_dma_buffer *dmab, struct pci_dev *pci)
595 if (dmab->area)
596 snd_dma_free_pages(dmab);
600 static const struct pci_device_id snd_hdsp_ids[] = {
602 .vendor = PCI_VENDOR_ID_XILINX,
603 .device = PCI_DEVICE_ID_XILINX_HAMMERFALL_DSP,
604 .subvendor = PCI_ANY_ID,
605 .subdevice = PCI_ANY_ID,
606 }, /* RME Hammerfall-DSP */
607 { 0, },
610 MODULE_DEVICE_TABLE(pci, snd_hdsp_ids);
612 /* prototypes */
613 static int snd_hdsp_create_alsa_devices(struct snd_card *card, struct hdsp *hdsp);
614 static int snd_hdsp_create_pcm(struct snd_card *card, struct hdsp *hdsp);
615 static int snd_hdsp_enable_io (struct hdsp *hdsp);
616 static void snd_hdsp_initialize_midi_flush (struct hdsp *hdsp);
617 static void snd_hdsp_initialize_channels (struct hdsp *hdsp);
618 static int hdsp_fifo_wait(struct hdsp *hdsp, int count, int timeout);
619 static int hdsp_autosync_ref(struct hdsp *hdsp);
620 static int snd_hdsp_set_defaults(struct hdsp *hdsp);
621 static void snd_hdsp_9652_enable_mixer (struct hdsp *hdsp);
623 static int hdsp_playback_to_output_key (struct hdsp *hdsp, int in, int out)
625 switch (hdsp->io_type) {
626 case Multiface:
627 case Digiface:
628 case RPM:
629 default:
630 if (hdsp->firmware_rev == 0xa)
631 return (64 * out) + (32 + (in));
632 else
633 return (52 * out) + (26 + (in));
634 case H9632:
635 return (32 * out) + (16 + (in));
636 case H9652:
637 return (52 * out) + (26 + (in));
641 static int hdsp_input_to_output_key (struct hdsp *hdsp, int in, int out)
643 switch (hdsp->io_type) {
644 case Multiface:
645 case Digiface:
646 case RPM:
647 default:
648 if (hdsp->firmware_rev == 0xa)
649 return (64 * out) + in;
650 else
651 return (52 * out) + in;
652 case H9632:
653 return (32 * out) + in;
654 case H9652:
655 return (52 * out) + in;
659 static void hdsp_write(struct hdsp *hdsp, int reg, int val)
661 writel(val, hdsp->iobase + reg);
664 static unsigned int hdsp_read(struct hdsp *hdsp, int reg)
666 return readl (hdsp->iobase + reg);
669 static int hdsp_check_for_iobox (struct hdsp *hdsp)
671 int i;
673 if (hdsp->io_type == H9652 || hdsp->io_type == H9632) return 0;
674 for (i = 0; i < 500; i++) {
675 if (0 == (hdsp_read(hdsp, HDSP_statusRegister) &
676 HDSP_ConfigError)) {
677 if (i) {
678 dev_dbg(hdsp->card->dev,
679 "IO box found after %d ms\n",
680 (20 * i));
682 return 0;
684 msleep(20);
686 dev_err(hdsp->card->dev, "no IO box connected!\n");
687 hdsp->state &= ~HDSP_FirmwareLoaded;
688 return -EIO;
691 static int hdsp_wait_for_iobox(struct hdsp *hdsp, unsigned int loops,
692 unsigned int delay)
694 unsigned int i;
696 if (hdsp->io_type == H9652 || hdsp->io_type == H9632)
697 return 0;
699 for (i = 0; i != loops; ++i) {
700 if (hdsp_read(hdsp, HDSP_statusRegister) & HDSP_ConfigError)
701 msleep(delay);
702 else {
703 dev_dbg(hdsp->card->dev, "iobox found after %ums!\n",
704 i * delay);
705 return 0;
709 dev_info(hdsp->card->dev, "no IO box connected!\n");
710 hdsp->state &= ~HDSP_FirmwareLoaded;
711 return -EIO;
714 static int snd_hdsp_load_firmware_from_cache(struct hdsp *hdsp) {
716 int i;
717 unsigned long flags;
718 const u32 *cache;
720 if (hdsp->fw_uploaded)
721 cache = hdsp->fw_uploaded;
722 else {
723 if (!hdsp->firmware)
724 return -ENODEV;
725 cache = (u32 *)hdsp->firmware->data;
726 if (!cache)
727 return -ENODEV;
730 if ((hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DllError) != 0) {
732 dev_info(hdsp->card->dev, "loading firmware\n");
734 hdsp_write (hdsp, HDSP_control2Reg, HDSP_S_PROGRAM);
735 hdsp_write (hdsp, HDSP_fifoData, 0);
737 if (hdsp_fifo_wait (hdsp, 0, HDSP_LONG_WAIT)) {
738 dev_info(hdsp->card->dev,
739 "timeout waiting for download preparation\n");
740 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S200);
741 return -EIO;
744 hdsp_write (hdsp, HDSP_control2Reg, HDSP_S_LOAD);
746 for (i = 0; i < HDSP_FIRMWARE_SIZE / 4; ++i) {
747 hdsp_write(hdsp, HDSP_fifoData, cache[i]);
748 if (hdsp_fifo_wait (hdsp, 127, HDSP_LONG_WAIT)) {
749 dev_info(hdsp->card->dev,
750 "timeout during firmware loading\n");
751 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S200);
752 return -EIO;
756 hdsp_fifo_wait(hdsp, 3, HDSP_LONG_WAIT);
757 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S200);
759 ssleep(3);
760 #ifdef SNDRV_BIG_ENDIAN
761 hdsp->control2_register = HDSP_BIGENDIAN_MODE;
762 #else
763 hdsp->control2_register = 0;
764 #endif
765 hdsp_write (hdsp, HDSP_control2Reg, hdsp->control2_register);
766 dev_info(hdsp->card->dev, "finished firmware loading\n");
769 if (hdsp->state & HDSP_InitializationComplete) {
770 dev_info(hdsp->card->dev,
771 "firmware loaded from cache, restoring defaults\n");
772 spin_lock_irqsave(&hdsp->lock, flags);
773 snd_hdsp_set_defaults(hdsp);
774 spin_unlock_irqrestore(&hdsp->lock, flags);
777 hdsp->state |= HDSP_FirmwareLoaded;
779 return 0;
782 static int hdsp_get_iobox_version (struct hdsp *hdsp)
784 if ((hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DllError) != 0) {
786 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S_LOAD);
787 hdsp_write(hdsp, HDSP_fifoData, 0);
789 if (hdsp_fifo_wait(hdsp, 0, HDSP_SHORT_WAIT) < 0) {
790 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S300);
791 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S_LOAD);
794 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S200 | HDSP_PROGRAM);
795 hdsp_write (hdsp, HDSP_fifoData, 0);
796 if (hdsp_fifo_wait(hdsp, 0, HDSP_SHORT_WAIT) < 0) {
797 hdsp->io_type = Multiface;
798 dev_info(hdsp->card->dev, "Multiface found\n");
799 return 0;
802 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S_LOAD);
803 hdsp_write(hdsp, HDSP_fifoData, 0);
804 if (hdsp_fifo_wait(hdsp, 0, HDSP_SHORT_WAIT) == 0) {
805 hdsp->io_type = Digiface;
806 dev_info(hdsp->card->dev, "Digiface found\n");
807 return 0;
810 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S300);
811 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S_LOAD);
812 hdsp_write(hdsp, HDSP_fifoData, 0);
813 if (hdsp_fifo_wait(hdsp, 0, HDSP_SHORT_WAIT) == 0) {
814 hdsp->io_type = Multiface;
815 dev_info(hdsp->card->dev, "Multiface found\n");
816 return 0;
819 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S300);
820 hdsp_write(hdsp, HDSP_control2Reg, HDSP_S_LOAD);
821 hdsp_write(hdsp, HDSP_fifoData, 0);
822 if (hdsp_fifo_wait(hdsp, 0, HDSP_SHORT_WAIT) < 0) {
823 hdsp->io_type = Multiface;
824 dev_info(hdsp->card->dev, "Multiface found\n");
825 return 0;
828 hdsp->io_type = RPM;
829 dev_info(hdsp->card->dev, "RPM found\n");
830 return 0;
831 } else {
832 /* firmware was already loaded, get iobox type */
833 if (hdsp_read(hdsp, HDSP_status2Register) & HDSP_version2)
834 hdsp->io_type = RPM;
835 else if (hdsp_read(hdsp, HDSP_status2Register) & HDSP_version1)
836 hdsp->io_type = Multiface;
837 else
838 hdsp->io_type = Digiface;
840 return 0;
844 static int hdsp_request_fw_loader(struct hdsp *hdsp);
846 static int hdsp_check_for_firmware (struct hdsp *hdsp, int load_on_demand)
848 if (hdsp->io_type == H9652 || hdsp->io_type == H9632)
849 return 0;
850 if ((hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DllError) != 0) {
851 hdsp->state &= ~HDSP_FirmwareLoaded;
852 if (! load_on_demand)
853 return -EIO;
854 dev_err(hdsp->card->dev, "firmware not present.\n");
855 /* try to load firmware */
856 if (! (hdsp->state & HDSP_FirmwareCached)) {
857 if (! hdsp_request_fw_loader(hdsp))
858 return 0;
859 dev_err(hdsp->card->dev,
860 "No firmware loaded nor cached, please upload firmware.\n");
861 return -EIO;
863 if (snd_hdsp_load_firmware_from_cache(hdsp) != 0) {
864 dev_err(hdsp->card->dev,
865 "Firmware loading from cache failed, please upload manually.\n");
866 return -EIO;
869 return 0;
873 static int hdsp_fifo_wait(struct hdsp *hdsp, int count, int timeout)
875 int i;
877 /* the fifoStatus registers reports on how many words
878 are available in the command FIFO.
881 for (i = 0; i < timeout; i++) {
883 if ((int)(hdsp_read (hdsp, HDSP_fifoStatus) & 0xff) <= count)
884 return 0;
886 /* not very friendly, but we only do this during a firmware
887 load and changing the mixer, so we just put up with it.
890 udelay (100);
893 dev_warn(hdsp->card->dev,
894 "wait for FIFO status <= %d failed after %d iterations\n",
895 count, timeout);
896 return -1;
899 static int hdsp_read_gain (struct hdsp *hdsp, unsigned int addr)
901 if (addr >= HDSP_MATRIX_MIXER_SIZE)
902 return 0;
904 return hdsp->mixer_matrix[addr];
907 static int hdsp_write_gain(struct hdsp *hdsp, unsigned int addr, unsigned short data)
909 unsigned int ad;
911 if (addr >= HDSP_MATRIX_MIXER_SIZE)
912 return -1;
914 if (hdsp->io_type == H9652 || hdsp->io_type == H9632) {
916 /* from martin bjornsen:
918 "You can only write dwords to the
919 mixer memory which contain two
920 mixer values in the low and high
921 word. So if you want to change
922 value 0 you have to read value 1
923 from the cache and write both to
924 the first dword in the mixer
925 memory."
928 if (hdsp->io_type == H9632 && addr >= 512)
929 return 0;
931 if (hdsp->io_type == H9652 && addr >= 1352)
932 return 0;
934 hdsp->mixer_matrix[addr] = data;
937 /* `addr' addresses a 16-bit wide address, but
938 the address space accessed via hdsp_write
939 uses byte offsets. put another way, addr
940 varies from 0 to 1351, but to access the
941 corresponding memory location, we need
942 to access 0 to 2703 ...
944 ad = addr/2;
946 hdsp_write (hdsp, 4096 + (ad*4),
947 (hdsp->mixer_matrix[(addr&0x7fe)+1] << 16) +
948 hdsp->mixer_matrix[addr&0x7fe]);
950 return 0;
952 } else {
954 ad = (addr << 16) + data;
956 if (hdsp_fifo_wait(hdsp, 127, HDSP_LONG_WAIT))
957 return -1;
959 hdsp_write (hdsp, HDSP_fifoData, ad);
960 hdsp->mixer_matrix[addr] = data;
964 return 0;
967 static int snd_hdsp_use_is_exclusive(struct hdsp *hdsp)
969 unsigned long flags;
970 int ret = 1;
972 spin_lock_irqsave(&hdsp->lock, flags);
973 if ((hdsp->playback_pid != hdsp->capture_pid) &&
974 (hdsp->playback_pid >= 0) && (hdsp->capture_pid >= 0))
975 ret = 0;
976 spin_unlock_irqrestore(&hdsp->lock, flags);
977 return ret;
980 static int hdsp_spdif_sample_rate(struct hdsp *hdsp)
982 unsigned int status = hdsp_read(hdsp, HDSP_statusRegister);
983 unsigned int rate_bits = (status & HDSP_spdifFrequencyMask);
985 /* For the 9632, the mask is different */
986 if (hdsp->io_type == H9632)
987 rate_bits = (status & HDSP_spdifFrequencyMask_9632);
989 if (status & HDSP_SPDIFErrorFlag)
990 return 0;
992 switch (rate_bits) {
993 case HDSP_spdifFrequency32KHz: return 32000;
994 case HDSP_spdifFrequency44_1KHz: return 44100;
995 case HDSP_spdifFrequency48KHz: return 48000;
996 case HDSP_spdifFrequency64KHz: return 64000;
997 case HDSP_spdifFrequency88_2KHz: return 88200;
998 case HDSP_spdifFrequency96KHz: return 96000;
999 case HDSP_spdifFrequency128KHz:
1000 if (hdsp->io_type == H9632) return 128000;
1001 break;
1002 case HDSP_spdifFrequency176_4KHz:
1003 if (hdsp->io_type == H9632) return 176400;
1004 break;
1005 case HDSP_spdifFrequency192KHz:
1006 if (hdsp->io_type == H9632) return 192000;
1007 break;
1008 default:
1009 break;
1011 dev_warn(hdsp->card->dev,
1012 "unknown spdif frequency status; bits = 0x%x, status = 0x%x\n",
1013 rate_bits, status);
1014 return 0;
1017 static int hdsp_external_sample_rate(struct hdsp *hdsp)
1019 unsigned int status2 = hdsp_read(hdsp, HDSP_status2Register);
1020 unsigned int rate_bits = status2 & HDSP_systemFrequencyMask;
1022 /* For the 9632 card, there seems to be no bit for indicating external
1023 * sample rate greater than 96kHz. The card reports the corresponding
1024 * single speed. So the best means seems to get spdif rate when
1025 * autosync reference is spdif */
1026 if (hdsp->io_type == H9632 &&
1027 hdsp_autosync_ref(hdsp) == HDSP_AUTOSYNC_FROM_SPDIF)
1028 return hdsp_spdif_sample_rate(hdsp);
1030 switch (rate_bits) {
1031 case HDSP_systemFrequency32: return 32000;
1032 case HDSP_systemFrequency44_1: return 44100;
1033 case HDSP_systemFrequency48: return 48000;
1034 case HDSP_systemFrequency64: return 64000;
1035 case HDSP_systemFrequency88_2: return 88200;
1036 case HDSP_systemFrequency96: return 96000;
1037 default:
1038 return 0;
1042 static void hdsp_compute_period_size(struct hdsp *hdsp)
1044 hdsp->period_bytes = 1 << ((hdsp_decode_latency(hdsp->control_register) + 8));
1047 static snd_pcm_uframes_t hdsp_hw_pointer(struct hdsp *hdsp)
1049 int position;
1051 position = hdsp_read(hdsp, HDSP_statusRegister);
1053 if (!hdsp->precise_ptr)
1054 return (position & HDSP_BufferID) ? (hdsp->period_bytes / 4) : 0;
1056 position &= HDSP_BufferPositionMask;
1057 position /= 4;
1058 position &= (hdsp->period_bytes/2) - 1;
1059 return position;
1062 static void hdsp_reset_hw_pointer(struct hdsp *hdsp)
1064 hdsp_write (hdsp, HDSP_resetPointer, 0);
1065 if (hdsp->io_type == H9632 && hdsp->firmware_rev >= 152)
1066 /* HDSP_resetPointer = HDSP_freqReg, which is strange and
1067 * requires (?) to write again DDS value after a reset pointer
1068 * (at least, it works like this) */
1069 hdsp_write (hdsp, HDSP_freqReg, hdsp->dds_value);
1072 static void hdsp_start_audio(struct hdsp *s)
1074 s->control_register |= (HDSP_AudioInterruptEnable | HDSP_Start);
1075 hdsp_write(s, HDSP_controlRegister, s->control_register);
1078 static void hdsp_stop_audio(struct hdsp *s)
1080 s->control_register &= ~(HDSP_Start | HDSP_AudioInterruptEnable);
1081 hdsp_write(s, HDSP_controlRegister, s->control_register);
1084 static void hdsp_silence_playback(struct hdsp *hdsp)
1086 memset(hdsp->playback_buffer, 0, HDSP_DMA_AREA_BYTES);
1089 static int hdsp_set_interrupt_interval(struct hdsp *s, unsigned int frames)
1091 int n;
1093 spin_lock_irq(&s->lock);
1095 frames >>= 7;
1096 n = 0;
1097 while (frames) {
1098 n++;
1099 frames >>= 1;
1102 s->control_register &= ~HDSP_LatencyMask;
1103 s->control_register |= hdsp_encode_latency(n);
1105 hdsp_write(s, HDSP_controlRegister, s->control_register);
1107 hdsp_compute_period_size(s);
1109 spin_unlock_irq(&s->lock);
1111 return 0;
1114 static void hdsp_set_dds_value(struct hdsp *hdsp, int rate)
1116 u64 n;
1118 if (rate >= 112000)
1119 rate /= 4;
1120 else if (rate >= 56000)
1121 rate /= 2;
1123 n = DDS_NUMERATOR;
1124 n = div_u64(n, rate);
1125 /* n should be less than 2^32 for being written to FREQ register */
1126 snd_BUG_ON(n >> 32);
1127 /* HDSP_freqReg and HDSP_resetPointer are the same, so keep the DDS
1128 value to write it after a reset */
1129 hdsp->dds_value = n;
1130 hdsp_write(hdsp, HDSP_freqReg, hdsp->dds_value);
1133 static int hdsp_set_rate(struct hdsp *hdsp, int rate, int called_internally)
1135 int reject_if_open = 0;
1136 int current_rate;
1137 int rate_bits;
1139 /* ASSUMPTION: hdsp->lock is either held, or
1140 there is no need for it (e.g. during module
1141 initialization).
1144 if (!(hdsp->control_register & HDSP_ClockModeMaster)) {
1145 if (called_internally) {
1146 /* request from ctl or card initialization */
1147 dev_err(hdsp->card->dev,
1148 "device is not running as a clock master: cannot set sample rate.\n");
1149 return -1;
1150 } else {
1151 /* hw_param request while in AutoSync mode */
1152 int external_freq = hdsp_external_sample_rate(hdsp);
1153 int spdif_freq = hdsp_spdif_sample_rate(hdsp);
1155 if ((spdif_freq == external_freq*2) && (hdsp_autosync_ref(hdsp) >= HDSP_AUTOSYNC_FROM_ADAT1))
1156 dev_info(hdsp->card->dev,
1157 "Detected ADAT in double speed mode\n");
1158 else if (hdsp->io_type == H9632 && (spdif_freq == external_freq*4) && (hdsp_autosync_ref(hdsp) >= HDSP_AUTOSYNC_FROM_ADAT1))
1159 dev_info(hdsp->card->dev,
1160 "Detected ADAT in quad speed mode\n");
1161 else if (rate != external_freq) {
1162 dev_info(hdsp->card->dev,
1163 "No AutoSync source for requested rate\n");
1164 return -1;
1169 current_rate = hdsp->system_sample_rate;
1171 /* Changing from a "single speed" to a "double speed" rate is
1172 not allowed if any substreams are open. This is because
1173 such a change causes a shift in the location of
1174 the DMA buffers and a reduction in the number of available
1175 buffers.
1177 Note that a similar but essentially insoluble problem
1178 exists for externally-driven rate changes. All we can do
1179 is to flag rate changes in the read/write routines. */
1181 if (rate > 96000 && hdsp->io_type != H9632)
1182 return -EINVAL;
1184 switch (rate) {
1185 case 32000:
1186 if (current_rate > 48000)
1187 reject_if_open = 1;
1188 rate_bits = HDSP_Frequency32KHz;
1189 break;
1190 case 44100:
1191 if (current_rate > 48000)
1192 reject_if_open = 1;
1193 rate_bits = HDSP_Frequency44_1KHz;
1194 break;
1195 case 48000:
1196 if (current_rate > 48000)
1197 reject_if_open = 1;
1198 rate_bits = HDSP_Frequency48KHz;
1199 break;
1200 case 64000:
1201 if (current_rate <= 48000 || current_rate > 96000)
1202 reject_if_open = 1;
1203 rate_bits = HDSP_Frequency64KHz;
1204 break;
1205 case 88200:
1206 if (current_rate <= 48000 || current_rate > 96000)
1207 reject_if_open = 1;
1208 rate_bits = HDSP_Frequency88_2KHz;
1209 break;
1210 case 96000:
1211 if (current_rate <= 48000 || current_rate > 96000)
1212 reject_if_open = 1;
1213 rate_bits = HDSP_Frequency96KHz;
1214 break;
1215 case 128000:
1216 if (current_rate < 128000)
1217 reject_if_open = 1;
1218 rate_bits = HDSP_Frequency128KHz;
1219 break;
1220 case 176400:
1221 if (current_rate < 128000)
1222 reject_if_open = 1;
1223 rate_bits = HDSP_Frequency176_4KHz;
1224 break;
1225 case 192000:
1226 if (current_rate < 128000)
1227 reject_if_open = 1;
1228 rate_bits = HDSP_Frequency192KHz;
1229 break;
1230 default:
1231 return -EINVAL;
1234 if (reject_if_open && (hdsp->capture_pid >= 0 || hdsp->playback_pid >= 0)) {
1235 dev_warn(hdsp->card->dev,
1236 "cannot change speed mode (capture PID = %d, playback PID = %d)\n",
1237 hdsp->capture_pid,
1238 hdsp->playback_pid);
1239 return -EBUSY;
1242 hdsp->control_register &= ~HDSP_FrequencyMask;
1243 hdsp->control_register |= rate_bits;
1244 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
1246 /* For HDSP9632 rev 152, need to set DDS value in FREQ register */
1247 if (hdsp->io_type == H9632 && hdsp->firmware_rev >= 152)
1248 hdsp_set_dds_value(hdsp, rate);
1250 if (rate >= 128000) {
1251 hdsp->channel_map = channel_map_H9632_qs;
1252 } else if (rate > 48000) {
1253 if (hdsp->io_type == H9632)
1254 hdsp->channel_map = channel_map_H9632_ds;
1255 else
1256 hdsp->channel_map = channel_map_ds;
1257 } else {
1258 switch (hdsp->io_type) {
1259 case RPM:
1260 case Multiface:
1261 hdsp->channel_map = channel_map_mf_ss;
1262 break;
1263 case Digiface:
1264 case H9652:
1265 hdsp->channel_map = channel_map_df_ss;
1266 break;
1267 case H9632:
1268 hdsp->channel_map = channel_map_H9632_ss;
1269 break;
1270 default:
1271 /* should never happen */
1272 break;
1276 hdsp->system_sample_rate = rate;
1278 return 0;
1281 /*----------------------------------------------------------------------------
1282 MIDI
1283 ----------------------------------------------------------------------------*/
1285 static unsigned char snd_hdsp_midi_read_byte (struct hdsp *hdsp, int id)
1287 /* the hardware already does the relevant bit-mask with 0xff */
1288 if (id)
1289 return hdsp_read(hdsp, HDSP_midiDataIn1);
1290 else
1291 return hdsp_read(hdsp, HDSP_midiDataIn0);
1294 static void snd_hdsp_midi_write_byte (struct hdsp *hdsp, int id, int val)
1296 /* the hardware already does the relevant bit-mask with 0xff */
1297 if (id)
1298 hdsp_write(hdsp, HDSP_midiDataOut1, val);
1299 else
1300 hdsp_write(hdsp, HDSP_midiDataOut0, val);
1303 static int snd_hdsp_midi_input_available (struct hdsp *hdsp, int id)
1305 if (id)
1306 return (hdsp_read(hdsp, HDSP_midiStatusIn1) & 0xff);
1307 else
1308 return (hdsp_read(hdsp, HDSP_midiStatusIn0) & 0xff);
1311 static int snd_hdsp_midi_output_possible (struct hdsp *hdsp, int id)
1313 int fifo_bytes_used;
1315 if (id)
1316 fifo_bytes_used = hdsp_read(hdsp, HDSP_midiStatusOut1) & 0xff;
1317 else
1318 fifo_bytes_used = hdsp_read(hdsp, HDSP_midiStatusOut0) & 0xff;
1320 if (fifo_bytes_used < 128)
1321 return 128 - fifo_bytes_used;
1322 else
1323 return 0;
1326 static void snd_hdsp_flush_midi_input (struct hdsp *hdsp, int id)
1328 while (snd_hdsp_midi_input_available (hdsp, id))
1329 snd_hdsp_midi_read_byte (hdsp, id);
1332 static int snd_hdsp_midi_output_write (struct hdsp_midi *hmidi)
1334 unsigned long flags;
1335 int n_pending;
1336 int to_write;
1337 int i;
1338 unsigned char buf[128];
1340 /* Output is not interrupt driven */
1342 spin_lock_irqsave (&hmidi->lock, flags);
1343 if (hmidi->output) {
1344 if (!snd_rawmidi_transmit_empty (hmidi->output)) {
1345 if ((n_pending = snd_hdsp_midi_output_possible (hmidi->hdsp, hmidi->id)) > 0) {
1346 if (n_pending > (int)sizeof (buf))
1347 n_pending = sizeof (buf);
1349 if ((to_write = snd_rawmidi_transmit (hmidi->output, buf, n_pending)) > 0) {
1350 for (i = 0; i < to_write; ++i)
1351 snd_hdsp_midi_write_byte (hmidi->hdsp, hmidi->id, buf[i]);
1356 spin_unlock_irqrestore (&hmidi->lock, flags);
1357 return 0;
1360 static int snd_hdsp_midi_input_read (struct hdsp_midi *hmidi)
1362 unsigned char buf[128]; /* this buffer is designed to match the MIDI input FIFO size */
1363 unsigned long flags;
1364 int n_pending;
1365 int i;
1367 spin_lock_irqsave (&hmidi->lock, flags);
1368 if ((n_pending = snd_hdsp_midi_input_available (hmidi->hdsp, hmidi->id)) > 0) {
1369 if (hmidi->input) {
1370 if (n_pending > (int)sizeof (buf))
1371 n_pending = sizeof (buf);
1372 for (i = 0; i < n_pending; ++i)
1373 buf[i] = snd_hdsp_midi_read_byte (hmidi->hdsp, hmidi->id);
1374 if (n_pending)
1375 snd_rawmidi_receive (hmidi->input, buf, n_pending);
1376 } else {
1377 /* flush the MIDI input FIFO */
1378 while (--n_pending)
1379 snd_hdsp_midi_read_byte (hmidi->hdsp, hmidi->id);
1382 hmidi->pending = 0;
1383 if (hmidi->id)
1384 hmidi->hdsp->control_register |= HDSP_Midi1InterruptEnable;
1385 else
1386 hmidi->hdsp->control_register |= HDSP_Midi0InterruptEnable;
1387 hdsp_write(hmidi->hdsp, HDSP_controlRegister, hmidi->hdsp->control_register);
1388 spin_unlock_irqrestore (&hmidi->lock, flags);
1389 return snd_hdsp_midi_output_write (hmidi);
1392 static void snd_hdsp_midi_input_trigger(struct snd_rawmidi_substream *substream, int up)
1394 struct hdsp *hdsp;
1395 struct hdsp_midi *hmidi;
1396 unsigned long flags;
1397 u32 ie;
1399 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1400 hdsp = hmidi->hdsp;
1401 ie = hmidi->id ? HDSP_Midi1InterruptEnable : HDSP_Midi0InterruptEnable;
1402 spin_lock_irqsave (&hdsp->lock, flags);
1403 if (up) {
1404 if (!(hdsp->control_register & ie)) {
1405 snd_hdsp_flush_midi_input (hdsp, hmidi->id);
1406 hdsp->control_register |= ie;
1408 } else {
1409 hdsp->control_register &= ~ie;
1410 tasklet_kill(&hdsp->midi_tasklet);
1413 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
1414 spin_unlock_irqrestore (&hdsp->lock, flags);
1417 static void snd_hdsp_midi_output_timer(unsigned long data)
1419 struct hdsp_midi *hmidi = (struct hdsp_midi *) data;
1420 unsigned long flags;
1422 snd_hdsp_midi_output_write(hmidi);
1423 spin_lock_irqsave (&hmidi->lock, flags);
1425 /* this does not bump hmidi->istimer, because the
1426 kernel automatically removed the timer when it
1427 expired, and we are now adding it back, thus
1428 leaving istimer wherever it was set before.
1431 if (hmidi->istimer) {
1432 hmidi->timer.expires = 1 + jiffies;
1433 add_timer(&hmidi->timer);
1436 spin_unlock_irqrestore (&hmidi->lock, flags);
1439 static void snd_hdsp_midi_output_trigger(struct snd_rawmidi_substream *substream, int up)
1441 struct hdsp_midi *hmidi;
1442 unsigned long flags;
1444 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1445 spin_lock_irqsave (&hmidi->lock, flags);
1446 if (up) {
1447 if (!hmidi->istimer) {
1448 init_timer(&hmidi->timer);
1449 hmidi->timer.function = snd_hdsp_midi_output_timer;
1450 hmidi->timer.data = (unsigned long) hmidi;
1451 hmidi->timer.expires = 1 + jiffies;
1452 add_timer(&hmidi->timer);
1453 hmidi->istimer++;
1455 } else {
1456 if (hmidi->istimer && --hmidi->istimer <= 0)
1457 del_timer (&hmidi->timer);
1459 spin_unlock_irqrestore (&hmidi->lock, flags);
1460 if (up)
1461 snd_hdsp_midi_output_write(hmidi);
1464 static int snd_hdsp_midi_input_open(struct snd_rawmidi_substream *substream)
1466 struct hdsp_midi *hmidi;
1468 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1469 spin_lock_irq (&hmidi->lock);
1470 snd_hdsp_flush_midi_input (hmidi->hdsp, hmidi->id);
1471 hmidi->input = substream;
1472 spin_unlock_irq (&hmidi->lock);
1474 return 0;
1477 static int snd_hdsp_midi_output_open(struct snd_rawmidi_substream *substream)
1479 struct hdsp_midi *hmidi;
1481 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1482 spin_lock_irq (&hmidi->lock);
1483 hmidi->output = substream;
1484 spin_unlock_irq (&hmidi->lock);
1486 return 0;
1489 static int snd_hdsp_midi_input_close(struct snd_rawmidi_substream *substream)
1491 struct hdsp_midi *hmidi;
1493 snd_hdsp_midi_input_trigger (substream, 0);
1495 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1496 spin_lock_irq (&hmidi->lock);
1497 hmidi->input = NULL;
1498 spin_unlock_irq (&hmidi->lock);
1500 return 0;
1503 static int snd_hdsp_midi_output_close(struct snd_rawmidi_substream *substream)
1505 struct hdsp_midi *hmidi;
1507 snd_hdsp_midi_output_trigger (substream, 0);
1509 hmidi = (struct hdsp_midi *) substream->rmidi->private_data;
1510 spin_lock_irq (&hmidi->lock);
1511 hmidi->output = NULL;
1512 spin_unlock_irq (&hmidi->lock);
1514 return 0;
1517 static struct snd_rawmidi_ops snd_hdsp_midi_output =
1519 .open = snd_hdsp_midi_output_open,
1520 .close = snd_hdsp_midi_output_close,
1521 .trigger = snd_hdsp_midi_output_trigger,
1524 static struct snd_rawmidi_ops snd_hdsp_midi_input =
1526 .open = snd_hdsp_midi_input_open,
1527 .close = snd_hdsp_midi_input_close,
1528 .trigger = snd_hdsp_midi_input_trigger,
1531 static int snd_hdsp_create_midi (struct snd_card *card, struct hdsp *hdsp, int id)
1533 char buf[32];
1535 hdsp->midi[id].id = id;
1536 hdsp->midi[id].rmidi = NULL;
1537 hdsp->midi[id].input = NULL;
1538 hdsp->midi[id].output = NULL;
1539 hdsp->midi[id].hdsp = hdsp;
1540 hdsp->midi[id].istimer = 0;
1541 hdsp->midi[id].pending = 0;
1542 spin_lock_init (&hdsp->midi[id].lock);
1544 sprintf (buf, "%s MIDI %d", card->shortname, id+1);
1545 if (snd_rawmidi_new (card, buf, id, 1, 1, &hdsp->midi[id].rmidi) < 0)
1546 return -1;
1548 sprintf(hdsp->midi[id].rmidi->name, "HDSP MIDI %d", id+1);
1549 hdsp->midi[id].rmidi->private_data = &hdsp->midi[id];
1551 snd_rawmidi_set_ops (hdsp->midi[id].rmidi, SNDRV_RAWMIDI_STREAM_OUTPUT, &snd_hdsp_midi_output);
1552 snd_rawmidi_set_ops (hdsp->midi[id].rmidi, SNDRV_RAWMIDI_STREAM_INPUT, &snd_hdsp_midi_input);
1554 hdsp->midi[id].rmidi->info_flags |= SNDRV_RAWMIDI_INFO_OUTPUT |
1555 SNDRV_RAWMIDI_INFO_INPUT |
1556 SNDRV_RAWMIDI_INFO_DUPLEX;
1558 return 0;
1561 /*-----------------------------------------------------------------------------
1562 Control Interface
1563 ----------------------------------------------------------------------------*/
1565 static u32 snd_hdsp_convert_from_aes(struct snd_aes_iec958 *aes)
1567 u32 val = 0;
1568 val |= (aes->status[0] & IEC958_AES0_PROFESSIONAL) ? HDSP_SPDIFProfessional : 0;
1569 val |= (aes->status[0] & IEC958_AES0_NONAUDIO) ? HDSP_SPDIFNonAudio : 0;
1570 if (val & HDSP_SPDIFProfessional)
1571 val |= (aes->status[0] & IEC958_AES0_PRO_EMPHASIS_5015) ? HDSP_SPDIFEmphasis : 0;
1572 else
1573 val |= (aes->status[0] & IEC958_AES0_CON_EMPHASIS_5015) ? HDSP_SPDIFEmphasis : 0;
1574 return val;
1577 static void snd_hdsp_convert_to_aes(struct snd_aes_iec958 *aes, u32 val)
1579 aes->status[0] = ((val & HDSP_SPDIFProfessional) ? IEC958_AES0_PROFESSIONAL : 0) |
1580 ((val & HDSP_SPDIFNonAudio) ? IEC958_AES0_NONAUDIO : 0);
1581 if (val & HDSP_SPDIFProfessional)
1582 aes->status[0] |= (val & HDSP_SPDIFEmphasis) ? IEC958_AES0_PRO_EMPHASIS_5015 : 0;
1583 else
1584 aes->status[0] |= (val & HDSP_SPDIFEmphasis) ? IEC958_AES0_CON_EMPHASIS_5015 : 0;
1587 static int snd_hdsp_control_spdif_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1589 uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958;
1590 uinfo->count = 1;
1591 return 0;
1594 static int snd_hdsp_control_spdif_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1596 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1598 snd_hdsp_convert_to_aes(&ucontrol->value.iec958, hdsp->creg_spdif);
1599 return 0;
1602 static int snd_hdsp_control_spdif_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1604 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1605 int change;
1606 u32 val;
1608 val = snd_hdsp_convert_from_aes(&ucontrol->value.iec958);
1609 spin_lock_irq(&hdsp->lock);
1610 change = val != hdsp->creg_spdif;
1611 hdsp->creg_spdif = val;
1612 spin_unlock_irq(&hdsp->lock);
1613 return change;
1616 static int snd_hdsp_control_spdif_stream_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1618 uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958;
1619 uinfo->count = 1;
1620 return 0;
1623 static int snd_hdsp_control_spdif_stream_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1625 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1627 snd_hdsp_convert_to_aes(&ucontrol->value.iec958, hdsp->creg_spdif_stream);
1628 return 0;
1631 static int snd_hdsp_control_spdif_stream_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1633 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1634 int change;
1635 u32 val;
1637 val = snd_hdsp_convert_from_aes(&ucontrol->value.iec958);
1638 spin_lock_irq(&hdsp->lock);
1639 change = val != hdsp->creg_spdif_stream;
1640 hdsp->creg_spdif_stream = val;
1641 hdsp->control_register &= ~(HDSP_SPDIFProfessional | HDSP_SPDIFNonAudio | HDSP_SPDIFEmphasis);
1642 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register |= val);
1643 spin_unlock_irq(&hdsp->lock);
1644 return change;
1647 static int snd_hdsp_control_spdif_mask_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1649 uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958;
1650 uinfo->count = 1;
1651 return 0;
1654 static int snd_hdsp_control_spdif_mask_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1656 ucontrol->value.iec958.status[0] = kcontrol->private_value;
1657 return 0;
1660 #define HDSP_SPDIF_IN(xname, xindex) \
1661 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1662 .name = xname, \
1663 .index = xindex, \
1664 .info = snd_hdsp_info_spdif_in, \
1665 .get = snd_hdsp_get_spdif_in, \
1666 .put = snd_hdsp_put_spdif_in }
1668 static unsigned int hdsp_spdif_in(struct hdsp *hdsp)
1670 return hdsp_decode_spdif_in(hdsp->control_register & HDSP_SPDIFInputMask);
1673 static int hdsp_set_spdif_input(struct hdsp *hdsp, int in)
1675 hdsp->control_register &= ~HDSP_SPDIFInputMask;
1676 hdsp->control_register |= hdsp_encode_spdif_in(in);
1677 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
1678 return 0;
1681 static int snd_hdsp_info_spdif_in(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1683 static char *texts[4] = {"Optical", "Coaxial", "Internal", "AES"};
1684 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1686 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1687 uinfo->count = 1;
1688 uinfo->value.enumerated.items = ((hdsp->io_type == H9632) ? 4 : 3);
1689 if (uinfo->value.enumerated.item > ((hdsp->io_type == H9632) ? 3 : 2))
1690 uinfo->value.enumerated.item = ((hdsp->io_type == H9632) ? 3 : 2);
1691 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
1692 return 0;
1695 static int snd_hdsp_get_spdif_in(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1697 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1699 ucontrol->value.enumerated.item[0] = hdsp_spdif_in(hdsp);
1700 return 0;
1703 static int snd_hdsp_put_spdif_in(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1705 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1706 int change;
1707 unsigned int val;
1709 if (!snd_hdsp_use_is_exclusive(hdsp))
1710 return -EBUSY;
1711 val = ucontrol->value.enumerated.item[0] % ((hdsp->io_type == H9632) ? 4 : 3);
1712 spin_lock_irq(&hdsp->lock);
1713 change = val != hdsp_spdif_in(hdsp);
1714 if (change)
1715 hdsp_set_spdif_input(hdsp, val);
1716 spin_unlock_irq(&hdsp->lock);
1717 return change;
1720 #define HDSP_TOGGLE_SETTING(xname, xindex) \
1721 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1722 .name = xname, \
1723 .private_value = xindex, \
1724 .info = snd_hdsp_info_toggle_setting, \
1725 .get = snd_hdsp_get_toggle_setting, \
1726 .put = snd_hdsp_put_toggle_setting \
1729 static int hdsp_toggle_setting(struct hdsp *hdsp, u32 regmask)
1731 return (hdsp->control_register & regmask) ? 1 : 0;
1734 static int hdsp_set_toggle_setting(struct hdsp *hdsp, u32 regmask, int out)
1736 if (out)
1737 hdsp->control_register |= regmask;
1738 else
1739 hdsp->control_register &= ~regmask;
1740 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
1742 return 0;
1745 #define snd_hdsp_info_toggle_setting snd_ctl_boolean_mono_info
1747 static int snd_hdsp_get_toggle_setting(struct snd_kcontrol *kcontrol,
1748 struct snd_ctl_elem_value *ucontrol)
1750 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1751 u32 regmask = kcontrol->private_value;
1753 spin_lock_irq(&hdsp->lock);
1754 ucontrol->value.integer.value[0] = hdsp_toggle_setting(hdsp, regmask);
1755 spin_unlock_irq(&hdsp->lock);
1756 return 0;
1759 static int snd_hdsp_put_toggle_setting(struct snd_kcontrol *kcontrol,
1760 struct snd_ctl_elem_value *ucontrol)
1762 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1763 u32 regmask = kcontrol->private_value;
1764 int change;
1765 unsigned int val;
1767 if (!snd_hdsp_use_is_exclusive(hdsp))
1768 return -EBUSY;
1769 val = ucontrol->value.integer.value[0] & 1;
1770 spin_lock_irq(&hdsp->lock);
1771 change = (int) val != hdsp_toggle_setting(hdsp, regmask);
1772 if (change)
1773 hdsp_set_toggle_setting(hdsp, regmask, val);
1774 spin_unlock_irq(&hdsp->lock);
1775 return change;
1778 #define HDSP_SPDIF_SAMPLE_RATE(xname, xindex) \
1779 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1780 .name = xname, \
1781 .index = xindex, \
1782 .access = SNDRV_CTL_ELEM_ACCESS_READ, \
1783 .info = snd_hdsp_info_spdif_sample_rate, \
1784 .get = snd_hdsp_get_spdif_sample_rate \
1787 static int snd_hdsp_info_spdif_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1789 static char *texts[] = {"32000", "44100", "48000", "64000", "88200", "96000", "None", "128000", "176400", "192000"};
1790 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1792 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1793 uinfo->count = 1;
1794 uinfo->value.enumerated.items = (hdsp->io_type == H9632) ? 10 : 7;
1795 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
1796 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
1797 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
1798 return 0;
1801 static int snd_hdsp_get_spdif_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1803 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1805 switch (hdsp_spdif_sample_rate(hdsp)) {
1806 case 32000:
1807 ucontrol->value.enumerated.item[0] = 0;
1808 break;
1809 case 44100:
1810 ucontrol->value.enumerated.item[0] = 1;
1811 break;
1812 case 48000:
1813 ucontrol->value.enumerated.item[0] = 2;
1814 break;
1815 case 64000:
1816 ucontrol->value.enumerated.item[0] = 3;
1817 break;
1818 case 88200:
1819 ucontrol->value.enumerated.item[0] = 4;
1820 break;
1821 case 96000:
1822 ucontrol->value.enumerated.item[0] = 5;
1823 break;
1824 case 128000:
1825 ucontrol->value.enumerated.item[0] = 7;
1826 break;
1827 case 176400:
1828 ucontrol->value.enumerated.item[0] = 8;
1829 break;
1830 case 192000:
1831 ucontrol->value.enumerated.item[0] = 9;
1832 break;
1833 default:
1834 ucontrol->value.enumerated.item[0] = 6;
1836 return 0;
1839 #define HDSP_SYSTEM_SAMPLE_RATE(xname, xindex) \
1840 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1841 .name = xname, \
1842 .index = xindex, \
1843 .access = SNDRV_CTL_ELEM_ACCESS_READ, \
1844 .info = snd_hdsp_info_system_sample_rate, \
1845 .get = snd_hdsp_get_system_sample_rate \
1848 static int snd_hdsp_info_system_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1850 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1851 uinfo->count = 1;
1852 return 0;
1855 static int snd_hdsp_get_system_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1857 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1859 ucontrol->value.enumerated.item[0] = hdsp->system_sample_rate;
1860 return 0;
1863 #define HDSP_AUTOSYNC_SAMPLE_RATE(xname, xindex) \
1864 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1865 .name = xname, \
1866 .index = xindex, \
1867 .access = SNDRV_CTL_ELEM_ACCESS_READ, \
1868 .info = snd_hdsp_info_autosync_sample_rate, \
1869 .get = snd_hdsp_get_autosync_sample_rate \
1872 static int snd_hdsp_info_autosync_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1874 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1875 static char *texts[] = {"32000", "44100", "48000", "64000", "88200", "96000", "None", "128000", "176400", "192000"};
1876 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1877 uinfo->count = 1;
1878 uinfo->value.enumerated.items = (hdsp->io_type == H9632) ? 10 : 7 ;
1879 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
1880 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
1881 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
1882 return 0;
1885 static int snd_hdsp_get_autosync_sample_rate(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1887 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1889 switch (hdsp_external_sample_rate(hdsp)) {
1890 case 32000:
1891 ucontrol->value.enumerated.item[0] = 0;
1892 break;
1893 case 44100:
1894 ucontrol->value.enumerated.item[0] = 1;
1895 break;
1896 case 48000:
1897 ucontrol->value.enumerated.item[0] = 2;
1898 break;
1899 case 64000:
1900 ucontrol->value.enumerated.item[0] = 3;
1901 break;
1902 case 88200:
1903 ucontrol->value.enumerated.item[0] = 4;
1904 break;
1905 case 96000:
1906 ucontrol->value.enumerated.item[0] = 5;
1907 break;
1908 case 128000:
1909 ucontrol->value.enumerated.item[0] = 7;
1910 break;
1911 case 176400:
1912 ucontrol->value.enumerated.item[0] = 8;
1913 break;
1914 case 192000:
1915 ucontrol->value.enumerated.item[0] = 9;
1916 break;
1917 default:
1918 ucontrol->value.enumerated.item[0] = 6;
1920 return 0;
1923 #define HDSP_SYSTEM_CLOCK_MODE(xname, xindex) \
1924 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1925 .name = xname, \
1926 .index = xindex, \
1927 .access = SNDRV_CTL_ELEM_ACCESS_READ, \
1928 .info = snd_hdsp_info_system_clock_mode, \
1929 .get = snd_hdsp_get_system_clock_mode \
1932 static int hdsp_system_clock_mode(struct hdsp *hdsp)
1934 if (hdsp->control_register & HDSP_ClockModeMaster)
1935 return 0;
1936 else if (hdsp_external_sample_rate(hdsp) != hdsp->system_sample_rate)
1937 return 0;
1938 return 1;
1941 static int snd_hdsp_info_system_clock_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
1943 static char *texts[] = {"Master", "Slave" };
1945 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1946 uinfo->count = 1;
1947 uinfo->value.enumerated.items = 2;
1948 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
1949 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
1950 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
1951 return 0;
1954 static int snd_hdsp_get_system_clock_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
1956 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
1958 ucontrol->value.enumerated.item[0] = hdsp_system_clock_mode(hdsp);
1959 return 0;
1962 #define HDSP_CLOCK_SOURCE(xname, xindex) \
1963 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1964 .name = xname, \
1965 .index = xindex, \
1966 .info = snd_hdsp_info_clock_source, \
1967 .get = snd_hdsp_get_clock_source, \
1968 .put = snd_hdsp_put_clock_source \
1971 static int hdsp_clock_source(struct hdsp *hdsp)
1973 if (hdsp->control_register & HDSP_ClockModeMaster) {
1974 switch (hdsp->system_sample_rate) {
1975 case 32000:
1976 return 1;
1977 case 44100:
1978 return 2;
1979 case 48000:
1980 return 3;
1981 case 64000:
1982 return 4;
1983 case 88200:
1984 return 5;
1985 case 96000:
1986 return 6;
1987 case 128000:
1988 return 7;
1989 case 176400:
1990 return 8;
1991 case 192000:
1992 return 9;
1993 default:
1994 return 3;
1996 } else {
1997 return 0;
2001 static int hdsp_set_clock_source(struct hdsp *hdsp, int mode)
2003 int rate;
2004 switch (mode) {
2005 case HDSP_CLOCK_SOURCE_AUTOSYNC:
2006 if (hdsp_external_sample_rate(hdsp) != 0) {
2007 if (!hdsp_set_rate(hdsp, hdsp_external_sample_rate(hdsp), 1)) {
2008 hdsp->control_register &= ~HDSP_ClockModeMaster;
2009 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2010 return 0;
2013 return -1;
2014 case HDSP_CLOCK_SOURCE_INTERNAL_32KHZ:
2015 rate = 32000;
2016 break;
2017 case HDSP_CLOCK_SOURCE_INTERNAL_44_1KHZ:
2018 rate = 44100;
2019 break;
2020 case HDSP_CLOCK_SOURCE_INTERNAL_48KHZ:
2021 rate = 48000;
2022 break;
2023 case HDSP_CLOCK_SOURCE_INTERNAL_64KHZ:
2024 rate = 64000;
2025 break;
2026 case HDSP_CLOCK_SOURCE_INTERNAL_88_2KHZ:
2027 rate = 88200;
2028 break;
2029 case HDSP_CLOCK_SOURCE_INTERNAL_96KHZ:
2030 rate = 96000;
2031 break;
2032 case HDSP_CLOCK_SOURCE_INTERNAL_128KHZ:
2033 rate = 128000;
2034 break;
2035 case HDSP_CLOCK_SOURCE_INTERNAL_176_4KHZ:
2036 rate = 176400;
2037 break;
2038 case HDSP_CLOCK_SOURCE_INTERNAL_192KHZ:
2039 rate = 192000;
2040 break;
2041 default:
2042 rate = 48000;
2044 hdsp->control_register |= HDSP_ClockModeMaster;
2045 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2046 hdsp_set_rate(hdsp, rate, 1);
2047 return 0;
2050 static int snd_hdsp_info_clock_source(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2052 static char *texts[] = {"AutoSync", "Internal 32.0 kHz", "Internal 44.1 kHz", "Internal 48.0 kHz", "Internal 64.0 kHz", "Internal 88.2 kHz", "Internal 96.0 kHz", "Internal 128 kHz", "Internal 176.4 kHz", "Internal 192.0 KHz" };
2053 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2055 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2056 uinfo->count = 1;
2057 if (hdsp->io_type == H9632)
2058 uinfo->value.enumerated.items = 10;
2059 else
2060 uinfo->value.enumerated.items = 7;
2061 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2062 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2063 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2064 return 0;
2067 static int snd_hdsp_get_clock_source(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2069 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2071 ucontrol->value.enumerated.item[0] = hdsp_clock_source(hdsp);
2072 return 0;
2075 static int snd_hdsp_put_clock_source(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2077 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2078 int change;
2079 int val;
2081 if (!snd_hdsp_use_is_exclusive(hdsp))
2082 return -EBUSY;
2083 val = ucontrol->value.enumerated.item[0];
2084 if (val < 0) val = 0;
2085 if (hdsp->io_type == H9632) {
2086 if (val > 9)
2087 val = 9;
2088 } else {
2089 if (val > 6)
2090 val = 6;
2092 spin_lock_irq(&hdsp->lock);
2093 if (val != hdsp_clock_source(hdsp))
2094 change = (hdsp_set_clock_source(hdsp, val) == 0) ? 1 : 0;
2095 else
2096 change = 0;
2097 spin_unlock_irq(&hdsp->lock);
2098 return change;
2101 #define snd_hdsp_info_clock_source_lock snd_ctl_boolean_mono_info
2103 static int snd_hdsp_get_clock_source_lock(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2105 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2107 ucontrol->value.integer.value[0] = hdsp->clock_source_locked;
2108 return 0;
2111 static int snd_hdsp_put_clock_source_lock(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2113 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2114 int change;
2116 change = (int)ucontrol->value.integer.value[0] != hdsp->clock_source_locked;
2117 if (change)
2118 hdsp->clock_source_locked = !!ucontrol->value.integer.value[0];
2119 return change;
2122 #define HDSP_DA_GAIN(xname, xindex) \
2123 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2124 .name = xname, \
2125 .index = xindex, \
2126 .info = snd_hdsp_info_da_gain, \
2127 .get = snd_hdsp_get_da_gain, \
2128 .put = snd_hdsp_put_da_gain \
2131 static int hdsp_da_gain(struct hdsp *hdsp)
2133 switch (hdsp->control_register & HDSP_DAGainMask) {
2134 case HDSP_DAGainHighGain:
2135 return 0;
2136 case HDSP_DAGainPlus4dBu:
2137 return 1;
2138 case HDSP_DAGainMinus10dBV:
2139 return 2;
2140 default:
2141 return 1;
2145 static int hdsp_set_da_gain(struct hdsp *hdsp, int mode)
2147 hdsp->control_register &= ~HDSP_DAGainMask;
2148 switch (mode) {
2149 case 0:
2150 hdsp->control_register |= HDSP_DAGainHighGain;
2151 break;
2152 case 1:
2153 hdsp->control_register |= HDSP_DAGainPlus4dBu;
2154 break;
2155 case 2:
2156 hdsp->control_register |= HDSP_DAGainMinus10dBV;
2157 break;
2158 default:
2159 return -1;
2162 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2163 return 0;
2166 static int snd_hdsp_info_da_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2168 static char *texts[] = {"Hi Gain", "+4 dBu", "-10 dbV"};
2170 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2171 uinfo->count = 1;
2172 uinfo->value.enumerated.items = 3;
2173 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2174 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2175 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2176 return 0;
2179 static int snd_hdsp_get_da_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2181 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2183 ucontrol->value.enumerated.item[0] = hdsp_da_gain(hdsp);
2184 return 0;
2187 static int snd_hdsp_put_da_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2189 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2190 int change;
2191 int val;
2193 if (!snd_hdsp_use_is_exclusive(hdsp))
2194 return -EBUSY;
2195 val = ucontrol->value.enumerated.item[0];
2196 if (val < 0) val = 0;
2197 if (val > 2) val = 2;
2198 spin_lock_irq(&hdsp->lock);
2199 if (val != hdsp_da_gain(hdsp))
2200 change = (hdsp_set_da_gain(hdsp, val) == 0) ? 1 : 0;
2201 else
2202 change = 0;
2203 spin_unlock_irq(&hdsp->lock);
2204 return change;
2207 #define HDSP_AD_GAIN(xname, xindex) \
2208 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2209 .name = xname, \
2210 .index = xindex, \
2211 .info = snd_hdsp_info_ad_gain, \
2212 .get = snd_hdsp_get_ad_gain, \
2213 .put = snd_hdsp_put_ad_gain \
2216 static int hdsp_ad_gain(struct hdsp *hdsp)
2218 switch (hdsp->control_register & HDSP_ADGainMask) {
2219 case HDSP_ADGainMinus10dBV:
2220 return 0;
2221 case HDSP_ADGainPlus4dBu:
2222 return 1;
2223 case HDSP_ADGainLowGain:
2224 return 2;
2225 default:
2226 return 1;
2230 static int hdsp_set_ad_gain(struct hdsp *hdsp, int mode)
2232 hdsp->control_register &= ~HDSP_ADGainMask;
2233 switch (mode) {
2234 case 0:
2235 hdsp->control_register |= HDSP_ADGainMinus10dBV;
2236 break;
2237 case 1:
2238 hdsp->control_register |= HDSP_ADGainPlus4dBu;
2239 break;
2240 case 2:
2241 hdsp->control_register |= HDSP_ADGainLowGain;
2242 break;
2243 default:
2244 return -1;
2247 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2248 return 0;
2251 static int snd_hdsp_info_ad_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2253 static char *texts[] = {"-10 dBV", "+4 dBu", "Lo Gain"};
2255 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2256 uinfo->count = 1;
2257 uinfo->value.enumerated.items = 3;
2258 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2259 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2260 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2261 return 0;
2264 static int snd_hdsp_get_ad_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2266 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2268 ucontrol->value.enumerated.item[0] = hdsp_ad_gain(hdsp);
2269 return 0;
2272 static int snd_hdsp_put_ad_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2274 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2275 int change;
2276 int val;
2278 if (!snd_hdsp_use_is_exclusive(hdsp))
2279 return -EBUSY;
2280 val = ucontrol->value.enumerated.item[0];
2281 if (val < 0) val = 0;
2282 if (val > 2) val = 2;
2283 spin_lock_irq(&hdsp->lock);
2284 if (val != hdsp_ad_gain(hdsp))
2285 change = (hdsp_set_ad_gain(hdsp, val) == 0) ? 1 : 0;
2286 else
2287 change = 0;
2288 spin_unlock_irq(&hdsp->lock);
2289 return change;
2292 #define HDSP_PHONE_GAIN(xname, xindex) \
2293 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2294 .name = xname, \
2295 .index = xindex, \
2296 .info = snd_hdsp_info_phone_gain, \
2297 .get = snd_hdsp_get_phone_gain, \
2298 .put = snd_hdsp_put_phone_gain \
2301 static int hdsp_phone_gain(struct hdsp *hdsp)
2303 switch (hdsp->control_register & HDSP_PhoneGainMask) {
2304 case HDSP_PhoneGain0dB:
2305 return 0;
2306 case HDSP_PhoneGainMinus6dB:
2307 return 1;
2308 case HDSP_PhoneGainMinus12dB:
2309 return 2;
2310 default:
2311 return 0;
2315 static int hdsp_set_phone_gain(struct hdsp *hdsp, int mode)
2317 hdsp->control_register &= ~HDSP_PhoneGainMask;
2318 switch (mode) {
2319 case 0:
2320 hdsp->control_register |= HDSP_PhoneGain0dB;
2321 break;
2322 case 1:
2323 hdsp->control_register |= HDSP_PhoneGainMinus6dB;
2324 break;
2325 case 2:
2326 hdsp->control_register |= HDSP_PhoneGainMinus12dB;
2327 break;
2328 default:
2329 return -1;
2332 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2333 return 0;
2336 static int snd_hdsp_info_phone_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2338 static char *texts[] = {"0 dB", "-6 dB", "-12 dB"};
2340 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2341 uinfo->count = 1;
2342 uinfo->value.enumerated.items = 3;
2343 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2344 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2345 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2346 return 0;
2349 static int snd_hdsp_get_phone_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2351 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2353 ucontrol->value.enumerated.item[0] = hdsp_phone_gain(hdsp);
2354 return 0;
2357 static int snd_hdsp_put_phone_gain(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2359 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2360 int change;
2361 int val;
2363 if (!snd_hdsp_use_is_exclusive(hdsp))
2364 return -EBUSY;
2365 val = ucontrol->value.enumerated.item[0];
2366 if (val < 0) val = 0;
2367 if (val > 2) val = 2;
2368 spin_lock_irq(&hdsp->lock);
2369 if (val != hdsp_phone_gain(hdsp))
2370 change = (hdsp_set_phone_gain(hdsp, val) == 0) ? 1 : 0;
2371 else
2372 change = 0;
2373 spin_unlock_irq(&hdsp->lock);
2374 return change;
2377 #define HDSP_PREF_SYNC_REF(xname, xindex) \
2378 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2379 .name = xname, \
2380 .index = xindex, \
2381 .info = snd_hdsp_info_pref_sync_ref, \
2382 .get = snd_hdsp_get_pref_sync_ref, \
2383 .put = snd_hdsp_put_pref_sync_ref \
2386 static int hdsp_pref_sync_ref(struct hdsp *hdsp)
2388 /* Notice that this looks at the requested sync source,
2389 not the one actually in use.
2392 switch (hdsp->control_register & HDSP_SyncRefMask) {
2393 case HDSP_SyncRef_ADAT1:
2394 return HDSP_SYNC_FROM_ADAT1;
2395 case HDSP_SyncRef_ADAT2:
2396 return HDSP_SYNC_FROM_ADAT2;
2397 case HDSP_SyncRef_ADAT3:
2398 return HDSP_SYNC_FROM_ADAT3;
2399 case HDSP_SyncRef_SPDIF:
2400 return HDSP_SYNC_FROM_SPDIF;
2401 case HDSP_SyncRef_WORD:
2402 return HDSP_SYNC_FROM_WORD;
2403 case HDSP_SyncRef_ADAT_SYNC:
2404 return HDSP_SYNC_FROM_ADAT_SYNC;
2405 default:
2406 return HDSP_SYNC_FROM_WORD;
2408 return 0;
2411 static int hdsp_set_pref_sync_ref(struct hdsp *hdsp, int pref)
2413 hdsp->control_register &= ~HDSP_SyncRefMask;
2414 switch (pref) {
2415 case HDSP_SYNC_FROM_ADAT1:
2416 hdsp->control_register &= ~HDSP_SyncRefMask; /* clear SyncRef bits */
2417 break;
2418 case HDSP_SYNC_FROM_ADAT2:
2419 hdsp->control_register |= HDSP_SyncRef_ADAT2;
2420 break;
2421 case HDSP_SYNC_FROM_ADAT3:
2422 hdsp->control_register |= HDSP_SyncRef_ADAT3;
2423 break;
2424 case HDSP_SYNC_FROM_SPDIF:
2425 hdsp->control_register |= HDSP_SyncRef_SPDIF;
2426 break;
2427 case HDSP_SYNC_FROM_WORD:
2428 hdsp->control_register |= HDSP_SyncRef_WORD;
2429 break;
2430 case HDSP_SYNC_FROM_ADAT_SYNC:
2431 hdsp->control_register |= HDSP_SyncRef_ADAT_SYNC;
2432 break;
2433 default:
2434 return -1;
2436 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
2437 return 0;
2440 static int snd_hdsp_info_pref_sync_ref(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2442 static char *texts[] = {"Word", "IEC958", "ADAT1", "ADAT Sync", "ADAT2", "ADAT3" };
2443 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2445 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2446 uinfo->count = 1;
2448 switch (hdsp->io_type) {
2449 case Digiface:
2450 case H9652:
2451 uinfo->value.enumerated.items = 6;
2452 break;
2453 case Multiface:
2454 uinfo->value.enumerated.items = 4;
2455 break;
2456 case H9632:
2457 uinfo->value.enumerated.items = 3;
2458 break;
2459 default:
2460 return -EINVAL;
2463 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2464 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2465 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2466 return 0;
2469 static int snd_hdsp_get_pref_sync_ref(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2471 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2473 ucontrol->value.enumerated.item[0] = hdsp_pref_sync_ref(hdsp);
2474 return 0;
2477 static int snd_hdsp_put_pref_sync_ref(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2479 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2480 int change, max;
2481 unsigned int val;
2483 if (!snd_hdsp_use_is_exclusive(hdsp))
2484 return -EBUSY;
2486 switch (hdsp->io_type) {
2487 case Digiface:
2488 case H9652:
2489 max = 6;
2490 break;
2491 case Multiface:
2492 max = 4;
2493 break;
2494 case H9632:
2495 max = 3;
2496 break;
2497 default:
2498 return -EIO;
2501 val = ucontrol->value.enumerated.item[0] % max;
2502 spin_lock_irq(&hdsp->lock);
2503 change = (int)val != hdsp_pref_sync_ref(hdsp);
2504 hdsp_set_pref_sync_ref(hdsp, val);
2505 spin_unlock_irq(&hdsp->lock);
2506 return change;
2509 #define HDSP_AUTOSYNC_REF(xname, xindex) \
2510 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2511 .name = xname, \
2512 .index = xindex, \
2513 .access = SNDRV_CTL_ELEM_ACCESS_READ, \
2514 .info = snd_hdsp_info_autosync_ref, \
2515 .get = snd_hdsp_get_autosync_ref, \
2518 static int hdsp_autosync_ref(struct hdsp *hdsp)
2520 /* This looks at the autosync selected sync reference */
2521 unsigned int status2 = hdsp_read(hdsp, HDSP_status2Register);
2523 switch (status2 & HDSP_SelSyncRefMask) {
2524 case HDSP_SelSyncRef_WORD:
2525 return HDSP_AUTOSYNC_FROM_WORD;
2526 case HDSP_SelSyncRef_ADAT_SYNC:
2527 return HDSP_AUTOSYNC_FROM_ADAT_SYNC;
2528 case HDSP_SelSyncRef_SPDIF:
2529 return HDSP_AUTOSYNC_FROM_SPDIF;
2530 case HDSP_SelSyncRefMask:
2531 return HDSP_AUTOSYNC_FROM_NONE;
2532 case HDSP_SelSyncRef_ADAT1:
2533 return HDSP_AUTOSYNC_FROM_ADAT1;
2534 case HDSP_SelSyncRef_ADAT2:
2535 return HDSP_AUTOSYNC_FROM_ADAT2;
2536 case HDSP_SelSyncRef_ADAT3:
2537 return HDSP_AUTOSYNC_FROM_ADAT3;
2538 default:
2539 return HDSP_AUTOSYNC_FROM_WORD;
2541 return 0;
2544 static int snd_hdsp_info_autosync_ref(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2546 static char *texts[] = {"Word", "ADAT Sync", "IEC958", "None", "ADAT1", "ADAT2", "ADAT3" };
2548 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2549 uinfo->count = 1;
2550 uinfo->value.enumerated.items = 7;
2551 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2552 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2553 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2554 return 0;
2557 static int snd_hdsp_get_autosync_ref(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2559 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2561 ucontrol->value.enumerated.item[0] = hdsp_autosync_ref(hdsp);
2562 return 0;
2565 #define HDSP_PRECISE_POINTER(xname, xindex) \
2566 { .iface = SNDRV_CTL_ELEM_IFACE_CARD, \
2567 .name = xname, \
2568 .index = xindex, \
2569 .info = snd_hdsp_info_precise_pointer, \
2570 .get = snd_hdsp_get_precise_pointer, \
2571 .put = snd_hdsp_put_precise_pointer \
2574 static int hdsp_set_precise_pointer(struct hdsp *hdsp, int precise)
2576 if (precise)
2577 hdsp->precise_ptr = 1;
2578 else
2579 hdsp->precise_ptr = 0;
2580 return 0;
2583 #define snd_hdsp_info_precise_pointer snd_ctl_boolean_mono_info
2585 static int snd_hdsp_get_precise_pointer(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2587 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2589 spin_lock_irq(&hdsp->lock);
2590 ucontrol->value.integer.value[0] = hdsp->precise_ptr;
2591 spin_unlock_irq(&hdsp->lock);
2592 return 0;
2595 static int snd_hdsp_put_precise_pointer(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2597 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2598 int change;
2599 unsigned int val;
2601 if (!snd_hdsp_use_is_exclusive(hdsp))
2602 return -EBUSY;
2603 val = ucontrol->value.integer.value[0] & 1;
2604 spin_lock_irq(&hdsp->lock);
2605 change = (int)val != hdsp->precise_ptr;
2606 hdsp_set_precise_pointer(hdsp, val);
2607 spin_unlock_irq(&hdsp->lock);
2608 return change;
2611 #define HDSP_USE_MIDI_TASKLET(xname, xindex) \
2612 { .iface = SNDRV_CTL_ELEM_IFACE_CARD, \
2613 .name = xname, \
2614 .index = xindex, \
2615 .info = snd_hdsp_info_use_midi_tasklet, \
2616 .get = snd_hdsp_get_use_midi_tasklet, \
2617 .put = snd_hdsp_put_use_midi_tasklet \
2620 static int hdsp_set_use_midi_tasklet(struct hdsp *hdsp, int use_tasklet)
2622 if (use_tasklet)
2623 hdsp->use_midi_tasklet = 1;
2624 else
2625 hdsp->use_midi_tasklet = 0;
2626 return 0;
2629 #define snd_hdsp_info_use_midi_tasklet snd_ctl_boolean_mono_info
2631 static int snd_hdsp_get_use_midi_tasklet(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2633 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2635 spin_lock_irq(&hdsp->lock);
2636 ucontrol->value.integer.value[0] = hdsp->use_midi_tasklet;
2637 spin_unlock_irq(&hdsp->lock);
2638 return 0;
2641 static int snd_hdsp_put_use_midi_tasklet(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2643 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2644 int change;
2645 unsigned int val;
2647 if (!snd_hdsp_use_is_exclusive(hdsp))
2648 return -EBUSY;
2649 val = ucontrol->value.integer.value[0] & 1;
2650 spin_lock_irq(&hdsp->lock);
2651 change = (int)val != hdsp->use_midi_tasklet;
2652 hdsp_set_use_midi_tasklet(hdsp, val);
2653 spin_unlock_irq(&hdsp->lock);
2654 return change;
2657 #define HDSP_MIXER(xname, xindex) \
2658 { .iface = SNDRV_CTL_ELEM_IFACE_HWDEP, \
2659 .name = xname, \
2660 .index = xindex, \
2661 .device = 0, \
2662 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | \
2663 SNDRV_CTL_ELEM_ACCESS_VOLATILE, \
2664 .info = snd_hdsp_info_mixer, \
2665 .get = snd_hdsp_get_mixer, \
2666 .put = snd_hdsp_put_mixer \
2669 static int snd_hdsp_info_mixer(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2671 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
2672 uinfo->count = 3;
2673 uinfo->value.integer.min = 0;
2674 uinfo->value.integer.max = 65536;
2675 uinfo->value.integer.step = 1;
2676 return 0;
2679 static int snd_hdsp_get_mixer(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2681 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2682 int source;
2683 int destination;
2684 int addr;
2686 source = ucontrol->value.integer.value[0];
2687 destination = ucontrol->value.integer.value[1];
2689 if (source >= hdsp->max_channels)
2690 addr = hdsp_playback_to_output_key(hdsp,source-hdsp->max_channels,destination);
2691 else
2692 addr = hdsp_input_to_output_key(hdsp,source, destination);
2694 spin_lock_irq(&hdsp->lock);
2695 ucontrol->value.integer.value[2] = hdsp_read_gain (hdsp, addr);
2696 spin_unlock_irq(&hdsp->lock);
2697 return 0;
2700 static int snd_hdsp_put_mixer(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2702 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2703 int change;
2704 int source;
2705 int destination;
2706 int gain;
2707 int addr;
2709 if (!snd_hdsp_use_is_exclusive(hdsp))
2710 return -EBUSY;
2712 source = ucontrol->value.integer.value[0];
2713 destination = ucontrol->value.integer.value[1];
2715 if (source >= hdsp->max_channels)
2716 addr = hdsp_playback_to_output_key(hdsp,source-hdsp->max_channels, destination);
2717 else
2718 addr = hdsp_input_to_output_key(hdsp,source, destination);
2720 gain = ucontrol->value.integer.value[2];
2722 spin_lock_irq(&hdsp->lock);
2723 change = gain != hdsp_read_gain(hdsp, addr);
2724 if (change)
2725 hdsp_write_gain(hdsp, addr, gain);
2726 spin_unlock_irq(&hdsp->lock);
2727 return change;
2730 #define HDSP_WC_SYNC_CHECK(xname, xindex) \
2731 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2732 .name = xname, \
2733 .index = xindex, \
2734 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE, \
2735 .info = snd_hdsp_info_sync_check, \
2736 .get = snd_hdsp_get_wc_sync_check \
2739 static int snd_hdsp_info_sync_check(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2741 static char *texts[] = {"No Lock", "Lock", "Sync" };
2742 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2743 uinfo->count = 1;
2744 uinfo->value.enumerated.items = 3;
2745 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
2746 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
2747 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
2748 return 0;
2751 static int hdsp_wc_sync_check(struct hdsp *hdsp)
2753 int status2 = hdsp_read(hdsp, HDSP_status2Register);
2754 if (status2 & HDSP_wc_lock) {
2755 if (status2 & HDSP_wc_sync)
2756 return 2;
2757 else
2758 return 1;
2759 } else
2760 return 0;
2761 return 0;
2764 static int snd_hdsp_get_wc_sync_check(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2766 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2768 ucontrol->value.enumerated.item[0] = hdsp_wc_sync_check(hdsp);
2769 return 0;
2772 #define HDSP_SPDIF_SYNC_CHECK(xname, xindex) \
2773 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2774 .name = xname, \
2775 .index = xindex, \
2776 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE, \
2777 .info = snd_hdsp_info_sync_check, \
2778 .get = snd_hdsp_get_spdif_sync_check \
2781 static int hdsp_spdif_sync_check(struct hdsp *hdsp)
2783 int status = hdsp_read(hdsp, HDSP_statusRegister);
2784 if (status & HDSP_SPDIFErrorFlag)
2785 return 0;
2786 else {
2787 if (status & HDSP_SPDIFSync)
2788 return 2;
2789 else
2790 return 1;
2792 return 0;
2795 static int snd_hdsp_get_spdif_sync_check(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2797 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2799 ucontrol->value.enumerated.item[0] = hdsp_spdif_sync_check(hdsp);
2800 return 0;
2803 #define HDSP_ADATSYNC_SYNC_CHECK(xname, xindex) \
2804 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2805 .name = xname, \
2806 .index = xindex, \
2807 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE, \
2808 .info = snd_hdsp_info_sync_check, \
2809 .get = snd_hdsp_get_adatsync_sync_check \
2812 static int hdsp_adatsync_sync_check(struct hdsp *hdsp)
2814 int status = hdsp_read(hdsp, HDSP_statusRegister);
2815 if (status & HDSP_TimecodeLock) {
2816 if (status & HDSP_TimecodeSync)
2817 return 2;
2818 else
2819 return 1;
2820 } else
2821 return 0;
2824 static int snd_hdsp_get_adatsync_sync_check(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2826 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2828 ucontrol->value.enumerated.item[0] = hdsp_adatsync_sync_check(hdsp);
2829 return 0;
2832 #define HDSP_ADAT_SYNC_CHECK \
2833 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2834 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE, \
2835 .info = snd_hdsp_info_sync_check, \
2836 .get = snd_hdsp_get_adat_sync_check \
2839 static int hdsp_adat_sync_check(struct hdsp *hdsp, int idx)
2841 int status = hdsp_read(hdsp, HDSP_statusRegister);
2843 if (status & (HDSP_Lock0>>idx)) {
2844 if (status & (HDSP_Sync0>>idx))
2845 return 2;
2846 else
2847 return 1;
2848 } else
2849 return 0;
2852 static int snd_hdsp_get_adat_sync_check(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2854 int offset;
2855 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2857 offset = ucontrol->id.index - 1;
2858 snd_BUG_ON(offset < 0);
2860 switch (hdsp->io_type) {
2861 case Digiface:
2862 case H9652:
2863 if (offset >= 3)
2864 return -EINVAL;
2865 break;
2866 case Multiface:
2867 case H9632:
2868 if (offset >= 1)
2869 return -EINVAL;
2870 break;
2871 default:
2872 return -EIO;
2875 ucontrol->value.enumerated.item[0] = hdsp_adat_sync_check(hdsp, offset);
2876 return 0;
2879 #define HDSP_DDS_OFFSET(xname, xindex) \
2880 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2881 .name = xname, \
2882 .index = xindex, \
2883 .info = snd_hdsp_info_dds_offset, \
2884 .get = snd_hdsp_get_dds_offset, \
2885 .put = snd_hdsp_put_dds_offset \
2888 static int hdsp_dds_offset(struct hdsp *hdsp)
2890 u64 n;
2891 unsigned int dds_value = hdsp->dds_value;
2892 int system_sample_rate = hdsp->system_sample_rate;
2894 if (!dds_value)
2895 return 0;
2897 n = DDS_NUMERATOR;
2899 * dds_value = n / rate
2900 * rate = n / dds_value
2902 n = div_u64(n, dds_value);
2903 if (system_sample_rate >= 112000)
2904 n *= 4;
2905 else if (system_sample_rate >= 56000)
2906 n *= 2;
2907 return ((int)n) - system_sample_rate;
2910 static int hdsp_set_dds_offset(struct hdsp *hdsp, int offset_hz)
2912 int rate = hdsp->system_sample_rate + offset_hz;
2913 hdsp_set_dds_value(hdsp, rate);
2914 return 0;
2917 static int snd_hdsp_info_dds_offset(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
2919 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
2920 uinfo->count = 1;
2921 uinfo->value.integer.min = -5000;
2922 uinfo->value.integer.max = 5000;
2923 return 0;
2926 static int snd_hdsp_get_dds_offset(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2928 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2930 ucontrol->value.enumerated.item[0] = hdsp_dds_offset(hdsp);
2931 return 0;
2934 static int snd_hdsp_put_dds_offset(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2936 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
2937 int change;
2938 int val;
2940 if (!snd_hdsp_use_is_exclusive(hdsp))
2941 return -EBUSY;
2942 val = ucontrol->value.enumerated.item[0];
2943 spin_lock_irq(&hdsp->lock);
2944 if (val != hdsp_dds_offset(hdsp))
2945 change = (hdsp_set_dds_offset(hdsp, val) == 0) ? 1 : 0;
2946 else
2947 change = 0;
2948 spin_unlock_irq(&hdsp->lock);
2949 return change;
2952 static struct snd_kcontrol_new snd_hdsp_9632_controls[] = {
2953 HDSP_DA_GAIN("DA Gain", 0),
2954 HDSP_AD_GAIN("AD Gain", 0),
2955 HDSP_PHONE_GAIN("Phones Gain", 0),
2956 HDSP_TOGGLE_SETTING("XLR Breakout Cable", HDSP_XLRBreakoutCable),
2957 HDSP_DDS_OFFSET("DDS Sample Rate Offset", 0)
2960 static struct snd_kcontrol_new snd_hdsp_controls[] = {
2962 .iface = SNDRV_CTL_ELEM_IFACE_PCM,
2963 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,DEFAULT),
2964 .info = snd_hdsp_control_spdif_info,
2965 .get = snd_hdsp_control_spdif_get,
2966 .put = snd_hdsp_control_spdif_put,
2969 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_INACTIVE,
2970 .iface = SNDRV_CTL_ELEM_IFACE_PCM,
2971 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,PCM_STREAM),
2972 .info = snd_hdsp_control_spdif_stream_info,
2973 .get = snd_hdsp_control_spdif_stream_get,
2974 .put = snd_hdsp_control_spdif_stream_put,
2977 .access = SNDRV_CTL_ELEM_ACCESS_READ,
2978 .iface = SNDRV_CTL_ELEM_IFACE_PCM,
2979 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,CON_MASK),
2980 .info = snd_hdsp_control_spdif_mask_info,
2981 .get = snd_hdsp_control_spdif_mask_get,
2982 .private_value = IEC958_AES0_NONAUDIO |
2983 IEC958_AES0_PROFESSIONAL |
2984 IEC958_AES0_CON_EMPHASIS,
2987 .access = SNDRV_CTL_ELEM_ACCESS_READ,
2988 .iface = SNDRV_CTL_ELEM_IFACE_PCM,
2989 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,PRO_MASK),
2990 .info = snd_hdsp_control_spdif_mask_info,
2991 .get = snd_hdsp_control_spdif_mask_get,
2992 .private_value = IEC958_AES0_NONAUDIO |
2993 IEC958_AES0_PROFESSIONAL |
2994 IEC958_AES0_PRO_EMPHASIS,
2996 HDSP_MIXER("Mixer", 0),
2997 HDSP_SPDIF_IN("IEC958 Input Connector", 0),
2998 HDSP_TOGGLE_SETTING("IEC958 Output also on ADAT1", HDSP_SPDIFOpticalOut),
2999 HDSP_TOGGLE_SETTING("IEC958 Professional Bit", HDSP_SPDIFProfessional),
3000 HDSP_TOGGLE_SETTING("IEC958 Emphasis Bit", HDSP_SPDIFEmphasis),
3001 HDSP_TOGGLE_SETTING("IEC958 Non-audio Bit", HDSP_SPDIFNonAudio),
3002 /* 'Sample Clock Source' complies with the alsa control naming scheme */
3003 HDSP_CLOCK_SOURCE("Sample Clock Source", 0),
3005 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3006 .name = "Sample Clock Source Locking",
3007 .info = snd_hdsp_info_clock_source_lock,
3008 .get = snd_hdsp_get_clock_source_lock,
3009 .put = snd_hdsp_put_clock_source_lock,
3011 HDSP_SYSTEM_CLOCK_MODE("System Clock Mode", 0),
3012 HDSP_PREF_SYNC_REF("Preferred Sync Reference", 0),
3013 HDSP_AUTOSYNC_REF("AutoSync Reference", 0),
3014 HDSP_SPDIF_SAMPLE_RATE("SPDIF Sample Rate", 0),
3015 HDSP_SYSTEM_SAMPLE_RATE("System Sample Rate", 0),
3016 /* 'External Rate' complies with the alsa control naming scheme */
3017 HDSP_AUTOSYNC_SAMPLE_RATE("External Rate", 0),
3018 HDSP_WC_SYNC_CHECK("Word Clock Lock Status", 0),
3019 HDSP_SPDIF_SYNC_CHECK("SPDIF Lock Status", 0),
3020 HDSP_ADATSYNC_SYNC_CHECK("ADAT Sync Lock Status", 0),
3021 HDSP_TOGGLE_SETTING("Line Out", HDSP_LineOut),
3022 HDSP_PRECISE_POINTER("Precise Pointer", 0),
3023 HDSP_USE_MIDI_TASKLET("Use Midi Tasklet", 0),
3027 static int hdsp_rpm_input12(struct hdsp *hdsp)
3029 switch (hdsp->control_register & HDSP_RPM_Inp12) {
3030 case HDSP_RPM_Inp12_Phon_6dB:
3031 return 0;
3032 case HDSP_RPM_Inp12_Phon_n6dB:
3033 return 2;
3034 case HDSP_RPM_Inp12_Line_0dB:
3035 return 3;
3036 case HDSP_RPM_Inp12_Line_n6dB:
3037 return 4;
3039 return 1;
3043 static int snd_hdsp_get_rpm_input12(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3045 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3047 ucontrol->value.enumerated.item[0] = hdsp_rpm_input12(hdsp);
3048 return 0;
3052 static int hdsp_set_rpm_input12(struct hdsp *hdsp, int mode)
3054 hdsp->control_register &= ~HDSP_RPM_Inp12;
3055 switch (mode) {
3056 case 0:
3057 hdsp->control_register |= HDSP_RPM_Inp12_Phon_6dB;
3058 break;
3059 case 1:
3060 break;
3061 case 2:
3062 hdsp->control_register |= HDSP_RPM_Inp12_Phon_n6dB;
3063 break;
3064 case 3:
3065 hdsp->control_register |= HDSP_RPM_Inp12_Line_0dB;
3066 break;
3067 case 4:
3068 hdsp->control_register |= HDSP_RPM_Inp12_Line_n6dB;
3069 break;
3070 default:
3071 return -1;
3074 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3075 return 0;
3079 static int snd_hdsp_put_rpm_input12(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3081 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3082 int change;
3083 int val;
3085 if (!snd_hdsp_use_is_exclusive(hdsp))
3086 return -EBUSY;
3087 val = ucontrol->value.enumerated.item[0];
3088 if (val < 0)
3089 val = 0;
3090 if (val > 4)
3091 val = 4;
3092 spin_lock_irq(&hdsp->lock);
3093 if (val != hdsp_rpm_input12(hdsp))
3094 change = (hdsp_set_rpm_input12(hdsp, val) == 0) ? 1 : 0;
3095 else
3096 change = 0;
3097 spin_unlock_irq(&hdsp->lock);
3098 return change;
3102 static int snd_hdsp_info_rpm_input(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
3104 static char *texts[] = {"Phono +6dB", "Phono 0dB", "Phono -6dB", "Line 0dB", "Line -6dB"};
3106 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
3107 uinfo->count = 1;
3108 uinfo->value.enumerated.items = 5;
3109 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
3110 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
3111 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
3112 return 0;
3116 static int hdsp_rpm_input34(struct hdsp *hdsp)
3118 switch (hdsp->control_register & HDSP_RPM_Inp34) {
3119 case HDSP_RPM_Inp34_Phon_6dB:
3120 return 0;
3121 case HDSP_RPM_Inp34_Phon_n6dB:
3122 return 2;
3123 case HDSP_RPM_Inp34_Line_0dB:
3124 return 3;
3125 case HDSP_RPM_Inp34_Line_n6dB:
3126 return 4;
3128 return 1;
3132 static int snd_hdsp_get_rpm_input34(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3134 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3136 ucontrol->value.enumerated.item[0] = hdsp_rpm_input34(hdsp);
3137 return 0;
3141 static int hdsp_set_rpm_input34(struct hdsp *hdsp, int mode)
3143 hdsp->control_register &= ~HDSP_RPM_Inp34;
3144 switch (mode) {
3145 case 0:
3146 hdsp->control_register |= HDSP_RPM_Inp34_Phon_6dB;
3147 break;
3148 case 1:
3149 break;
3150 case 2:
3151 hdsp->control_register |= HDSP_RPM_Inp34_Phon_n6dB;
3152 break;
3153 case 3:
3154 hdsp->control_register |= HDSP_RPM_Inp34_Line_0dB;
3155 break;
3156 case 4:
3157 hdsp->control_register |= HDSP_RPM_Inp34_Line_n6dB;
3158 break;
3159 default:
3160 return -1;
3163 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3164 return 0;
3168 static int snd_hdsp_put_rpm_input34(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3170 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3171 int change;
3172 int val;
3174 if (!snd_hdsp_use_is_exclusive(hdsp))
3175 return -EBUSY;
3176 val = ucontrol->value.enumerated.item[0];
3177 if (val < 0)
3178 val = 0;
3179 if (val > 4)
3180 val = 4;
3181 spin_lock_irq(&hdsp->lock);
3182 if (val != hdsp_rpm_input34(hdsp))
3183 change = (hdsp_set_rpm_input34(hdsp, val) == 0) ? 1 : 0;
3184 else
3185 change = 0;
3186 spin_unlock_irq(&hdsp->lock);
3187 return change;
3191 /* RPM Bypass switch */
3192 static int hdsp_rpm_bypass(struct hdsp *hdsp)
3194 return (hdsp->control_register & HDSP_RPM_Bypass) ? 1 : 0;
3198 static int snd_hdsp_get_rpm_bypass(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3200 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3202 ucontrol->value.integer.value[0] = hdsp_rpm_bypass(hdsp);
3203 return 0;
3207 static int hdsp_set_rpm_bypass(struct hdsp *hdsp, int on)
3209 if (on)
3210 hdsp->control_register |= HDSP_RPM_Bypass;
3211 else
3212 hdsp->control_register &= ~HDSP_RPM_Bypass;
3213 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3214 return 0;
3218 static int snd_hdsp_put_rpm_bypass(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3220 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3221 int change;
3222 unsigned int val;
3224 if (!snd_hdsp_use_is_exclusive(hdsp))
3225 return -EBUSY;
3226 val = ucontrol->value.integer.value[0] & 1;
3227 spin_lock_irq(&hdsp->lock);
3228 change = (int)val != hdsp_rpm_bypass(hdsp);
3229 hdsp_set_rpm_bypass(hdsp, val);
3230 spin_unlock_irq(&hdsp->lock);
3231 return change;
3235 static int snd_hdsp_info_rpm_bypass(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
3237 static char *texts[] = {"On", "Off"};
3239 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
3240 uinfo->count = 1;
3241 uinfo->value.enumerated.items = 2;
3242 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
3243 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
3244 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
3245 return 0;
3249 /* RPM Disconnect switch */
3250 static int hdsp_rpm_disconnect(struct hdsp *hdsp)
3252 return (hdsp->control_register & HDSP_RPM_Disconnect) ? 1 : 0;
3256 static int snd_hdsp_get_rpm_disconnect(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3258 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3260 ucontrol->value.integer.value[0] = hdsp_rpm_disconnect(hdsp);
3261 return 0;
3265 static int hdsp_set_rpm_disconnect(struct hdsp *hdsp, int on)
3267 if (on)
3268 hdsp->control_register |= HDSP_RPM_Disconnect;
3269 else
3270 hdsp->control_register &= ~HDSP_RPM_Disconnect;
3271 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3272 return 0;
3276 static int snd_hdsp_put_rpm_disconnect(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
3278 struct hdsp *hdsp = snd_kcontrol_chip(kcontrol);
3279 int change;
3280 unsigned int val;
3282 if (!snd_hdsp_use_is_exclusive(hdsp))
3283 return -EBUSY;
3284 val = ucontrol->value.integer.value[0] & 1;
3285 spin_lock_irq(&hdsp->lock);
3286 change = (int)val != hdsp_rpm_disconnect(hdsp);
3287 hdsp_set_rpm_disconnect(hdsp, val);
3288 spin_unlock_irq(&hdsp->lock);
3289 return change;
3292 static int snd_hdsp_info_rpm_disconnect(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
3294 static char *texts[] = {"On", "Off"};
3296 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
3297 uinfo->count = 1;
3298 uinfo->value.enumerated.items = 2;
3299 if (uinfo->value.enumerated.item >= uinfo->value.enumerated.items)
3300 uinfo->value.enumerated.item = uinfo->value.enumerated.items - 1;
3301 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
3302 return 0;
3305 static struct snd_kcontrol_new snd_hdsp_rpm_controls[] = {
3307 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3308 .name = "RPM Bypass",
3309 .get = snd_hdsp_get_rpm_bypass,
3310 .put = snd_hdsp_put_rpm_bypass,
3311 .info = snd_hdsp_info_rpm_bypass
3314 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3315 .name = "RPM Disconnect",
3316 .get = snd_hdsp_get_rpm_disconnect,
3317 .put = snd_hdsp_put_rpm_disconnect,
3318 .info = snd_hdsp_info_rpm_disconnect
3321 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3322 .name = "Input 1/2",
3323 .get = snd_hdsp_get_rpm_input12,
3324 .put = snd_hdsp_put_rpm_input12,
3325 .info = snd_hdsp_info_rpm_input
3328 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3329 .name = "Input 3/4",
3330 .get = snd_hdsp_get_rpm_input34,
3331 .put = snd_hdsp_put_rpm_input34,
3332 .info = snd_hdsp_info_rpm_input
3334 HDSP_SYSTEM_SAMPLE_RATE("System Sample Rate", 0),
3335 HDSP_MIXER("Mixer", 0)
3338 static struct snd_kcontrol_new snd_hdsp_96xx_aeb =
3339 HDSP_TOGGLE_SETTING("Analog Extension Board",
3340 HDSP_AnalogExtensionBoard);
3341 static struct snd_kcontrol_new snd_hdsp_adat_sync_check = HDSP_ADAT_SYNC_CHECK;
3343 static int snd_hdsp_create_controls(struct snd_card *card, struct hdsp *hdsp)
3345 unsigned int idx;
3346 int err;
3347 struct snd_kcontrol *kctl;
3349 if (hdsp->io_type == RPM) {
3350 /* RPM Bypass, Disconnect and Input switches */
3351 for (idx = 0; idx < ARRAY_SIZE(snd_hdsp_rpm_controls); idx++) {
3352 err = snd_ctl_add(card, kctl = snd_ctl_new1(&snd_hdsp_rpm_controls[idx], hdsp));
3353 if (err < 0)
3354 return err;
3356 return 0;
3359 for (idx = 0; idx < ARRAY_SIZE(snd_hdsp_controls); idx++) {
3360 if ((err = snd_ctl_add(card, kctl = snd_ctl_new1(&snd_hdsp_controls[idx], hdsp))) < 0)
3361 return err;
3362 if (idx == 1) /* IEC958 (S/PDIF) Stream */
3363 hdsp->spdif_ctl = kctl;
3366 /* ADAT SyncCheck status */
3367 snd_hdsp_adat_sync_check.name = "ADAT Lock Status";
3368 snd_hdsp_adat_sync_check.index = 1;
3369 if ((err = snd_ctl_add (card, kctl = snd_ctl_new1(&snd_hdsp_adat_sync_check, hdsp))))
3370 return err;
3371 if (hdsp->io_type == Digiface || hdsp->io_type == H9652) {
3372 for (idx = 1; idx < 3; ++idx) {
3373 snd_hdsp_adat_sync_check.index = idx+1;
3374 if ((err = snd_ctl_add (card, kctl = snd_ctl_new1(&snd_hdsp_adat_sync_check, hdsp))))
3375 return err;
3379 /* DA, AD and Phone gain and XLR breakout cable controls for H9632 cards */
3380 if (hdsp->io_type == H9632) {
3381 for (idx = 0; idx < ARRAY_SIZE(snd_hdsp_9632_controls); idx++) {
3382 if ((err = snd_ctl_add(card, kctl = snd_ctl_new1(&snd_hdsp_9632_controls[idx], hdsp))) < 0)
3383 return err;
3387 /* AEB control for H96xx card */
3388 if (hdsp->io_type == H9632 || hdsp->io_type == H9652) {
3389 if ((err = snd_ctl_add(card, kctl = snd_ctl_new1(&snd_hdsp_96xx_aeb, hdsp))) < 0)
3390 return err;
3393 return 0;
3396 /*------------------------------------------------------------
3397 /proc interface
3398 ------------------------------------------------------------*/
3400 static void
3401 snd_hdsp_proc_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer)
3403 struct hdsp *hdsp = entry->private_data;
3404 unsigned int status;
3405 unsigned int status2;
3406 char *pref_sync_ref;
3407 char *autosync_ref;
3408 char *system_clock_mode;
3409 char *clock_source;
3410 int x;
3412 status = hdsp_read(hdsp, HDSP_statusRegister);
3413 status2 = hdsp_read(hdsp, HDSP_status2Register);
3415 snd_iprintf(buffer, "%s (Card #%d)\n", hdsp->card_name,
3416 hdsp->card->number + 1);
3417 snd_iprintf(buffer, "Buffers: capture %p playback %p\n",
3418 hdsp->capture_buffer, hdsp->playback_buffer);
3419 snd_iprintf(buffer, "IRQ: %d Registers bus: 0x%lx VM: 0x%lx\n",
3420 hdsp->irq, hdsp->port, (unsigned long)hdsp->iobase);
3421 snd_iprintf(buffer, "Control register: 0x%x\n", hdsp->control_register);
3422 snd_iprintf(buffer, "Control2 register: 0x%x\n",
3423 hdsp->control2_register);
3424 snd_iprintf(buffer, "Status register: 0x%x\n", status);
3425 snd_iprintf(buffer, "Status2 register: 0x%x\n", status2);
3427 if (hdsp_check_for_iobox(hdsp)) {
3428 snd_iprintf(buffer, "No I/O box connected.\n"
3429 "Please connect one and upload firmware.\n");
3430 return;
3433 if (hdsp_check_for_firmware(hdsp, 0)) {
3434 if (hdsp->state & HDSP_FirmwareCached) {
3435 if (snd_hdsp_load_firmware_from_cache(hdsp) != 0) {
3436 snd_iprintf(buffer, "Firmware loading from "
3437 "cache failed, "
3438 "please upload manually.\n");
3439 return;
3441 } else {
3442 int err = -EINVAL;
3443 err = hdsp_request_fw_loader(hdsp);
3444 if (err < 0) {
3445 snd_iprintf(buffer,
3446 "No firmware loaded nor cached, "
3447 "please upload firmware.\n");
3448 return;
3453 snd_iprintf(buffer, "FIFO status: %d\n", hdsp_read(hdsp, HDSP_fifoStatus) & 0xff);
3454 snd_iprintf(buffer, "MIDI1 Output status: 0x%x\n", hdsp_read(hdsp, HDSP_midiStatusOut0));
3455 snd_iprintf(buffer, "MIDI1 Input status: 0x%x\n", hdsp_read(hdsp, HDSP_midiStatusIn0));
3456 snd_iprintf(buffer, "MIDI2 Output status: 0x%x\n", hdsp_read(hdsp, HDSP_midiStatusOut1));
3457 snd_iprintf(buffer, "MIDI2 Input status: 0x%x\n", hdsp_read(hdsp, HDSP_midiStatusIn1));
3458 snd_iprintf(buffer, "Use Midi Tasklet: %s\n", hdsp->use_midi_tasklet ? "on" : "off");
3460 snd_iprintf(buffer, "\n");
3462 x = 1 << (6 + hdsp_decode_latency(hdsp->control_register & HDSP_LatencyMask));
3464 snd_iprintf(buffer, "Buffer Size (Latency): %d samples (2 periods of %lu bytes)\n", x, (unsigned long) hdsp->period_bytes);
3465 snd_iprintf(buffer, "Hardware pointer (frames): %ld\n", hdsp_hw_pointer(hdsp));
3466 snd_iprintf(buffer, "Precise pointer: %s\n", hdsp->precise_ptr ? "on" : "off");
3467 snd_iprintf(buffer, "Line out: %s\n", (hdsp->control_register & HDSP_LineOut) ? "on" : "off");
3469 snd_iprintf(buffer, "Firmware version: %d\n", (status2&HDSP_version0)|(status2&HDSP_version1)<<1|(status2&HDSP_version2)<<2);
3471 snd_iprintf(buffer, "\n");
3473 switch (hdsp_clock_source(hdsp)) {
3474 case HDSP_CLOCK_SOURCE_AUTOSYNC:
3475 clock_source = "AutoSync";
3476 break;
3477 case HDSP_CLOCK_SOURCE_INTERNAL_32KHZ:
3478 clock_source = "Internal 32 kHz";
3479 break;
3480 case HDSP_CLOCK_SOURCE_INTERNAL_44_1KHZ:
3481 clock_source = "Internal 44.1 kHz";
3482 break;
3483 case HDSP_CLOCK_SOURCE_INTERNAL_48KHZ:
3484 clock_source = "Internal 48 kHz";
3485 break;
3486 case HDSP_CLOCK_SOURCE_INTERNAL_64KHZ:
3487 clock_source = "Internal 64 kHz";
3488 break;
3489 case HDSP_CLOCK_SOURCE_INTERNAL_88_2KHZ:
3490 clock_source = "Internal 88.2 kHz";
3491 break;
3492 case HDSP_CLOCK_SOURCE_INTERNAL_96KHZ:
3493 clock_source = "Internal 96 kHz";
3494 break;
3495 case HDSP_CLOCK_SOURCE_INTERNAL_128KHZ:
3496 clock_source = "Internal 128 kHz";
3497 break;
3498 case HDSP_CLOCK_SOURCE_INTERNAL_176_4KHZ:
3499 clock_source = "Internal 176.4 kHz";
3500 break;
3501 case HDSP_CLOCK_SOURCE_INTERNAL_192KHZ:
3502 clock_source = "Internal 192 kHz";
3503 break;
3504 default:
3505 clock_source = "Error";
3507 snd_iprintf (buffer, "Sample Clock Source: %s\n", clock_source);
3509 if (hdsp_system_clock_mode(hdsp))
3510 system_clock_mode = "Slave";
3511 else
3512 system_clock_mode = "Master";
3514 switch (hdsp_pref_sync_ref (hdsp)) {
3515 case HDSP_SYNC_FROM_WORD:
3516 pref_sync_ref = "Word Clock";
3517 break;
3518 case HDSP_SYNC_FROM_ADAT_SYNC:
3519 pref_sync_ref = "ADAT Sync";
3520 break;
3521 case HDSP_SYNC_FROM_SPDIF:
3522 pref_sync_ref = "SPDIF";
3523 break;
3524 case HDSP_SYNC_FROM_ADAT1:
3525 pref_sync_ref = "ADAT1";
3526 break;
3527 case HDSP_SYNC_FROM_ADAT2:
3528 pref_sync_ref = "ADAT2";
3529 break;
3530 case HDSP_SYNC_FROM_ADAT3:
3531 pref_sync_ref = "ADAT3";
3532 break;
3533 default:
3534 pref_sync_ref = "Word Clock";
3535 break;
3537 snd_iprintf (buffer, "Preferred Sync Reference: %s\n", pref_sync_ref);
3539 switch (hdsp_autosync_ref (hdsp)) {
3540 case HDSP_AUTOSYNC_FROM_WORD:
3541 autosync_ref = "Word Clock";
3542 break;
3543 case HDSP_AUTOSYNC_FROM_ADAT_SYNC:
3544 autosync_ref = "ADAT Sync";
3545 break;
3546 case HDSP_AUTOSYNC_FROM_SPDIF:
3547 autosync_ref = "SPDIF";
3548 break;
3549 case HDSP_AUTOSYNC_FROM_NONE:
3550 autosync_ref = "None";
3551 break;
3552 case HDSP_AUTOSYNC_FROM_ADAT1:
3553 autosync_ref = "ADAT1";
3554 break;
3555 case HDSP_AUTOSYNC_FROM_ADAT2:
3556 autosync_ref = "ADAT2";
3557 break;
3558 case HDSP_AUTOSYNC_FROM_ADAT3:
3559 autosync_ref = "ADAT3";
3560 break;
3561 default:
3562 autosync_ref = "---";
3563 break;
3565 snd_iprintf (buffer, "AutoSync Reference: %s\n", autosync_ref);
3567 snd_iprintf (buffer, "AutoSync Frequency: %d\n", hdsp_external_sample_rate(hdsp));
3569 snd_iprintf (buffer, "System Clock Mode: %s\n", system_clock_mode);
3571 snd_iprintf (buffer, "System Clock Frequency: %d\n", hdsp->system_sample_rate);
3572 snd_iprintf (buffer, "System Clock Locked: %s\n", hdsp->clock_source_locked ? "Yes" : "No");
3574 snd_iprintf(buffer, "\n");
3576 if (hdsp->io_type != RPM) {
3577 switch (hdsp_spdif_in(hdsp)) {
3578 case HDSP_SPDIFIN_OPTICAL:
3579 snd_iprintf(buffer, "IEC958 input: Optical\n");
3580 break;
3581 case HDSP_SPDIFIN_COAXIAL:
3582 snd_iprintf(buffer, "IEC958 input: Coaxial\n");
3583 break;
3584 case HDSP_SPDIFIN_INTERNAL:
3585 snd_iprintf(buffer, "IEC958 input: Internal\n");
3586 break;
3587 case HDSP_SPDIFIN_AES:
3588 snd_iprintf(buffer, "IEC958 input: AES\n");
3589 break;
3590 default:
3591 snd_iprintf(buffer, "IEC958 input: ???\n");
3592 break;
3596 if (RPM == hdsp->io_type) {
3597 if (hdsp->control_register & HDSP_RPM_Bypass)
3598 snd_iprintf(buffer, "RPM Bypass: disabled\n");
3599 else
3600 snd_iprintf(buffer, "RPM Bypass: enabled\n");
3601 if (hdsp->control_register & HDSP_RPM_Disconnect)
3602 snd_iprintf(buffer, "RPM disconnected\n");
3603 else
3604 snd_iprintf(buffer, "RPM connected\n");
3606 switch (hdsp->control_register & HDSP_RPM_Inp12) {
3607 case HDSP_RPM_Inp12_Phon_6dB:
3608 snd_iprintf(buffer, "Input 1/2: Phono, 6dB\n");
3609 break;
3610 case HDSP_RPM_Inp12_Phon_0dB:
3611 snd_iprintf(buffer, "Input 1/2: Phono, 0dB\n");
3612 break;
3613 case HDSP_RPM_Inp12_Phon_n6dB:
3614 snd_iprintf(buffer, "Input 1/2: Phono, -6dB\n");
3615 break;
3616 case HDSP_RPM_Inp12_Line_0dB:
3617 snd_iprintf(buffer, "Input 1/2: Line, 0dB\n");
3618 break;
3619 case HDSP_RPM_Inp12_Line_n6dB:
3620 snd_iprintf(buffer, "Input 1/2: Line, -6dB\n");
3621 break;
3622 default:
3623 snd_iprintf(buffer, "Input 1/2: ???\n");
3626 switch (hdsp->control_register & HDSP_RPM_Inp34) {
3627 case HDSP_RPM_Inp34_Phon_6dB:
3628 snd_iprintf(buffer, "Input 3/4: Phono, 6dB\n");
3629 break;
3630 case HDSP_RPM_Inp34_Phon_0dB:
3631 snd_iprintf(buffer, "Input 3/4: Phono, 0dB\n");
3632 break;
3633 case HDSP_RPM_Inp34_Phon_n6dB:
3634 snd_iprintf(buffer, "Input 3/4: Phono, -6dB\n");
3635 break;
3636 case HDSP_RPM_Inp34_Line_0dB:
3637 snd_iprintf(buffer, "Input 3/4: Line, 0dB\n");
3638 break;
3639 case HDSP_RPM_Inp34_Line_n6dB:
3640 snd_iprintf(buffer, "Input 3/4: Line, -6dB\n");
3641 break;
3642 default:
3643 snd_iprintf(buffer, "Input 3/4: ???\n");
3646 } else {
3647 if (hdsp->control_register & HDSP_SPDIFOpticalOut)
3648 snd_iprintf(buffer, "IEC958 output: Coaxial & ADAT1\n");
3649 else
3650 snd_iprintf(buffer, "IEC958 output: Coaxial only\n");
3652 if (hdsp->control_register & HDSP_SPDIFProfessional)
3653 snd_iprintf(buffer, "IEC958 quality: Professional\n");
3654 else
3655 snd_iprintf(buffer, "IEC958 quality: Consumer\n");
3657 if (hdsp->control_register & HDSP_SPDIFEmphasis)
3658 snd_iprintf(buffer, "IEC958 emphasis: on\n");
3659 else
3660 snd_iprintf(buffer, "IEC958 emphasis: off\n");
3662 if (hdsp->control_register & HDSP_SPDIFNonAudio)
3663 snd_iprintf(buffer, "IEC958 NonAudio: on\n");
3664 else
3665 snd_iprintf(buffer, "IEC958 NonAudio: off\n");
3666 x = hdsp_spdif_sample_rate(hdsp);
3667 if (x != 0)
3668 snd_iprintf(buffer, "IEC958 sample rate: %d\n", x);
3669 else
3670 snd_iprintf(buffer, "IEC958 sample rate: Error flag set\n");
3672 snd_iprintf(buffer, "\n");
3674 /* Sync Check */
3675 x = status & HDSP_Sync0;
3676 if (status & HDSP_Lock0)
3677 snd_iprintf(buffer, "ADAT1: %s\n", x ? "Sync" : "Lock");
3678 else
3679 snd_iprintf(buffer, "ADAT1: No Lock\n");
3681 switch (hdsp->io_type) {
3682 case Digiface:
3683 case H9652:
3684 x = status & HDSP_Sync1;
3685 if (status & HDSP_Lock1)
3686 snd_iprintf(buffer, "ADAT2: %s\n", x ? "Sync" : "Lock");
3687 else
3688 snd_iprintf(buffer, "ADAT2: No Lock\n");
3689 x = status & HDSP_Sync2;
3690 if (status & HDSP_Lock2)
3691 snd_iprintf(buffer, "ADAT3: %s\n", x ? "Sync" : "Lock");
3692 else
3693 snd_iprintf(buffer, "ADAT3: No Lock\n");
3694 break;
3695 default:
3696 /* relax */
3697 break;
3700 x = status & HDSP_SPDIFSync;
3701 if (status & HDSP_SPDIFErrorFlag)
3702 snd_iprintf (buffer, "SPDIF: No Lock\n");
3703 else
3704 snd_iprintf (buffer, "SPDIF: %s\n", x ? "Sync" : "Lock");
3706 x = status2 & HDSP_wc_sync;
3707 if (status2 & HDSP_wc_lock)
3708 snd_iprintf (buffer, "Word Clock: %s\n", x ? "Sync" : "Lock");
3709 else
3710 snd_iprintf (buffer, "Word Clock: No Lock\n");
3712 x = status & HDSP_TimecodeSync;
3713 if (status & HDSP_TimecodeLock)
3714 snd_iprintf(buffer, "ADAT Sync: %s\n", x ? "Sync" : "Lock");
3715 else
3716 snd_iprintf(buffer, "ADAT Sync: No Lock\n");
3718 snd_iprintf(buffer, "\n");
3720 /* Informations about H9632 specific controls */
3721 if (hdsp->io_type == H9632) {
3722 char *tmp;
3724 switch (hdsp_ad_gain(hdsp)) {
3725 case 0:
3726 tmp = "-10 dBV";
3727 break;
3728 case 1:
3729 tmp = "+4 dBu";
3730 break;
3731 default:
3732 tmp = "Lo Gain";
3733 break;
3735 snd_iprintf(buffer, "AD Gain : %s\n", tmp);
3737 switch (hdsp_da_gain(hdsp)) {
3738 case 0:
3739 tmp = "Hi Gain";
3740 break;
3741 case 1:
3742 tmp = "+4 dBu";
3743 break;
3744 default:
3745 tmp = "-10 dBV";
3746 break;
3748 snd_iprintf(buffer, "DA Gain : %s\n", tmp);
3750 switch (hdsp_phone_gain(hdsp)) {
3751 case 0:
3752 tmp = "0 dB";
3753 break;
3754 case 1:
3755 tmp = "-6 dB";
3756 break;
3757 default:
3758 tmp = "-12 dB";
3759 break;
3761 snd_iprintf(buffer, "Phones Gain : %s\n", tmp);
3763 snd_iprintf(buffer, "XLR Breakout Cable : %s\n",
3764 hdsp_toggle_setting(hdsp, HDSP_XLRBreakoutCable) ?
3765 "yes" : "no");
3767 if (hdsp->control_register & HDSP_AnalogExtensionBoard)
3768 snd_iprintf(buffer, "AEB : on (ADAT1 internal)\n");
3769 else
3770 snd_iprintf(buffer, "AEB : off (ADAT1 external)\n");
3771 snd_iprintf(buffer, "\n");
3776 static void snd_hdsp_proc_init(struct hdsp *hdsp)
3778 struct snd_info_entry *entry;
3780 if (! snd_card_proc_new(hdsp->card, "hdsp", &entry))
3781 snd_info_set_text_ops(entry, hdsp, snd_hdsp_proc_read);
3784 static void snd_hdsp_free_buffers(struct hdsp *hdsp)
3786 snd_hammerfall_free_buffer(&hdsp->capture_dma_buf, hdsp->pci);
3787 snd_hammerfall_free_buffer(&hdsp->playback_dma_buf, hdsp->pci);
3790 static int snd_hdsp_initialize_memory(struct hdsp *hdsp)
3792 unsigned long pb_bus, cb_bus;
3794 if (snd_hammerfall_get_buffer(hdsp->pci, &hdsp->capture_dma_buf, HDSP_DMA_AREA_BYTES) < 0 ||
3795 snd_hammerfall_get_buffer(hdsp->pci, &hdsp->playback_dma_buf, HDSP_DMA_AREA_BYTES) < 0) {
3796 if (hdsp->capture_dma_buf.area)
3797 snd_dma_free_pages(&hdsp->capture_dma_buf);
3798 dev_err(hdsp->card->dev,
3799 "%s: no buffers available\n", hdsp->card_name);
3800 return -ENOMEM;
3803 /* Align to bus-space 64K boundary */
3805 cb_bus = ALIGN(hdsp->capture_dma_buf.addr, 0x10000ul);
3806 pb_bus = ALIGN(hdsp->playback_dma_buf.addr, 0x10000ul);
3808 /* Tell the card where it is */
3810 hdsp_write(hdsp, HDSP_inputBufferAddress, cb_bus);
3811 hdsp_write(hdsp, HDSP_outputBufferAddress, pb_bus);
3813 hdsp->capture_buffer = hdsp->capture_dma_buf.area + (cb_bus - hdsp->capture_dma_buf.addr);
3814 hdsp->playback_buffer = hdsp->playback_dma_buf.area + (pb_bus - hdsp->playback_dma_buf.addr);
3816 return 0;
3819 static int snd_hdsp_set_defaults(struct hdsp *hdsp)
3821 unsigned int i;
3823 /* ASSUMPTION: hdsp->lock is either held, or
3824 there is no need to hold it (e.g. during module
3825 initialization).
3828 /* set defaults:
3830 SPDIF Input via Coax
3831 Master clock mode
3832 maximum latency (7 => 2^7 = 8192 samples, 64Kbyte buffer,
3833 which implies 2 4096 sample, 32Kbyte periods).
3834 Enable line out.
3837 hdsp->control_register = HDSP_ClockModeMaster |
3838 HDSP_SPDIFInputCoaxial |
3839 hdsp_encode_latency(7) |
3840 HDSP_LineOut;
3843 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3845 #ifdef SNDRV_BIG_ENDIAN
3846 hdsp->control2_register = HDSP_BIGENDIAN_MODE;
3847 #else
3848 hdsp->control2_register = 0;
3849 #endif
3850 if (hdsp->io_type == H9652)
3851 snd_hdsp_9652_enable_mixer (hdsp);
3852 else
3853 hdsp_write (hdsp, HDSP_control2Reg, hdsp->control2_register);
3855 hdsp_reset_hw_pointer(hdsp);
3856 hdsp_compute_period_size(hdsp);
3858 /* silence everything */
3860 for (i = 0; i < HDSP_MATRIX_MIXER_SIZE; ++i)
3861 hdsp->mixer_matrix[i] = MINUS_INFINITY_GAIN;
3863 for (i = 0; i < ((hdsp->io_type == H9652 || hdsp->io_type == H9632) ? 1352 : HDSP_MATRIX_MIXER_SIZE); ++i) {
3864 if (hdsp_write_gain (hdsp, i, MINUS_INFINITY_GAIN))
3865 return -EIO;
3868 /* H9632 specific defaults */
3869 if (hdsp->io_type == H9632) {
3870 hdsp->control_register |= (HDSP_DAGainPlus4dBu | HDSP_ADGainPlus4dBu | HDSP_PhoneGain0dB);
3871 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3874 /* set a default rate so that the channel map is set up.
3877 hdsp_set_rate(hdsp, 48000, 1);
3879 return 0;
3882 static void hdsp_midi_tasklet(unsigned long arg)
3884 struct hdsp *hdsp = (struct hdsp *)arg;
3886 if (hdsp->midi[0].pending)
3887 snd_hdsp_midi_input_read (&hdsp->midi[0]);
3888 if (hdsp->midi[1].pending)
3889 snd_hdsp_midi_input_read (&hdsp->midi[1]);
3892 static irqreturn_t snd_hdsp_interrupt(int irq, void *dev_id)
3894 struct hdsp *hdsp = (struct hdsp *) dev_id;
3895 unsigned int status;
3896 int audio;
3897 int midi0;
3898 int midi1;
3899 unsigned int midi0status;
3900 unsigned int midi1status;
3901 int schedule = 0;
3903 status = hdsp_read(hdsp, HDSP_statusRegister);
3905 audio = status & HDSP_audioIRQPending;
3906 midi0 = status & HDSP_midi0IRQPending;
3907 midi1 = status & HDSP_midi1IRQPending;
3909 if (!audio && !midi0 && !midi1)
3910 return IRQ_NONE;
3912 hdsp_write(hdsp, HDSP_interruptConfirmation, 0);
3914 midi0status = hdsp_read (hdsp, HDSP_midiStatusIn0) & 0xff;
3915 midi1status = hdsp_read (hdsp, HDSP_midiStatusIn1) & 0xff;
3917 if (!(hdsp->state & HDSP_InitializationComplete))
3918 return IRQ_HANDLED;
3920 if (audio) {
3921 if (hdsp->capture_substream)
3922 snd_pcm_period_elapsed(hdsp->pcm->streams[SNDRV_PCM_STREAM_CAPTURE].substream);
3924 if (hdsp->playback_substream)
3925 snd_pcm_period_elapsed(hdsp->pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream);
3928 if (midi0 && midi0status) {
3929 if (hdsp->use_midi_tasklet) {
3930 /* we disable interrupts for this input until processing is done */
3931 hdsp->control_register &= ~HDSP_Midi0InterruptEnable;
3932 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3933 hdsp->midi[0].pending = 1;
3934 schedule = 1;
3935 } else {
3936 snd_hdsp_midi_input_read (&hdsp->midi[0]);
3939 if (hdsp->io_type != Multiface && hdsp->io_type != RPM && hdsp->io_type != H9632 && midi1 && midi1status) {
3940 if (hdsp->use_midi_tasklet) {
3941 /* we disable interrupts for this input until processing is done */
3942 hdsp->control_register &= ~HDSP_Midi1InterruptEnable;
3943 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register);
3944 hdsp->midi[1].pending = 1;
3945 schedule = 1;
3946 } else {
3947 snd_hdsp_midi_input_read (&hdsp->midi[1]);
3950 if (hdsp->use_midi_tasklet && schedule)
3951 tasklet_schedule(&hdsp->midi_tasklet);
3952 return IRQ_HANDLED;
3955 static snd_pcm_uframes_t snd_hdsp_hw_pointer(struct snd_pcm_substream *substream)
3957 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
3958 return hdsp_hw_pointer(hdsp);
3961 static char *hdsp_channel_buffer_location(struct hdsp *hdsp,
3962 int stream,
3963 int channel)
3966 int mapped_channel;
3968 if (snd_BUG_ON(channel < 0 || channel >= hdsp->max_channels))
3969 return NULL;
3971 if ((mapped_channel = hdsp->channel_map[channel]) < 0)
3972 return NULL;
3974 if (stream == SNDRV_PCM_STREAM_CAPTURE)
3975 return hdsp->capture_buffer + (mapped_channel * HDSP_CHANNEL_BUFFER_BYTES);
3976 else
3977 return hdsp->playback_buffer + (mapped_channel * HDSP_CHANNEL_BUFFER_BYTES);
3980 static int snd_hdsp_playback_copy(struct snd_pcm_substream *substream, int channel,
3981 snd_pcm_uframes_t pos, void __user *src, snd_pcm_uframes_t count)
3983 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
3984 char *channel_buf;
3986 if (snd_BUG_ON(pos + count > HDSP_CHANNEL_BUFFER_BYTES / 4))
3987 return -EINVAL;
3989 channel_buf = hdsp_channel_buffer_location (hdsp, substream->pstr->stream, channel);
3990 if (snd_BUG_ON(!channel_buf))
3991 return -EIO;
3992 if (copy_from_user(channel_buf + pos * 4, src, count * 4))
3993 return -EFAULT;
3994 return count;
3997 static int snd_hdsp_capture_copy(struct snd_pcm_substream *substream, int channel,
3998 snd_pcm_uframes_t pos, void __user *dst, snd_pcm_uframes_t count)
4000 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4001 char *channel_buf;
4003 if (snd_BUG_ON(pos + count > HDSP_CHANNEL_BUFFER_BYTES / 4))
4004 return -EINVAL;
4006 channel_buf = hdsp_channel_buffer_location (hdsp, substream->pstr->stream, channel);
4007 if (snd_BUG_ON(!channel_buf))
4008 return -EIO;
4009 if (copy_to_user(dst, channel_buf + pos * 4, count * 4))
4010 return -EFAULT;
4011 return count;
4014 static int snd_hdsp_hw_silence(struct snd_pcm_substream *substream, int channel,
4015 snd_pcm_uframes_t pos, snd_pcm_uframes_t count)
4017 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4018 char *channel_buf;
4020 channel_buf = hdsp_channel_buffer_location (hdsp, substream->pstr->stream, channel);
4021 if (snd_BUG_ON(!channel_buf))
4022 return -EIO;
4023 memset(channel_buf + pos * 4, 0, count * 4);
4024 return count;
4027 static int snd_hdsp_reset(struct snd_pcm_substream *substream)
4029 struct snd_pcm_runtime *runtime = substream->runtime;
4030 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4031 struct snd_pcm_substream *other;
4032 if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
4033 other = hdsp->capture_substream;
4034 else
4035 other = hdsp->playback_substream;
4036 if (hdsp->running)
4037 runtime->status->hw_ptr = hdsp_hw_pointer(hdsp);
4038 else
4039 runtime->status->hw_ptr = 0;
4040 if (other) {
4041 struct snd_pcm_substream *s;
4042 struct snd_pcm_runtime *oruntime = other->runtime;
4043 snd_pcm_group_for_each_entry(s, substream) {
4044 if (s == other) {
4045 oruntime->status->hw_ptr = runtime->status->hw_ptr;
4046 break;
4050 return 0;
4053 static int snd_hdsp_hw_params(struct snd_pcm_substream *substream,
4054 struct snd_pcm_hw_params *params)
4056 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4057 int err;
4058 pid_t this_pid;
4059 pid_t other_pid;
4061 if (hdsp_check_for_iobox (hdsp))
4062 return -EIO;
4064 if (hdsp_check_for_firmware(hdsp, 1))
4065 return -EIO;
4067 spin_lock_irq(&hdsp->lock);
4069 if (substream->pstr->stream == SNDRV_PCM_STREAM_PLAYBACK) {
4070 hdsp->control_register &= ~(HDSP_SPDIFProfessional | HDSP_SPDIFNonAudio | HDSP_SPDIFEmphasis);
4071 hdsp_write(hdsp, HDSP_controlRegister, hdsp->control_register |= hdsp->creg_spdif_stream);
4072 this_pid = hdsp->playback_pid;
4073 other_pid = hdsp->capture_pid;
4074 } else {
4075 this_pid = hdsp->capture_pid;
4076 other_pid = hdsp->playback_pid;
4079 if ((other_pid > 0) && (this_pid != other_pid)) {
4081 /* The other stream is open, and not by the same
4082 task as this one. Make sure that the parameters
4083 that matter are the same.
4086 if (params_rate(params) != hdsp->system_sample_rate) {
4087 spin_unlock_irq(&hdsp->lock);
4088 _snd_pcm_hw_param_setempty(params, SNDRV_PCM_HW_PARAM_RATE);
4089 return -EBUSY;
4092 if (params_period_size(params) != hdsp->period_bytes / 4) {
4093 spin_unlock_irq(&hdsp->lock);
4094 _snd_pcm_hw_param_setempty(params, SNDRV_PCM_HW_PARAM_PERIOD_SIZE);
4095 return -EBUSY;
4098 /* We're fine. */
4100 spin_unlock_irq(&hdsp->lock);
4101 return 0;
4103 } else {
4104 spin_unlock_irq(&hdsp->lock);
4107 /* how to make sure that the rate matches an externally-set one ?
4110 spin_lock_irq(&hdsp->lock);
4111 if (! hdsp->clock_source_locked) {
4112 if ((err = hdsp_set_rate(hdsp, params_rate(params), 0)) < 0) {
4113 spin_unlock_irq(&hdsp->lock);
4114 _snd_pcm_hw_param_setempty(params, SNDRV_PCM_HW_PARAM_RATE);
4115 return err;
4118 spin_unlock_irq(&hdsp->lock);
4120 if ((err = hdsp_set_interrupt_interval(hdsp, params_period_size(params))) < 0) {
4121 _snd_pcm_hw_param_setempty(params, SNDRV_PCM_HW_PARAM_PERIOD_SIZE);
4122 return err;
4125 return 0;
4128 static int snd_hdsp_channel_info(struct snd_pcm_substream *substream,
4129 struct snd_pcm_channel_info *info)
4131 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4132 int mapped_channel;
4134 if (snd_BUG_ON(info->channel >= hdsp->max_channels))
4135 return -EINVAL;
4137 if ((mapped_channel = hdsp->channel_map[info->channel]) < 0)
4138 return -EINVAL;
4140 info->offset = mapped_channel * HDSP_CHANNEL_BUFFER_BYTES;
4141 info->first = 0;
4142 info->step = 32;
4143 return 0;
4146 static int snd_hdsp_ioctl(struct snd_pcm_substream *substream,
4147 unsigned int cmd, void *arg)
4149 switch (cmd) {
4150 case SNDRV_PCM_IOCTL1_RESET:
4151 return snd_hdsp_reset(substream);
4152 case SNDRV_PCM_IOCTL1_CHANNEL_INFO:
4153 return snd_hdsp_channel_info(substream, arg);
4154 default:
4155 break;
4158 return snd_pcm_lib_ioctl(substream, cmd, arg);
4161 static int snd_hdsp_trigger(struct snd_pcm_substream *substream, int cmd)
4163 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4164 struct snd_pcm_substream *other;
4165 int running;
4167 if (hdsp_check_for_iobox (hdsp))
4168 return -EIO;
4170 if (hdsp_check_for_firmware(hdsp, 0)) /* no auto-loading in trigger */
4171 return -EIO;
4173 spin_lock(&hdsp->lock);
4174 running = hdsp->running;
4175 switch (cmd) {
4176 case SNDRV_PCM_TRIGGER_START:
4177 running |= 1 << substream->stream;
4178 break;
4179 case SNDRV_PCM_TRIGGER_STOP:
4180 running &= ~(1 << substream->stream);
4181 break;
4182 default:
4183 snd_BUG();
4184 spin_unlock(&hdsp->lock);
4185 return -EINVAL;
4187 if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
4188 other = hdsp->capture_substream;
4189 else
4190 other = hdsp->playback_substream;
4192 if (other) {
4193 struct snd_pcm_substream *s;
4194 snd_pcm_group_for_each_entry(s, substream) {
4195 if (s == other) {
4196 snd_pcm_trigger_done(s, substream);
4197 if (cmd == SNDRV_PCM_TRIGGER_START)
4198 running |= 1 << s->stream;
4199 else
4200 running &= ~(1 << s->stream);
4201 goto _ok;
4204 if (cmd == SNDRV_PCM_TRIGGER_START) {
4205 if (!(running & (1 << SNDRV_PCM_STREAM_PLAYBACK)) &&
4206 substream->stream == SNDRV_PCM_STREAM_CAPTURE)
4207 hdsp_silence_playback(hdsp);
4208 } else {
4209 if (running &&
4210 substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
4211 hdsp_silence_playback(hdsp);
4213 } else {
4214 if (substream->stream == SNDRV_PCM_STREAM_CAPTURE)
4215 hdsp_silence_playback(hdsp);
4217 _ok:
4218 snd_pcm_trigger_done(substream, substream);
4219 if (!hdsp->running && running)
4220 hdsp_start_audio(hdsp);
4221 else if (hdsp->running && !running)
4222 hdsp_stop_audio(hdsp);
4223 hdsp->running = running;
4224 spin_unlock(&hdsp->lock);
4226 return 0;
4229 static int snd_hdsp_prepare(struct snd_pcm_substream *substream)
4231 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4232 int result = 0;
4234 if (hdsp_check_for_iobox (hdsp))
4235 return -EIO;
4237 if (hdsp_check_for_firmware(hdsp, 1))
4238 return -EIO;
4240 spin_lock_irq(&hdsp->lock);
4241 if (!hdsp->running)
4242 hdsp_reset_hw_pointer(hdsp);
4243 spin_unlock_irq(&hdsp->lock);
4244 return result;
4247 static struct snd_pcm_hardware snd_hdsp_playback_subinfo =
4249 .info = (SNDRV_PCM_INFO_MMAP |
4250 SNDRV_PCM_INFO_MMAP_VALID |
4251 SNDRV_PCM_INFO_NONINTERLEAVED |
4252 SNDRV_PCM_INFO_SYNC_START |
4253 SNDRV_PCM_INFO_DOUBLE),
4254 #ifdef SNDRV_BIG_ENDIAN
4255 .formats = SNDRV_PCM_FMTBIT_S32_BE,
4256 #else
4257 .formats = SNDRV_PCM_FMTBIT_S32_LE,
4258 #endif
4259 .rates = (SNDRV_PCM_RATE_32000 |
4260 SNDRV_PCM_RATE_44100 |
4261 SNDRV_PCM_RATE_48000 |
4262 SNDRV_PCM_RATE_64000 |
4263 SNDRV_PCM_RATE_88200 |
4264 SNDRV_PCM_RATE_96000),
4265 .rate_min = 32000,
4266 .rate_max = 96000,
4267 .channels_min = 6,
4268 .channels_max = HDSP_MAX_CHANNELS,
4269 .buffer_bytes_max = HDSP_CHANNEL_BUFFER_BYTES * HDSP_MAX_CHANNELS,
4270 .period_bytes_min = (64 * 4) * 10,
4271 .period_bytes_max = (8192 * 4) * HDSP_MAX_CHANNELS,
4272 .periods_min = 2,
4273 .periods_max = 2,
4274 .fifo_size = 0
4277 static struct snd_pcm_hardware snd_hdsp_capture_subinfo =
4279 .info = (SNDRV_PCM_INFO_MMAP |
4280 SNDRV_PCM_INFO_MMAP_VALID |
4281 SNDRV_PCM_INFO_NONINTERLEAVED |
4282 SNDRV_PCM_INFO_SYNC_START),
4283 #ifdef SNDRV_BIG_ENDIAN
4284 .formats = SNDRV_PCM_FMTBIT_S32_BE,
4285 #else
4286 .formats = SNDRV_PCM_FMTBIT_S32_LE,
4287 #endif
4288 .rates = (SNDRV_PCM_RATE_32000 |
4289 SNDRV_PCM_RATE_44100 |
4290 SNDRV_PCM_RATE_48000 |
4291 SNDRV_PCM_RATE_64000 |
4292 SNDRV_PCM_RATE_88200 |
4293 SNDRV_PCM_RATE_96000),
4294 .rate_min = 32000,
4295 .rate_max = 96000,
4296 .channels_min = 5,
4297 .channels_max = HDSP_MAX_CHANNELS,
4298 .buffer_bytes_max = HDSP_CHANNEL_BUFFER_BYTES * HDSP_MAX_CHANNELS,
4299 .period_bytes_min = (64 * 4) * 10,
4300 .period_bytes_max = (8192 * 4) * HDSP_MAX_CHANNELS,
4301 .periods_min = 2,
4302 .periods_max = 2,
4303 .fifo_size = 0
4306 static unsigned int hdsp_period_sizes[] = { 64, 128, 256, 512, 1024, 2048, 4096, 8192 };
4308 static struct snd_pcm_hw_constraint_list hdsp_hw_constraints_period_sizes = {
4309 .count = ARRAY_SIZE(hdsp_period_sizes),
4310 .list = hdsp_period_sizes,
4311 .mask = 0
4314 static unsigned int hdsp_9632_sample_rates[] = { 32000, 44100, 48000, 64000, 88200, 96000, 128000, 176400, 192000 };
4316 static struct snd_pcm_hw_constraint_list hdsp_hw_constraints_9632_sample_rates = {
4317 .count = ARRAY_SIZE(hdsp_9632_sample_rates),
4318 .list = hdsp_9632_sample_rates,
4319 .mask = 0
4322 static int snd_hdsp_hw_rule_in_channels(struct snd_pcm_hw_params *params,
4323 struct snd_pcm_hw_rule *rule)
4325 struct hdsp *hdsp = rule->private;
4326 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4327 if (hdsp->io_type == H9632) {
4328 unsigned int list[3];
4329 list[0] = hdsp->qs_in_channels;
4330 list[1] = hdsp->ds_in_channels;
4331 list[2] = hdsp->ss_in_channels;
4332 return snd_interval_list(c, 3, list, 0);
4333 } else {
4334 unsigned int list[2];
4335 list[0] = hdsp->ds_in_channels;
4336 list[1] = hdsp->ss_in_channels;
4337 return snd_interval_list(c, 2, list, 0);
4341 static int snd_hdsp_hw_rule_out_channels(struct snd_pcm_hw_params *params,
4342 struct snd_pcm_hw_rule *rule)
4344 unsigned int list[3];
4345 struct hdsp *hdsp = rule->private;
4346 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4347 if (hdsp->io_type == H9632) {
4348 list[0] = hdsp->qs_out_channels;
4349 list[1] = hdsp->ds_out_channels;
4350 list[2] = hdsp->ss_out_channels;
4351 return snd_interval_list(c, 3, list, 0);
4352 } else {
4353 list[0] = hdsp->ds_out_channels;
4354 list[1] = hdsp->ss_out_channels;
4356 return snd_interval_list(c, 2, list, 0);
4359 static int snd_hdsp_hw_rule_in_channels_rate(struct snd_pcm_hw_params *params,
4360 struct snd_pcm_hw_rule *rule)
4362 struct hdsp *hdsp = rule->private;
4363 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4364 struct snd_interval *r = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
4365 if (r->min > 96000 && hdsp->io_type == H9632) {
4366 struct snd_interval t = {
4367 .min = hdsp->qs_in_channels,
4368 .max = hdsp->qs_in_channels,
4369 .integer = 1,
4371 return snd_interval_refine(c, &t);
4372 } else if (r->min > 48000 && r->max <= 96000) {
4373 struct snd_interval t = {
4374 .min = hdsp->ds_in_channels,
4375 .max = hdsp->ds_in_channels,
4376 .integer = 1,
4378 return snd_interval_refine(c, &t);
4379 } else if (r->max < 64000) {
4380 struct snd_interval t = {
4381 .min = hdsp->ss_in_channels,
4382 .max = hdsp->ss_in_channels,
4383 .integer = 1,
4385 return snd_interval_refine(c, &t);
4387 return 0;
4390 static int snd_hdsp_hw_rule_out_channels_rate(struct snd_pcm_hw_params *params,
4391 struct snd_pcm_hw_rule *rule)
4393 struct hdsp *hdsp = rule->private;
4394 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4395 struct snd_interval *r = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
4396 if (r->min > 96000 && hdsp->io_type == H9632) {
4397 struct snd_interval t = {
4398 .min = hdsp->qs_out_channels,
4399 .max = hdsp->qs_out_channels,
4400 .integer = 1,
4402 return snd_interval_refine(c, &t);
4403 } else if (r->min > 48000 && r->max <= 96000) {
4404 struct snd_interval t = {
4405 .min = hdsp->ds_out_channels,
4406 .max = hdsp->ds_out_channels,
4407 .integer = 1,
4409 return snd_interval_refine(c, &t);
4410 } else if (r->max < 64000) {
4411 struct snd_interval t = {
4412 .min = hdsp->ss_out_channels,
4413 .max = hdsp->ss_out_channels,
4414 .integer = 1,
4416 return snd_interval_refine(c, &t);
4418 return 0;
4421 static int snd_hdsp_hw_rule_rate_out_channels(struct snd_pcm_hw_params *params,
4422 struct snd_pcm_hw_rule *rule)
4424 struct hdsp *hdsp = rule->private;
4425 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4426 struct snd_interval *r = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
4427 if (c->min >= hdsp->ss_out_channels) {
4428 struct snd_interval t = {
4429 .min = 32000,
4430 .max = 48000,
4431 .integer = 1,
4433 return snd_interval_refine(r, &t);
4434 } else if (c->max <= hdsp->qs_out_channels && hdsp->io_type == H9632) {
4435 struct snd_interval t = {
4436 .min = 128000,
4437 .max = 192000,
4438 .integer = 1,
4440 return snd_interval_refine(r, &t);
4441 } else if (c->max <= hdsp->ds_out_channels) {
4442 struct snd_interval t = {
4443 .min = 64000,
4444 .max = 96000,
4445 .integer = 1,
4447 return snd_interval_refine(r, &t);
4449 return 0;
4452 static int snd_hdsp_hw_rule_rate_in_channels(struct snd_pcm_hw_params *params,
4453 struct snd_pcm_hw_rule *rule)
4455 struct hdsp *hdsp = rule->private;
4456 struct snd_interval *c = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS);
4457 struct snd_interval *r = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE);
4458 if (c->min >= hdsp->ss_in_channels) {
4459 struct snd_interval t = {
4460 .min = 32000,
4461 .max = 48000,
4462 .integer = 1,
4464 return snd_interval_refine(r, &t);
4465 } else if (c->max <= hdsp->qs_in_channels && hdsp->io_type == H9632) {
4466 struct snd_interval t = {
4467 .min = 128000,
4468 .max = 192000,
4469 .integer = 1,
4471 return snd_interval_refine(r, &t);
4472 } else if (c->max <= hdsp->ds_in_channels) {
4473 struct snd_interval t = {
4474 .min = 64000,
4475 .max = 96000,
4476 .integer = 1,
4478 return snd_interval_refine(r, &t);
4480 return 0;
4483 static int snd_hdsp_playback_open(struct snd_pcm_substream *substream)
4485 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4486 struct snd_pcm_runtime *runtime = substream->runtime;
4488 if (hdsp_check_for_iobox (hdsp))
4489 return -EIO;
4491 if (hdsp_check_for_firmware(hdsp, 1))
4492 return -EIO;
4494 spin_lock_irq(&hdsp->lock);
4496 snd_pcm_set_sync(substream);
4498 runtime->hw = snd_hdsp_playback_subinfo;
4499 runtime->dma_area = hdsp->playback_buffer;
4500 runtime->dma_bytes = HDSP_DMA_AREA_BYTES;
4502 hdsp->playback_pid = current->pid;
4503 hdsp->playback_substream = substream;
4505 spin_unlock_irq(&hdsp->lock);
4507 snd_pcm_hw_constraint_msbits(runtime, 0, 32, 24);
4508 snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_SIZE, &hdsp_hw_constraints_period_sizes);
4509 if (hdsp->clock_source_locked) {
4510 runtime->hw.rate_min = runtime->hw.rate_max = hdsp->system_sample_rate;
4511 } else if (hdsp->io_type == H9632) {
4512 runtime->hw.rate_max = 192000;
4513 runtime->hw.rates = SNDRV_PCM_RATE_KNOT;
4514 snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_RATE, &hdsp_hw_constraints_9632_sample_rates);
4516 if (hdsp->io_type == H9632) {
4517 runtime->hw.channels_min = hdsp->qs_out_channels;
4518 runtime->hw.channels_max = hdsp->ss_out_channels;
4521 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
4522 snd_hdsp_hw_rule_out_channels, hdsp,
4523 SNDRV_PCM_HW_PARAM_CHANNELS, -1);
4524 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
4525 snd_hdsp_hw_rule_out_channels_rate, hdsp,
4526 SNDRV_PCM_HW_PARAM_RATE, -1);
4527 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_RATE,
4528 snd_hdsp_hw_rule_rate_out_channels, hdsp,
4529 SNDRV_PCM_HW_PARAM_CHANNELS, -1);
4531 if (RPM != hdsp->io_type) {
4532 hdsp->creg_spdif_stream = hdsp->creg_spdif;
4533 hdsp->spdif_ctl->vd[0].access &= ~SNDRV_CTL_ELEM_ACCESS_INACTIVE;
4534 snd_ctl_notify(hdsp->card, SNDRV_CTL_EVENT_MASK_VALUE |
4535 SNDRV_CTL_EVENT_MASK_INFO, &hdsp->spdif_ctl->id);
4537 return 0;
4540 static int snd_hdsp_playback_release(struct snd_pcm_substream *substream)
4542 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4544 spin_lock_irq(&hdsp->lock);
4546 hdsp->playback_pid = -1;
4547 hdsp->playback_substream = NULL;
4549 spin_unlock_irq(&hdsp->lock);
4551 if (RPM != hdsp->io_type) {
4552 hdsp->spdif_ctl->vd[0].access |= SNDRV_CTL_ELEM_ACCESS_INACTIVE;
4553 snd_ctl_notify(hdsp->card, SNDRV_CTL_EVENT_MASK_VALUE |
4554 SNDRV_CTL_EVENT_MASK_INFO, &hdsp->spdif_ctl->id);
4556 return 0;
4560 static int snd_hdsp_capture_open(struct snd_pcm_substream *substream)
4562 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4563 struct snd_pcm_runtime *runtime = substream->runtime;
4565 if (hdsp_check_for_iobox (hdsp))
4566 return -EIO;
4568 if (hdsp_check_for_firmware(hdsp, 1))
4569 return -EIO;
4571 spin_lock_irq(&hdsp->lock);
4573 snd_pcm_set_sync(substream);
4575 runtime->hw = snd_hdsp_capture_subinfo;
4576 runtime->dma_area = hdsp->capture_buffer;
4577 runtime->dma_bytes = HDSP_DMA_AREA_BYTES;
4579 hdsp->capture_pid = current->pid;
4580 hdsp->capture_substream = substream;
4582 spin_unlock_irq(&hdsp->lock);
4584 snd_pcm_hw_constraint_msbits(runtime, 0, 32, 24);
4585 snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_SIZE, &hdsp_hw_constraints_period_sizes);
4586 if (hdsp->io_type == H9632) {
4587 runtime->hw.channels_min = hdsp->qs_in_channels;
4588 runtime->hw.channels_max = hdsp->ss_in_channels;
4589 runtime->hw.rate_max = 192000;
4590 runtime->hw.rates = SNDRV_PCM_RATE_KNOT;
4591 snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_RATE, &hdsp_hw_constraints_9632_sample_rates);
4593 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
4594 snd_hdsp_hw_rule_in_channels, hdsp,
4595 SNDRV_PCM_HW_PARAM_CHANNELS, -1);
4596 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
4597 snd_hdsp_hw_rule_in_channels_rate, hdsp,
4598 SNDRV_PCM_HW_PARAM_RATE, -1);
4599 snd_pcm_hw_rule_add(runtime, 0, SNDRV_PCM_HW_PARAM_RATE,
4600 snd_hdsp_hw_rule_rate_in_channels, hdsp,
4601 SNDRV_PCM_HW_PARAM_CHANNELS, -1);
4602 return 0;
4605 static int snd_hdsp_capture_release(struct snd_pcm_substream *substream)
4607 struct hdsp *hdsp = snd_pcm_substream_chip(substream);
4609 spin_lock_irq(&hdsp->lock);
4611 hdsp->capture_pid = -1;
4612 hdsp->capture_substream = NULL;
4614 spin_unlock_irq(&hdsp->lock);
4615 return 0;
4618 /* helper functions for copying meter values */
4619 static inline int copy_u32_le(void __user *dest, void __iomem *src)
4621 u32 val = readl(src);
4622 return copy_to_user(dest, &val, 4);
4625 static inline int copy_u64_le(void __user *dest, void __iomem *src_low, void __iomem *src_high)
4627 u32 rms_low, rms_high;
4628 u64 rms;
4629 rms_low = readl(src_low);
4630 rms_high = readl(src_high);
4631 rms = ((u64)rms_high << 32) | rms_low;
4632 return copy_to_user(dest, &rms, 8);
4635 static inline int copy_u48_le(void __user *dest, void __iomem *src_low, void __iomem *src_high)
4637 u32 rms_low, rms_high;
4638 u64 rms;
4639 rms_low = readl(src_low) & 0xffffff00;
4640 rms_high = readl(src_high) & 0xffffff00;
4641 rms = ((u64)rms_high << 32) | rms_low;
4642 return copy_to_user(dest, &rms, 8);
4645 static int hdsp_9652_get_peak(struct hdsp *hdsp, struct hdsp_peak_rms __user *peak_rms)
4647 int doublespeed = 0;
4648 int i, j, channels, ofs;
4650 if (hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DoubleSpeedStatus)
4651 doublespeed = 1;
4652 channels = doublespeed ? 14 : 26;
4653 for (i = 0, j = 0; i < 26; ++i) {
4654 if (doublespeed && (i & 4))
4655 continue;
4656 ofs = HDSP_9652_peakBase - j * 4;
4657 if (copy_u32_le(&peak_rms->input_peaks[i], hdsp->iobase + ofs))
4658 return -EFAULT;
4659 ofs -= channels * 4;
4660 if (copy_u32_le(&peak_rms->playback_peaks[i], hdsp->iobase + ofs))
4661 return -EFAULT;
4662 ofs -= channels * 4;
4663 if (copy_u32_le(&peak_rms->output_peaks[i], hdsp->iobase + ofs))
4664 return -EFAULT;
4665 ofs = HDSP_9652_rmsBase + j * 8;
4666 if (copy_u48_le(&peak_rms->input_rms[i], hdsp->iobase + ofs,
4667 hdsp->iobase + ofs + 4))
4668 return -EFAULT;
4669 ofs += channels * 8;
4670 if (copy_u48_le(&peak_rms->playback_rms[i], hdsp->iobase + ofs,
4671 hdsp->iobase + ofs + 4))
4672 return -EFAULT;
4673 ofs += channels * 8;
4674 if (copy_u48_le(&peak_rms->output_rms[i], hdsp->iobase + ofs,
4675 hdsp->iobase + ofs + 4))
4676 return -EFAULT;
4677 j++;
4679 return 0;
4682 static int hdsp_9632_get_peak(struct hdsp *hdsp, struct hdsp_peak_rms __user *peak_rms)
4684 int i, j;
4685 struct hdsp_9632_meters __iomem *m;
4686 int doublespeed = 0;
4688 if (hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DoubleSpeedStatus)
4689 doublespeed = 1;
4690 m = (struct hdsp_9632_meters __iomem *)(hdsp->iobase+HDSP_9632_metersBase);
4691 for (i = 0, j = 0; i < 16; ++i, ++j) {
4692 if (copy_u32_le(&peak_rms->input_peaks[i], &m->input_peak[j]))
4693 return -EFAULT;
4694 if (copy_u32_le(&peak_rms->playback_peaks[i], &m->playback_peak[j]))
4695 return -EFAULT;
4696 if (copy_u32_le(&peak_rms->output_peaks[i], &m->output_peak[j]))
4697 return -EFAULT;
4698 if (copy_u64_le(&peak_rms->input_rms[i], &m->input_rms_low[j],
4699 &m->input_rms_high[j]))
4700 return -EFAULT;
4701 if (copy_u64_le(&peak_rms->playback_rms[i], &m->playback_rms_low[j],
4702 &m->playback_rms_high[j]))
4703 return -EFAULT;
4704 if (copy_u64_le(&peak_rms->output_rms[i], &m->output_rms_low[j],
4705 &m->output_rms_high[j]))
4706 return -EFAULT;
4707 if (doublespeed && i == 3) i += 4;
4709 return 0;
4712 static int hdsp_get_peak(struct hdsp *hdsp, struct hdsp_peak_rms __user *peak_rms)
4714 int i;
4716 for (i = 0; i < 26; i++) {
4717 if (copy_u32_le(&peak_rms->playback_peaks[i],
4718 hdsp->iobase + HDSP_playbackPeakLevel + i * 4))
4719 return -EFAULT;
4720 if (copy_u32_le(&peak_rms->input_peaks[i],
4721 hdsp->iobase + HDSP_inputPeakLevel + i * 4))
4722 return -EFAULT;
4724 for (i = 0; i < 28; i++) {
4725 if (copy_u32_le(&peak_rms->output_peaks[i],
4726 hdsp->iobase + HDSP_outputPeakLevel + i * 4))
4727 return -EFAULT;
4729 for (i = 0; i < 26; ++i) {
4730 if (copy_u64_le(&peak_rms->playback_rms[i],
4731 hdsp->iobase + HDSP_playbackRmsLevel + i * 8 + 4,
4732 hdsp->iobase + HDSP_playbackRmsLevel + i * 8))
4733 return -EFAULT;
4734 if (copy_u64_le(&peak_rms->input_rms[i],
4735 hdsp->iobase + HDSP_inputRmsLevel + i * 8 + 4,
4736 hdsp->iobase + HDSP_inputRmsLevel + i * 8))
4737 return -EFAULT;
4739 return 0;
4742 static int snd_hdsp_hwdep_ioctl(struct snd_hwdep *hw, struct file *file, unsigned int cmd, unsigned long arg)
4744 struct hdsp *hdsp = hw->private_data;
4745 void __user *argp = (void __user *)arg;
4746 int err;
4748 switch (cmd) {
4749 case SNDRV_HDSP_IOCTL_GET_PEAK_RMS: {
4750 struct hdsp_peak_rms __user *peak_rms = (struct hdsp_peak_rms __user *)arg;
4752 err = hdsp_check_for_iobox(hdsp);
4753 if (err < 0)
4754 return err;
4756 err = hdsp_check_for_firmware(hdsp, 1);
4757 if (err < 0)
4758 return err;
4760 if (!(hdsp->state & HDSP_FirmwareLoaded)) {
4761 dev_err(hdsp->card->dev,
4762 "firmware needs to be uploaded to the card.\n");
4763 return -EINVAL;
4766 switch (hdsp->io_type) {
4767 case H9652:
4768 return hdsp_9652_get_peak(hdsp, peak_rms);
4769 case H9632:
4770 return hdsp_9632_get_peak(hdsp, peak_rms);
4771 default:
4772 return hdsp_get_peak(hdsp, peak_rms);
4775 case SNDRV_HDSP_IOCTL_GET_CONFIG_INFO: {
4776 struct hdsp_config_info info;
4777 unsigned long flags;
4778 int i;
4780 err = hdsp_check_for_iobox(hdsp);
4781 if (err < 0)
4782 return err;
4784 err = hdsp_check_for_firmware(hdsp, 1);
4785 if (err < 0)
4786 return err;
4788 memset(&info, 0, sizeof(info));
4789 spin_lock_irqsave(&hdsp->lock, flags);
4790 info.pref_sync_ref = (unsigned char)hdsp_pref_sync_ref(hdsp);
4791 info.wordclock_sync_check = (unsigned char)hdsp_wc_sync_check(hdsp);
4792 if (hdsp->io_type != H9632)
4793 info.adatsync_sync_check = (unsigned char)hdsp_adatsync_sync_check(hdsp);
4794 info.spdif_sync_check = (unsigned char)hdsp_spdif_sync_check(hdsp);
4795 for (i = 0; i < ((hdsp->io_type != Multiface && hdsp->io_type != RPM && hdsp->io_type != H9632) ? 3 : 1); ++i)
4796 info.adat_sync_check[i] = (unsigned char)hdsp_adat_sync_check(hdsp, i);
4797 info.spdif_in = (unsigned char)hdsp_spdif_in(hdsp);
4798 info.spdif_out = (unsigned char)hdsp_toggle_setting(hdsp,
4799 HDSP_SPDIFOpticalOut);
4800 info.spdif_professional = (unsigned char)
4801 hdsp_toggle_setting(hdsp, HDSP_SPDIFProfessional);
4802 info.spdif_emphasis = (unsigned char)
4803 hdsp_toggle_setting(hdsp, HDSP_SPDIFEmphasis);
4804 info.spdif_nonaudio = (unsigned char)
4805 hdsp_toggle_setting(hdsp, HDSP_SPDIFNonAudio);
4806 info.spdif_sample_rate = hdsp_spdif_sample_rate(hdsp);
4807 info.system_sample_rate = hdsp->system_sample_rate;
4808 info.autosync_sample_rate = hdsp_external_sample_rate(hdsp);
4809 info.system_clock_mode = (unsigned char)hdsp_system_clock_mode(hdsp);
4810 info.clock_source = (unsigned char)hdsp_clock_source(hdsp);
4811 info.autosync_ref = (unsigned char)hdsp_autosync_ref(hdsp);
4812 info.line_out = (unsigned char)
4813 hdsp_toggle_setting(hdsp, HDSP_LineOut);
4814 if (hdsp->io_type == H9632) {
4815 info.da_gain = (unsigned char)hdsp_da_gain(hdsp);
4816 info.ad_gain = (unsigned char)hdsp_ad_gain(hdsp);
4817 info.phone_gain = (unsigned char)hdsp_phone_gain(hdsp);
4818 info.xlr_breakout_cable =
4819 (unsigned char)hdsp_toggle_setting(hdsp,
4820 HDSP_XLRBreakoutCable);
4822 } else if (hdsp->io_type == RPM) {
4823 info.da_gain = (unsigned char) hdsp_rpm_input12(hdsp);
4824 info.ad_gain = (unsigned char) hdsp_rpm_input34(hdsp);
4826 if (hdsp->io_type == H9632 || hdsp->io_type == H9652)
4827 info.analog_extension_board =
4828 (unsigned char)hdsp_toggle_setting(hdsp,
4829 HDSP_AnalogExtensionBoard);
4830 spin_unlock_irqrestore(&hdsp->lock, flags);
4831 if (copy_to_user(argp, &info, sizeof(info)))
4832 return -EFAULT;
4833 break;
4835 case SNDRV_HDSP_IOCTL_GET_9632_AEB: {
4836 struct hdsp_9632_aeb h9632_aeb;
4838 if (hdsp->io_type != H9632) return -EINVAL;
4839 h9632_aeb.aebi = hdsp->ss_in_channels - H9632_SS_CHANNELS;
4840 h9632_aeb.aebo = hdsp->ss_out_channels - H9632_SS_CHANNELS;
4841 if (copy_to_user(argp, &h9632_aeb, sizeof(h9632_aeb)))
4842 return -EFAULT;
4843 break;
4845 case SNDRV_HDSP_IOCTL_GET_VERSION: {
4846 struct hdsp_version hdsp_version;
4847 int err;
4849 if (hdsp->io_type == H9652 || hdsp->io_type == H9632) return -EINVAL;
4850 if (hdsp->io_type == Undefined) {
4851 if ((err = hdsp_get_iobox_version(hdsp)) < 0)
4852 return err;
4854 memset(&hdsp_version, 0, sizeof(hdsp_version));
4855 hdsp_version.io_type = hdsp->io_type;
4856 hdsp_version.firmware_rev = hdsp->firmware_rev;
4857 if ((err = copy_to_user(argp, &hdsp_version, sizeof(hdsp_version))))
4858 return -EFAULT;
4859 break;
4861 case SNDRV_HDSP_IOCTL_UPLOAD_FIRMWARE: {
4862 struct hdsp_firmware __user *firmware;
4863 u32 __user *firmware_data;
4864 int err;
4866 if (hdsp->io_type == H9652 || hdsp->io_type == H9632) return -EINVAL;
4867 /* SNDRV_HDSP_IOCTL_GET_VERSION must have been called */
4868 if (hdsp->io_type == Undefined) return -EINVAL;
4870 if (hdsp->state & (HDSP_FirmwareCached | HDSP_FirmwareLoaded))
4871 return -EBUSY;
4873 dev_info(hdsp->card->dev,
4874 "initializing firmware upload\n");
4875 firmware = (struct hdsp_firmware __user *)argp;
4877 if (get_user(firmware_data, &firmware->firmware_data))
4878 return -EFAULT;
4880 if (hdsp_check_for_iobox (hdsp))
4881 return -EIO;
4883 if (!hdsp->fw_uploaded) {
4884 hdsp->fw_uploaded = vmalloc(HDSP_FIRMWARE_SIZE);
4885 if (!hdsp->fw_uploaded)
4886 return -ENOMEM;
4889 if (copy_from_user(hdsp->fw_uploaded, firmware_data,
4890 HDSP_FIRMWARE_SIZE)) {
4891 vfree(hdsp->fw_uploaded);
4892 hdsp->fw_uploaded = NULL;
4893 return -EFAULT;
4896 hdsp->state |= HDSP_FirmwareCached;
4898 if ((err = snd_hdsp_load_firmware_from_cache(hdsp)) < 0)
4899 return err;
4901 if (!(hdsp->state & HDSP_InitializationComplete)) {
4902 if ((err = snd_hdsp_enable_io(hdsp)) < 0)
4903 return err;
4905 snd_hdsp_initialize_channels(hdsp);
4906 snd_hdsp_initialize_midi_flush(hdsp);
4908 if ((err = snd_hdsp_create_alsa_devices(hdsp->card, hdsp)) < 0) {
4909 dev_err(hdsp->card->dev,
4910 "error creating alsa devices\n");
4911 return err;
4914 break;
4916 case SNDRV_HDSP_IOCTL_GET_MIXER: {
4917 struct hdsp_mixer __user *mixer = (struct hdsp_mixer __user *)argp;
4918 if (copy_to_user(mixer->matrix, hdsp->mixer_matrix, sizeof(unsigned short)*HDSP_MATRIX_MIXER_SIZE))
4919 return -EFAULT;
4920 break;
4922 default:
4923 return -EINVAL;
4925 return 0;
4928 static struct snd_pcm_ops snd_hdsp_playback_ops = {
4929 .open = snd_hdsp_playback_open,
4930 .close = snd_hdsp_playback_release,
4931 .ioctl = snd_hdsp_ioctl,
4932 .hw_params = snd_hdsp_hw_params,
4933 .prepare = snd_hdsp_prepare,
4934 .trigger = snd_hdsp_trigger,
4935 .pointer = snd_hdsp_hw_pointer,
4936 .copy = snd_hdsp_playback_copy,
4937 .silence = snd_hdsp_hw_silence,
4940 static struct snd_pcm_ops snd_hdsp_capture_ops = {
4941 .open = snd_hdsp_capture_open,
4942 .close = snd_hdsp_capture_release,
4943 .ioctl = snd_hdsp_ioctl,
4944 .hw_params = snd_hdsp_hw_params,
4945 .prepare = snd_hdsp_prepare,
4946 .trigger = snd_hdsp_trigger,
4947 .pointer = snd_hdsp_hw_pointer,
4948 .copy = snd_hdsp_capture_copy,
4951 static int snd_hdsp_create_hwdep(struct snd_card *card, struct hdsp *hdsp)
4953 struct snd_hwdep *hw;
4954 int err;
4956 if ((err = snd_hwdep_new(card, "HDSP hwdep", 0, &hw)) < 0)
4957 return err;
4959 hdsp->hwdep = hw;
4960 hw->private_data = hdsp;
4961 strcpy(hw->name, "HDSP hwdep interface");
4963 hw->ops.ioctl = snd_hdsp_hwdep_ioctl;
4964 hw->ops.ioctl_compat = snd_hdsp_hwdep_ioctl;
4966 return 0;
4969 static int snd_hdsp_create_pcm(struct snd_card *card, struct hdsp *hdsp)
4971 struct snd_pcm *pcm;
4972 int err;
4974 if ((err = snd_pcm_new(card, hdsp->card_name, 0, 1, 1, &pcm)) < 0)
4975 return err;
4977 hdsp->pcm = pcm;
4978 pcm->private_data = hdsp;
4979 strcpy(pcm->name, hdsp->card_name);
4981 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_hdsp_playback_ops);
4982 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_hdsp_capture_ops);
4984 pcm->info_flags = SNDRV_PCM_INFO_JOINT_DUPLEX;
4986 return 0;
4989 static void snd_hdsp_9652_enable_mixer (struct hdsp *hdsp)
4991 hdsp->control2_register |= HDSP_9652_ENABLE_MIXER;
4992 hdsp_write (hdsp, HDSP_control2Reg, hdsp->control2_register);
4995 static int snd_hdsp_enable_io (struct hdsp *hdsp)
4997 int i;
4999 if (hdsp_fifo_wait (hdsp, 0, 100)) {
5000 dev_err(hdsp->card->dev,
5001 "enable_io fifo_wait failed\n");
5002 return -EIO;
5005 for (i = 0; i < hdsp->max_channels; ++i) {
5006 hdsp_write (hdsp, HDSP_inputEnable + (4 * i), 1);
5007 hdsp_write (hdsp, HDSP_outputEnable + (4 * i), 1);
5010 return 0;
5013 static void snd_hdsp_initialize_channels(struct hdsp *hdsp)
5015 int status, aebi_channels, aebo_channels;
5017 switch (hdsp->io_type) {
5018 case Digiface:
5019 hdsp->card_name = "RME Hammerfall DSP + Digiface";
5020 hdsp->ss_in_channels = hdsp->ss_out_channels = DIGIFACE_SS_CHANNELS;
5021 hdsp->ds_in_channels = hdsp->ds_out_channels = DIGIFACE_DS_CHANNELS;
5022 break;
5024 case H9652:
5025 hdsp->card_name = "RME Hammerfall HDSP 9652";
5026 hdsp->ss_in_channels = hdsp->ss_out_channels = H9652_SS_CHANNELS;
5027 hdsp->ds_in_channels = hdsp->ds_out_channels = H9652_DS_CHANNELS;
5028 break;
5030 case H9632:
5031 status = hdsp_read(hdsp, HDSP_statusRegister);
5032 /* HDSP_AEBx bits are low when AEB are connected */
5033 aebi_channels = (status & HDSP_AEBI) ? 0 : 4;
5034 aebo_channels = (status & HDSP_AEBO) ? 0 : 4;
5035 hdsp->card_name = "RME Hammerfall HDSP 9632";
5036 hdsp->ss_in_channels = H9632_SS_CHANNELS+aebi_channels;
5037 hdsp->ds_in_channels = H9632_DS_CHANNELS+aebi_channels;
5038 hdsp->qs_in_channels = H9632_QS_CHANNELS+aebi_channels;
5039 hdsp->ss_out_channels = H9632_SS_CHANNELS+aebo_channels;
5040 hdsp->ds_out_channels = H9632_DS_CHANNELS+aebo_channels;
5041 hdsp->qs_out_channels = H9632_QS_CHANNELS+aebo_channels;
5042 break;
5044 case Multiface:
5045 hdsp->card_name = "RME Hammerfall DSP + Multiface";
5046 hdsp->ss_in_channels = hdsp->ss_out_channels = MULTIFACE_SS_CHANNELS;
5047 hdsp->ds_in_channels = hdsp->ds_out_channels = MULTIFACE_DS_CHANNELS;
5048 break;
5050 case RPM:
5051 hdsp->card_name = "RME Hammerfall DSP + RPM";
5052 hdsp->ss_in_channels = RPM_CHANNELS-1;
5053 hdsp->ss_out_channels = RPM_CHANNELS;
5054 hdsp->ds_in_channels = RPM_CHANNELS-1;
5055 hdsp->ds_out_channels = RPM_CHANNELS;
5056 break;
5058 default:
5059 /* should never get here */
5060 break;
5064 static void snd_hdsp_initialize_midi_flush (struct hdsp *hdsp)
5066 snd_hdsp_flush_midi_input (hdsp, 0);
5067 snd_hdsp_flush_midi_input (hdsp, 1);
5070 static int snd_hdsp_create_alsa_devices(struct snd_card *card, struct hdsp *hdsp)
5072 int err;
5074 if ((err = snd_hdsp_create_pcm(card, hdsp)) < 0) {
5075 dev_err(card->dev,
5076 "Error creating pcm interface\n");
5077 return err;
5081 if ((err = snd_hdsp_create_midi(card, hdsp, 0)) < 0) {
5082 dev_err(card->dev,
5083 "Error creating first midi interface\n");
5084 return err;
5087 if (hdsp->io_type == Digiface || hdsp->io_type == H9652) {
5088 if ((err = snd_hdsp_create_midi(card, hdsp, 1)) < 0) {
5089 dev_err(card->dev,
5090 "Error creating second midi interface\n");
5091 return err;
5095 if ((err = snd_hdsp_create_controls(card, hdsp)) < 0) {
5096 dev_err(card->dev,
5097 "Error creating ctl interface\n");
5098 return err;
5101 snd_hdsp_proc_init(hdsp);
5103 hdsp->system_sample_rate = -1;
5104 hdsp->playback_pid = -1;
5105 hdsp->capture_pid = -1;
5106 hdsp->capture_substream = NULL;
5107 hdsp->playback_substream = NULL;
5109 if ((err = snd_hdsp_set_defaults(hdsp)) < 0) {
5110 dev_err(card->dev,
5111 "Error setting default values\n");
5112 return err;
5115 if (!(hdsp->state & HDSP_InitializationComplete)) {
5116 strcpy(card->shortname, "Hammerfall DSP");
5117 sprintf(card->longname, "%s at 0x%lx, irq %d", hdsp->card_name,
5118 hdsp->port, hdsp->irq);
5120 if ((err = snd_card_register(card)) < 0) {
5121 dev_err(card->dev,
5122 "error registering card\n");
5123 return err;
5125 hdsp->state |= HDSP_InitializationComplete;
5128 return 0;
5131 /* load firmware via hotplug fw loader */
5132 static int hdsp_request_fw_loader(struct hdsp *hdsp)
5134 const char *fwfile;
5135 const struct firmware *fw;
5136 int err;
5138 if (hdsp->io_type == H9652 || hdsp->io_type == H9632)
5139 return 0;
5140 if (hdsp->io_type == Undefined) {
5141 if ((err = hdsp_get_iobox_version(hdsp)) < 0)
5142 return err;
5143 if (hdsp->io_type == H9652 || hdsp->io_type == H9632)
5144 return 0;
5147 /* caution: max length of firmware filename is 30! */
5148 switch (hdsp->io_type) {
5149 case RPM:
5150 fwfile = "rpm_firmware.bin";
5151 break;
5152 case Multiface:
5153 if (hdsp->firmware_rev == 0xa)
5154 fwfile = "multiface_firmware.bin";
5155 else
5156 fwfile = "multiface_firmware_rev11.bin";
5157 break;
5158 case Digiface:
5159 if (hdsp->firmware_rev == 0xa)
5160 fwfile = "digiface_firmware.bin";
5161 else
5162 fwfile = "digiface_firmware_rev11.bin";
5163 break;
5164 default:
5165 dev_err(hdsp->card->dev,
5166 "invalid io_type %d\n", hdsp->io_type);
5167 return -EINVAL;
5170 if (request_firmware(&fw, fwfile, &hdsp->pci->dev)) {
5171 dev_err(hdsp->card->dev,
5172 "cannot load firmware %s\n", fwfile);
5173 return -ENOENT;
5175 if (fw->size < HDSP_FIRMWARE_SIZE) {
5176 dev_err(hdsp->card->dev,
5177 "too short firmware size %d (expected %d)\n",
5178 (int)fw->size, HDSP_FIRMWARE_SIZE);
5179 return -EINVAL;
5182 hdsp->firmware = fw;
5184 hdsp->state |= HDSP_FirmwareCached;
5186 if ((err = snd_hdsp_load_firmware_from_cache(hdsp)) < 0)
5187 return err;
5189 if (!(hdsp->state & HDSP_InitializationComplete)) {
5190 if ((err = snd_hdsp_enable_io(hdsp)) < 0)
5191 return err;
5193 if ((err = snd_hdsp_create_hwdep(hdsp->card, hdsp)) < 0) {
5194 dev_err(hdsp->card->dev,
5195 "error creating hwdep device\n");
5196 return err;
5198 snd_hdsp_initialize_channels(hdsp);
5199 snd_hdsp_initialize_midi_flush(hdsp);
5200 if ((err = snd_hdsp_create_alsa_devices(hdsp->card, hdsp)) < 0) {
5201 dev_err(hdsp->card->dev,
5202 "error creating alsa devices\n");
5203 return err;
5206 return 0;
5209 static int snd_hdsp_create(struct snd_card *card,
5210 struct hdsp *hdsp)
5212 struct pci_dev *pci = hdsp->pci;
5213 int err;
5214 int is_9652 = 0;
5215 int is_9632 = 0;
5217 hdsp->irq = -1;
5218 hdsp->state = 0;
5219 hdsp->midi[0].rmidi = NULL;
5220 hdsp->midi[1].rmidi = NULL;
5221 hdsp->midi[0].input = NULL;
5222 hdsp->midi[1].input = NULL;
5223 hdsp->midi[0].output = NULL;
5224 hdsp->midi[1].output = NULL;
5225 hdsp->midi[0].pending = 0;
5226 hdsp->midi[1].pending = 0;
5227 spin_lock_init(&hdsp->midi[0].lock);
5228 spin_lock_init(&hdsp->midi[1].lock);
5229 hdsp->iobase = NULL;
5230 hdsp->control_register = 0;
5231 hdsp->control2_register = 0;
5232 hdsp->io_type = Undefined;
5233 hdsp->max_channels = 26;
5235 hdsp->card = card;
5237 spin_lock_init(&hdsp->lock);
5239 tasklet_init(&hdsp->midi_tasklet, hdsp_midi_tasklet, (unsigned long)hdsp);
5241 pci_read_config_word(hdsp->pci, PCI_CLASS_REVISION, &hdsp->firmware_rev);
5242 hdsp->firmware_rev &= 0xff;
5244 /* From Martin Bjoernsen :
5245 "It is important that the card's latency timer register in
5246 the PCI configuration space is set to a value much larger
5247 than 0 by the computer's BIOS or the driver.
5248 The windows driver always sets this 8 bit register [...]
5249 to its maximum 255 to avoid problems with some computers."
5251 pci_write_config_byte(hdsp->pci, PCI_LATENCY_TIMER, 0xFF);
5253 strcpy(card->driver, "H-DSP");
5254 strcpy(card->mixername, "Xilinx FPGA");
5256 if (hdsp->firmware_rev < 0xa)
5257 return -ENODEV;
5258 else if (hdsp->firmware_rev < 0x64)
5259 hdsp->card_name = "RME Hammerfall DSP";
5260 else if (hdsp->firmware_rev < 0x96) {
5261 hdsp->card_name = "RME HDSP 9652";
5262 is_9652 = 1;
5263 } else {
5264 hdsp->card_name = "RME HDSP 9632";
5265 hdsp->max_channels = 16;
5266 is_9632 = 1;
5269 if ((err = pci_enable_device(pci)) < 0)
5270 return err;
5272 pci_set_master(hdsp->pci);
5274 if ((err = pci_request_regions(pci, "hdsp")) < 0)
5275 return err;
5276 hdsp->port = pci_resource_start(pci, 0);
5277 if ((hdsp->iobase = ioremap_nocache(hdsp->port, HDSP_IO_EXTENT)) == NULL) {
5278 dev_err(hdsp->card->dev, "unable to remap region 0x%lx-0x%lx\n",
5279 hdsp->port, hdsp->port + HDSP_IO_EXTENT - 1);
5280 return -EBUSY;
5283 if (request_irq(pci->irq, snd_hdsp_interrupt, IRQF_SHARED,
5284 KBUILD_MODNAME, hdsp)) {
5285 dev_err(hdsp->card->dev, "unable to use IRQ %d\n", pci->irq);
5286 return -EBUSY;
5289 hdsp->irq = pci->irq;
5290 hdsp->precise_ptr = 0;
5291 hdsp->use_midi_tasklet = 1;
5292 hdsp->dds_value = 0;
5294 if ((err = snd_hdsp_initialize_memory(hdsp)) < 0)
5295 return err;
5297 if (!is_9652 && !is_9632) {
5298 /* we wait a maximum of 10 seconds to let freshly
5299 * inserted cardbus cards do their hardware init */
5300 err = hdsp_wait_for_iobox(hdsp, 1000, 10);
5302 if (err < 0)
5303 return err;
5305 if ((hdsp_read (hdsp, HDSP_statusRegister) & HDSP_DllError) != 0) {
5306 if ((err = hdsp_request_fw_loader(hdsp)) < 0)
5307 /* we don't fail as this can happen
5308 if userspace is not ready for
5309 firmware upload
5311 dev_err(hdsp->card->dev,
5312 "couldn't get firmware from userspace. try using hdsploader\n");
5313 else
5314 /* init is complete, we return */
5315 return 0;
5316 /* we defer initialization */
5317 dev_info(hdsp->card->dev,
5318 "card initialization pending : waiting for firmware\n");
5319 if ((err = snd_hdsp_create_hwdep(card, hdsp)) < 0)
5320 return err;
5321 return 0;
5322 } else {
5323 dev_info(hdsp->card->dev,
5324 "Firmware already present, initializing card.\n");
5325 if (hdsp_read(hdsp, HDSP_status2Register) & HDSP_version2)
5326 hdsp->io_type = RPM;
5327 else if (hdsp_read(hdsp, HDSP_status2Register) & HDSP_version1)
5328 hdsp->io_type = Multiface;
5329 else
5330 hdsp->io_type = Digiface;
5334 if ((err = snd_hdsp_enable_io(hdsp)) != 0)
5335 return err;
5337 if (is_9652)
5338 hdsp->io_type = H9652;
5340 if (is_9632)
5341 hdsp->io_type = H9632;
5343 if ((err = snd_hdsp_create_hwdep(card, hdsp)) < 0)
5344 return err;
5346 snd_hdsp_initialize_channels(hdsp);
5347 snd_hdsp_initialize_midi_flush(hdsp);
5349 hdsp->state |= HDSP_FirmwareLoaded;
5351 if ((err = snd_hdsp_create_alsa_devices(card, hdsp)) < 0)
5352 return err;
5354 return 0;
5357 static int snd_hdsp_free(struct hdsp *hdsp)
5359 if (hdsp->port) {
5360 /* stop the audio, and cancel all interrupts */
5361 tasklet_kill(&hdsp->midi_tasklet);
5362 hdsp->control_register &= ~(HDSP_Start|HDSP_AudioInterruptEnable|HDSP_Midi0InterruptEnable|HDSP_Midi1InterruptEnable);
5363 hdsp_write (hdsp, HDSP_controlRegister, hdsp->control_register);
5366 if (hdsp->irq >= 0)
5367 free_irq(hdsp->irq, (void *)hdsp);
5369 snd_hdsp_free_buffers(hdsp);
5371 if (hdsp->firmware)
5372 release_firmware(hdsp->firmware);
5373 vfree(hdsp->fw_uploaded);
5375 if (hdsp->iobase)
5376 iounmap(hdsp->iobase);
5378 if (hdsp->port)
5379 pci_release_regions(hdsp->pci);
5381 pci_disable_device(hdsp->pci);
5382 return 0;
5385 static void snd_hdsp_card_free(struct snd_card *card)
5387 struct hdsp *hdsp = card->private_data;
5389 if (hdsp)
5390 snd_hdsp_free(hdsp);
5393 static int snd_hdsp_probe(struct pci_dev *pci,
5394 const struct pci_device_id *pci_id)
5396 static int dev;
5397 struct hdsp *hdsp;
5398 struct snd_card *card;
5399 int err;
5401 if (dev >= SNDRV_CARDS)
5402 return -ENODEV;
5403 if (!enable[dev]) {
5404 dev++;
5405 return -ENOENT;
5408 err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
5409 sizeof(struct hdsp), &card);
5410 if (err < 0)
5411 return err;
5413 hdsp = card->private_data;
5414 card->private_free = snd_hdsp_card_free;
5415 hdsp->dev = dev;
5416 hdsp->pci = pci;
5418 if ((err = snd_hdsp_create(card, hdsp)) < 0) {
5419 snd_card_free(card);
5420 return err;
5423 strcpy(card->shortname, "Hammerfall DSP");
5424 sprintf(card->longname, "%s at 0x%lx, irq %d", hdsp->card_name,
5425 hdsp->port, hdsp->irq);
5427 if ((err = snd_card_register(card)) < 0) {
5428 snd_card_free(card);
5429 return err;
5431 pci_set_drvdata(pci, card);
5432 dev++;
5433 return 0;
5436 static void snd_hdsp_remove(struct pci_dev *pci)
5438 snd_card_free(pci_get_drvdata(pci));
5441 static struct pci_driver hdsp_driver = {
5442 .name = KBUILD_MODNAME,
5443 .id_table = snd_hdsp_ids,
5444 .probe = snd_hdsp_probe,
5445 .remove = snd_hdsp_remove,
5448 module_pci_driver(hdsp_driver);