From 19aa4245b4b8509b7147c16ac9d3265f607731ac Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Thu, 20 Nov 2014 12:28:12 -0800 Subject: Remember serial and firmware for divecomputers This is not the right way to get serial numbers and firmware versions. The libdivecomputer interface here is simply broken. Those ARE NOT numbers. But until we have the capability in libdivecomputer to return reasonable strings to us, this could be a stop gap measure to help us understand how these are formatted. Signed-off-by: Dirk Hohndel --- libdivecomputer.c | 29 ++++++++++++++++++++++++----- libdivecomputer.h | 2 +- 2 files changed, 25 insertions(+), 6 deletions(-) diff --git a/libdivecomputer.c b/libdivecomputer.c index 9ac50a4eb..fc1dad265 100644 --- a/libdivecomputer.c +++ b/libdivecomputer.c @@ -384,16 +384,18 @@ static void parse_string_field(struct dive *dive, dc_field_string_t *str) } if (!strcmp(str->desc, "Serial")) { - if (!dive->dc.serial) - dive->dc.serial = strdup(str->value); + fprintf(stderr, "string field \"Serial\": %s -- overwriting the existing serial of %s", str->value, dive->dc.serial); + dive->dc.serial = strdup(str->value); + /* should we just overwrite this whenever we have the "Serial" field? + * It's a much better deviceid then what we have so far... for now I'm leaving it as is */ if (!dive->dc.deviceid) dive->dc.deviceid = calculate_string_hash(str->value); return; } if (!strcmp(str->desc, "FW Version")) { - if (!dive->dc.fw_version) - dive->dc.fw_version = strdup(str->value); + fprintf(stderr, "string field \"FW Version\": %s -- overwriting the existing firware of %s", str->value, dive->dc.fw_version); + dive->dc.fw_version = strdup(str->value); return; } @@ -439,6 +441,10 @@ static int dive_cb(const unsigned char *data, unsigned int size, } dive->dc.model = strdup(devdata->model); dive->dc.deviceid = devdata->deviceid; + /* for now copy the "made up" strings converted from the 32bit numbers that libdivecomputer gives us; + * if the dive computer backend supports the DC_FIELD_STRING interface this will later be overwritten by the correct strings */ + dive->dc.serial = copy_string(devdata->serial); + dive->dc.fw_version = copy_string(devdata->firmware); dive->dc.diveid = calculate_diveid(fingerprint, fsize); tm.tm_year = dt.year; @@ -702,6 +708,7 @@ static void event_cb(dc_device_t *device, dc_event_type_t event, const void *dat const dc_event_vendor_t *vendor = data; device_data_t *devdata = userdata; unsigned int serial; + char buffer[16]; switch (event) { case DC_EVENT_WAITING: @@ -731,7 +738,19 @@ static void event_cb(dc_device_t *device, dc_event_type_t event, const void *dat if (!strcmp(devdata->vendor, "Suunto")) serial = fixup_suunto_versions(devdata, devinfo); devdata->deviceid = calculate_sha1(devinfo->model, devinfo->firmware, serial); - + /* really, serial and firmware version are NOT numbers. We'll try to save them here + * in something that might work, but this really needs to be handled with the + * DC_FIELD_STRING interface instead */ + if (serial != 0) { + snprintf(buffer, sizeof(buffer), "%04u-%04u", serial / 10000, serial % 10000); + devdata->serial = strdup(buffer); + fprintf(stderr, "libdc devinfo serial nr converted to %s\n", devdata->serial); + } + if (devinfo->firmware != 0) { + snprintf(buffer, sizeof(buffer), "%02u.%02u", devinfo->firmware / 100, devinfo->firmware % 100); + devdata->firmware = strdup(buffer); + fprintf(stderr, "libdc devinfo firmware version converted to %s\n", devdata->firmware); + } break; case DC_EVENT_CLOCK: dev_info(devdata, translate("gettextFromC", "Event: systime=%" PRId64 ", devtime=%u\n"), diff --git a/libdivecomputer.h b/libdivecomputer.h index af51854a0..795c4ae85 100644 --- a/libdivecomputer.h +++ b/libdivecomputer.h @@ -19,7 +19,7 @@ typedef struct device_data_t { dc_descriptor_t *descriptor; const char *vendor, *product, *devname; - const char *model; + const char *model, *serial, *firmware; uint32_t deviceid, diveid; dc_device_t *device; dc_context_t *context; -- cgit v1.2.3-70-g09d2