diff options
author | Takashi Iwai <tiwai@suse.de> | 2021-02-27 09:20:02 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2021-02-27 09:26:05 +0100 |
commit | dcf269b3f703f5dbc2101824d9dbe95feed87b3d (patch) | |
tree | d1bef79c07367525fe5d4790f4299cb23563edc9 /sound | |
parent | c88fb897c1fb5a590dc6353ac4b01c8f46a347b3 (diff) | |
download | linux-dcf269b3f703f5dbc2101824d9dbe95feed87b3d.tar.gz linux-dcf269b3f703f5dbc2101824d9dbe95feed87b3d.tar.bz2 linux-dcf269b3f703f5dbc2101824d9dbe95feed87b3d.zip |
ALSA: usb-audio: Don't abort even if the clock rate differs
The commit 93db51d06b32 ("ALSA: usb-audio: Check valid altsetting at
parsing rates for UAC2/3") changed the behavior of the function
set_sample_rate_v2v3() slightly to treat the inconsistent sample rate
as an error. It was done by assumption that the sample rate
validation should have been done at the parser phase as implemented in
that patch. But the validation is later selectively enabled only for
certain devices as it causes a regression (the commit fe773b8711e3
"ALSA: usb-audio: workaround for iface reset issue"), and now the
inconsistency surfaced as a fatal error while it worked in the past as
is, as reported for FiiO M3K DAC.
For recovering from the regression, change set_sample_rate_v2v3()
again to ignore the sample rate difference as non-error.
BugLink: https://bugzilla.opensuse.org/show_bug.cgi?id=1182633
Fixes: 93db51d06b32 ("ALSA: usb-audio: Check valid altsetting at parsing rates for UAC2/3")
Cc: <stable@vger.kernel.org>
Link: https://lore.kernel.org/r/20210227082002.21185-1-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound')
-rw-r--r-- | sound/usb/clock.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/sound/usb/clock.c b/sound/usb/clock.c index 8243652d5604..a746802d0ac3 100644 --- a/sound/usb/clock.c +++ b/sound/usb/clock.c @@ -652,10 +652,10 @@ static int set_sample_rate_v2v3(struct snd_usb_audio *chip, cur_rate = prev_rate; if (cur_rate != rate) { - usb_audio_warn(chip, - "%d:%d: freq mismatch (RO clock): req %d, clock runs @%d\n", - fmt->iface, fmt->altsetting, rate, cur_rate); - return -ENXIO; + usb_audio_dbg(chip, + "%d:%d: freq mismatch: req %d, clock runs @%d\n", + fmt->iface, fmt->altsetting, rate, cur_rate); + /* continue processing */ } validation: |