summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2018-04-17 15:57:04 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-04-24 17:54:08 -0700
commitacc343834ae416aa4a17a0cd508c8ddf31f8281d (patch)
treea55bf94f0fa82cc56f1a2fd87afb2f84a2510fcb
parent13f5c75ac49d88bd1d1f45e798a5e75b6426aa81 (diff)
downloadsubsurface-acc343834ae416aa4a17a0cd508c8ddf31f8281d.tar.gz
Actually tie in the new libdivecomputer IO model to open the dive computer device
This creates a new libdivecomputer_device_open() helper, and makes downloading and configuration use it to open the dive computer device using the proper protocol. The IRDA case was tested by Sébastien Dugué - I had initially left it undone believing that "nobody uses IRDA". Reported-and-tested-by: Sébastien Dugué <sebastien.dugue.subsurface@gmail.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--core/configuredivecomputer.cpp6
-rw-r--r--core/libdivecomputer.c95
-rw-r--r--core/libdivecomputer.h2
3 files changed, 92 insertions, 11 deletions
diff --git a/core/configuredivecomputer.cpp b/core/configuredivecomputer.cpp
index 6fef1eb21..ae0c882f5 100644
--- a/core/configuredivecomputer.cpp
+++ b/core/configuredivecomputer.cpp
@@ -635,11 +635,7 @@ QString ConfigureDiveComputer::dc_open(device_data_t *data)
fprintf(data->libdc_logfile, "built with libdivecomputer v%s\n", dc_version(NULL));
}
- if (data->bluetooth_mode) {
-#if defined(BT_SUPPORT)
- rc = ble_packet_open(&data->iostream, data->context, data->devname, data);
-#endif
- }
+ rc = divecomputer_device_open(data);
if (rc != DC_STATUS_SUCCESS) {
report_error(errmsg(rc));
diff --git a/core/libdivecomputer.c b/core/libdivecomputer.c
index ed5158c69..c547a85b2 100644
--- a/core/libdivecomputer.c
+++ b/core/libdivecomputer.c
@@ -15,6 +15,10 @@
#include "display.h"
#include <libdivecomputer/version.h>
+#include <libdivecomputer/usbhid.h>
+#include <libdivecomputer/serial.h>
+#include <libdivecomputer/irda.h>
+
#include "libdivecomputer.h"
#include "core/version.h"
@@ -1061,6 +1065,89 @@ void logfunc(dc_context_t *context, dc_loglevel_t loglevel, const char *file, un
}
}
+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;
+ transports = dc_descriptor_get_transports(descriptor);
+
+#ifdef BLE_SUPPORT
+ if (data->bluetooth_mode && (transports & DC_TRANSPORT_BLE)) {
+ rc = ble_packet_open(&data->iostream, context, data->devname, data);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+ }
+#endif
+
+#ifdef BT_SUPPORT
+ if (data->bluetooth_mode && (transports & DC_TRANSPORT_BLUETOOTH)) {
+ rc = rfcomm_stream_open(&data->iostream, context, data->devname);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+ }
+#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) {
+ rc = dc_usbhid_open(&data->iostream, context, device);
+ dc_usbhid_device_free(device);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+ }
+ }
+
+ /* The dive computer backend does this all internally */
+ if (transports & DC_TRANSPORT_USB)
+ return DC_STATUS_SUCCESS;
+
+ if (transports & DC_TRANSPORT_SERIAL) {
+ rc = dc_serial_open(&data->iostream, context, data->devname);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+
+#ifdef SERIAL_FTDI
+ if (!strcmp(data->devname, "ftdi")) {
+ rc = ftdi_open(&data->iostream, context);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+ }
+#endif
+ }
+
+ 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);
+
+ rc = dc_irda_open(&data->iostream, context, address, 1);
+ if (rc == DC_STATUS_SUCCESS)
+ return rc;
+ }
+
+ return DC_STATUS_UNSUPPORTED;
+}
+
const char *do_libdivecomputer_import(device_data_t *data)
{
dc_status_t rc;
@@ -1091,17 +1178,13 @@ const char *do_libdivecomputer_import(device_data_t *data)
err = translate("gettextFromC", "Unable to open %s %s (%s)");
- if (data->bluetooth_mode) {
-#if defined(BT_SUPPORT)
- rc = ble_packet_open(&data->iostream, data->context, data->devname, data);
-#endif
- }
+ rc = divecomputer_device_open(data);
if (rc != DC_STATUS_SUCCESS) {
report_error(errmsg(rc));
} else {
rc = dc_device_open(&data->device, data->context, data->descriptor, data->iostream);
- INFO(0, "dc_deveice_open error value of %d", rc);
+ INFO(0, "dc_device_open error value of %d", rc);
if (rc != DC_STATUS_SUCCESS && subsurface_access(data->devname, R_OK | W_OK) != 0)
err = translate("gettextFromC", "Error opening the device %s %s (%s).\nIn most cases, in order to debug this issue, a libdivecomputer logfile will be useful.\nYou can create this logfile by selecting the corresponding checkbox in the download dialog.");
}
diff --git a/core/libdivecomputer.h b/core/libdivecomputer.h
index 3da7fdc7b..1ff9f0fa0 100644
--- a/core/libdivecomputer.h
+++ b/core/libdivecomputer.h
@@ -59,6 +59,8 @@ dc_status_t ble_packet_open(dc_iostream_t **iostream, dc_context_t *context, con
dc_status_t rfcomm_stream_open(dc_iostream_t **iostream, dc_context_t *context, const char* devaddr);
dc_status_t ftdi_open(dc_iostream_t **iostream, dc_context_t *context);
+dc_status_t divecomputer_device_open(device_data_t *data);
+
#ifdef __cplusplus
}
#endif