st/prober: Tidy and re-order functions

This commit is contained in:
Jakob Bornecrantz 2021-09-29 22:28:23 +01:00 committed by Moses Turner
parent 874d48a810
commit 9a4cc80e87

View file

@ -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();