]> err.no Git - linux-2.6/commitdiff
[ALSA] usb-audio: fix packets per URB calculation for playback
authorClemens Ladisch <clemens@ladisch.de>
Fri, 12 Aug 2005 06:28:27 +0000 (08:28 +0200)
committerJaroslav Kysela <perex@suse.cz>
Tue, 30 Aug 2005 06:45:08 +0000 (08:45 +0200)
USB generic driver
When determining how many packets are needed for one period, we cannot
assume that all packets have their maximum size -- we always use the
nominal sample rate when sending data, and could use an even lower rate
when the endpoint uses frequency feedback.

Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
sound/usb/usbaudio.c

index 9e38d3d1322a78f6c821b857e473b44a5d8f8a63..d28106e390c443d9f49b24e75a3da1ab3c3da821 100644 (file)
@@ -938,7 +938,15 @@ static int init_substream_urbs(snd_usb_substream_t *subs, unsigned int period_by
 
        /* decide how many packets to be used */
        if (is_playback) {
-               total_packs = (period_bytes + maxsize - 1) / maxsize;
+               unsigned int minsize;
+               /* determine how small a packet can be */
+               minsize = (subs->freqn >> (16 - subs->datainterval))
+                         * (frame_bits >> 3);
+               /* with sync from device, assume it can be 25% lower */
+               if (subs->syncpipe)
+                       minsize -= minsize >> 2;
+               minsize = max(minsize, 1u);
+               total_packs = (period_bytes + minsize - 1) / minsize;
                if (total_packs < 2 * MIN_PACKS_URB)
                        total_packs = 2 * MIN_PACKS_URB;
        } else {