victor-dmm: Convert to use SR_DF_ANALOG2.

This commit is contained in:
Uwe Hermann 2014-11-12 16:31:30 +01:00
parent e02e9e6a1c
commit a84a26d98a
1 changed files with 63 additions and 37 deletions

View File

@ -43,7 +43,10 @@ static uint8_t decode_digit(uint8_t in)
static void decode_buf(struct sr_dev_inst *sdi, unsigned char *data) static void decode_buf(struct sr_dev_inst *sdi, unsigned char *data)
{ {
struct sr_datafeed_packet packet; struct sr_datafeed_packet packet;
struct sr_datafeed_analog analog; struct sr_datafeed_analog2 analog;
struct sr_analog_encoding encoding;
struct sr_analog_meaning meaning;
struct sr_analog_spec spec;
struct dev_context *devc; struct dev_context *devc;
long factor, ivalue; long factor, ivalue;
uint8_t digits[4]; uint8_t digits[4];
@ -164,52 +167,56 @@ static void decode_buf(struct sr_dev_inst *sdi, unsigned char *data)
if (minus) if (minus)
fvalue = -fvalue; fvalue = -fvalue;
memset(&analog, 0, sizeof(struct sr_datafeed_analog)); memset(&analog, 0, sizeof(struct sr_datafeed_analog2));
memset(&encoding, 0, sizeof(struct sr_analog_encoding));
memset(&meaning, 0, sizeof(struct sr_analog_meaning));
memset(&spec, 0, sizeof(struct sr_analog_spec));
/* Measurement mode */ /* Measurement mode */
analog.mq = -1; meaning.channels = sdi->channels;
meaning.mq = 0;
switch (data[3]) { switch (data[3]) {
case 0x00: case 0x00:
if (is_duty) { if (is_duty) {
analog.mq = SR_MQ_DUTY_CYCLE; meaning.mq = SR_MQ_DUTY_CYCLE;
analog.unit = SR_UNIT_PERCENTAGE; meaning.unit = SR_UNIT_PERCENTAGE;
} else } else
sr_dbg("Unknown measurement mode: %.2x.", data[3]); sr_dbg("Unknown measurement mode: %.2x.", data[3]);
break; break;
case 0x01: case 0x01:
if (is_diode) { if (is_diode) {
analog.mq = SR_MQ_VOLTAGE; meaning.mq = SR_MQ_VOLTAGE;
analog.unit = SR_UNIT_VOLT; meaning.unit = SR_UNIT_VOLT;
analog.mqflags |= SR_MQFLAG_DIODE; meaning.mqflags |= SR_MQFLAG_DIODE;
if (ivalue < 0) if (ivalue < 0)
fvalue = NAN; fvalue = NAN;
} else { } else {
if (ivalue < 0) if (ivalue < 0)
break; break;
analog.mq = SR_MQ_VOLTAGE; meaning.mq = SR_MQ_VOLTAGE;
analog.unit = SR_UNIT_VOLT; meaning.unit = SR_UNIT_VOLT;
if (is_ac) if (is_ac)
analog.mqflags |= SR_MQFLAG_AC; meaning.mqflags |= SR_MQFLAG_AC;
if (is_dc) if (is_dc)
analog.mqflags |= SR_MQFLAG_DC; meaning.mqflags |= SR_MQFLAG_DC;
} }
break; break;
case 0x02: case 0x02:
analog.mq = SR_MQ_CURRENT; meaning.mq = SR_MQ_CURRENT;
analog.unit = SR_UNIT_AMPERE; meaning.unit = SR_UNIT_AMPERE;
if (is_ac) if (is_ac)
analog.mqflags |= SR_MQFLAG_AC; meaning.mqflags |= SR_MQFLAG_AC;
if (is_dc) if (is_dc)
analog.mqflags |= SR_MQFLAG_DC; meaning.mqflags |= SR_MQFLAG_DC;
break; break;
case 0x04: case 0x04:
if (is_continuity) { if (is_continuity) {
analog.mq = SR_MQ_CONTINUITY; meaning.mq = SR_MQ_CONTINUITY;
analog.unit = SR_UNIT_BOOLEAN; meaning.unit = SR_UNIT_BOOLEAN;
fvalue = ivalue < 0 ? 0.0 : 1.0; fvalue = ivalue < 0 ? 0.0 : 1.0;
} else { } else {
analog.mq = SR_MQ_RESISTANCE; meaning.mq = SR_MQ_RESISTANCE;
analog.unit = SR_UNIT_OHM; meaning.unit = SR_UNIT_OHM;
if (ivalue < 0) if (ivalue < 0)
fvalue = INFINITY; fvalue = INFINITY;
} }
@ -219,43 +226,62 @@ static void decode_buf(struct sr_dev_inst *sdi, unsigned char *data)
sr_dbg("Unknown measurement mode: 0x%.2x.", data[3]); sr_dbg("Unknown measurement mode: 0x%.2x.", data[3]);
break; break;
case 0x10: case 0x10:
analog.mq = SR_MQ_FREQUENCY; meaning.mq = SR_MQ_FREQUENCY;
analog.unit = SR_UNIT_HERTZ; meaning.unit = SR_UNIT_HERTZ;
break; break;
case 0x20: case 0x20:
analog.mq = SR_MQ_CAPACITANCE; meaning.mq = SR_MQ_CAPACITANCE;
analog.unit = SR_UNIT_FARAD; meaning.unit = SR_UNIT_FARAD;
break; break;
case 0x40: case 0x40:
analog.mq = SR_MQ_TEMPERATURE; meaning.mq = SR_MQ_TEMPERATURE;
analog.unit = SR_UNIT_CELSIUS; meaning.unit = SR_UNIT_CELSIUS;
break; break;
case 0x80: case 0x80:
analog.mq = SR_MQ_TEMPERATURE; meaning.mq = SR_MQ_TEMPERATURE;
analog.unit = SR_UNIT_FAHRENHEIT; meaning.unit = SR_UNIT_FAHRENHEIT;
break; break;
default: default:
sr_dbg("Unknown/invalid measurement mode: 0x%.2x.", data[3]); sr_dbg("Unknown/invalid measurement mode: 0x%.2x.", data[3]);
break; break;
} }
if (analog.mq == -1) if (meaning.mq == 0)
return; return;
if (is_auto) if (is_auto)
analog.mqflags |= SR_MQFLAG_AUTORANGE; meaning.mqflags |= SR_MQFLAG_AUTORANGE;
if (is_hold) if (is_hold)
analog.mqflags |= SR_MQFLAG_HOLD; meaning.mqflags |= SR_MQFLAG_HOLD;
if (is_max) if (is_max)
analog.mqflags |= SR_MQFLAG_MAX; meaning.mqflags |= SR_MQFLAG_MAX;
if (is_min) if (is_min)
analog.mqflags |= SR_MQFLAG_MIN; meaning.mqflags |= SR_MQFLAG_MIN;
if (is_relative) if (is_relative)
analog.mqflags |= SR_MQFLAG_RELATIVE; meaning.mqflags |= SR_MQFLAG_RELATIVE;
encoding.unitsize = sizeof(float);
encoding.is_float = TRUE;
#ifdef WORDS_BIGENDIAN
encoding.is_bigendian = TRUE;
#else
encoding.is_bigendian = FALSE;
#endif
encoding.digits = 4; /* Values are always 4-digit numbers. */
encoding.is_digits_decimal = TRUE;
encoding.scale.p = 1;
encoding.scale.q = 1;
encoding.offset.p = 0;
encoding.offset.q = 1;
spec.spec_digits = encoding.digits;
analog.channels = sdi->channels;
analog.num_samples = 1;
analog.data = &fvalue; analog.data = &fvalue;
packet.type = SR_DF_ANALOG; analog.num_samples = 1;
analog.encoding = &encoding;
analog.meaning = &meaning;
analog.spec = &spec;
packet.type = SR_DF_ANALOG2;
packet.payload = &analog; packet.payload = &analog;
sr_session_send(devc->cb_data, &packet); sr_session_send(devc->cb_data, &packet);