]> sigrok.org Git - libsigrok.git/blobdiff - src/transform/scale.c
configure.ac: The ft2232h driver also depends on libusb.
[libsigrok.git] / src / transform / scale.c
index b4dd13cb90e028423cd11b5e959db8a2b0d0ceb3..ef2d6b456d724a10814a518a5983cd0ec5be5624 100644 (file)
@@ -49,6 +49,7 @@ static int receive(const struct sr_transform *t,
                struct sr_datafeed_packet **packet_out)
 {
        struct context *ctx;
+       const struct sr_datafeed_analog_old *analog_old;
        const struct sr_datafeed_analog *analog;
        struct sr_channel *ch;
        GSList *l;
@@ -61,20 +62,25 @@ static int receive(const struct sr_transform *t,
        ctx = t->priv;
 
        switch (packet_in->type) {
-       case SR_DF_ANALOG:
-               analog = packet_in->payload;
-               fdata = (float *)analog->data;
-               num_channels = g_slist_length(analog->channels);
+       case SR_DF_ANALOG_OLD:
+               analog_old = packet_in->payload;
+               fdata = (float *)analog_old->data;
+               num_channels = g_slist_length(analog_old->channels);
                factor = (float) ctx->factor.p / ctx->factor.q;
-               for (i = 0; i < analog->num_samples; i++) {
+               for (i = 0; i < analog_old->num_samples; i++) {
                        /* For now scale all values in all channels. */
-                       for (l = analog->channels, c = 0; l; l = l->next, c++) {
+                       for (l = analog_old->channels, c = 0; l; l = l->next, c++) {
                                ch = l->data;
                                (void)ch;
                                fdata[i * num_channels + c] *= factor;
                        }
                }
                break;
+       case SR_DF_ANALOG:
+               analog = packet_in->payload;
+               analog->encoding->scale.p *= ctx->factor.p;
+               analog->encoding->scale.q *= ctx->factor.q;
+               break;
        default:
                sr_spew("Unsupported packet type %d, ignoring.", packet_in->type);
                break;
@@ -112,7 +118,7 @@ static const struct sr_option *get_options(void)
 
        /* Default to a scaling factor of 1.0. */
        if (!options[0].def)
-               options[0].def = g_variant_ref_sink(g_variant_new(("(xt"), &p, &q));
+               options[0].def = g_variant_ref_sink(g_variant_new("(xt)", &p, &q));
 
        return options;
 }