[ALSA] usb-audio: show USB error descriptions
Modules: USB generic driver When usb_submit_urb() fails, show an error description instead of just the error code. Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
This commit is contained in:
parent
0243ef71ac
commit
32e19e882c
@ -773,6 +773,31 @@ static int deactivate_urbs(struct snd_usb_substream *subs, int force, int can_sl
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static const char *usb_error_string(int err)
|
||||||
|
{
|
||||||
|
switch (err) {
|
||||||
|
case -ENODEV:
|
||||||
|
return "no device";
|
||||||
|
case -ENOENT:
|
||||||
|
return "endpoint not enabled";
|
||||||
|
case -EPIPE:
|
||||||
|
return "endpoint stalled";
|
||||||
|
case -ENOSPC:
|
||||||
|
return "not enough bandwidth";
|
||||||
|
case -ESHUTDOWN:
|
||||||
|
return "device disabled";
|
||||||
|
case -EHOSTUNREACH:
|
||||||
|
return "device suspended";
|
||||||
|
case -EINVAL:
|
||||||
|
case -EAGAIN:
|
||||||
|
case -EFBIG:
|
||||||
|
case -EMSGSIZE:
|
||||||
|
return "internal error";
|
||||||
|
default:
|
||||||
|
return "unknown error";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* set up and start data/sync urbs
|
* set up and start data/sync urbs
|
||||||
*/
|
*/
|
||||||
@ -805,16 +830,22 @@ static int start_urbs(struct snd_usb_substream *subs, struct snd_pcm_runtime *ru
|
|||||||
subs->unlink_mask = 0;
|
subs->unlink_mask = 0;
|
||||||
subs->running = 1;
|
subs->running = 1;
|
||||||
for (i = 0; i < subs->nurbs; i++) {
|
for (i = 0; i < subs->nurbs; i++) {
|
||||||
if ((err = usb_submit_urb(subs->dataurb[i].urb, GFP_ATOMIC)) < 0) {
|
err = usb_submit_urb(subs->dataurb[i].urb, GFP_ATOMIC);
|
||||||
snd_printk(KERN_ERR "cannot submit datapipe for urb %d, err = %d\n", i, err);
|
if (err < 0) {
|
||||||
|
snd_printk(KERN_ERR "cannot submit datapipe "
|
||||||
|
"for urb %d, error %d: %s\n",
|
||||||
|
i, err, usb_error_string(err));
|
||||||
goto __error;
|
goto __error;
|
||||||
}
|
}
|
||||||
set_bit(i, &subs->active_mask);
|
set_bit(i, &subs->active_mask);
|
||||||
}
|
}
|
||||||
if (subs->syncpipe) {
|
if (subs->syncpipe) {
|
||||||
for (i = 0; i < SYNC_URBS; i++) {
|
for (i = 0; i < SYNC_URBS; i++) {
|
||||||
if ((err = usb_submit_urb(subs->syncurb[i].urb, GFP_ATOMIC)) < 0) {
|
err = usb_submit_urb(subs->syncurb[i].urb, GFP_ATOMIC);
|
||||||
snd_printk(KERN_ERR "cannot submit syncpipe for urb %d, err = %d\n", i, err);
|
if (err < 0) {
|
||||||
|
snd_printk(KERN_ERR "cannot submit syncpipe "
|
||||||
|
"for urb %d, error %d: %s\n",
|
||||||
|
i, err, usb_error_string(err));
|
||||||
goto __error;
|
goto __error;
|
||||||
}
|
}
|
||||||
set_bit(i + 16, &subs->active_mask);
|
set_bit(i + 16, &subs->active_mask);
|
||||||
|
Loading…
Reference in New Issue
Block a user