diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2009-03-02 05:45:50 -0500 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2009-03-02 08:49:58 -0500 |
commit | eab2b553c3d3ed20698c4a9c7e049a60b804e2f5 (patch) | |
tree | a024f65cc06de0de4a07271135cfb6c7d1ec3864 /sound | |
parent | f3990e610a157e9c36af85a75bc66260dff31f40 (diff) |
sound: usb-audio: fix rules check for 32-channel devices
When storing the channel numbers used by a format, and if the device
happens to support 32 channels, the code would try to store 1<<32 in
a 32-bit value.
Since no valid format can have zero channels, we can use 1<<(channels-1)
instead of 1<<channels so that all the channel numbers that we test for
fit into 32 bits.
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound')
-rw-r--r-- | sound/usb/usbaudio.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/sound/usb/usbaudio.c b/sound/usb/usbaudio.c index 2b24496ddec7..f853b627cf43 100644 --- a/sound/usb/usbaudio.c +++ b/sound/usb/usbaudio.c | |||
@@ -1783,7 +1783,7 @@ static int check_hw_params_convention(struct snd_usb_substream *subs) | |||
1783 | if (rates[f->format] && rates[f->format] != f->rates) | 1783 | if (rates[f->format] && rates[f->format] != f->rates) |
1784 | goto __out; | 1784 | goto __out; |
1785 | } | 1785 | } |
1786 | channels[f->format] |= (1 << f->channels); | 1786 | channels[f->format] |= 1 << (f->channels - 1); |
1787 | rates[f->format] |= f->rates; | 1787 | rates[f->format] |= f->rates; |
1788 | /* needs knot? */ | 1788 | /* needs knot? */ |
1789 | if (f->rates & SNDRV_PCM_RATE_KNOT) | 1789 | if (f->rates & SNDRV_PCM_RATE_KNOT) |
@@ -1810,7 +1810,7 @@ static int check_hw_params_convention(struct snd_usb_substream *subs) | |||
1810 | continue; | 1810 | continue; |
1811 | for (i = 0; i < 32; i++) { | 1811 | for (i = 0; i < 32; i++) { |
1812 | if (f->rates & (1 << i)) | 1812 | if (f->rates & (1 << i)) |
1813 | channels[i] |= (1 << f->channels); | 1813 | channels[i] |= 1 << (f->channels - 1); |
1814 | } | 1814 | } |
1815 | } | 1815 | } |
1816 | cmaster = 0; | 1816 | cmaster = 0; |