1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2007 by Christian Gmeiner
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
28 /* define some audiohw caps */
29 #define TREBLE_CAP (1 << 0)
30 #define BASS_CAP (1 << 1)
31 #define BALANCE_CAP (1 << 2)
32 #define CLIPPING_CAP (1 << 3)
33 #define PRESCALER_CAP (1 << 4)
34 #define BASS_CUTOFF_CAP (1 << 5)
35 #define TREBLE_CUTOFF_CAP (1 << 6)
39 #elif defined(HAVE_WM8751)
41 #elif defined(HAVE_WM8978)
43 #elif defined(HAVE_WM8975)
45 #elif defined(HAVE_WM8985)
47 #elif defined(HAVE_WM8758)
49 #elif defined(HAVE_WM8711) || defined(HAVE_WM8721) || \
52 #elif defined(HAVE_TLV320)
54 #elif defined(HAVE_AS3514)
56 #elif defined(HAVE_MAS35XX)
58 #elif defined(HAVE_TSC2100)
60 #elif defined(HAVE_JZ4740_CODEC)
61 #include "jz4740-codec.h"
64 /* convert caps into defines */
66 #if (AUDIOHW_CAPS & TREBLE_CAP)
67 #define AUDIOHW_HAVE_TREBLE
70 #if (AUDIOHW_CAPS & BASS_CAP)
71 #define AUDIOHW_HAVE_BASS
74 #if (AUDIOHW_CAPS & BALANCE_CAP)
75 #define AUDIOHW_HAVE_BALANCE
78 #if (AUDIOHW_CAPS & CLIPPING_CAP)
79 #define AUDIOHW_HAVE_CLIPPING
82 #if (AUDIOHW_CAPS & PRESCALER_CAP)
83 #define AUDIOHW_HAVE_PRESCALER
86 #if (AUDIOHW_CAPS & BASS_CUTOFF_CAP)
87 #define AUDIOHW_HAVE_BASS_CUTOFF
90 #if (AUDIOHW_CAPS & TREBLE_CUTOFF_CAP)
91 #define AUDIOHW_HAVE_TREBLE_CUTOFF
93 #endif /* AUDIOHW_CAPS */
102 #if (CONFIG_CODEC == MAS3587F) || (CONFIG_CODEC == MAS3539F)
112 #if defined(HAVE_RECORDING)
117 #if defined(AUDIOHW_HAVE_BASS_CUTOFF)
120 #if defined(AUDIOHW_HAVE_TREBLE_CUTOFF)
123 SOUND_LAST_SETTING
, /* Keep this last */
130 SOUND_CHAN_MONO_LEFT
,
131 SOUND_CHAN_MONO_RIGHT
,
133 SOUND_CHAN_NUM_MODES
,
136 struct sound_settings_info
{
145 /* This struct is used by every driver to export its min/max/default values for
146 * its audio settings. Keep in mind that the order must be correct! */
147 extern const struct sound_settings_info audiohw_settings
[];
149 /* All usable functions implemented by a audio codec drivers. Most of
150 * the function in sound settings are only called, when in audio codecs
151 * .h file suitable defines are added.
155 * Initialize audio codec to a well defined state. Includes SoC-specific
158 void audiohw_init(void);
161 * Do initial audio codec setup. Usually called from audiohw_init.
163 void audiohw_preinit(void);
166 * Do some stuff (codec related) after audiohw_init that needs to be
167 * delayed such as enabling outputs to prevent popping. This lets
168 * other inits in the system complete in the meantime.
170 void audiohw_postinit(void);
175 void audiohw_close(void);
177 #ifdef AUDIOHW_HAVE_CLIPPING
179 * Set new volume value
181 * NOTE: AUDIOHW_CAPS need to contain
184 void audiohw_set_volume(int val
);
187 #ifdef AUDIOHW_HAVE_PRESCALER
189 * Set new prescaler value.
191 * NOTE: AUDIOHW_CAPS need to contain
194 void audiohw_set_prescaler(int val
);
197 #ifdef AUDIOHW_HAVE_BALANCE
199 * Set new balance value
201 * NOTE: AUDIOHW_CAPS need to contain
204 void audiohw_set_balance(int val
);
208 * Mute or enable sound.
209 * @param mute true or false.
211 void audiohw_mute(bool mute
);
213 #ifdef AUDIOHW_HAVE_TREBLE
215 * Set new treble value.
217 * NOTE: AUDIOHW_CAPS need to contain
220 void audiohw_set_treble(int val
);
223 #ifdef AUDIOHW_HAVE_BASS
225 * Set new bass value.
227 * NOTE: AUDIOHW_CAPS need to contain
230 void audiohw_set_bass(int val
);
233 #ifdef AUDIOHW_HAVE_BASS_CUTOFF
235 * Set new bass cut off value.
237 * NOTE: AUDIOHW_CAPS need to contain
240 void audiohw_set_bass_cutoff(int val
);
243 #ifdef AUDIOHW_HAVE_TREBLE_CUTOFF
245 * Set new treble cut off value.
247 * NOTE: AUDIOHW_CAPS need to contain
250 void audiohw_set_treble_cutoff(int val
);
253 void audiohw_set_frequency(int fsel
);
255 #ifdef HAVE_RECORDING
259 * @param source_mic if this is true, we want to record from microphone,
260 * else we want to record FM/LineIn.
262 void audiohw_enable_recording(bool source_mic
);
267 void audiohw_disable_recording(void);
270 * Set gain of recording source.
271 * @param left gain value.
272 * @param right will not be used if recording from micophone (mono).
273 * @param type AUDIO_GAIN_MIC, AUDIO_GAIN_LINEIN.
275 void audiohw_set_recvol(int left
, int right
, int type
);
277 #endif /*HAVE_RECORDING*/
279 #if defined(HAVE_RECORDING) || defined(HAVE_FMRADIO_IN)
282 * Enable or disable recording monitor.
283 * @param enable ture or false.
285 void audiohw_set_monitor(bool enable
);
287 #endif /* HAVE_RECORDING || HAVE_FMRADIO_IN */
289 #if CONFIG_CODEC != SWCODEC
291 /* functions which are only used by mas35xx codecs, but are also
292 aviable on SWCODECS through dsp */
295 * Set channel configuration.
296 * @param val new channel value (see enum Channel).
298 void audiohw_set_channel(int val
);
302 * @param val new stereo width value.
304 void audiohw_set_stereo_width(int val
);
306 #endif /* CONFIG_CODEC != SWCODEC */
310 void audiohw_enable_speaker(bool on
);
312 #endif /* HAVE_SPEAKER */
314 #endif /* _AUDIOHW_H_ */