alsa-devel.alsa-project.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] ALSA: usb: Work around CM6631 sample rate change bug
@ 2013-03-02 13:04 Torstein Hegge
  2013-03-02 13:12 ` Daniel Mack
  0 siblings, 1 reply; 12+ messages in thread
From: Torstein Hegge @ 2013-03-02 13:04 UTC (permalink / raw)
  To: alsa-devel

The C-Media CM6631 USB-to-S/PDIF receiver doesn't respond to changes in
sampling frequency while the interface is active.

Reset the interface after setting the sampling frequency, to ensure that the
sample rate set by snd_usb_init_sample_rate() is used. Otherwise, the device
will try to use the sample rate of the previous file, causing distorted sound
on sample rate changes.

Signed-off-by: Torstein Hegge <hegge@resisty.net>
---
 sound/usb/pcm.c |   10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c
index d82e378..01978a6 100644
--- a/sound/usb/pcm.c
+++ b/sound/usb/pcm.c
@@ -710,6 +710,16 @@ static int snd_usb_pcm_prepare(struct snd_pcm_substream *substream)
 		subs->need_setup_ep = false;
 	}
 
+	/* Some devices doesn't respond to sample rate changes while the
+	 * interface is active. */
+	switch (subs->stream->chip->usb_id) {
+	case USB_ID(0x0d8c, 0x0304): /* C-Media - Schiit USB Interface */
+	case USB_ID(0x0d8c, 0x0309): /* C-Media CM6631 */
+		usb_set_interface(subs->dev, subs->cur_audiofmt->iface,
+					subs->cur_audiofmt->altset_idx);
+		break;
+	}
+
 	/* some unit conversions in runtime */
 	subs->data_endpoint->maxframesize =
 		bytes_to_frames(runtime, subs->data_endpoint->maxpacksize);
-- 
1.7.10.4

^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2013-03-05 21:41 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-03-02 13:04 [PATCH] ALSA: usb: Work around CM6631 sample rate change bug Torstein Hegge
2013-03-02 13:12 ` Daniel Mack
2013-03-03 19:29   ` Torstein Hegge
2013-03-04  8:53     ` Takashi Iwai
2013-03-04 10:31       ` Clemens Ladisch
2013-03-04 21:33         ` Torstein Hegge
2013-03-05  7:55           ` Clemens Ladisch
2013-03-05 10:22             ` Torstein Hegge
2013-03-05 10:35               ` Clemens Ladisch
2013-03-05 21:24                 ` Torstein Hegge
2013-03-05 21:39                   ` Clemens Ladisch
2013-03-04 21:29       ` Torstein Hegge

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).