summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2014-11-20 12:28:12 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-11-20 15:04:37 -0800
commit19aa4245b4b8509b7147c16ac9d3265f607731ac (patch)
tree95349c3ac58e9b1331b265db62f3238a6d482234
parent7cedc4d48f574aa763771c40017c78279302c129 (diff)
downloadsubsurface-19aa4245b4b8509b7147c16ac9d3265f607731ac.tar.gz
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 <dirk@hohndel.org>
-rw-r--r--libdivecomputer.c29
-rw-r--r--libdivecomputer.h2
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;