1. NAME

usb_lock_device_for_reset - cautiously acquire the lock for a usb device structure

2. SYNOPSIS

int usb_lock_device_for_reset(struct usb_device *  udev , const struct usb_interface *  iface );

3. ARGUMENTS

udev
    device thatAqs being locked

iface
    interface bound to the driver making the request (optional)

4. DESCRIPTION

Attempts to acquire the device lock, but fails if the device is NOTATTACHED or SUSPENDED, or if iface is specified and the interface is neither BINDING nor BOUND. Rather than sleeping to wait for the lock, the routine polls repeatedly. This is to prevent deadlock with disconnect; in some drivers (such as usb-storage) the disconnect or suspend method will block waiting for a device reset to complete.

Returns a negative error code for failure, otherwise 0.

5. COPYRIGHT