if (atomic_read(&ep->chip->shutdown))
                return -EBADFD;
 
+       usb_audio_dbg(ep->chip, "Starting %s EP 0x%x (count %d)\n",
+                     ep_type_name(ep->type), ep->ep_num, ep->use_count);
+
        /* already running? */
        if (++ep->use_count != 1)
                return 0;
        if (!ep)
                return;
 
+       usb_audio_dbg(ep->chip, "Stopping %s EP 0x%x (count %d)\n",
+                     ep_type_name(ep->type), ep->ep_num, ep->use_count);
+
        if (snd_BUG_ON(ep->use_count == 0))
                return;
 
 
        }
 }
 
+static void stop_endpoints(struct snd_usb_substream *subs)
+{
+       if (test_and_clear_bit(SUBSTREAM_FLAG_SYNC_EP_STARTED, &subs->flags)) {
+               snd_usb_endpoint_stop(subs->sync_endpoint);
+               subs->sync_endpoint->sync_slave = NULL;
+       }
+
+       if (test_and_clear_bit(SUBSTREAM_FLAG_DATA_EP_STARTED, &subs->flags))
+               snd_usb_endpoint_stop(subs->data_endpoint);
+}
+
 static int start_endpoints(struct snd_usb_substream *subs)
 {
        int err;
        if (!test_and_set_bit(SUBSTREAM_FLAG_DATA_EP_STARTED, &subs->flags)) {
                struct snd_usb_endpoint *ep = subs->data_endpoint;
 
-               dev_dbg(&subs->dev->dev, "Starting data EP 0x%x\n", ep->ep_num);
-
                ep->data_subs = subs;
                err = snd_usb_endpoint_start(ep);
                if (err < 0) {
                        clear_bit(SUBSTREAM_FLAG_DATA_EP_STARTED, &subs->flags);
-                       return err;
+                       goto error;
                }
        }
 
            !test_and_set_bit(SUBSTREAM_FLAG_SYNC_EP_STARTED, &subs->flags)) {
                struct snd_usb_endpoint *ep = subs->sync_endpoint;
 
-               dev_dbg(&subs->dev->dev, "Starting sync EP 0x%x\n", ep->ep_num);
-
                ep->sync_slave = subs->data_endpoint;
                err = snd_usb_endpoint_start(ep);
                if (err < 0) {
                        clear_bit(SUBSTREAM_FLAG_SYNC_EP_STARTED, &subs->flags);
                        ep->sync_slave = NULL;
-                       return err;
+                       goto error;
                }
        }
 
        return 0;
+
+ error:
+       stop_endpoints(subs);
+       return err;
 }
 
 static void sync_pending_stops(struct snd_usb_substream *subs)
        snd_usb_endpoint_sync_pending_stop(subs->data_endpoint);
 }
 
-static void stop_endpoints(struct snd_usb_substream *subs)
-{
-       if (test_and_clear_bit(SUBSTREAM_FLAG_SYNC_EP_STARTED, &subs->flags)) {
-               dev_dbg(&subs->dev->dev, "Stopping sync EP 0x%x\n",
-                       subs->sync_endpoint->ep_num);
-               snd_usb_endpoint_stop(subs->sync_endpoint);
-               subs->sync_endpoint->sync_slave = NULL;
-       }
-
-       if (test_and_clear_bit(SUBSTREAM_FLAG_DATA_EP_STARTED, &subs->flags)) {
-               dev_dbg(&subs->dev->dev, "Stopping data EP 0x%x\n",
-                       subs->data_endpoint->ep_num);
-               snd_usb_endpoint_stop(subs->data_endpoint);
-       }
-}
-
 /* PCM sync_stop callback */
 static int snd_usb_pcm_sync_stop(struct snd_pcm_substream *substream)
 {