mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-16 11:55:39 +00:00
st/prober: Tidy and re-order functions
This commit is contained in:
parent
874d48a810
commit
9a4cc80e87
|
@ -41,15 +41,25 @@
|
||||||
|
|
||||||
#include "multi_wrapper/multi.h"
|
#include "multi_wrapper/multi.h"
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* Pre-declare functions.
|
* Env variable options.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
DEBUG_GET_ONCE_LOG_OPTION(prober_log, "PROBER_LOG", U_LOGGING_INFO)
|
DEBUG_GET_ONCE_LOG_OPTION(prober_log, "PROBER_LOG", U_LOGGING_INFO)
|
||||||
DEBUG_GET_ONCE_BOOL_OPTION(qwerty_enable, "QWERTY_ENABLE", false)
|
DEBUG_GET_ONCE_BOOL_OPTION(qwerty_enable, "QWERTY_ENABLE", false)
|
||||||
DEBUG_GET_ONCE_BOOL_OPTION(qwerty_combine, "QWERTY_COMBINE", false)
|
DEBUG_GET_ONCE_BOOL_OPTION(qwerty_combine, "QWERTY_COMBINE", false)
|
||||||
|
DEBUG_GET_ONCE_OPTION(vf_path, "VF_PATH", NULL)
|
||||||
|
DEBUG_GET_ONCE_OPTION(euroc_path, "EUROC_PATH", NULL)
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Pre-declare functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
static void
|
static void
|
||||||
add_device(struct prober *p, struct prober_device **out_dev);
|
add_device(struct prober *p, struct prober_device **out_dev);
|
||||||
|
@ -64,47 +74,47 @@ static void
|
||||||
teardown(struct prober *p);
|
teardown(struct prober *p);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
probe(struct xrt_prober *xp);
|
p_probe(struct xrt_prober *xp);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
dump(struct xrt_prober *xp);
|
p_dump(struct xrt_prober *xp);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
select_device(struct xrt_prober *xp, struct xrt_device **xdevs, size_t num_xdevs);
|
p_select_device(struct xrt_prober *xp, struct xrt_device **xdevs, size_t num_xdevs);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
open_hid_interface(struct xrt_prober *xp,
|
p_open_hid_interface(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
int interface,
|
int interface,
|
||||||
struct os_hid_device **out_hid_dev);
|
struct os_hid_device **out_hid_dev);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
open_video_device(struct xrt_prober *xp,
|
p_open_video_device(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
struct xrt_frame_context *xfctx,
|
struct xrt_frame_context *xfctx,
|
||||||
struct xrt_fs **out_xfs);
|
struct xrt_fs **out_xfs);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
list_video_devices(struct xrt_prober *xp, xrt_prober_list_video_cb cb, void *ptr);
|
p_list_video_devices(struct xrt_prober *xp, xrt_prober_list_video_cb cb, void *ptr);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
get_entries(struct xrt_prober *xp,
|
p_get_entries(struct xrt_prober *xp,
|
||||||
size_t *out_num_entries,
|
size_t *out_num_entries,
|
||||||
struct xrt_prober_entry ***out_entries,
|
struct xrt_prober_entry ***out_entries,
|
||||||
struct xrt_auto_prober ***out_auto_probers);
|
struct xrt_auto_prober ***out_auto_probers);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
get_string_descriptor(struct xrt_prober *xp,
|
p_get_string_descriptor(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
enum xrt_prober_string which_string,
|
enum xrt_prober_string which_string,
|
||||||
unsigned char *buffer,
|
unsigned char *buffer,
|
||||||
size_t length);
|
size_t length);
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
can_open(struct xrt_prober *xp, struct xrt_prober_device *xpdev);
|
p_can_open(struct xrt_prober *xp, struct xrt_prober_device *xpdev);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
destroy(struct xrt_prober **xp);
|
p_destroy(struct xrt_prober **xp);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -169,7 +179,6 @@ xrt_prober_match_string(struct xrt_prober *xp,
|
||||||
return 0 == strncmp(to_match, (const char *)s, sizeof(s));
|
return 0 == strncmp(to_match, (const char *)s, sizeof(s));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
p_dev_get_usb_dev(struct prober *p,
|
p_dev_get_usb_dev(struct prober *p,
|
||||||
uint16_t bus,
|
uint16_t bus,
|
||||||
|
@ -414,16 +423,16 @@ initialize(struct prober *p, struct xrt_prober_entry_lists *lists)
|
||||||
{
|
{
|
||||||
XRT_TRACE_MARKER();
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
p->base.probe = probe;
|
p->base.probe = p_probe;
|
||||||
p->base.dump = dump;
|
p->base.dump = p_dump;
|
||||||
p->base.select = select_device;
|
p->base.select = p_select_device;
|
||||||
p->base.open_hid_interface = open_hid_interface;
|
p->base.open_hid_interface = p_open_hid_interface;
|
||||||
p->base.open_video_device = open_video_device;
|
p->base.open_video_device = p_open_video_device;
|
||||||
p->base.list_video_devices = list_video_devices;
|
p->base.list_video_devices = p_list_video_devices;
|
||||||
p->base.get_entries = get_entries;
|
p->base.get_entries = p_get_entries;
|
||||||
p->base.get_string_descriptor = get_string_descriptor;
|
p->base.get_string_descriptor = p_get_string_descriptor;
|
||||||
p->base.can_open = can_open;
|
p->base.can_open = p_can_open;
|
||||||
p->base.destroy = destroy;
|
p->base.destroy = p_destroy;
|
||||||
p->lists = lists;
|
p->lists = lists;
|
||||||
p->ll = debug_get_log_option_prober_log();
|
p->ll = debug_get_log_option_prober_log();
|
||||||
|
|
||||||
|
@ -593,68 +602,6 @@ teardown(struct prober *p)
|
||||||
free(p->disabled_drivers);
|
free(p->disabled_drivers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
*
|
|
||||||
* Member functions.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int
|
|
||||||
probe(struct xrt_prober *xp)
|
|
||||||
{
|
|
||||||
XRT_TRACE_MARKER();
|
|
||||||
|
|
||||||
struct prober *p = (struct prober *)xp;
|
|
||||||
XRT_MAYBE_UNUSED int ret = 0;
|
|
||||||
|
|
||||||
// Free old list first.
|
|
||||||
teardown_devices(p);
|
|
||||||
|
|
||||||
#ifdef XRT_HAVE_LIBUDEV
|
|
||||||
ret = p_udev_probe(p);
|
|
||||||
if (ret != 0) {
|
|
||||||
P_ERROR(p, "Failed to enumerate udev devices\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef XRT_HAVE_LIBUSB
|
|
||||||
ret = p_libusb_probe(p);
|
|
||||||
if (ret != 0) {
|
|
||||||
P_ERROR(p, "Failed to enumerate libusb devices\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef XRT_HAVE_LIBUVC
|
|
||||||
ret = p_libuvc_probe(p);
|
|
||||||
if (ret != 0) {
|
|
||||||
P_ERROR(p, "Failed to enumerate libuvc devices\n");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
dump(struct xrt_prober *xp)
|
|
||||||
{
|
|
||||||
XRT_TRACE_MARKER();
|
|
||||||
|
|
||||||
struct prober *p = (struct prober *)xp;
|
|
||||||
XRT_MAYBE_UNUSED ssize_t k = 0;
|
|
||||||
XRT_MAYBE_UNUSED size_t j = 0;
|
|
||||||
|
|
||||||
for (size_t i = 0; i < p->num_devices; i++) {
|
|
||||||
struct prober_device *pdev = &p->devices[i];
|
|
||||||
p_dump_device(p, pdev, (int)i);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
handle_found_device(
|
handle_found_device(
|
||||||
struct prober *p, struct xrt_device **xdevs, size_t num_xdevs, bool *have_hmd, struct xrt_device *xdev)
|
struct prober *p, struct xrt_device **xdevs, size_t num_xdevs, bool *have_hmd, struct xrt_device *xdev)
|
||||||
|
@ -852,8 +799,70 @@ apply_tracking_override(struct prober *p, struct xrt_device **xdevs, size_t num_
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Member functions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
static int
|
static int
|
||||||
select_device(struct xrt_prober *xp, struct xrt_device **xdevs, size_t num_xdevs)
|
p_probe(struct xrt_prober *xp)
|
||||||
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
|
struct prober *p = (struct prober *)xp;
|
||||||
|
XRT_MAYBE_UNUSED int ret = 0;
|
||||||
|
|
||||||
|
// Free old list first.
|
||||||
|
teardown_devices(p);
|
||||||
|
|
||||||
|
#ifdef XRT_HAVE_LIBUDEV
|
||||||
|
ret = p_udev_probe(p);
|
||||||
|
if (ret != 0) {
|
||||||
|
P_ERROR(p, "Failed to enumerate udev devices\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XRT_HAVE_LIBUSB
|
||||||
|
ret = p_libusb_probe(p);
|
||||||
|
if (ret != 0) {
|
||||||
|
P_ERROR(p, "Failed to enumerate libusb devices\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XRT_HAVE_LIBUVC
|
||||||
|
ret = p_libuvc_probe(p);
|
||||||
|
if (ret != 0) {
|
||||||
|
P_ERROR(p, "Failed to enumerate libuvc devices\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
p_dump(struct xrt_prober *xp)
|
||||||
|
{
|
||||||
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
|
struct prober *p = (struct prober *)xp;
|
||||||
|
XRT_MAYBE_UNUSED ssize_t k = 0;
|
||||||
|
XRT_MAYBE_UNUSED size_t j = 0;
|
||||||
|
|
||||||
|
for (size_t i = 0; i < p->num_devices; i++) {
|
||||||
|
struct prober_device *pdev = &p->devices[i];
|
||||||
|
p_dump_device(p, pdev, (int)i);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
p_select_device(struct xrt_prober *xp, struct xrt_device **xdevs, size_t num_xdevs)
|
||||||
{
|
{
|
||||||
XRT_TRACE_MARKER();
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
|
@ -923,7 +932,7 @@ select_device(struct xrt_prober *xp, struct xrt_device **xdevs, size_t num_xdevs
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
open_hid_interface(struct xrt_prober *xp,
|
p_open_hid_interface(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
int interface,
|
int interface,
|
||||||
struct os_hid_device **out_hid_dev)
|
struct os_hid_device **out_hid_dev)
|
||||||
|
@ -958,11 +967,8 @@ open_hid_interface(struct xrt_prober *xp,
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_GET_ONCE_OPTION(vf_path, "VF_PATH", NULL)
|
|
||||||
DEBUG_GET_ONCE_OPTION(euroc_path, "EUROC_PATH", NULL)
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
open_video_device(struct xrt_prober *xp,
|
p_open_video_device(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
struct xrt_frame_context *xfctx,
|
struct xrt_frame_context *xfctx,
|
||||||
struct xrt_fs **out_xfs)
|
struct xrt_fs **out_xfs)
|
||||||
|
@ -1010,7 +1016,7 @@ open_video_device(struct xrt_prober *xp,
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
list_video_devices(struct xrt_prober *xp, xrt_prober_list_video_cb cb, void *ptr)
|
p_list_video_devices(struct xrt_prober *xp, xrt_prober_list_video_cb cb, void *ptr)
|
||||||
{
|
{
|
||||||
struct prober *p = (struct prober *)xp;
|
struct prober *p = (struct prober *)xp;
|
||||||
|
|
||||||
|
@ -1051,7 +1057,7 @@ list_video_devices(struct xrt_prober *xp, xrt_prober_list_video_cb cb, void *ptr
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
get_entries(struct xrt_prober *xp,
|
p_get_entries(struct xrt_prober *xp,
|
||||||
size_t *out_num_entries,
|
size_t *out_num_entries,
|
||||||
struct xrt_prober_entry ***out_entries,
|
struct xrt_prober_entry ***out_entries,
|
||||||
struct xrt_auto_prober ***out_auto_probers)
|
struct xrt_auto_prober ***out_auto_probers)
|
||||||
|
@ -1067,7 +1073,7 @@ get_entries(struct xrt_prober *xp,
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
get_string_descriptor(struct xrt_prober *xp,
|
p_get_string_descriptor(struct xrt_prober *xp,
|
||||||
struct xrt_prober_device *xpdev,
|
struct xrt_prober_device *xpdev,
|
||||||
enum xrt_prober_string which_string,
|
enum xrt_prober_string which_string,
|
||||||
unsigned char *buffer,
|
unsigned char *buffer,
|
||||||
|
@ -1102,7 +1108,7 @@ get_string_descriptor(struct xrt_prober *xp,
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
can_open(struct xrt_prober *xp, struct xrt_prober_device *xpdev)
|
p_can_open(struct xrt_prober *xp, struct xrt_prober_device *xpdev)
|
||||||
{
|
{
|
||||||
XRT_TRACE_MARKER();
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
|
@ -1117,9 +1123,8 @@ can_open(struct xrt_prober *xp, struct xrt_prober_device *xpdev)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
destroy(struct xrt_prober **xp)
|
p_destroy(struct xrt_prober **xp)
|
||||||
{
|
{
|
||||||
XRT_TRACE_MARKER();
|
XRT_TRACE_MARKER();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue