mirror of
https://github.com/adulau/aha.git
synced 2024-12-28 19:56:18 +00:00
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6: ASoC: Only register AC97 bus if it's not done already ALSA: hda - Add snd_hda_multi_out_dig_cleanup() ALSA: hda - Add missing terminator in slave dig-out array ALSA: hda - Change HP dv7 (103c:30f4) quirk from hp-m4 to hp-dv5 model ALSA: hda - Register (new) devices at reconfig ALSA: mtpav - Fix initial value for input hwport ALSA: hda - add id for Intel IbexPeak integrated HDMI codec ALSA: hda - compute checksum in HDMI audio infoframe ALSA: hda - enable HDMI audio pin out at module loading time ALSA: hda - allow multi-channel HDMI audio playback when ELD is not present ASoC: Update SDP3430 machine driver for snd_soc_card ALSA: hda - Add quirk for Asus z37e (1043:8284) sound: Remove OSSlib stuff from linux/soundcard.h ASoC: WM8990: Fix kcontrol's private value use in put callback ASoC: TLV320AIC3X: Fix kcontrol's private value use in put callback
This commit is contained in:
commit
b51ebdc40c
13 changed files with 110 additions and 91 deletions
|
@ -1045,50 +1045,36 @@ typedef struct mixer_vol_table {
|
||||||
*/
|
*/
|
||||||
#define LOCL_STARTAUDIO 1
|
#define LOCL_STARTAUDIO 1
|
||||||
|
|
||||||
#if (!defined(__KERNEL__) && !defined(KERNEL) && !defined(INKERNEL) && !defined(_KERNEL)) || defined(USE_SEQ_MACROS)
|
#if !defined(__KERNEL__) || defined(USE_SEQ_MACROS)
|
||||||
/*
|
/*
|
||||||
* Some convenience macros to simplify programming of the
|
* Some convenience macros to simplify programming of the
|
||||||
* /dev/sequencer interface
|
* /dev/sequencer interface
|
||||||
*
|
*
|
||||||
* These macros define the API which should be used when possible.
|
* This is a legacy interface for applications written against
|
||||||
|
* the OSSlib-3.8 style interface. It is no longer possible
|
||||||
|
* to actually link against OSSlib with this header, but we
|
||||||
|
* still provide these macros for programs using them.
|
||||||
|
*
|
||||||
|
* If you want to use OSSlib, it is recommended that you get
|
||||||
|
* the GPL version of OSS-4.x and build against that version
|
||||||
|
* of the header.
|
||||||
|
*
|
||||||
|
* We redefine the extern keyword so that make headers_check
|
||||||
|
* does not complain about SEQ_USE_EXTBUF.
|
||||||
*/
|
*/
|
||||||
#define SEQ_DECLAREBUF() SEQ_USE_EXTBUF()
|
#define SEQ_DECLAREBUF() SEQ_USE_EXTBUF()
|
||||||
|
|
||||||
void seqbuf_dump(void); /* This function must be provided by programs */
|
void seqbuf_dump(void); /* This function must be provided by programs */
|
||||||
|
|
||||||
extern int OSS_init(int seqfd, int buflen);
|
|
||||||
extern void OSS_seqbuf_dump(int fd, unsigned char *buf, int buflen);
|
|
||||||
extern void OSS_seq_advbuf(int len, int fd, unsigned char *buf, int buflen);
|
|
||||||
extern void OSS_seq_needbuf(int len, int fd, unsigned char *buf, int buflen);
|
|
||||||
extern void OSS_patch_caching(int dev, int chn, int patch,
|
|
||||||
int fd, unsigned char *buf, int buflen);
|
|
||||||
extern void OSS_drum_caching(int dev, int chn, int patch,
|
|
||||||
int fd, unsigned char *buf, int buflen);
|
|
||||||
extern void OSS_write_patch(int fd, unsigned char *buf, int len);
|
|
||||||
extern int OSS_write_patch2(int fd, unsigned char *buf, int len);
|
|
||||||
|
|
||||||
#define SEQ_PM_DEFINES int __foo_bar___
|
#define SEQ_PM_DEFINES int __foo_bar___
|
||||||
#ifdef OSSLIB
|
|
||||||
# define SEQ_USE_EXTBUF() \
|
|
||||||
extern unsigned char *_seqbuf; \
|
|
||||||
extern int _seqbuflen;extern int _seqbufptr
|
|
||||||
# define SEQ_DEFINEBUF(len) SEQ_USE_EXTBUF();static int _requested_seqbuflen=len
|
|
||||||
# define _SEQ_ADVBUF(len) OSS_seq_advbuf(len, seqfd, _seqbuf, _seqbuflen)
|
|
||||||
# define _SEQ_NEEDBUF(len) OSS_seq_needbuf(len, seqfd, _seqbuf, _seqbuflen)
|
|
||||||
# define SEQ_DUMPBUF() OSS_seqbuf_dump(seqfd, _seqbuf, _seqbuflen)
|
|
||||||
|
|
||||||
# define SEQ_LOAD_GMINSTR(dev, instr) \
|
#define SEQ_LOAD_GMINSTR(dev, instr)
|
||||||
OSS_patch_caching(dev, -1, instr, seqfd, _seqbuf, _seqbuflen)
|
#define SEQ_LOAD_GMDRUM(dev, drum)
|
||||||
# define SEQ_LOAD_GMDRUM(dev, drum) \
|
|
||||||
OSS_drum_caching(dev, -1, drum, seqfd, _seqbuf, _seqbuflen)
|
|
||||||
#else /* !OSSLIB */
|
|
||||||
|
|
||||||
# define SEQ_LOAD_GMINSTR(dev, instr)
|
#define _SEQ_EXTERN extern
|
||||||
# define SEQ_LOAD_GMDRUM(dev, drum)
|
#define SEQ_USE_EXTBUF() \
|
||||||
|
_SEQ_EXTERN unsigned char _seqbuf[]; \
|
||||||
# define SEQ_USE_EXTBUF() \
|
_SEQ_EXTERN int _seqbuflen; _SEQ_EXTERN int _seqbufptr
|
||||||
extern unsigned char _seqbuf[]; \
|
|
||||||
extern int _seqbuflen;extern int _seqbufptr
|
|
||||||
|
|
||||||
#ifndef USE_SIMPLE_MACROS
|
#ifndef USE_SIMPLE_MACROS
|
||||||
/* Sample seqbuf_dump() implementation:
|
/* Sample seqbuf_dump() implementation:
|
||||||
|
@ -1131,7 +1117,6 @@ extern int OSS_write_patch2(int fd, unsigned char *buf, int len);
|
||||||
*/
|
*/
|
||||||
#define _SEQ_NEEDBUF(len) /* empty */
|
#define _SEQ_NEEDBUF(len) /* empty */
|
||||||
#endif
|
#endif
|
||||||
#endif /* !OSSLIB */
|
|
||||||
|
|
||||||
#define SEQ_VOLUME_MODE(dev, mode) {_SEQ_NEEDBUF(8);\
|
#define SEQ_VOLUME_MODE(dev, mode) {_SEQ_NEEDBUF(8);\
|
||||||
_seqbuf[_seqbufptr] = SEQ_EXTENDED;\
|
_seqbuf[_seqbufptr] = SEQ_EXTENDED;\
|
||||||
|
@ -1215,14 +1200,8 @@ extern int OSS_write_patch2(int fd, unsigned char *buf, int len);
|
||||||
_CHN_COMMON(dev, MIDI_CHN_PRESSURE, chn, pressure, 0, 0)
|
_CHN_COMMON(dev, MIDI_CHN_PRESSURE, chn, pressure, 0, 0)
|
||||||
|
|
||||||
#define SEQ_SET_PATCH SEQ_PGM_CHANGE
|
#define SEQ_SET_PATCH SEQ_PGM_CHANGE
|
||||||
#ifdef OSSLIB
|
#define SEQ_PGM_CHANGE(dev, chn, patch) \
|
||||||
# define SEQ_PGM_CHANGE(dev, chn, patch) \
|
|
||||||
{OSS_patch_caching(dev, chn, patch, seqfd, _seqbuf, _seqbuflen); \
|
|
||||||
_CHN_COMMON(dev, MIDI_PGM_CHANGE, chn, patch, 0, 0);}
|
|
||||||
#else
|
|
||||||
# define SEQ_PGM_CHANGE(dev, chn, patch) \
|
|
||||||
_CHN_COMMON(dev, MIDI_PGM_CHANGE, chn, patch, 0, 0)
|
_CHN_COMMON(dev, MIDI_PGM_CHANGE, chn, patch, 0, 0)
|
||||||
#endif
|
|
||||||
|
|
||||||
#define SEQ_CONTROL(dev, chn, controller, value) \
|
#define SEQ_CONTROL(dev, chn, controller, value) \
|
||||||
_CHN_COMMON(dev, MIDI_CTL_CHANGE, chn, controller, 0, value)
|
_CHN_COMMON(dev, MIDI_CTL_CHANGE, chn, controller, 0, value)
|
||||||
|
@ -1300,19 +1279,12 @@ extern int OSS_write_patch2(int fd, unsigned char *buf, int len);
|
||||||
/*
|
/*
|
||||||
* Patch loading.
|
* Patch loading.
|
||||||
*/
|
*/
|
||||||
#ifdef OSSLIB
|
#define SEQ_WRPATCH(patchx, len) \
|
||||||
# define SEQ_WRPATCH(patchx, len) \
|
|
||||||
OSS_write_patch(seqfd, (char*)(patchx), len)
|
|
||||||
# define SEQ_WRPATCH2(patchx, len) \
|
|
||||||
OSS_write_patch2(seqfd, (char*)(patchx), len)
|
|
||||||
#else
|
|
||||||
# define SEQ_WRPATCH(patchx, len) \
|
|
||||||
{if (_seqbufptr) SEQ_DUMPBUF();\
|
{if (_seqbufptr) SEQ_DUMPBUF();\
|
||||||
if (write(seqfd, (char*)(patchx), len)==-1) \
|
if (write(seqfd, (char*)(patchx), len)==-1) \
|
||||||
perror("Write patch: /dev/sequencer");}
|
perror("Write patch: /dev/sequencer");}
|
||||||
# define SEQ_WRPATCH2(patchx, len) \
|
#define SEQ_WRPATCH2(patchx, len) \
|
||||||
(SEQ_DUMPBUF(), write(seqfd, (char*)(patchx), len))
|
(SEQ_DUMPBUF(), write(seqfd, (char*)(patchx), len))
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -706,7 +706,6 @@ static int __devinit snd_mtpav_probe(struct platform_device *dev)
|
||||||
mtp_card->card = card;
|
mtp_card->card = card;
|
||||||
mtp_card->irq = -1;
|
mtp_card->irq = -1;
|
||||||
mtp_card->share_irq = 0;
|
mtp_card->share_irq = 0;
|
||||||
mtp_card->inmidiport = 0xffffffff;
|
|
||||||
mtp_card->inmidistate = 0;
|
mtp_card->inmidistate = 0;
|
||||||
mtp_card->outmidihwport = 0xffffffff;
|
mtp_card->outmidihwport = 0xffffffff;
|
||||||
init_timer(&mtp_card->timer);
|
init_timer(&mtp_card->timer);
|
||||||
|
@ -719,6 +718,8 @@ static int __devinit snd_mtpav_probe(struct platform_device *dev)
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto __error;
|
goto __error;
|
||||||
|
|
||||||
|
mtp_card->inmidiport = mtp_card->num_ports + MTPAV_PIDX_BROADCAST;
|
||||||
|
|
||||||
err = snd_mtpav_get_ISA(mtp_card);
|
err = snd_mtpav_get_ISA(mtp_card);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto __error;
|
goto __error;
|
||||||
|
|
|
@ -3088,6 +3088,16 @@ int snd_hda_multi_out_dig_prepare(struct hda_codec *codec,
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_HDA(snd_hda_multi_out_dig_prepare);
|
EXPORT_SYMBOL_HDA(snd_hda_multi_out_dig_prepare);
|
||||||
|
|
||||||
|
int snd_hda_multi_out_dig_cleanup(struct hda_codec *codec,
|
||||||
|
struct hda_multi_out *mout)
|
||||||
|
{
|
||||||
|
mutex_lock(&codec->spdif_mutex);
|
||||||
|
cleanup_dig_out_stream(codec, mout->dig_out_nid);
|
||||||
|
mutex_unlock(&codec->spdif_mutex);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_HDA(snd_hda_multi_out_dig_cleanup);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* release the digital out
|
* release the digital out
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -175,7 +175,7 @@ static int reconfig_codec(struct hda_codec *codec)
|
||||||
err = snd_hda_codec_build_controls(codec);
|
err = snd_hda_codec_build_controls(codec);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
return 0;
|
return snd_card_register(codec->bus->card);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -251,6 +251,8 @@ int snd_hda_multi_out_dig_prepare(struct hda_codec *codec,
|
||||||
unsigned int stream_tag,
|
unsigned int stream_tag,
|
||||||
unsigned int format,
|
unsigned int format,
|
||||||
struct snd_pcm_substream *substream);
|
struct snd_pcm_substream *substream);
|
||||||
|
int snd_hda_multi_out_dig_cleanup(struct hda_codec *codec,
|
||||||
|
struct hda_multi_out *mout);
|
||||||
int snd_hda_multi_out_analog_open(struct hda_codec *codec,
|
int snd_hda_multi_out_analog_open(struct hda_codec *codec,
|
||||||
struct hda_multi_out *mout,
|
struct hda_multi_out *mout,
|
||||||
struct snd_pcm_substream *substream,
|
struct snd_pcm_substream *substream,
|
||||||
|
|
|
@ -275,6 +275,14 @@ static int ad198x_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
|
||||||
format, substream);
|
format, substream);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ad198x_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
|
||||||
|
struct hda_codec *codec,
|
||||||
|
struct snd_pcm_substream *substream)
|
||||||
|
{
|
||||||
|
struct ad198x_spec *spec = codec->spec;
|
||||||
|
return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Analog capture
|
* Analog capture
|
||||||
*/
|
*/
|
||||||
|
@ -333,7 +341,8 @@ static struct hda_pcm_stream ad198x_pcm_digital_playback = {
|
||||||
.ops = {
|
.ops = {
|
||||||
.open = ad198x_dig_playback_pcm_open,
|
.open = ad198x_dig_playback_pcm_open,
|
||||||
.close = ad198x_dig_playback_pcm_close,
|
.close = ad198x_dig_playback_pcm_close,
|
||||||
.prepare = ad198x_dig_playback_pcm_prepare
|
.prepare = ad198x_dig_playback_pcm_prepare,
|
||||||
|
.cleanup = ad198x_dig_playback_pcm_cleanup
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1885,8 +1894,8 @@ static hda_nid_t ad1988_capsrc_nids[3] = {
|
||||||
#define AD1988_SPDIF_OUT_HDMI 0x0b
|
#define AD1988_SPDIF_OUT_HDMI 0x0b
|
||||||
#define AD1988_SPDIF_IN 0x07
|
#define AD1988_SPDIF_IN 0x07
|
||||||
|
|
||||||
static hda_nid_t ad1989b_slave_dig_outs[2] = {
|
static hda_nid_t ad1989b_slave_dig_outs[] = {
|
||||||
AD1988_SPDIF_OUT, AD1988_SPDIF_OUT_HDMI
|
AD1988_SPDIF_OUT, AD1988_SPDIF_OUT_HDMI, 0
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct hda_input_mux ad1988_6stack_capture_source = {
|
static struct hda_input_mux ad1988_6stack_capture_source = {
|
||||||
|
|
|
@ -49,11 +49,6 @@ static struct hda_verb pinout_enable_verb[] = {
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct hda_verb pinout_disable_verb[] = {
|
|
||||||
{PIN_NID, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00},
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct hda_verb unsolicited_response_verb[] = {
|
static struct hda_verb unsolicited_response_verb[] = {
|
||||||
{PIN_NID, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN |
|
{PIN_NID, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN |
|
||||||
INTEL_HDMI_EVENT_TAG},
|
INTEL_HDMI_EVENT_TAG},
|
||||||
|
@ -248,10 +243,6 @@ static void hdmi_write_dip_byte(struct hda_codec *codec, hda_nid_t nid,
|
||||||
|
|
||||||
static void hdmi_enable_output(struct hda_codec *codec)
|
static void hdmi_enable_output(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
/* Enable Audio InfoFrame Transmission */
|
|
||||||
hdmi_set_dip_index(codec, PIN_NID, 0x0, 0x0);
|
|
||||||
snd_hda_codec_write(codec, PIN_NID, 0, AC_VERB_SET_HDMI_DIP_XMIT,
|
|
||||||
AC_DIPXMIT_BEST);
|
|
||||||
/* Unmute */
|
/* Unmute */
|
||||||
if (get_wcaps(codec, PIN_NID) & AC_WCAP_OUT_AMP)
|
if (get_wcaps(codec, PIN_NID) & AC_WCAP_OUT_AMP)
|
||||||
snd_hda_codec_write(codec, PIN_NID, 0,
|
snd_hda_codec_write(codec, PIN_NID, 0,
|
||||||
|
@ -260,17 +251,24 @@ static void hdmi_enable_output(struct hda_codec *codec)
|
||||||
snd_hda_sequence_write(codec, pinout_enable_verb);
|
snd_hda_sequence_write(codec, pinout_enable_verb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void hdmi_disable_output(struct hda_codec *codec)
|
/*
|
||||||
|
* Enable Audio InfoFrame Transmission
|
||||||
|
*/
|
||||||
|
static void hdmi_start_infoframe_trans(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
snd_hda_sequence_write(codec, pinout_disable_verb);
|
hdmi_set_dip_index(codec, PIN_NID, 0x0, 0x0);
|
||||||
if (get_wcaps(codec, PIN_NID) & AC_WCAP_OUT_AMP)
|
snd_hda_codec_write(codec, PIN_NID, 0, AC_VERB_SET_HDMI_DIP_XMIT,
|
||||||
snd_hda_codec_write(codec, PIN_NID, 0,
|
AC_DIPXMIT_BEST);
|
||||||
AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE);
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FIXME: noises may arise when playing music after reloading the
|
* Disable Audio InfoFrame Transmission
|
||||||
* kernel module, until the next X restart or monitor repower.
|
*/
|
||||||
*/
|
static void hdmi_stop_infoframe_trans(struct hda_codec *codec)
|
||||||
|
{
|
||||||
|
hdmi_set_dip_index(codec, PIN_NID, 0x0, 0x0);
|
||||||
|
snd_hda_codec_write(codec, PIN_NID, 0, AC_VERB_SET_HDMI_DIP_XMIT,
|
||||||
|
AC_DIPXMIT_DISABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hdmi_get_channel_count(struct hda_codec *codec)
|
static int hdmi_get_channel_count(struct hda_codec *codec)
|
||||||
|
@ -368,11 +366,16 @@ static void hdmi_fill_audio_infoframe(struct hda_codec *codec,
|
||||||
struct hdmi_audio_infoframe *ai)
|
struct hdmi_audio_infoframe *ai)
|
||||||
{
|
{
|
||||||
u8 *params = (u8 *)ai;
|
u8 *params = (u8 *)ai;
|
||||||
|
u8 sum = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
hdmi_debug_dip_size(codec);
|
hdmi_debug_dip_size(codec);
|
||||||
hdmi_clear_dip_buffers(codec); /* be paranoid */
|
hdmi_clear_dip_buffers(codec); /* be paranoid */
|
||||||
|
|
||||||
|
for (i = 0; i < sizeof(ai); i++)
|
||||||
|
sum += params[i];
|
||||||
|
ai->checksum = - sum;
|
||||||
|
|
||||||
hdmi_set_dip_index(codec, PIN_NID, 0x0, 0x0);
|
hdmi_set_dip_index(codec, PIN_NID, 0x0, 0x0);
|
||||||
for (i = 0; i < sizeof(ai); i++)
|
for (i = 0; i < sizeof(ai); i++)
|
||||||
hdmi_write_dip_byte(codec, PIN_NID, params[i]);
|
hdmi_write_dip_byte(codec, PIN_NID, params[i]);
|
||||||
|
@ -419,13 +422,17 @@ static int hdmi_setup_channel_allocation(struct hda_codec *codec,
|
||||||
/*
|
/*
|
||||||
* CA defaults to 0 for basic stereo audio
|
* CA defaults to 0 for basic stereo audio
|
||||||
*/
|
*/
|
||||||
if (!eld->eld_ver)
|
|
||||||
return 0;
|
|
||||||
if (!eld->spk_alloc)
|
|
||||||
return 0;
|
|
||||||
if (channels <= 2)
|
if (channels <= 2)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* HDMI sink's ELD info cannot always be retrieved for now, e.g.
|
||||||
|
* in console or for audio devices. Assume the highest speakers
|
||||||
|
* configuration, to _not_ prohibit multi-channel audio playback.
|
||||||
|
*/
|
||||||
|
if (!eld->spk_alloc)
|
||||||
|
eld->spk_alloc = 0xffff;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* expand ELD's speaker allocation mask
|
* expand ELD's speaker allocation mask
|
||||||
*
|
*
|
||||||
|
@ -485,6 +492,7 @@ static void hdmi_setup_audio_infoframe(struct hda_codec *codec,
|
||||||
hdmi_setup_channel_mapping(codec, &ai);
|
hdmi_setup_channel_mapping(codec, &ai);
|
||||||
|
|
||||||
hdmi_fill_audio_infoframe(codec, &ai);
|
hdmi_fill_audio_infoframe(codec, &ai);
|
||||||
|
hdmi_start_infoframe_trans(codec);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -562,7 +570,7 @@ static int intel_hdmi_playback_pcm_close(struct hda_pcm_stream *hinfo,
|
||||||
{
|
{
|
||||||
struct intel_hdmi_spec *spec = codec->spec;
|
struct intel_hdmi_spec *spec = codec->spec;
|
||||||
|
|
||||||
hdmi_disable_output(codec);
|
hdmi_stop_infoframe_trans(codec);
|
||||||
|
|
||||||
return snd_hda_multi_out_dig_close(codec, &spec->multiout);
|
return snd_hda_multi_out_dig_close(codec, &spec->multiout);
|
||||||
}
|
}
|
||||||
|
@ -582,8 +590,6 @@ static int intel_hdmi_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
|
||||||
|
|
||||||
hdmi_setup_audio_infoframe(codec, substream);
|
hdmi_setup_audio_infoframe(codec, substream);
|
||||||
|
|
||||||
hdmi_enable_output(codec);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -628,8 +634,7 @@ static int intel_hdmi_build_controls(struct hda_codec *codec)
|
||||||
|
|
||||||
static int intel_hdmi_init(struct hda_codec *codec)
|
static int intel_hdmi_init(struct hda_codec *codec)
|
||||||
{
|
{
|
||||||
/* disable audio output as early as possible */
|
hdmi_enable_output(codec);
|
||||||
hdmi_disable_output(codec);
|
|
||||||
|
|
||||||
snd_hda_sequence_write(codec, unsolicited_response_verb);
|
snd_hda_sequence_write(codec, unsolicited_response_verb);
|
||||||
|
|
||||||
|
@ -679,6 +684,7 @@ static struct hda_codec_preset snd_hda_preset_intelhdmi[] = {
|
||||||
{ .id = 0x80862801, .name = "G45 DEVBLC", .patch = patch_intel_hdmi },
|
{ .id = 0x80862801, .name = "G45 DEVBLC", .patch = patch_intel_hdmi },
|
||||||
{ .id = 0x80862802, .name = "G45 DEVCTG", .patch = patch_intel_hdmi },
|
{ .id = 0x80862802, .name = "G45 DEVCTG", .patch = patch_intel_hdmi },
|
||||||
{ .id = 0x80862803, .name = "G45 DEVELK", .patch = patch_intel_hdmi },
|
{ .id = 0x80862803, .name = "G45 DEVELK", .patch = patch_intel_hdmi },
|
||||||
|
{ .id = 0x80862804, .name = "G45 DEVIBX", .patch = patch_intel_hdmi },
|
||||||
{ .id = 0x10951392, .name = "SiI1392 HDMI", .patch = patch_intel_hdmi },
|
{ .id = 0x10951392, .name = "SiI1392 HDMI", .patch = patch_intel_hdmi },
|
||||||
{} /* terminator */
|
{} /* terminator */
|
||||||
};
|
};
|
||||||
|
@ -687,6 +693,7 @@ MODULE_ALIAS("snd-hda-codec-id:808629fb");
|
||||||
MODULE_ALIAS("snd-hda-codec-id:80862801");
|
MODULE_ALIAS("snd-hda-codec-id:80862801");
|
||||||
MODULE_ALIAS("snd-hda-codec-id:80862802");
|
MODULE_ALIAS("snd-hda-codec-id:80862802");
|
||||||
MODULE_ALIAS("snd-hda-codec-id:80862803");
|
MODULE_ALIAS("snd-hda-codec-id:80862803");
|
||||||
|
MODULE_ALIAS("snd-hda-codec-id:80862804");
|
||||||
MODULE_ALIAS("snd-hda-codec-id:10951392");
|
MODULE_ALIAS("snd-hda-codec-id:10951392");
|
||||||
|
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
|
|
@ -8478,6 +8478,7 @@ static struct snd_pci_quirk alc883_cfg_tbl[] = {
|
||||||
SND_PCI_QUIRK(0x103c, 0x2a66, "HP Acacia", ALC888_3ST_HP),
|
SND_PCI_QUIRK(0x103c, 0x2a66, "HP Acacia", ALC888_3ST_HP),
|
||||||
SND_PCI_QUIRK(0x1043, 0x1873, "Asus M90V", ALC888_ASUS_M90V),
|
SND_PCI_QUIRK(0x1043, 0x1873, "Asus M90V", ALC888_ASUS_M90V),
|
||||||
SND_PCI_QUIRK(0x1043, 0x8249, "Asus M2A-VM HDMI", ALC883_3ST_6ch_DIG),
|
SND_PCI_QUIRK(0x1043, 0x8249, "Asus M2A-VM HDMI", ALC883_3ST_6ch_DIG),
|
||||||
|
SND_PCI_QUIRK(0x1043, 0x8284, "Asus Z37E", ALC883_6ST_DIG),
|
||||||
SND_PCI_QUIRK(0x1043, 0x82fe, "Asus P5Q-EM HDMI", ALC1200_ASUS_P5Q),
|
SND_PCI_QUIRK(0x1043, 0x82fe, "Asus P5Q-EM HDMI", ALC1200_ASUS_P5Q),
|
||||||
SND_PCI_QUIRK(0x1043, 0x835f, "Asus Eee 1601", ALC888_ASUS_EEE1601),
|
SND_PCI_QUIRK(0x1043, 0x835f, "Asus Eee 1601", ALC888_ASUS_EEE1601),
|
||||||
SND_PCI_QUIRK(0x105b, 0x0ce8, "Foxconn P35AX-S", ALC883_6ST_DIG),
|
SND_PCI_QUIRK(0x105b, 0x0ce8, "Foxconn P35AX-S", ALC883_6ST_DIG),
|
||||||
|
|
|
@ -1799,7 +1799,7 @@ static struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = {
|
||||||
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f2,
|
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f2,
|
||||||
"HP dv5", STAC_HP_M4),
|
"HP dv5", STAC_HP_M4),
|
||||||
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f4,
|
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f4,
|
||||||
"HP dv7", STAC_HP_M4),
|
"HP dv7", STAC_HP_DV5),
|
||||||
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f7,
|
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30f7,
|
||||||
"HP dv4", STAC_HP_DV5),
|
"HP dv4", STAC_HP_DV5),
|
||||||
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30fc,
|
SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30fc,
|
||||||
|
@ -2442,6 +2442,14 @@ static int stac92xx_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
|
||||||
stream_tag, format, substream);
|
stream_tag, format, substream);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int stac92xx_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
|
||||||
|
struct hda_codec *codec,
|
||||||
|
struct snd_pcm_substream *substream)
|
||||||
|
{
|
||||||
|
struct sigmatel_spec *spec = codec->spec;
|
||||||
|
return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Analog capture callbacks
|
* Analog capture callbacks
|
||||||
|
@ -2486,7 +2494,8 @@ static struct hda_pcm_stream stac92xx_pcm_digital_playback = {
|
||||||
.ops = {
|
.ops = {
|
||||||
.open = stac92xx_dig_playback_pcm_open,
|
.open = stac92xx_dig_playback_pcm_open,
|
||||||
.close = stac92xx_dig_playback_pcm_close,
|
.close = stac92xx_dig_playback_pcm_close,
|
||||||
.prepare = stac92xx_dig_playback_pcm_prepare
|
.prepare = stac92xx_dig_playback_pcm_prepare,
|
||||||
|
.cleanup = stac92xx_dig_playback_pcm_cleanup
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -165,10 +165,13 @@ static int snd_soc_dapm_put_volsw_aic3x(struct snd_kcontrol *kcontrol,
|
||||||
struct snd_ctl_elem_value *ucontrol)
|
struct snd_ctl_elem_value *ucontrol)
|
||||||
{
|
{
|
||||||
struct snd_soc_dapm_widget *widget = snd_kcontrol_chip(kcontrol);
|
struct snd_soc_dapm_widget *widget = snd_kcontrol_chip(kcontrol);
|
||||||
int reg = kcontrol->private_value & 0xff;
|
struct soc_mixer_control *mc =
|
||||||
int shift = (kcontrol->private_value >> 8) & 0x0f;
|
(struct soc_mixer_control *)kcontrol->private_value;
|
||||||
int mask = (kcontrol->private_value >> 16) & 0xff;
|
unsigned int reg = mc->reg;
|
||||||
int invert = (kcontrol->private_value >> 24) & 0x01;
|
unsigned int shift = mc->shift;
|
||||||
|
int max = mc->max;
|
||||||
|
unsigned int mask = (1 << fls(max)) - 1;
|
||||||
|
unsigned int invert = mc->invert;
|
||||||
unsigned short val, val_mask;
|
unsigned short val, val_mask;
|
||||||
int ret;
|
int ret;
|
||||||
struct snd_soc_dapm_path *path;
|
struct snd_soc_dapm_path *path;
|
||||||
|
|
|
@ -176,7 +176,9 @@ static int wm899x_outpga_put_volsw_vu(struct snd_kcontrol *kcontrol,
|
||||||
struct snd_ctl_elem_value *ucontrol)
|
struct snd_ctl_elem_value *ucontrol)
|
||||||
{
|
{
|
||||||
struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
|
struct snd_soc_codec *codec = snd_kcontrol_chip(kcontrol);
|
||||||
int reg = kcontrol->private_value & 0xff;
|
struct soc_mixer_control *mc =
|
||||||
|
(struct soc_mixer_control *)kcontrol->private_value;
|
||||||
|
int reg = mc->reg;
|
||||||
int ret;
|
int ret;
|
||||||
u16 val;
|
u16 val;
|
||||||
|
|
||||||
|
|
|
@ -91,7 +91,7 @@ static struct snd_soc_dai_link sdp3430_dai = {
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Audio machine driver */
|
/* Audio machine driver */
|
||||||
static struct snd_soc_machine snd_soc_machine_sdp3430 = {
|
static struct snd_soc_card snd_soc_sdp3430 = {
|
||||||
.name = "SDP3430",
|
.name = "SDP3430",
|
||||||
.platform = &omap_soc_platform,
|
.platform = &omap_soc_platform,
|
||||||
.dai_link = &sdp3430_dai,
|
.dai_link = &sdp3430_dai,
|
||||||
|
@ -100,7 +100,7 @@ static struct snd_soc_machine snd_soc_machine_sdp3430 = {
|
||||||
|
|
||||||
/* Audio subsystem */
|
/* Audio subsystem */
|
||||||
static struct snd_soc_device sdp3430_snd_devdata = {
|
static struct snd_soc_device sdp3430_snd_devdata = {
|
||||||
.machine = &snd_soc_machine_sdp3430,
|
.card = &snd_soc_sdp3430,
|
||||||
.codec_dev = &soc_codec_dev_twl4030,
|
.codec_dev = &soc_codec_dev_twl4030,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1385,7 +1385,10 @@ int snd_soc_init_card(struct snd_soc_device *socdev)
|
||||||
|
|
||||||
mutex_lock(&codec->mutex);
|
mutex_lock(&codec->mutex);
|
||||||
#ifdef CONFIG_SND_SOC_AC97_BUS
|
#ifdef CONFIG_SND_SOC_AC97_BUS
|
||||||
if (ac97) {
|
/* Only instantiate AC97 if not already done by the adaptor
|
||||||
|
* for the generic AC97 subsystem.
|
||||||
|
*/
|
||||||
|
if (ac97 && strcmp(codec->name, "AC97") != 0) {
|
||||||
ret = soc_ac97_dev_register(codec);
|
ret = soc_ac97_dev_register(codec);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
printk(KERN_ERR "asoc: AC97 device register failed\n");
|
printk(KERN_ERR "asoc: AC97 device register failed\n");
|
||||||
|
|
Loading…
Reference in a new issue