summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2020-08-20 13:05:53 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-08-21 08:47:08 -0700
commitefc1b4f31ac64d4815d1ab49d9da90dd37c7f3b8 (patch)
tree9103f61707c417493539c20efa10e6e65bd3e6c0
parent4d15f8ee33335286c3b55b37119cdef9910ea5a3 (diff)
downloadsubsurface-efc1b4f31ac64d4815d1ab49d9da90dd37c7f3b8.tar.gz
Update to current libdivecomputer
The libdivecomputer internals changed for USB devices, and now we need to scan the USB devices before calling libdivecomputer. That's the same pattern as for USBHID and IRDA, so let's just regularize this all. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--core/libdivecomputer.c121
m---------libdivecomputer0
2 files changed, 82 insertions, 39 deletions
diff --git a/core/libdivecomputer.c b/core/libdivecomputer.c
index a99d15ae8..c3f62bbcf 100644
--- a/core/libdivecomputer.c
+++ b/core/libdivecomputer.c
@@ -25,6 +25,7 @@
#include <libdivecomputer/version.h>
#include <libdivecomputer/usbhid.h>
+#include <libdivecomputer/usb.h>
#include <libdivecomputer/serial.h>
#include <libdivecomputer/irda.h>
@@ -1269,14 +1270,83 @@ unsigned int get_supported_transports(device_data_t *data)
return supported;
}
+static dc_status_t usbhid_device_open(dc_iostream_t **iostream, dc_context_t *context, device_data_t *data)
+{
+ dc_status_t rc;
+ dc_iterator_t *iterator = NULL;
+ dc_usbhid_device_t *device = NULL;
+
+ // Discover the usbhid device.
+ dc_usbhid_iterator_new (&iterator, context, data->descriptor);
+ while (dc_iterator_next (iterator, &device) == DC_STATUS_SUCCESS)
+ break;
+ dc_iterator_free (iterator);
+
+ if (!device)
+ return DC_STATUS_NODEVICE;
+
+ dev_info(data, "Opening USB HID device for %04x:%04x",
+ dc_usbhid_device_get_vid(device),
+ dc_usbhid_device_get_pid(device));
+ rc = dc_usbhid_open(iostream, context, device);
+ dc_usbhid_device_free(device);
+ return rc;
+}
+
+static dc_status_t usb_device_open(dc_iostream_t **iostream, dc_context_t *context, device_data_t *data)
+{
+ dc_status_t rc;
+ dc_iterator_t *iterator = NULL;
+ dc_usb_device_t *device = NULL;
+
+ // Discover the usb device.
+ dc_usb_iterator_new (&iterator, context, data->descriptor);
+ while (dc_iterator_next (iterator, &device) == DC_STATUS_SUCCESS)
+ break;
+ dc_iterator_free (iterator);
+
+ if (!device)
+ return DC_STATUS_NODEVICE;
+
+ dev_info(data, "Opening USB device for %04x:%04x",
+ dc_usb_device_get_vid(device),
+ dc_usb_device_get_pid(device));
+ rc = dc_usb_open(iostream, context, device);
+ dc_usb_device_free(device);
+ return rc;
+}
+
+static dc_status_t irda_device_open(dc_iostream_t **iostream, dc_context_t *context, device_data_t *data)
+{
+ unsigned int address = 0;
+ dc_iterator_t *iterator = NULL;
+ dc_irda_device_t *device = NULL;
+
+ // Try to find the IRDA address
+ dc_irda_iterator_new (&iterator, context, data->descriptor);
+ while (dc_iterator_next (iterator, &device) == DC_STATUS_SUCCESS) {
+ address = dc_irda_device_get_address (device);
+ dc_irda_device_free (device);
+ break;
+ }
+ dc_iterator_free (iterator);
+
+ // If that fails, use the device name. This will
+ // use address 0 if it's not a number.
+ if (!address)
+ address = strtoul(data->devname, NULL, 0);
+
+ dev_info(data, "Opening IRDA address %u", address);
+ return dc_irda_open(&data->iostream, context, address, 1);
+}
+
dc_status_t divecomputer_device_open(device_data_t *data)
{
dc_status_t rc;
- dc_descriptor_t *descriptor = data->descriptor;
dc_context_t *context = data->context;
unsigned int transports, supported;
- transports = dc_descriptor_get_transports(descriptor);
+ transports = dc_descriptor_get_transports(data->descriptor);
supported = get_supported_transports(data);
transports &= supported;
@@ -1304,29 +1374,17 @@ dc_status_t divecomputer_device_open(device_data_t *data)
#endif
if (transports & DC_TRANSPORT_USBHID) {
- // Discover the usbhid device.
- dc_iterator_t *iterator = NULL;
- dc_usbhid_device_t *device = NULL;
- dc_usbhid_iterator_new (&iterator, context, descriptor);
- while (dc_iterator_next (iterator, &device) == DC_STATUS_SUCCESS)
- break;
- dc_iterator_free (iterator);
-
- if (device) {
- dev_info(data, "Opening USB HID device for %04x:%04x",
- dc_usbhid_device_get_vid(device),
- dc_usbhid_device_get_pid(device));
- rc = dc_usbhid_open(&data->iostream, context, device);
- dc_usbhid_device_free(device);
- if (rc == DC_STATUS_SUCCESS)
- return rc;
- }
+ dev_info(data, "Connecting to USB HID device");
+ rc = usbhid_device_open(&data->iostream, context, data);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
}
- /* The dive computer backend does this all internally */
if (transports & DC_TRANSPORT_USB) {
- dev_info(data, "Opening native USB device");
- return DC_STATUS_SUCCESS;
+ dev_info(data, "Connecting to native USB device");
+ rc = usb_device_open(&data->iostream, context, data);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
}
if (transports & DC_TRANSPORT_SERIAL) {
@@ -1346,23 +1404,8 @@ dc_status_t divecomputer_device_open(device_data_t *data)
}
if (transports & DC_TRANSPORT_IRDA) {
- unsigned int address = 0;
-
- dc_iterator_t *iterator = NULL;
- dc_irda_device_t *device = NULL;
- dc_irda_iterator_new (&iterator, context, descriptor);
- while (dc_iterator_next (iterator, &device) == DC_STATUS_SUCCESS) {
- address = dc_irda_device_get_address (device);
- dc_irda_device_free (device);
- break;
- }
- dc_iterator_free (iterator);
-
- if (!address)
- address = strtoul(data->devname, NULL, 0);
-
- dev_info(data, "Opening IRDA address %u", address);
- rc = dc_irda_open(&data->iostream, context, address, 1);
+ dev_info(data, "Connecting to IRDA device");
+ rc = irda_device_open(&data->iostream, context, data);
if (rc == DC_STATUS_SUCCESS)
return rc;
}
diff --git a/libdivecomputer b/libdivecomputer
-Subproject 6935fe717ac73402c589c2ccc435ad8efd60cd5
+Subproject 1df0e13cc44041743836065c66928c06a5c035a