summaryrefslogtreecommitdiffstats
path: root/core/libdivecomputer.c
diff options
context:
space:
mode:
Diffstat (limited to 'core/libdivecomputer.c')
-rw-r--r--core/libdivecomputer.c121
1 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;
}