sr_dbg("Name for probe %d can't be read: %s",
prb_num, err->message);
g_string_free(path, TRUE);
+ g_error_free(err);
return ret;
}
if (!dir) {
sr_err("Error opening %s: %s", path->str, err->message);
g_string_free(path, TRUE);
+ g_error_free(err);
return -1;
}
return -1;
rd = read(fd, eeprom_buf, EEPROM_SIZE);
- g_close(fd, NULL);
+ close(fd);
if (rd != EEPROM_SIZE)
return -1;
if (!status) {
sr_err("Error reading shunt resistance: %s", err->message);
ret = SR_ERR_IO;
+ g_error_free(err);
goto out;
}
SR_PRIV int bl_acme_receive_data(int fd, int revents, void *cb_data)
{
- uint32_t cur_time, elapsed_time;
uint64_t nrexpiration;
struct sr_datafeed_packet packet, framep;
struct sr_datafeed_analog_old analog;
*/
for (i = 0; i < nrexpiration; i++) {
framep.type = SR_DF_FRAME_BEGIN;
- sr_session_send(cb_data, &framep);
+ sr_session_send(sdi, &framep);
/*
* Due to different units used in each channel we're sending
chp->val = read_sample(ch);
analog.data = &chp->val;
- sr_session_send(cb_data, &packet);
+ sr_session_send(sdi, &packet);
}
framep.type = SR_DF_FRAME_END;
- sr_session_send(cb_data, &framep);
+ sr_session_send(sdi, &framep);
}
- devc->samples_read++;
- if (devc->limit_samples > 0 &&
- devc->samples_read >= devc->limit_samples) {
- sr_info("Requested number of samples reached.");
- sdi->driver->dev_acquisition_stop(sdi, cb_data);
- devc->last_sample_fin = g_get_monotonic_time();
+ sr_sw_limits_update_samples_read(&devc->limits, 1);
+
+ if (sr_sw_limits_check(&devc->limits)) {
+ sdi->driver->dev_acquisition_stop(sdi);
return TRUE;
- } else if (devc->limit_msec > 0) {
- cur_time = g_get_monotonic_time();
- elapsed_time = cur_time - devc->start_time;
-
- if (elapsed_time >= devc->limit_msec) {
- sr_info("Sampling time limit reached.");
- sdi->driver->dev_acquisition_stop(sdi, cb_data);
- devc->last_sample_fin = g_get_monotonic_time();
- return TRUE;
- }
}
devc->last_sample_fin = g_get_monotonic_time();