]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
ALSA: usb-audio: Always set up the parameters after resume
authorTakashi Iwai <tiwai@suse.de>
Mon, 23 Nov 2020 08:53:29 +0000 (09:53 +0100)
committerTakashi Iwai <tiwai@suse.de>
Mon, 23 Nov 2020 14:14:54 +0000 (15:14 +0100)
The commit 92adc96f8eec ("ALSA: usb-audio: set the interface format
after resume on Dell WD19") introduced the workaround for the broken
setup after the resume specifically on a Dell dock model.  However,
the full setup should have been performed after the resume on all
devices, as we can't guarantee the same state.  So this patch removes
the conditional check and applies the workaround always.

Tested-by: Keith Milner <kamilner@superlative.org>
Tested-by: Dylan Robinson <dylan_robinson@motu.com>
Link: https://lore.kernel.org/r/20201123085347.19667-24-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/usb/pcm.c
sound/usb/quirks-table.h
sound/usb/quirks.c
sound/usb/usbaudio.h

index 32237623de96bbd63b5f55d6d91dd28140b9a044..ac6385a4eb70ed63b6beef032f350c578957a688 100644 (file)
@@ -1835,6 +1835,9 @@ static int snd_usb_substream_playback_trigger(struct snd_pcm_substream *substrea
                                              subs);
                subs->running = 1;
                return 0;
+       case SNDRV_PCM_TRIGGER_SUSPEND:
+               subs->need_setup_fmt = true;
+               fallthrough;
        case SNDRV_PCM_TRIGGER_STOP:
                stop_endpoints(subs);
                snd_usb_endpoint_set_callback(subs->data_endpoint,
@@ -1849,13 +1852,6 @@ static int snd_usb_substream_playback_trigger(struct snd_pcm_substream *substrea
                                              subs);
                subs->running = 0;
                return 0;
-       case SNDRV_PCM_TRIGGER_SUSPEND:
-               if (subs->stream->chip->setup_fmt_after_resume_quirk) {
-                       stop_endpoints(subs);
-                       subs->need_setup_fmt = true;
-                       return 0;
-               }
-               break;
        }
 
        return -EINVAL;
@@ -1879,6 +1875,9 @@ static int snd_usb_substream_capture_trigger(struct snd_pcm_substream *substream
                                              subs);
                subs->running = 1;
                return 0;
+       case SNDRV_PCM_TRIGGER_SUSPEND:
+               subs->need_setup_fmt = true;
+               fallthrough;
        case SNDRV_PCM_TRIGGER_STOP:
                stop_endpoints(subs);
                fallthrough;
@@ -1887,13 +1886,6 @@ static int snd_usb_substream_capture_trigger(struct snd_pcm_substream *substream
                                              NULL, NULL, NULL);
                subs->running = 0;
                return 0;
-       case SNDRV_PCM_TRIGGER_SUSPEND:
-               if (subs->stream->chip->setup_fmt_after_resume_quirk) {
-                       stop_endpoints(subs);
-                       subs->need_setup_fmt = true;
-                       return 0;
-               }
-               break;
        }
 
        return -EINVAL;
index 3c1697f6b60c9774aa6496d1df9e18c0ce448a68..85b99c6d3c61a47467d099699f9e044503f7cf53 100644 (file)
@@ -3256,14 +3256,6 @@ AU0828_DEVICE(0x2040, 0x7270, "Hauppauge", "HVR-950Q"),
                }
        }
 },
-/* Dell WD19 Dock */
-{
-       USB_DEVICE(0x0bda, 0x402e),
-       .driver_info = (unsigned long) & (const struct snd_usb_audio_quirk) {
-               .ifnum = QUIRK_ANY_INTERFACE,
-               .type = QUIRK_SETUP_FMT_AFTER_RESUME
-       }
-},
 /* MOTU Microbook II */
 {
        USB_DEVICE_VENDOR_SPEC(0x07fd, 0x0004),
index 013ab93fb640e7f02aab92a835c94cb58c4be143..7e7f258011ff9d15f6c870e168a6d8b37b1a2b2c 100644 (file)
@@ -508,16 +508,6 @@ static int create_standard_mixer_quirk(struct snd_usb_audio *chip,
        return snd_usb_create_mixer(chip, quirk->ifnum, 0);
 }
 
-
-static int setup_fmt_after_resume_quirk(struct snd_usb_audio *chip,
-                                      struct usb_interface *iface,
-                                      struct usb_driver *driver,
-                                      const struct snd_usb_audio_quirk *quirk)
-{
-       chip->setup_fmt_after_resume_quirk = 1;
-       return 1;       /* Continue with creating streams and mixer */
-}
-
 static int setup_disable_autosuspend(struct snd_usb_audio *chip,
                                       struct usb_interface *iface,
                                       struct usb_driver *driver,
@@ -565,7 +555,6 @@ int snd_usb_create_quirk(struct snd_usb_audio *chip,
                [QUIRK_AUDIO_EDIROL_UAXX] = create_uaxx_quirk,
                [QUIRK_AUDIO_ALIGN_TRANSFER] = create_align_transfer_quirk,
                [QUIRK_AUDIO_STANDARD_MIXER] = create_standard_mixer_quirk,
-               [QUIRK_SETUP_FMT_AFTER_RESUME] = setup_fmt_after_resume_quirk,
                [QUIRK_SETUP_DISABLE_AUTOSUSPEND] = setup_disable_autosuspend,
        };
 
index aa017a93f7bd1a0493f299ae5db911b6c801441c..cc338e8e25975b3e2a5662239e5abd80f0e8d1d8 100644 (file)
@@ -35,7 +35,6 @@ struct snd_usb_audio {
        wait_queue_head_t shutdown_wait;
        unsigned int txfr_quirk:1; /* Subframe boundaries on transfers */
        unsigned int tx_length_quirk:1; /* Put length specifier in transfers */
-       unsigned int setup_fmt_after_resume_quirk:1; /* setup the format to interface after resume */
        unsigned int need_delayed_register:1; /* warn for delayed registration */
        int num_interfaces;
        int num_suspended_intf;