X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=src%2Fanalog.c;h=9def3ac8fa62347f405d2acabf2d59b98c6eb4e8;hb=4b4fdeea947950725b704a7af65b166e46521882;hp=29fb8426204c998f0512ca22735a3113f945cb0f;hpb=41caa31909882a34b88c8b8a844d555816b78453;p=libsigrok.git diff --git a/src/analog.c b/src/analog.c index 29fb8426..9def3ac8 100644 --- a/src/analog.c +++ b/src/analog.c @@ -58,7 +58,7 @@ SR_PRIV int sr_analog_init(struct sr_datafeed_analog2 *analog, } SR_API int sr_analog_to_float(const struct sr_datafeed_analog2 *analog, - float *buf) + float *outbuf) { float offset; unsigned int b, i; @@ -71,28 +71,28 @@ SR_API int sr_analog_to_float(const struct sr_datafeed_analog2 *analog, #endif if (!analog->encoding->is_float) { /* TODO */ - sr_err("Only floating-point analog data supported so far."); + sr_err("Only floating-point encoding supported so far."); return SR_ERR; } if (analog->encoding->unitsize == sizeof(float) && analog->encoding->is_bigendian == bigendian && (analog->encoding->scale.p == analog->encoding->scale.q) - && analog->encoding->scale.p / (float)analog->encoding->scale.q == 0) { + && analog->encoding->offset.p / (float)analog->encoding->offset.q == 0) { /* The data is already in the right format. */ - memcpy(buf, analog->data, analog->num_samples * sizeof(float)); + memcpy(outbuf, analog->data, analog->num_samples * sizeof(float)); } else { for (i = 0; i < analog->num_samples; i += analog->encoding->unitsize) { for (b = 0; b < analog->encoding->unitsize; b++) { if (analog->encoding->is_bigendian == bigendian) - buf[i + b] = ((float *)analog->data)[i * analog->encoding->unitsize + b]; + outbuf[i + b] = ((float *)analog->data)[i * analog->encoding->unitsize + b]; else - buf[i + (analog->encoding->unitsize - b)] = ((float *)analog->data)[i * analog->encoding->unitsize + b]; + outbuf[i + (analog->encoding->unitsize - b)] = ((float *)analog->data)[i * analog->encoding->unitsize + b]; } if (analog->encoding->scale.p != analog->encoding->scale.q) - buf[i] = (buf[i] * analog->encoding->scale.p) / analog->encoding->scale.q; - offset = ((float)analog->encoding->scale.p / (float)analog->encoding->scale.q); - buf[i] += offset; + outbuf[i] = (outbuf[i] * analog->encoding->scale.p) / analog->encoding->scale.q; + offset = ((float)analog->encoding->offset.p / (float)analog->encoding->offset.q); + outbuf[i] += offset; } }