t/common: Add Qwerty builder

This commit is contained in:
Jakob Bornecrantz 2023-04-19 21:31:21 +01:00
parent 76c5d677d7
commit be58024ffb
4 changed files with 157 additions and 0 deletions

View file

@ -50,6 +50,11 @@ if(XRT_BUILD_DRIVER_WMR)
target_link_libraries(target_lists PRIVATE drv_wmr) target_link_libraries(target_lists PRIVATE drv_wmr)
endif() endif()
if(XRT_BUILD_DRIVER_QWERTY)
target_sources(target_lists PRIVATE target_builder_qwerty.c)
target_link_libraries(target_lists PRIVATE drv_qwerty)
endif()
### ###
# Drivers # Drivers
# #

View file

@ -31,6 +31,10 @@
#define T_BUILDER_REMOTE #define T_BUILDER_REMOTE
#endif #endif
#if defined(XRT_BUILD_DRIVER_QWERTY) || defined(XRT_DOXYGEN)
#define T_BUILDER_QWERTY
#endif
#if defined(XRT_BUILD_DRIVER_PSMV) || defined(XRT_BUILD_DRIVER_PSVR) || defined(XRT_DOXYGEN) #if defined(XRT_BUILD_DRIVER_PSMV) || defined(XRT_BUILD_DRIVER_PSVR) || defined(XRT_DOXYGEN)
#define T_BUILDER_RGB_TRACKING #define T_BUILDER_RGB_TRACKING
#endif #endif
@ -78,6 +82,14 @@ struct xrt_builder *
t_builder_north_star_create(void); t_builder_north_star_create(void);
#endif #endif
#ifdef T_BUILDER_QWERTY
/*!
* The qwerty driver builder.
*/
struct xrt_builder *
t_builder_qwerty_create(void);
#endif
#ifdef T_BUILDER_REMOTE #ifdef T_BUILDER_REMOTE
/*! /*!
* The remote driver builder. * The remote driver builder.

View file

@ -0,0 +1,136 @@
// Copyright 2022-2023, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Qwerty devices builder.
* @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup drv_qwerty
*/
#include "xrt/xrt_config_drivers.h"
#include "util/u_misc.h"
#include "util/u_debug.h"
#include "util/u_builders.h"
#include "util/u_system_helpers.h"
#include "target_builder_interface.h"
#include "qwerty/qwerty_interface.h"
#include <assert.h>
#ifndef XRT_BUILD_DRIVER_QWERTY
#error "Must only be built with XRT_BUILD_DRIVER_QWERTY set"
#endif
// Using INFO as default to inform events real devices could report physically
DEBUG_GET_ONCE_LOG_OPTION(qwerty_log, "QWERTY_LOG", U_LOGGING_INFO)
// Driver disabled by default for being experimental
DEBUG_GET_ONCE_BOOL_OPTION(enable_qwerty, "QWERTY_ENABLE", false)
/*
*
* Helper functions.
*
*/
static const char *driver_list[] = {
"qwerty",
};
/*
*
* Member functions.
*
*/
static xrt_result_t
qwerty_estimate_system(struct xrt_builder *xb,
cJSON *config,
struct xrt_prober *xp,
struct xrt_builder_estimate *estimate)
{
if (!debug_get_bool_option_enable_qwerty()) {
return XRT_SUCCESS;
}
estimate->certain.head = true;
estimate->certain.left = true;
estimate->certain.right = true;
estimate->priority = -25;
return XRT_SUCCESS;
}
static xrt_result_t
qwerty_open_system(struct xrt_builder *xb,
cJSON *config,
struct xrt_prober *xp,
struct xrt_system_devices **out_xsysd,
struct xrt_space_overseer **out_xso)
{
assert(out_xsysd != NULL);
assert(*out_xsysd == NULL);
struct xrt_device *head = NULL;
struct xrt_device *left = NULL;
struct xrt_device *right = NULL;
enum u_logging_level log_level = debug_get_log_option_qwerty_log();
xrt_result_t xret = qwerty_create_devices(log_level, &head, &left, &right);
if (xret != XRT_SUCCESS) {
return xret;
}
struct u_system_devices *usysd = u_system_devices_allocate();
usysd->base.roles.head = head;
usysd->base.roles.left = left;
usysd->base.roles.right = right;
usysd->base.xdevs[usysd->base.xdev_count++] = head;
if (left != NULL) {
usysd->base.xdevs[usysd->base.xdev_count++] = left;
}
if (right != NULL) {
usysd->base.xdevs[usysd->base.xdev_count++] = right;
}
*out_xsysd = &usysd->base;
u_builder_create_space_overseer(&usysd->base, out_xso);
return XRT_SUCCESS;
}
static void
qwerty_destroy(struct xrt_builder *xb)
{
free(xb);
}
/*
*
* 'Exported' functions.
*
*/
struct xrt_builder *
t_builder_qwerty_create(void)
{
struct xrt_builder *xb = U_TYPED_CALLOC(struct xrt_builder);
xb->estimate_system = qwerty_estimate_system;
xb->open_system = qwerty_open_system;
xb->destroy = qwerty_destroy;
xb->identifier = "qwerty";
xb->name = "Qwerty devices builder";
xb->driver_identifiers = driver_list;
xb->driver_identifier_count = ARRAY_SIZE(driver_list);
xb->exclude_from_automatic_discovery = !debug_get_bool_option_enable_qwerty();
return xb;
}

View file

@ -104,6 +104,10 @@ xrt_builder_create_func_t target_builder_list[] = {
t_builder_rgb_tracking_create, t_builder_rgb_tracking_create,
#endif // T_BUILDER_RGB_TRACKING #endif // T_BUILDER_RGB_TRACKING
#ifdef T_BUILDER_QWERTY
t_builder_qwerty_create,
#endif // T_BUILDER_QWERTY
#ifdef T_BUILDER_SIMULATED #ifdef T_BUILDER_SIMULATED
t_builder_simulated_create, t_builder_simulated_create,
#endif // T_BUILDER_SIMULATED #endif // T_BUILDER_SIMULATED