mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
xrt: Re-order things in xrt_prober
This commit is contained in:
parent
3a9ac6aa5d
commit
aeb11566cd
|
@ -28,7 +28,10 @@ typedef struct cJSON cJSON;
|
||||||
struct xrt_fs;
|
struct xrt_fs;
|
||||||
struct xrt_frame_context;
|
struct xrt_frame_context;
|
||||||
struct xrt_prober;
|
struct xrt_prober;
|
||||||
|
struct xrt_prober_entry;
|
||||||
struct xrt_prober_device;
|
struct xrt_prober_device;
|
||||||
|
struct xrt_prober_entry_lists;
|
||||||
|
struct xrt_auto_prober;
|
||||||
struct xrt_tracking_factory;
|
struct xrt_tracking_factory;
|
||||||
struct os_hid_device;
|
struct os_hid_device;
|
||||||
|
|
||||||
|
@ -44,70 +47,6 @@ struct os_hid_device;
|
||||||
|
|
||||||
#define XRT_MAX_AUTO_PROBERS 16
|
#define XRT_MAX_AUTO_PROBERS 16
|
||||||
|
|
||||||
/*!
|
|
||||||
* Function pointer type for a handler that gets called when a device matching vendor and product ID is detected.
|
|
||||||
*
|
|
||||||
* @param xp Prober
|
|
||||||
* @param devices The array of prober devices found by the prober.
|
|
||||||
* @param num_devices The number of elements in @p devices
|
|
||||||
* @param index Which element in the prober device array matches your query?
|
|
||||||
* @param attached_data
|
|
||||||
* @param out_xdevs An empty array of size @p XRT_MAX_DEVICES_PER_PROBE you may populate with @ref xrt_device
|
|
||||||
* instances.
|
|
||||||
*
|
|
||||||
* @return the number of elements of @p out_xdevs populated by this call.
|
|
||||||
*/
|
|
||||||
typedef int (*xrt_prober_found_func_t)(struct xrt_prober *xp,
|
|
||||||
struct xrt_prober_device **devices,
|
|
||||||
size_t num_devices,
|
|
||||||
size_t index,
|
|
||||||
cJSON *attached_data,
|
|
||||||
struct xrt_device **out_xdevs);
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* Entry for a single device.
|
|
||||||
*
|
|
||||||
* @ingroup xrt_iface
|
|
||||||
*/
|
|
||||||
struct xrt_prober_entry
|
|
||||||
{
|
|
||||||
/*!
|
|
||||||
* USB/Bluetooth vendor ID (VID) to filter on.
|
|
||||||
*/
|
|
||||||
uint16_t vendor_id;
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* USB/Bluetooth product ID (PID) to filter on.
|
|
||||||
*/
|
|
||||||
uint16_t product_id;
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* Handler that gets called when a device matching vendor and product ID is detected.
|
|
||||||
*
|
|
||||||
* @see xrt_prober_found_func_t
|
|
||||||
*/
|
|
||||||
xrt_prober_found_func_t found;
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* A human-readable name for the device associated with this VID/PID.
|
|
||||||
*/
|
|
||||||
const char *name;
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* A human-readable name for the driver associated with this VID/PID.
|
|
||||||
*
|
|
||||||
* Separate because a single driver might handle multiple VID/PID entries.
|
|
||||||
*/
|
|
||||||
const char *driver_name;
|
|
||||||
};
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* Function pointer type for creating a auto prober.
|
|
||||||
*
|
|
||||||
* @ingroup xrt_iface
|
|
||||||
*/
|
|
||||||
typedef struct xrt_auto_prober *(*xrt_auto_prober_create_func_t)();
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Bus type of a device.
|
* Bus type of a device.
|
||||||
*/
|
*/
|
||||||
|
@ -429,12 +368,83 @@ xrt_prober_destroy(struct xrt_prober **xp_ptr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Found device interface.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Function pointer type for a handler that gets called when a device matching vendor and product ID is detected.
|
||||||
|
*
|
||||||
|
* @param xp Prober
|
||||||
|
* @param devices The array of prober devices found by the prober.
|
||||||
|
* @param num_devices The number of elements in @p devices
|
||||||
|
* @param index Which element in the prober device array matches your query?
|
||||||
|
* @param attached_data
|
||||||
|
* @param out_xdevs An empty array of size @p XRT_MAX_DEVICES_PER_PROBE you may populate with @ref xrt_device
|
||||||
|
* instances.
|
||||||
|
*
|
||||||
|
* @return the number of elements of @p out_xdevs populated by this call.
|
||||||
|
*/
|
||||||
|
typedef int (*xrt_prober_found_func_t)(struct xrt_prober *xp,
|
||||||
|
struct xrt_prober_device **devices,
|
||||||
|
size_t num_devices,
|
||||||
|
size_t index,
|
||||||
|
cJSON *attached_data,
|
||||||
|
struct xrt_device **out_xdevs);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Entry for a single device.
|
||||||
|
*
|
||||||
|
* @ingroup xrt_iface
|
||||||
|
*/
|
||||||
|
struct xrt_prober_entry
|
||||||
|
{
|
||||||
|
/*!
|
||||||
|
* USB/Bluetooth vendor ID (VID) to filter on.
|
||||||
|
*/
|
||||||
|
uint16_t vendor_id;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* USB/Bluetooth product ID (PID) to filter on.
|
||||||
|
*/
|
||||||
|
uint16_t product_id;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Handler that gets called when a device matching vendor and product ID is detected.
|
||||||
|
*
|
||||||
|
* @see xrt_prober_found_func_t
|
||||||
|
*/
|
||||||
|
xrt_prober_found_func_t found;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* A human-readable name for the device associated with this VID/PID.
|
||||||
|
*/
|
||||||
|
const char *name;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* A human-readable name for the driver associated with this VID/PID.
|
||||||
|
*
|
||||||
|
* Separate because a single driver might handle multiple VID/PID entries.
|
||||||
|
*/
|
||||||
|
const char *driver_name;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Auto prober.
|
* Auto prober.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Function pointer type for creating a auto prober.
|
||||||
|
*
|
||||||
|
* @ingroup xrt_iface
|
||||||
|
*/
|
||||||
|
typedef struct xrt_auto_prober *(*xrt_auto_prober_create_func_t)();
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* @interface xrt_auto_prober
|
* @interface xrt_auto_prober
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue