+ if (packet->type == SR_DF_ANALOG_OLD) {
+ /* Convert to SR_DF_ANALOG. */
+ const struct sr_datafeed_analog_old *analog_old = packet->payload;
+ struct sr_analog_encoding encoding;
+ struct sr_analog_meaning meaning;
+ struct sr_analog_spec spec;
+ struct sr_datafeed_analog analog;
+ struct sr_datafeed_packet new_packet;
+ new_packet.type = SR_DF_ANALOG;
+ new_packet.payload = &analog;
+ analog.data = analog_old->data;
+ analog.num_samples = analog_old->num_samples;
+ analog.encoding = &encoding;
+ analog.meaning = &meaning;
+ analog.spec = &spec;
+ encoding.unitsize = sizeof(float);
+ encoding.is_signed = TRUE;
+ encoding.is_float = TRUE;
+#ifdef WORDS_BIGENDIAN
+ encoding.is_bigendian = TRUE;
+#else
+ encoding.is_bigendian = FALSE;
+#endif
+ encoding.digits = 0;
+ encoding.is_digits_decimal = FALSE;
+ encoding.scale.p = 1;
+ encoding.scale.q = 1;
+ encoding.offset.p = 0;
+ encoding.offset.q = 1;
+ meaning.mq = analog_old->mq;
+ meaning.unit = analog_old->unit;
+ meaning.mqflags = analog_old->mqflags;
+ meaning.channels = analog_old->channels;
+ spec.spec_digits = 0;
+ return sr_session_send(sdi, &new_packet);
+ }
+