rigol-ds: Support 4 analog channels.

This commit is contained in:
Martin Ling 2013-12-29 01:34:58 +01:00
parent 0d9f5a12cb
commit 821fbcadcc
3 changed files with 123 additions and 97 deletions

View File

@ -117,6 +117,8 @@ static const uint64_t vdivs[][2] = {
static const char *trigger_sources[] = { static const char *trigger_sources[] = {
"CH1", "CH1",
"CH2", "CH2",
"CH3",
"CH4",
"EXT", "EXT",
"AC Line", "AC Line",
"D0", "D0",
@ -159,26 +161,26 @@ static const char *data_sources[] = {
#define AGILENT "Agilent Technologies" #define AGILENT "Agilent Technologies"
static const struct rigol_ds_model supported_models[] = { static const struct rigol_ds_model supported_models[] = {
{RIGOL, "DS1052E", RIGOL_DS1000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, false, 12}, {RIGOL, "DS1052E", RIGOL_DS1000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, 2, false, 12},
{RIGOL, "DS1102E", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, false, 12}, {RIGOL, "DS1102E", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, false, 12},
{RIGOL, "DS1152E", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, false, 12}, {RIGOL, "DS1152E", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, false, 12},
{RIGOL, "DS1052D", RIGOL_DS1000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, true, 12}, {RIGOL, "DS1052D", RIGOL_DS1000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, 2, true, 12},
{RIGOL, "DS1102D", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, true, 12}, {RIGOL, "DS1102D", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, true, 12},
{RIGOL, "DS1152D", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, true, 12}, {RIGOL, "DS1152D", RIGOL_DS1000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, true, 12},
{RIGOL, "DS2072", RIGOL_DS2000, PROTOCOL_IEEE488_2, {5, 1000000000}, {500, 1}, {500, 1000000}, false, 14}, {RIGOL, "DS2072", RIGOL_DS2000, PROTOCOL_IEEE488_2, {5, 1000000000}, {500, 1}, {500, 1000000}, 2, false, 14},
{RIGOL, "DS2102", RIGOL_DS2000, PROTOCOL_IEEE488_2, {5, 1000000000}, {500, 1}, {500, 1000000}, false, 14}, {RIGOL, "DS2102", RIGOL_DS2000, PROTOCOL_IEEE488_2, {5, 1000000000}, {500, 1}, {500, 1000000}, 2, false, 14},
{RIGOL, "DS2202", RIGOL_DS2000, PROTOCOL_IEEE488_2, {2, 1000000000}, {500, 1}, {500, 1000000}, false, 14}, {RIGOL, "DS2202", RIGOL_DS2000, PROTOCOL_IEEE488_2, {2, 1000000000}, {500, 1}, {500, 1000000}, 2, false, 14},
{RIGOL, "VS5022", RIGOL_VS5000, PROTOCOL_LEGACY, {20, 1000000000}, {50, 1}, {2, 1000}, false, 14}, {RIGOL, "VS5022", RIGOL_VS5000, PROTOCOL_LEGACY, {20, 1000000000}, {50, 1}, {2, 1000}, 2, false, 14},
{RIGOL, "VS5022D", RIGOL_VS5000, PROTOCOL_LEGACY, {20, 1000000000}, {50, 1}, {2, 1000}, true, 14}, {RIGOL, "VS5022D", RIGOL_VS5000, PROTOCOL_LEGACY, {20, 1000000000}, {50, 1}, {2, 1000}, 2, true, 14},
{RIGOL, "VS5042", RIGOL_VS5000, PROTOCOL_LEGACY, {10, 1000000000}, {50, 1}, {2, 1000}, false, 14}, {RIGOL, "VS5042", RIGOL_VS5000, PROTOCOL_LEGACY, {10, 1000000000}, {50, 1}, {2, 1000}, 2, false, 14},
{RIGOL, "VS5042D", RIGOL_VS5000, PROTOCOL_LEGACY, {10, 1000000000}, {50, 1}, {2, 1000}, true, 14}, {RIGOL, "VS5042D", RIGOL_VS5000, PROTOCOL_LEGACY, {10, 1000000000}, {50, 1}, {2, 1000}, 2, true, 14},
{RIGOL, "VS5062", RIGOL_VS5000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, false, 14}, {RIGOL, "VS5062", RIGOL_VS5000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, 2, false, 14},
{RIGOL, "VS5062D", RIGOL_VS5000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, true, 14}, {RIGOL, "VS5062D", RIGOL_VS5000, PROTOCOL_LEGACY, {5, 1000000000}, {50, 1}, {2, 1000}, 2, true, 14},
{RIGOL, "VS5102", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, false, 14}, {RIGOL, "VS5102", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, false, 14},
{RIGOL, "VS5102D", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, true, 14}, {RIGOL, "VS5102D", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, true, 14},
{RIGOL, "VS5202", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, false, 14}, {RIGOL, "VS5202", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, false, 14},
{RIGOL, "VS5202D", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, true, 14}, {RIGOL, "VS5202D", RIGOL_VS5000, PROTOCOL_LEGACY, {2, 1000000000}, {50, 1}, {2, 1000}, 2, true, 14},
{AGILENT, "DSO1014A", AGILENT_DSO1000, PROTOCOL_IEEE488_2, {2, 1000000000}, {50, 1}, {2, 1000}, false, 12}, {AGILENT, "DSO1014A", AGILENT_DSO1000, PROTOCOL_IEEE488_2, {2, 1000000000}, {50, 1}, {2, 1000}, 4, false, 12},
}; };
SR_PRIV struct sr_dev_driver rigol_ds_driver_info; SR_PRIV struct sr_dev_driver rigol_ds_driver_info;
@ -314,10 +316,10 @@ static int probe_port(const char *resource, const char *serialcomm, GSList **dev
devc->limit_frames = 0; devc->limit_frames = 0;
devc->model = model; devc->model = model;
for (i = 0; i < 2; i++) { for (i = 0; i < model->analog_channels; i++) {
channel_name = (i == 0 ? "CH1" : "CH2"); if (!(channel_name = g_strdup_printf("CH%d", i + 1)))
if (!(probe = sr_probe_new(i, SR_PROBE_ANALOG, TRUE, channel_name)))
return SR_ERR_MALLOC; return SR_ERR_MALLOC;
probe = sr_probe_new(i, SR_PROBE_ANALOG, TRUE, channel_name);
sdi->probes = g_slist_append(sdi->probes, probe); sdi->probes = g_slist_append(sdi->probes, probe);
devc->analog_groups[i].name = channel_name; devc->analog_groups[i].name = channel_name;
devc->analog_groups[i].probes = g_slist_append(NULL, probe); devc->analog_groups[i].probes = g_slist_append(NULL, probe);
@ -591,6 +593,10 @@ static int config_set(int id, GVariant *data, const struct sr_dev_inst *sdi,
tmp_str = "CHAN1"; tmp_str = "CHAN1";
else if (!strcmp(devc->trigger_source, "CH2")) else if (!strcmp(devc->trigger_source, "CH2"))
tmp_str = "CHAN2"; tmp_str = "CHAN2";
else if (!strcmp(devc->trigger_source, "CH3"))
tmp_str = "CHAN3";
else if (!strcmp(devc->trigger_source, "CH4"))
tmp_str = "CHAN4";
else else
tmp_str = (char *)devc->trigger_source; tmp_str = (char *)devc->trigger_source;
ret = set_cfg(sdi, ":TRIG:EDGE:SOUR %s", tmp_str); ret = set_cfg(sdi, ":TRIG:EDGE:SOUR %s", tmp_str);
@ -836,15 +842,16 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
/* Send header packet to the session bus. */ /* Send header packet to the session bus. */
std_session_send_df_header(cb_data, LOG_PREFIX); std_session_send_df_header(cb_data, LOG_PREFIX);
if (devc->enabled_analog_probes)
devc->channel_entry = devc->enabled_analog_probes;
else
devc->channel_entry = devc->enabled_digital_probes;
if (devc->model->protocol == PROTOCOL_LEGACY) { if (devc->model->protocol == PROTOCOL_LEGACY) {
devc->analog_frame_size = (devc->model->series == RIGOL_VS5000 ? devc->analog_frame_size = (devc->model->series == RIGOL_VS5000 ?
VS5000_ANALOG_LIVE_WAVEFORM_SIZE : VS5000_ANALOG_LIVE_WAVEFORM_SIZE :
DS1000_ANALOG_LIVE_WAVEFORM_SIZE); DS1000_ANALOG_LIVE_WAVEFORM_SIZE);
/* Fetch the first frame. */ /* Fetch the first frame. */
if (devc->enabled_analog_probes)
devc->channel = devc->enabled_analog_probes->data;
else
devc->channel = devc->enabled_digital_probes->data;
if (rigol_ds_channel_start(sdi) != SR_OK) if (rigol_ds_channel_start(sdi) != SR_OK)
return SR_ERR; return SR_ERR;
} else { } else {
@ -870,7 +877,6 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
else else
devc->analog_frame_size = DS2000_ANALOG_LIVE_WAVEFORM_SIZE; devc->analog_frame_size = DS2000_ANALOG_LIVE_WAVEFORM_SIZE;
} }
devc->channel = devc->enabled_analog_probes->data;
if (rigol_ds_capture_start(sdi) != SR_OK) if (rigol_ds_capture_start(sdi) != SR_OK)
return SR_ERR; return SR_ERR;
} }

View File

@ -211,13 +211,16 @@ static int rigol_ds_stop_wait(const struct sr_dev_inst *sdi)
static int rigol_ds_check_stop(const struct sr_dev_inst *sdi) static int rigol_ds_check_stop(const struct sr_dev_inst *sdi)
{ {
struct dev_context *devc; struct dev_context *devc;
struct sr_probe *probe;
int tmp; int tmp;
if (!(devc = sdi->priv)) if (!(devc = sdi->priv))
return SR_ERR; return SR_ERR;
probe = devc->channel_entry->data;
if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN%d", if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN%d",
devc->channel->index + 1) != SR_OK) probe->index + 1) != SR_OK)
return SR_ERR; return SR_ERR;
/* Check that the number of samples will be accepted */ /* Check that the number of samples will be accepted */
if (sr_scpi_send(sdi->conn, ":WAV:POIN %d;*OPC", devc->analog_frame_size) != SR_OK) if (sr_scpi_send(sdi->conn, ":WAV:POIN %d;*OPC", devc->analog_frame_size) != SR_OK)
@ -320,25 +323,27 @@ SR_PRIV int rigol_ds_capture_start(const struct sr_dev_inst *sdi)
SR_PRIV int rigol_ds_channel_start(const struct sr_dev_inst *sdi) SR_PRIV int rigol_ds_channel_start(const struct sr_dev_inst *sdi)
{ {
struct dev_context *devc; struct dev_context *devc;
struct sr_probe *probe;
if (!(devc = sdi->priv)) if (!(devc = sdi->priv))
return SR_ERR; return SR_ERR;
sr_dbg("Starting reading data from channel %d", probe = devc->channel_entry->data;
devc->channel->index + 1);
sr_dbg("Starting reading data from channel %d", probe->index + 1);
if (devc->model->protocol == PROTOCOL_LEGACY) { if (devc->model->protocol == PROTOCOL_LEGACY) {
if (devc->channel->type == SR_PROBE_LOGIC) { if (probe->type == SR_PROBE_LOGIC) {
if (sr_scpi_send(sdi->conn, ":WAV:DATA? DIG") != SR_OK) if (sr_scpi_send(sdi->conn, ":WAV:DATA? DIG") != SR_OK)
return SR_ERR; return SR_ERR;
} else { } else {
if (sr_scpi_send(sdi->conn, ":WAV:DATA? CHAN%c", if (sr_scpi_send(sdi->conn, ":WAV:DATA? CHAN%d",
devc->channel->name[2]) != SR_OK) probe->index + 1) != SR_OK)
return SR_ERR; return SR_ERR;
} }
} else { } else {
if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN%d", if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN%d",
devc->channel->index + 1) != SR_OK) probe->index + 1) != SR_OK)
return SR_ERR; return SR_ERR;
if (devc->data_source != DATA_SOURCE_LIVE) { if (devc->data_source != DATA_SOURCE_LIVE) {
if (sr_scpi_send(sdi->conn, ":WAV:RES") != SR_OK) if (sr_scpi_send(sdi->conn, ":WAV:RES") != SR_OK)
@ -450,7 +455,7 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
} }
} }
probe = devc->channel; probe = devc->channel_entry->data;
if (devc->num_block_bytes == 0) { if (devc->num_block_bytes == 0) {
if (devc->model->protocol == PROTOCOL_IEEE488_2) { if (devc->model->protocol == PROTOCOL_IEEE488_2) {
@ -565,19 +570,18 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
sr_scpi_send(sdi->conn, ":WAV:END"); sr_scpi_send(sdi->conn, ":WAV:END");
} }
if (devc->enabled_analog_probes if (probe->type == SR_PROBE_ANALOG
&& devc->channel == devc->enabled_analog_probes->data && devc->channel_entry->next != NULL) {
&& devc->enabled_analog_probes->next != NULL) { /* We got the frame for this analog channel, but
/* We got the frame for the first analog channel, but * there's another analog channel. */
* there's a second analog channel. */ devc->channel_entry = devc->channel_entry->next;
devc->channel = devc->enabled_analog_probes->next->data;
rigol_ds_channel_start(sdi); rigol_ds_channel_start(sdi);
} else { } else {
/* Done with both analog channels in this frame. */ /* Done with all analog channels in this frame. */
if (devc->enabled_digital_probes if (devc->enabled_digital_probes
&& devc->channel != devc->enabled_digital_probes->data) { && devc->channel_entry != devc->enabled_digital_probes) {
/* Now we need to get the digital data. */ /* Now we need to get the digital data. */
devc->channel = devc->enabled_digital_probes->data; 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 if (++devc->num_frames == devc->limit_frames) {
/* End of last frame. */ /* End of last frame. */
@ -587,9 +591,9 @@ SR_PRIV int rigol_ds_receive(int fd, int revents, void *cb_data)
} else { } else {
/* Get the next frame, starting with the first analog channel. */ /* Get the next frame, starting with the first analog channel. */
if (devc->enabled_analog_probes) if (devc->enabled_analog_probes)
devc->channel = devc->enabled_analog_probes->data; devc->channel_entry = devc->enabled_analog_probes;
else else
devc->channel = devc->enabled_digital_probes->data; devc->channel_entry = devc->enabled_digital_probes;
if (devc->model->protocol == PROTOCOL_LEGACY) if (devc->model->protocol == PROTOCOL_LEGACY)
rigol_ds_channel_start(sdi); rigol_ds_channel_start(sdi);
@ -673,35 +677,36 @@ SR_PRIV int rigol_ds_get_dev_cfg(const struct sr_dev_inst *sdi)
{ {
struct dev_context *devc; struct dev_context *devc;
char *t_s, *cmd; char *t_s, *cmd;
int i, res; unsigned int i;
int res;
devc = sdi->priv; devc = sdi->priv;
/* Analog channel state. */ /* Analog channel state. */
if (get_cfg_string(sdi, ":CHAN1:DISP?", &t_s) != SR_OK) for (i = 0; i < devc->model->analog_channels; i++) {
return SR_ERR; cmd = g_strdup_printf(":CHAN%d:DISP?", i + 1);
devc->analog_channels[0] = !strcmp(t_s, "ON") || !strcmp(t_s, "1"); res = get_cfg_string(sdi, cmd, &t_s);
g_free(t_s); g_free(cmd);
if (get_cfg_string(sdi, ":CHAN2:DISP?", &t_s) != SR_OK) if (res != SR_OK)
return SR_ERR; return SR_ERR;
devc->analog_channels[1] = !strcmp(t_s, "ON") || !strcmp(t_s, "1"); devc->analog_channels[i] = !strcmp(t_s, "ON") || !strcmp(t_s, "1");
g_free(t_s); }
sr_dbg("Current analog channel state CH1 %s CH2 %s", sr_dbg("Current analog channel state:");
devc->analog_channels[0] ? "on" : "off", for (i = 0; i < devc->model->analog_channels; i++)
devc->analog_channels[1] ? "on" : "off"); sr_dbg("CH%d %s", i + 1, devc->analog_channels[i] ? "on" : "off");
/* Digital channel state. */ /* Digital channel state. */
if (devc->model->has_digital) { if (devc->model->has_digital) {
sr_dbg("Current digital channel state:"); sr_dbg("Current digital channel state:");
for (i = 0; i < 16; i++) { for (i = 0; i < 16; i++) {
cmd = g_strdup_printf(":DIG%d:TURN?", i); cmd = g_strdup_printf(":DIG%d:TURN?", i + 1);
res = get_cfg_string(sdi, cmd, &t_s); res = get_cfg_string(sdi, cmd, &t_s);
g_free(cmd); g_free(cmd);
if (res != SR_OK) if (res != SR_OK)
return SR_ERR; return SR_ERR;
devc->digital_channels[i] = !strcmp(t_s, "ON") ? TRUE : FALSE; devc->digital_channels[i] = !strcmp(t_s, "ON") ? TRUE : FALSE;
g_free(t_s); g_free(t_s);
sr_dbg("D%d: %s", i, devc->digital_channels[i] ? "on" : "off"); sr_dbg("D%d: %s", i + 1, devc->digital_channels[i] ? "on" : "off");
} }
} }
@ -711,41 +716,52 @@ SR_PRIV int rigol_ds_get_dev_cfg(const struct sr_dev_inst *sdi)
sr_dbg("Current timebase %g", devc->timebase); sr_dbg("Current timebase %g", devc->timebase);
/* Vertical gain. */ /* Vertical gain. */
if (get_cfg_float(sdi, ":CHAN1:SCAL?", &devc->vdiv[0]) != SR_OK) for (i = 0; i < devc->model->analog_channels; i++) {
return SR_ERR; cmd = g_strdup_printf(":CHAN%d:SCAL?", i + 1);
if (get_cfg_float(sdi, ":CHAN2:SCAL?", &devc->vdiv[1]) != SR_OK) res = get_cfg_float(sdi, cmd, &devc->vdiv[i]);
return SR_ERR; g_free(cmd);
sr_dbg("Current vertical gain CH1 %g CH2 %g", devc->vdiv[0], devc->vdiv[1]); if (res != SR_OK)
return SR_ERR;
}
sr_dbg("Current vertical gain:");
for (i = 0; i < devc->model->analog_channels; i++)
sr_dbg("CH%d %g", i + 1, devc->vdiv[i]);
sr_dbg("Current vertical reference:");
if (devc->model->protocol == PROTOCOL_IEEE488_2) { if (devc->model->protocol == PROTOCOL_IEEE488_2) {
/* Vertical reference - not certain if this is the place to read it. */ /* Vertical reference - not certain if this is the place to read it. */
if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN1") != SR_OK) for (i = 0; i < devc->model->analog_channels; i++) {
return SR_ERR; if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN%d", i + 1) != SR_OK)
if (get_cfg_int(sdi, ":WAV:YREF?", &devc->vert_reference[0]) != SR_OK) return SR_ERR;
return SR_ERR; if (get_cfg_int(sdi, ":WAV:YREF?", &devc->vert_reference[i]) != SR_OK)
if (sr_scpi_send(sdi->conn, ":WAV:SOUR CHAN2") != SR_OK) return SR_ERR;
return SR_ERR; sr_dbg("CH%d %d", i + 1, devc->vert_reference[i]);
if (get_cfg_int(sdi, ":WAV:YREF?", &devc->vert_reference[1]) != SR_OK) }
return SR_ERR;
sr_dbg("Current vertical reference CH1 %d CH2 %d",
devc->vert_reference[0], devc->vert_reference[1]);
} }
/* Vertical offset. */ /* Vertical offset. */
if (get_cfg_float(sdi, ":CHAN1:OFFS?", &devc->vert_offset[0]) != SR_OK) for (i = 0; i < devc->model->analog_channels; i++) {
return SR_ERR; cmd = g_strdup_printf(":CHAN%d:OFFS?", i + 1);
if (get_cfg_float(sdi, ":CHAN2:OFFS?", &devc->vert_offset[1]) != SR_OK) res = get_cfg_float(sdi, cmd, &devc->vert_offset[i]);
return SR_ERR; g_free(cmd);
sr_dbg("Current vertical offset CH1 %g CH2 %g", devc->vert_offset[0], if (res != SR_OK)
devc->vert_offset[1]); return SR_ERR;
}
sr_dbg("Current vertical offset:");
for (i = 0; i < devc->model->analog_channels; i++)
sr_dbg("CH%d %g", i + 1, devc->vert_offset[i]);
/* Coupling. */ /* Coupling. */
if (get_cfg_string(sdi, ":CHAN1:COUP?", &devc->coupling[0]) != SR_OK) for (i = 0; i < devc->model->analog_channels; i++) {
return SR_ERR; cmd = g_strdup_printf(":CHAN%d:COUP?", i + 1);
if (get_cfg_string(sdi, ":CHAN2:COUP?", &devc->coupling[1]) != SR_OK) res = get_cfg_string(sdi, cmd, &devc->coupling[i]);
return SR_ERR; g_free(cmd);
sr_dbg("Current coupling CH1 %s CH2 %s", devc->coupling[0], if (res != SR_OK)
devc->coupling[1]); return SR_ERR;
}
sr_dbg("Current coupling:");
for (i = 0; i < devc->model->analog_channels; i++)
sr_dbg("CH%d %s", i + 1, devc->coupling[i]);
/* Trigger source. */ /* Trigger source. */
if (get_cfg_string(sdi, ":TRIG:EDGE:SOUR?", &devc->trigger_source) != SR_OK) if (get_cfg_string(sdi, ":TRIG:EDGE:SOUR?", &devc->trigger_source) != SR_OK)

View File

@ -39,6 +39,9 @@
/* Size of acquisition buffers */ /* Size of acquisition buffers */
#define ACQ_BUFFER_SIZE 32768 #define ACQ_BUFFER_SIZE 32768
#define MAX_ANALOG_PROBES 4
#define MAX_DIGITAL_PROBES 16
enum rigol_ds_series { enum rigol_ds_series {
RIGOL_DS1000, RIGOL_DS1000,
RIGOL_DS1000Z, RIGOL_DS1000Z,
@ -70,6 +73,7 @@ struct rigol_ds_model {
uint64_t min_timebase[2]; uint64_t min_timebase[2];
uint64_t max_timebase[2]; uint64_t max_timebase[2];
uint64_t min_vdiv[2]; uint64_t min_vdiv[2];
unsigned int analog_channels;
bool has_digital; bool has_digital;
int num_horizontal_divs; int num_horizontal_divs;
}; };
@ -93,7 +97,7 @@ struct dev_context {
uint64_t num_vdivs; uint64_t num_vdivs;
/* Probe groups */ /* Probe groups */
struct sr_probe_group analog_groups[2]; struct sr_probe_group analog_groups[MAX_ANALOG_PROBES];
struct sr_probe_group digital_group; struct sr_probe_group digital_group;
/* Acquisition settings */ /* Acquisition settings */
@ -105,23 +109,23 @@ struct dev_context {
uint64_t analog_frame_size; uint64_t analog_frame_size;
/* Device settings */ /* Device settings */
gboolean analog_channels[2]; gboolean analog_channels[MAX_ANALOG_PROBES];
gboolean digital_channels[16]; gboolean digital_channels[MAX_DIGITAL_PROBES];
float timebase; float timebase;
float vdiv[2]; float vdiv[MAX_ANALOG_PROBES];
int vert_reference[2]; int vert_reference[MAX_ANALOG_PROBES];
float vert_offset[2]; float vert_offset[MAX_ANALOG_PROBES];
char *trigger_source; char *trigger_source;
float horiz_triggerpos; float horiz_triggerpos;
char *trigger_slope; char *trigger_slope;
char *coupling[2]; char *coupling[MAX_ANALOG_PROBES];
/* Operational state */ /* Operational state */
/* Number of frames received in total. */ /* Number of frames received in total. */
uint64_t num_frames; uint64_t num_frames;
/* The channel we are currently receiving data for. */ /* GSList entry for the current channel. */
struct sr_probe *channel; GSList *channel_entry;
/* Number of samples received in current frame. */ /* Number of samples received in current frame. */
uint64_t num_frame_samples; uint64_t num_frame_samples;
/* Number of bytes in current data block, if 0 block header expected */ /* Number of bytes in current data block, if 0 block header expected */