rigol-ds: Send FRAME_BEGIN and FRAME_END per frame, not per channel.
This commit is contained in:
parent
bac11aeb1b
commit
f76c24f6fd
|
@ -807,6 +807,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
struct sr_scpi_dev_inst *scpi;
|
struct sr_scpi_dev_inst *scpi;
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
struct sr_probe *probe;
|
struct sr_probe *probe;
|
||||||
|
struct sr_datafeed_packet packet;
|
||||||
GSList *l;
|
GSList *l;
|
||||||
|
|
||||||
if (sdi->status != SR_ST_ACTIVE)
|
if (sdi->status != SR_ST_ACTIVE)
|
||||||
|
@ -908,6 +909,10 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Start of first frame. */
|
||||||
|
packet.type = SR_DF_FRAME_BEGIN;
|
||||||
|
sr_session_send(cb_data, &packet);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -351,7 +351,7 @@ SR_PRIV int rigol_ds_channel_start(const struct sr_dev_inst *sdi)
|
||||||
rigol_ds_set_wait_event(devc, WAIT_NONE);
|
rigol_ds_set_wait_event(devc, WAIT_NONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
devc->num_frame_samples = 0;
|
devc->num_channel_bytes = 0;
|
||||||
devc->num_block_bytes = 0;
|
devc->num_block_bytes = 0;
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
@ -494,12 +494,6 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
|
||||||
|
|
||||||
devc->num_block_read += len;
|
devc->num_block_read += len;
|
||||||
|
|
||||||
if (devc->num_frame_samples == 0) {
|
|
||||||
/* Start of a new frame. */
|
|
||||||
packet.type = SR_DF_FRAME_BEGIN;
|
|
||||||
sr_session_send(sdi, &packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (probe->type == SR_PROBE_ANALOG) {
|
if (probe->type == SR_PROBE_ANALOG) {
|
||||||
vref = devc->vert_reference[probe->index];
|
vref = devc->vert_reference[probe->index];
|
||||||
vdiv = devc->vdiv[probe->index] / 25.6;
|
vdiv = devc->vdiv[probe->index] / 25.6;
|
||||||
|
@ -551,16 +545,13 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
|
||||||
sr_dbg("%d of %d block bytes read", devc->num_block_read, devc->num_block_bytes);
|
sr_dbg("%d of %d block bytes read", devc->num_block_read, devc->num_block_bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
devc->num_frame_samples += len;
|
devc->num_channel_bytes += len;
|
||||||
|
|
||||||
if (devc->num_frame_samples < expected_data_bytes)
|
if (devc->num_channel_bytes < expected_data_bytes)
|
||||||
/* Don't have the whole frame yet. */
|
/* Don't have the full data for this channel yet, re-run. */
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
/* End of the frame. */
|
/* End of data for this channel. */
|
||||||
sr_dbg("Frame completed, %d samples", devc->num_frame_samples);
|
|
||||||
packet.type = SR_DF_FRAME_END;
|
|
||||||
sr_session_send(sdi, &packet);
|
|
||||||
if (devc->model->series >= RIGOL_DS1000Z) {
|
if (devc->model->series >= RIGOL_DS1000Z) {
|
||||||
/* Signal end of data download to scope */
|
/* Signal end of data download to scope */
|
||||||
if (devc->data_source != DATA_SOURCE_LIVE)
|
if (devc->data_source != DATA_SOURCE_LIVE)
|
||||||
|
@ -585,7 +576,13 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
|
||||||
/* Now we need to get the digital data. */
|
/* Now we need to get the digital data. */
|
||||||
devc->channel_entry = devc->enabled_digital_probes;
|
devc->channel_entry = devc->enabled_digital_probes;
|
||||||
rigol_ds_channel_start(sdi);
|
rigol_ds_channel_start(sdi);
|
||||||
} else if (++devc->num_frames == devc->limit_frames) {
|
} else {
|
||||||
|
/* Done with this frame. */
|
||||||
|
packet.type = SR_DF_FRAME_END;
|
||||||
|
sr_session_send(cb_data, &packet);
|
||||||
|
|
||||||
|
if (++devc->num_frames == devc->limit_frames) {
|
||||||
|
/* Last frame, stop capture. */
|
||||||
sdi->driver->dev_acquisition_stop(sdi, cb_data);
|
sdi->driver->dev_acquisition_stop(sdi, cb_data);
|
||||||
} else {
|
} else {
|
||||||
/* Get the next frame, starting with the first analog channel. */
|
/* Get the next frame, starting with the first analog channel. */
|
||||||
|
@ -598,6 +595,11 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
|
||||||
rigol_ds_channel_start(sdi);
|
rigol_ds_channel_start(sdi);
|
||||||
else
|
else
|
||||||
rigol_ds_capture_start(sdi);
|
rigol_ds_capture_start(sdi);
|
||||||
|
|
||||||
|
/* Start of next frame. */
|
||||||
|
packet.type = SR_DF_FRAME_BEGIN;
|
||||||
|
sr_session_send(cb_data, &packet);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -132,8 +132,8 @@ struct dev_context {
|
||||||
uint64_t num_frames;
|
uint64_t num_frames;
|
||||||
/* GSList entry for the current channel. */
|
/* GSList entry for the current channel. */
|
||||||
GSList *channel_entry;
|
GSList *channel_entry;
|
||||||
/* Number of samples received in current frame. */
|
/* Number of bytes received for current channel. */
|
||||||
uint64_t num_frame_samples;
|
uint64_t num_channel_bytes;
|
||||||
/* Number of bytes in current data block, if 0 block header expected */
|
/* Number of bytes in current data block, if 0 block header expected */
|
||||||
uint64_t num_block_bytes;
|
uint64_t num_block_bytes;
|
||||||
/* Number of data block bytes already read */
|
/* Number of data block bytes already read */
|
||||||
|
|
Loading…
Reference in New Issue