From: Takashi Iwai Date: Wed, 5 Nov 2014 14:37:22 +0000 (+0100) Subject: Merge branch 'for-linus' into for-next X-Git-Tag: firefly_0821_release~176^2~2610^2~39^2~80 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=19566b0bd93c34e4941822ed3c0d76a5abddcf82;p=firefly-linux-kernel-4.4.55.git Merge branch 'for-linus' into for-next This merges the USB-audio disconnect fix and resolves the conflicts so that we can continue working on development of usb-audio stuff. Conflicts: sound/usb/card.c --- 19566b0bd93c34e4941822ed3c0d76a5abddcf82 diff --cc sound/usb/card.c index 69725d5fa2d6,f61ebb17cc64..1fab9778807a --- a/sound/usb/card.c +++ b/sound/usb/card.c @@@ -580,11 -586,12 +580,12 @@@ static int usb_audio_probe(struct usb_i * we need to take care of counter, since disconnection can be called also * many times as well as usb_audio_probe(). */ -static void snd_usb_audio_disconnect(struct usb_device *dev, - struct snd_usb_audio *chip) +static void usb_audio_disconnect(struct usb_interface *intf) { + struct snd_usb_audio *chip = usb_get_intfdata(intf); struct snd_card *card; struct list_head *p; + bool was_shutdown; if (chip == (void *)-1L) return; @@@ -595,11 -603,8 +597,10 @@@ up_write(&chip->shutdown_rwsem); mutex_lock(®ister_mutex); - chip->num_interfaces--; - if (chip->num_interfaces <= 0) { + if (!was_shutdown) { + struct snd_usb_stream *as; struct snd_usb_endpoint *ep; + struct usb_mixer_interface *mixer; snd_card_disconnect(card); /* release the pcm resources */ @@@ -615,9 -620,13 +616,13 @@@ snd_usbmidi_disconnect(p); } /* release mixer resources */ - list_for_each(p, &chip->mixer_list) { - snd_usb_mixer_disconnect(p); + list_for_each_entry(mixer, &chip->mixer_list, list) { + snd_usb_mixer_disconnect(mixer); } + } + + chip->num_interfaces--; + if (chip->num_interfaces <= 0) { usb_chip[chip->index] = NULL; mutex_unlock(®ister_mutex); snd_card_free_when_closed(card);