2019-03-18 05:52:32 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief OSVR HDK prober code.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
|
2019-04-12 13:08:46 +00:00
|
|
|
* @ingroup drv_hdk
|
2019-03-18 05:52:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <wchar.h>
|
|
|
|
|
|
|
|
#include <hidapi.h>
|
|
|
|
#include "xrt/xrt_prober.h"
|
|
|
|
|
|
|
|
#include "util/u_misc.h"
|
|
|
|
#include "util/u_debug.h"
|
|
|
|
|
|
|
|
#include "hdk_device.h"
|
|
|
|
|
|
|
|
|
|
|
|
DEBUG_GET_ONCE_BOOL_OPTION(hdk_spew, "HDK_PRINT_SPEW", false)
|
|
|
|
DEBUG_GET_ONCE_BOOL_OPTION(hdk_debug, "HDK_PRINT_DEBUG", false)
|
|
|
|
|
|
|
|
struct hdk_prober
|
|
|
|
{
|
2019-04-22 20:36:59 +00:00
|
|
|
struct xrt_auto_prober base;
|
2019-03-18 05:52:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct hdk_prober *
|
2019-04-22 20:36:59 +00:00
|
|
|
hdk_prober(struct xrt_auto_prober *p)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
return (struct hdk_prober *)p;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2019-04-22 20:36:59 +00:00
|
|
|
hdk_prober_destroy(struct xrt_auto_prober *p)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
struct hdk_prober *hhp = hdk_prober(p);
|
|
|
|
|
|
|
|
|
|
|
|
free(hhp);
|
|
|
|
}
|
|
|
|
#define HDK_MAKE_STRING(NAME, STR) \
|
|
|
|
static const char NAME[] = STR; \
|
|
|
|
static const wchar_t NAME##_W[] = L##STR
|
|
|
|
|
|
|
|
HDK_MAKE_STRING(HDK2_PRODUCT_STRING, "OSVR HDK 2");
|
|
|
|
HDK_MAKE_STRING(HDK13_PRODUCT_STRING, "OSVR HDK 1.3/1.4");
|
2019-03-13 18:20:10 +00:00
|
|
|
static const wchar_t HDK1_PRODUCT_STRING_W[] = L"OSVR HDK 1.x";
|
|
|
|
static const char HDK12_PRODUCT_STRING[] = "OSVR HDK 1.2";
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
static const uint16_t HDK_VID = 0x1532;
|
|
|
|
static const uint16_t HDK_PID = 0x0b00;
|
|
|
|
|
|
|
|
static struct xrt_device *
|
2019-04-22 20:36:59 +00:00
|
|
|
hdk_prober_autoprobe(struct xrt_auto_prober *p)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
|
|
|
struct hdk_prober *hhp = hdk_prober(p);
|
|
|
|
|
|
|
|
(void)hhp;
|
|
|
|
|
|
|
|
bool print_spew = debug_get_bool_option_hdk_spew();
|
|
|
|
bool print_debug = debug_get_bool_option_hdk_debug();
|
|
|
|
struct hid_device_info *devs = hid_enumerate(HDK_VID, HDK_PID);
|
2019-03-15 21:39:12 +00:00
|
|
|
struct hid_device_info *current = devs;
|
|
|
|
enum HDK_VARIANT variant = HDK_UNKNOWN;
|
|
|
|
const char *name = NULL;
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-03-15 21:39:12 +00:00
|
|
|
// Just take the first one that responds correctly.
|
|
|
|
while (current != NULL) {
|
2019-03-22 19:30:38 +00:00
|
|
|
if (current->product_string == NULL ||
|
|
|
|
current->serial_number == NULL) {
|
2019-03-15 21:39:12 +00:00
|
|
|
// Skip if the product string is null.
|
2019-03-22 19:30:38 +00:00
|
|
|
if (print_debug) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"%s - skipping an apparent match with "
|
|
|
|
"null product string\n",
|
|
|
|
__func__);
|
|
|
|
}
|
2019-03-15 21:39:12 +00:00
|
|
|
continue;
|
|
|
|
}
|
2019-03-22 19:30:38 +00:00
|
|
|
if (current->serial_number == NULL) {
|
|
|
|
// Skip if the serial number is null.
|
|
|
|
if (print_debug) {
|
|
|
|
fprintf(stderr,
|
|
|
|
"%s - skipping an apparent match with "
|
|
|
|
"null serial number\n",
|
|
|
|
__func__);
|
|
|
|
}
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (0 ==
|
|
|
|
wcscmp(HDK2_PRODUCT_STRING_W, current->product_string)) {
|
2019-03-15 21:39:12 +00:00
|
|
|
variant = HDK_VARIANT_2;
|
|
|
|
name = HDK2_PRODUCT_STRING;
|
|
|
|
break;
|
|
|
|
} else if (0 == wcscmp(HDK1_PRODUCT_STRING_W,
|
|
|
|
current->product_string)) {
|
|
|
|
variant = HDK_VARIANT_1_2;
|
|
|
|
name = HDK12_PRODUCT_STRING;
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
//! @todo just assuming anything else is 1.3 for now
|
|
|
|
(void)HDK13_PRODUCT_STRING_W;
|
|
|
|
variant = HDK_VARIANT_1_3_1_4;
|
|
|
|
name = HDK13_PRODUCT_STRING;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (current == NULL) {
|
2019-03-18 05:52:32 +00:00
|
|
|
if (print_debug) {
|
|
|
|
fprintf(stderr, "%s - no device found\n", __func__);
|
|
|
|
}
|
2019-03-15 21:39:12 +00:00
|
|
|
hid_free_enumeration(devs);
|
2019-03-18 05:52:32 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-03-15 21:39:12 +00:00
|
|
|
|
|
|
|
hid_device *dev = hid_open(HDK_VID, HDK_PID, current->serial_number);
|
2019-03-18 05:52:32 +00:00
|
|
|
struct hdk_device *hd =
|
|
|
|
hdk_device_create(dev, variant, print_spew, print_debug);
|
|
|
|
hid_free_enumeration(devs);
|
|
|
|
devs = NULL;
|
|
|
|
|
|
|
|
printf("%s - Found at least the tracker of some HDK: %s\n", __func__,
|
|
|
|
name);
|
|
|
|
|
|
|
|
return &hd->base;
|
|
|
|
}
|
|
|
|
|
2019-04-22 20:36:59 +00:00
|
|
|
struct xrt_auto_prober *
|
|
|
|
hdk_create_auto_prober()
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2019-03-21 20:19:52 +00:00
|
|
|
struct hdk_prober *hhp = U_TYPED_CALLOC(struct hdk_prober);
|
2019-03-18 05:52:32 +00:00
|
|
|
hhp->base.destroy = hdk_prober_destroy;
|
|
|
|
hhp->base.lelo_dallas_autoprobe = hdk_prober_autoprobe;
|
|
|
|
|
|
|
|
return &hhp->base;
|
|
|
|
}
|