From c6695b7a276170483841cf848f3a595c99d1680f Mon Sep 17 00:00:00 2001 From: Christoph Haag Date: Mon, 15 Feb 2021 14:52:32 +0100 Subject: [PATCH] prober: return XRT_PROBER_STRING_SERIAL_NUMBER for bluetooth devices Using the bluetooth id gotten from uevent. --- src/xrt/state_trackers/prober/p_prober.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/src/xrt/state_trackers/prober/p_prober.c b/src/xrt/state_trackers/prober/p_prober.c index 76383e7e7..54d3e6bc0 100644 --- a/src/xrt/state_trackers/prober/p_prober.c +++ b/src/xrt/state_trackers/prober/p_prober.c @@ -818,13 +818,23 @@ get_string_descriptor(struct xrt_prober *xp, XRT_MAYBE_UNUSED struct prober_device *pdev = (struct prober_device *)xpdev; XRT_MAYBE_UNUSED int ret; #ifdef XRT_HAVE_LIBUSB - if (pdev->usb.dev != NULL) { + if (pdev->base.bus == XRT_BUS_TYPE_USB && pdev->usb.dev != NULL) { ret = p_libusb_get_string_descriptor(p, pdev, which_string, buffer, length); if (ret >= 0) { return ret; } } #endif + if (pdev->base.bus == XRT_BUS_TYPE_BLUETOOTH && which_string == XRT_PROBER_STRING_SERIAL_NUMBER) { + union { + uint8_t arr[8]; + uint64_t v; + } u; + u.v = pdev->bluetooth.id; + return snprintf((char *)buffer, length, "%02X:%02X:%02X:%02X:%02X:%02X", u.arr[5], u.arr[4], u.arr[3], + u.arr[2], u.arr[1], u.arr[0]); + } + //! @todo add more backends //! @todo make this unicode (utf-16)? utf-8 would be better... return 0;