diff options
| -rw-r--r-- | sound/core/pcm_native.c | 8 | ||||
| -rw-r--r-- | sound/pci/echoaudio/echoaudio.c | 4 | ||||
| -rw-r--r-- | sound/pci/via82xx.c | 6 | ||||
| -rw-r--r-- | sound/usb/usbmidi.c | 18 |
4 files changed, 28 insertions, 8 deletions
diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 25b0641e6b8c..f7e1c9f0d3ed 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c | |||
| @@ -315,10 +315,10 @@ int snd_pcm_hw_refine(struct snd_pcm_substream *substream, | |||
| 315 | if (!params->info) | 315 | if (!params->info) |
| 316 | params->info = hw->info & ~SNDRV_PCM_INFO_FIFO_IN_FRAMES; | 316 | params->info = hw->info & ~SNDRV_PCM_INFO_FIFO_IN_FRAMES; |
| 317 | if (!params->fifo_size) { | 317 | if (!params->fifo_size) { |
| 318 | if (snd_mask_min(¶ms->masks[SNDRV_PCM_HW_PARAM_FORMAT]) == | 318 | m = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT); |
| 319 | snd_mask_max(¶ms->masks[SNDRV_PCM_HW_PARAM_FORMAT]) && | 319 | i = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS); |
| 320 | snd_mask_min(¶ms->masks[SNDRV_PCM_HW_PARAM_CHANNELS]) == | 320 | if (snd_mask_min(m) == snd_mask_max(m) && |
| 321 | snd_mask_max(¶ms->masks[SNDRV_PCM_HW_PARAM_CHANNELS])) { | 321 | snd_interval_min(i) == snd_interval_max(i)) { |
| 322 | changed = substream->ops->ioctl(substream, | 322 | changed = substream->ops->ioctl(substream, |
| 323 | SNDRV_PCM_IOCTL1_FIFO_SIZE, params); | 323 | SNDRV_PCM_IOCTL1_FIFO_SIZE, params); |
| 324 | if (changed < 0) | 324 | if (changed < 0) |
diff --git a/sound/pci/echoaudio/echoaudio.c b/sound/pci/echoaudio/echoaudio.c index 1305f7ca02c3..641d7f07392c 100644 --- a/sound/pci/echoaudio/echoaudio.c +++ b/sound/pci/echoaudio/echoaudio.c | |||
| @@ -1821,7 +1821,9 @@ static irqreturn_t snd_echo_interrupt(int irq, void *dev_id) | |||
| 1821 | /* The hardware doesn't tell us which substream caused the irq, | 1821 | /* The hardware doesn't tell us which substream caused the irq, |
| 1822 | thus we have to check all running substreams. */ | 1822 | thus we have to check all running substreams. */ |
| 1823 | for (ss = 0; ss < DSP_MAXPIPES; ss++) { | 1823 | for (ss = 0; ss < DSP_MAXPIPES; ss++) { |
| 1824 | if ((substream = chip->substream[ss])) { | 1824 | substream = chip->substream[ss]; |
| 1825 | if (substream && ((struct audiopipe *)substream->runtime-> | ||
| 1826 | private_data)->state == PIPE_STATE_STARTED) { | ||
| 1825 | period = pcm_pointer(substream) / | 1827 | period = pcm_pointer(substream) / |
| 1826 | substream->runtime->period_size; | 1828 | substream->runtime->period_size; |
| 1827 | if (period != chip->last_period[ss]) { | 1829 | if (period != chip->last_period[ss]) { |
diff --git a/sound/pci/via82xx.c b/sound/pci/via82xx.c index 8a332d2f615c..03d6aea19749 100644 --- a/sound/pci/via82xx.c +++ b/sound/pci/via82xx.c | |||
| @@ -1791,6 +1791,12 @@ static struct ac97_quirk ac97_quirks[] = { | |||
| 1791 | .type = AC97_TUNE_HP_ONLY | 1791 | .type = AC97_TUNE_HP_ONLY |
| 1792 | }, | 1792 | }, |
| 1793 | { | 1793 | { |
| 1794 | .subvendor = 0x110a, | ||
| 1795 | .subdevice = 0x0079, | ||
| 1796 | .name = "Fujitsu Siemens D1289", | ||
| 1797 | .type = AC97_TUNE_HP_ONLY | ||
| 1798 | }, | ||
| 1799 | { | ||
| 1794 | .subvendor = 0x1019, | 1800 | .subvendor = 0x1019, |
| 1795 | .subdevice = 0x0a81, | 1801 | .subdevice = 0x0a81, |
| 1796 | .name = "ECS K7VTA3", | 1802 | .name = "ECS K7VTA3", |
diff --git a/sound/usb/usbmidi.c b/sound/usb/usbmidi.c index 6e89b8368d9a..aae50df06232 100644 --- a/sound/usb/usbmidi.c +++ b/sound/usb/usbmidi.c | |||
| @@ -1162,10 +1162,22 @@ static int snd_usbmidi_out_endpoint_create(struct snd_usb_midi* umidi, | |||
| 1162 | pipe = usb_sndintpipe(umidi->dev, ep_info->out_ep); | 1162 | pipe = usb_sndintpipe(umidi->dev, ep_info->out_ep); |
| 1163 | else | 1163 | else |
| 1164 | pipe = usb_sndbulkpipe(umidi->dev, ep_info->out_ep); | 1164 | pipe = usb_sndbulkpipe(umidi->dev, ep_info->out_ep); |
| 1165 | if (umidi->usb_id == USB_ID(0x0a92, 0x1020)) /* ESI M4U */ | 1165 | switch (umidi->usb_id) { |
| 1166 | ep->max_transfer = 4; | 1166 | default: |
| 1167 | else | ||
| 1168 | ep->max_transfer = usb_maxpacket(umidi->dev, pipe, 1); | 1167 | ep->max_transfer = usb_maxpacket(umidi->dev, pipe, 1); |
| 1168 | break; | ||
| 1169 | /* | ||
| 1170 | * Various chips declare a packet size larger than 4 bytes, but | ||
| 1171 | * do not actually work with larger packets: | ||
| 1172 | */ | ||
| 1173 | case USB_ID(0x0a92, 0x1020): /* ESI M4U */ | ||
| 1174 | case USB_ID(0x1430, 0x474b): /* RedOctane GH MIDI INTERFACE */ | ||
| 1175 | case USB_ID(0x15ca, 0x0101): /* Textech USB Midi Cable */ | ||
| 1176 | case USB_ID(0x15ca, 0x1806): /* Textech USB Midi Cable */ | ||
| 1177 | case USB_ID(0x1a86, 0x752d): /* QinHeng CH345 "USB2.0-MIDI" */ | ||
| 1178 | ep->max_transfer = 4; | ||
| 1179 | break; | ||
| 1180 | } | ||
| 1169 | for (i = 0; i < OUTPUT_URBS; ++i) { | 1181 | for (i = 0; i < OUTPUT_URBS; ++i) { |
| 1170 | buffer = usb_buffer_alloc(umidi->dev, | 1182 | buffer = usb_buffer_alloc(umidi->dev, |
| 1171 | ep->max_transfer, GFP_KERNEL, | 1183 | ep->max_transfer, GFP_KERNEL, |
