diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-04-17 15:57:04 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2018-04-24 17:54:08 -0700 |
commit | acc343834ae416aa4a17a0cd508c8ddf31f8281d (patch) | |
tree | a55bf94f0fa82cc56f1a2fd87afb2f84a2510fcb | |
parent | 13f5c75ac49d88bd1d1f45e798a5e75b6426aa81 (diff) | |
download | subsurface-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.cpp | 6 | ||||
-rw-r--r-- | core/libdivecomputer.c | 95 | ||||
-rw-r--r-- | core/libdivecomputer.h | 2 |
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 |