Introduction
Version 1.0.16, LIBUSBX_API_VERSION >= 0x01000102, has added support for hotplug events on some platforms (you should test if your platform supports hotplug notification by calling libusb_has_capability() with parameter LIBUSB_CAP_HAS_HOTPLUG).
This interface allows you to request notification for the arrival and departure of matching USB devices.
To receive hotplug notification you register a callback by calling libusb_hotplug_register_callback(). This function will optionally return a callback handle that can be passed to libusb_hotplug_deregister_callback().
A callback function must return an int (0 or 1) indicating whether the callback is expecting additional events. Returning 0 will rearm the callback and 1 will cause the callback to be deregistered. Note that when callbacks are called from libusb_hotplug_register_callback() because of the LIBUSB_HOTPLUG_ENUMERATE flag, the callback return value is ignored. In other words, you cannot cause a callback to be deregistered by returning 1 when it is called from libusb_hotplug_register_callback().
Callbacks for a particular context are automatically deregistered by libusb_exit().
As of 1.0.16 there are two supported hotplug events:
- LIBUSB_HOTPLUG_EVENT_DEVICE_ARRIVED: A device has arrived and is ready to use
- LIBUSB_HOTPLUG_EVENT_DEVICE_LEFT: A device has left and is no longer available
A hotplug event can listen for either or both of these events.
Note: If you receive notification that a device has left and you have any libusb_device_handles for the device it is up to you to call libusb_close() on each device handle to free up any remaining resources associated with the device. Once a device has left any libusb_device_handle associated with the device are invalid and will remain so even if the device comes back.
When handling a LIBUSB_HOTPLUG_EVENT_DEVICE_ARRIVED event it is considered safe to call any libusb function that takes a libusb_device. It also safe to open a device and submit asynchronous transfers. However, most other functions that take a libusb_device_handle are not safe to call. Examples of such functions are any of the synchronous API functions or the blocking functions that retrieve various USB descriptors. These functions must be used outside of the context of the hotplug callback.
When handling a LIBUSB_HOTPLUG_EVENT_DEVICE_LEFT event the only safe function is libusb_get_device_descriptor().
The following code provides an example of the usage of the hotplug interface:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <libusb.h>
static int count = 0;
int rc;
printf("Could not open USB device\n");
}
if (dev_handle) {
dev_handle = NULL;
}
} else {
printf("Unhandled event %d\n", event);
}
count++;
return 0;
}
int main (void) {
int rc;
&callback_handle);
printf("Error creating a hotplug callback\n");
return EXIT_FAILURE;
}
while (count < 2) {
nanosleep(&(struct timespec){0, 10000000UL}, NULL);
}
return 0;
}
int libusb_get_device_descriptor(libusb_device *dev, struct libusb_device_descriptor *desc)
Get the USB device descriptor for a given device.
Definition descriptor.c:518
int libusb_open(libusb_device *dev, libusb_device_handle **dev_handle)
Open a device and obtain a device handle.
Definition core.c:1405
void libusb_close(libusb_device_handle *dev_handle)
Close a device handle.
Definition core.c:1562
struct libusb_device libusb_device
Structure representing a USB device detected on the system.
Definition libusb.h:1236
struct libusb_device_handle libusb_device_handle
Structure representing a handle on a USB device.
Definition libusb.h:1247
int libusb_hotplug_callback_handle
Callback handle.
Definition libusb.h:2283
libusb_hotplug_event
Since version 1.0.16, LIBUSB_API_VERSION >= 0x01000102.
Definition libusb.h:2290
int libusb_hotplug_register_callback(libusb_context *ctx, int events, int flags, int vendor_id, int product_id, int dev_class, libusb_hotplug_callback_fn cb_fn, void *user_data, libusb_hotplug_callback_handle *callback_handle)
Register a hotplug callback function.
Definition hotplug.c:342
#define LIBUSB_HOTPLUG_MATCH_ANY
Wildcard matching for hotplug events.
Definition libusb.h:2316
void libusb_hotplug_deregister_callback(libusb_context *ctx, libusb_hotplug_callback_handle callback_handle)
Deregisters a hotplug callback.
Definition hotplug.c:427
@ LIBUSB_HOTPLUG_EVENT_DEVICE_ARRIVED
A device has been plugged in and is ready to use.
Definition libusb.h:2292
@ LIBUSB_HOTPLUG_EVENT_DEVICE_LEFT
A device has left and is no longer available.
Definition libusb.h:2297
struct libusb_context libusb_context
Structure representing a libusb session.
Definition libusb.h:1219
int libusb_init_context(libusb_context **ctx, const struct libusb_init_option options[], int num_options)
Initialize libusb.
Definition core.c:2422
void libusb_exit(libusb_context *ctx)
Deinitialize libusb.
Definition core.c:2575
@ LIBUSB_SUCCESS
Success (no error)
Definition libusb.h:1284
int libusb_handle_events_completed(libusb_context *ctx, int *completed)
Handle any pending events in blocking mode.
Definition io.c:2463
A structure representing the standard USB device descriptor.
Definition libusb.h:578