Commit 52521e83 authored by Takashi Iwai's avatar Takashi Iwai
Browse files

ALSA: usb-audio: Evaluate packsize caps at the right place

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: 7fe8dec3 ("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: default avatarTakashi Iwai <tiwai@suse.de>
parent 00afb181
Loading
Loading
Loading
Loading
+3 −3
Original line number Diff line number Diff line
@@ -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;