*/
#include <config.h>
+#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>
struct channel_priv {
int ch_type;
int fd;
+ int digits;
float val;
struct channel_group_priv *probe;
};
probe_name_path(addr, path);
status = g_file_get_contents(path->str, &buf, &size, &err);
if (!status) {
- sr_dbg("Name for probe %d can't be read: %s",
- prb_num, err->message);
+ /* Don't log "No such file or directory" messages. */
+ if (err->code != G_FILE_ERROR_NOENT)
+ sr_dbg("Name for probe %d can't be read (%d): %s",
+ prb_num, err->code, err->message);
g_string_free(path, TRUE);
g_error_free(err);
return ret;
static int revB_addr_to_num(unsigned int addr)
{
switch (addr) {
- case 0x44: return 5;
- case 0x45: return 6;
- case 0x42: return 3;
- case 0x43: return 4;
- default: return addr - 0x3f;
+ case 0x44: return 5;
+ case 0x45: return 6;
+ case 0x42: return 3;
+ case 0x43: return 4;
+ default: return addr - 0x3f;
}
}
}
/* We need to scale measurements down from the units used by the drivers. */
-static float adjust_data(int val, int type)
+static int type_digits(int type)
{
switch (type) {
case ENRG_PWR:
- return ((float)val) / 1000000.0;
+ return 6;
case ENRG_CURR: /* Fallthrough */
case ENRG_VOL: /* Fallthrough */
case TEMP_IN: /* Fallthrough */
case TEMP_OUT:
- return ((float)val) / 1000.0;
+ return 3;
default:
- return 0.0;
+ return 0;
}
}
return -1.0;
}
- return adjust_data(strtol(buf, NULL, 10), chp->ch_type);
+ chp->digits = type_digits(chp->ch_type);
+ return strtol(buf, NULL, 10) * powf(10, -chp->digits);
}
SR_PRIV int bl_acme_open_channel(struct sr_channel *ch)
SR_PRIV int bl_acme_receive_data(int fd, int revents, void *cb_data)
{
uint64_t nrexpiration;
- struct sr_datafeed_packet packet, framep;
+ struct sr_datafeed_packet packet;
struct sr_datafeed_analog analog;
struct sr_analog_encoding encoding;
struct sr_analog_meaning meaning;
* accuracy.
*/
for (i = 0; i < nrexpiration; i++) {
- framep.type = SR_DF_FRAME_BEGIN;
- sr_session_send(sdi, &framep);
+ std_session_send_df_frame_begin(sdi);
/*
* Due to different units used in each channel we're sending
if (i < 1)
chp->val = read_sample(ch);
+ analog.encoding->digits = chp->digits;
+ analog.spec->spec_digits = chp->digits;
analog.data = &chp->val;
sr_session_send(sdi, &packet);
}
- framep.type = SR_DF_FRAME_END;
- sr_session_send(sdi, &framep);
+ std_session_send_df_frame_end(sdi);
}
sr_sw_limits_update_samples_read(&devc->limits, 1);
if (sr_sw_limits_check(&devc->limits)) {
- sdi->driver->dev_acquisition_stop(sdi);
+ sr_dev_acquisition_stop(sdi);
return TRUE;
}