]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ALSA: usb-audio: Evaluate packsize caps at the right place
authorTakashi Iwai <tiwai@suse.de>
Fri, 10 Apr 2026 14:32:19 +0000 (16:32 +0200)
committerTakashi Iwai <tiwai@suse.de>
Fri, 10 Apr 2026 14:34:06 +0000 (16:34 +0200)
We introduced the upper bound checks of the packet sizes by the
ep->maxframesize for avoiding the URB submission errors.  However, the
check was applied at an incorrect place in the function
snd_usb_endpoint_set_params() where ep->maxframesize isn't defined
yet; the value is defined at a bit later position.  So this ended up
with a failure at the first run while the second run works.

For fixing it, move the check at the correct place, right after the
calculation of ep->maxframesize in the same function.

Fixes: 7fe8dec3f628 ("ALSA: usb-audio: Cap the packet size pre-calculations")
Link: https://bugzilla.kernel.org/show_bug.cgi?id=221292
Cc: <stable@vger.kernel.org>
Link: https://patch.msgid.link/20260410143220.1676344-1-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/usb/endpoint.c

index bf4401aba76ca88450ef292c221610a59c5de75b..6fbcb117555c6b5d717dee3b5e10ae7af3433939 100644 (file)
@@ -1379,9 +1379,6 @@ int snd_usb_endpoint_set_params(struct snd_usb_audio *chip,
                return -EINVAL;
        }
 
-       ep->packsize[0] = min(ep->packsize[0], ep->maxframesize);
-       ep->packsize[1] = min(ep->packsize[1], ep->maxframesize);
-
        /* calculate the frequency in 16.16 format */
        ep->freqm = ep->freqn;
        ep->freqshift = INT_MIN;
@@ -1408,6 +1405,9 @@ int snd_usb_endpoint_set_params(struct snd_usb_audio *chip,
        ep->maxframesize = ep->maxpacksize / ep->cur_frame_bytes;
        ep->curframesize = ep->curpacksize / ep->cur_frame_bytes;
 
+       ep->packsize[0] = min(ep->packsize[0], ep->maxframesize);
+       ep->packsize[1] = min(ep->packsize[1], ep->maxframesize);
+
        err = update_clock_ref_rate(chip, ep);
        if (err >= 0) {
                ep->need_setup = false;