victor-dmm: Convert to use SR_DF_ANALOG2.
This commit is contained in:
parent
e02e9e6a1c
commit
a84a26d98a
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue