From: Gerhard Sittig Date: Mon, 17 Aug 2020 17:07:37 +0000 (+0200) Subject: scpi: Raise severity when IDN response lacks the serial number field. X-Git-Url: https://sigrok.org/gitweb/?p=libsigrok.git;a=commitdiff_plain;h=72cd558d4ac706d4d3f934d177c58d0aa0e806fa scpi: Raise severity when IDN response lacks the serial number field. Raise the diagnostics message's severity from debug to warn when the '*IDN?' response lacks the serial number field. Although it has only been seen for some GWInstek DMMs, it violates the SCPI spec, and more or other activity is required in a future implementation. This change amends commit 47e7a6395e21. --- diff --git a/src/scpi/scpi.c b/src/scpi/scpi.c index cc213ff8..f72164a6 100644 --- a/src/scpi/scpi.c +++ b/src/scpi/scpi.c @@ -1114,6 +1114,12 @@ SR_PRIV int sr_scpi_get_hw_id(struct sr_scpi_dev_inst *scpi, * The response to a '*IDN?' is specified by the SCPI spec. It contains * a comma-separated list containing the manufacturer name, instrument * model, serial number of the instrument and the firmware version. + * + * BEWARE! Although strictly speaking a smaller field count is invalid, + * this implementation also accepts IDN responses with one field less, + * and assumes that the serial number is missing. Some GWInstek DMMs + * were found to do this. Keep warning about this condition, which may + * need more consideration later. */ tokens = g_strsplit(response, ",", 0); num_tokens = g_strv_length(tokens); @@ -1123,6 +1129,9 @@ SR_PRIV int sr_scpi_get_hw_id(struct sr_scpi_dev_inst *scpi, g_free(response); return SR_ERR_DATA; } + if (num_tokens < 4) { + sr_warn("Short IDN response, assume missing serial number."); + } g_free(response); hw_info = g_malloc0(sizeof(struct sr_scpi_hw_info));