mso-19: Initial analog probe support (unfinished).
- Added the analog probe (unfinished). - Reset trigger to state to 0 before capture, just incase the scope is in the middle of a capture.
This commit is contained in:
parent
5952553f56
commit
365f04d61f
|
@ -22,6 +22,7 @@
|
||||||
#include "protocol.h"
|
#include "protocol.h"
|
||||||
|
|
||||||
static const int hwcaps[] = {
|
static const int hwcaps[] = {
|
||||||
|
SR_CONF_OSCILLOSCOPE,
|
||||||
SR_CONF_LOGIC_ANALYZER,
|
SR_CONF_LOGIC_ANALYZER,
|
||||||
SR_CONF_SAMPLERATE,
|
SR_CONF_SAMPLERATE,
|
||||||
SR_CONF_TRIGGER_SLOPE,
|
SR_CONF_TRIGGER_SLOPE,
|
||||||
|
@ -38,7 +39,8 @@ static const int hwcaps[] = {
|
||||||
* See also: http://www.linkinstruments.com/images/mso19_1113.gif
|
* See also: http://www.linkinstruments.com/images/mso19_1113.gif
|
||||||
*/
|
*/
|
||||||
SR_PRIV const char *mso19_probe_names[NUM_PROBES + 1] = {
|
SR_PRIV const char *mso19_probe_names[NUM_PROBES + 1] = {
|
||||||
"0", "1", "2", "3", "4", "5", "6", "7", NULL
|
/* Note: DSO needs to be first. */
|
||||||
|
"DSO", "0", "1", "2", "3", "4", "5", "6", "7", NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct sr_samplerates samplerates = {
|
static const struct sr_samplerates samplerates = {
|
||||||
|
@ -65,6 +67,7 @@ static GSList *hw_scan(GSList *options)
|
||||||
GSList *l;
|
GSList *l;
|
||||||
struct sr_config *src;
|
struct sr_config *src;
|
||||||
struct udev *udev;
|
struct udev *udev;
|
||||||
|
int ptype;
|
||||||
|
|
||||||
(void)options;
|
(void)options;
|
||||||
|
|
||||||
|
@ -183,7 +186,8 @@ static GSList *hw_scan(GSList *options)
|
||||||
|
|
||||||
for (i = 0; i < NUM_PROBES; i++) {
|
for (i = 0; i < NUM_PROBES; i++) {
|
||||||
struct sr_probe *probe;
|
struct sr_probe *probe;
|
||||||
if (!(probe = sr_probe_new(i, SR_PROBE_LOGIC, TRUE,
|
ptype = (i == 0) ? SR_PROBE_ANALOG : SR_PROBE_LOGIC;
|
||||||
|
if (!(probe = sr_probe_new(i, ptype, TRUE,
|
||||||
mso19_probe_names[i])))
|
mso19_probe_names[i])))
|
||||||
return 0;
|
return 0;
|
||||||
sdi->probes = g_slist_append(sdi->probes, probe);
|
sdi->probes = g_slist_append(sdi->probes, probe);
|
||||||
|
@ -443,9 +447,15 @@ static int hw_dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
if (ret != SR_OK)
|
if (ret != SR_OK)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
/* Reset trigger state. */
|
||||||
|
devc->trigger_state = 0x00;
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, DRIVER_LOG_DOMAIN);
|
std_session_send_df_header(cb_data, DRIVER_LOG_DOMAIN);
|
||||||
|
|
||||||
|
/* Our first probe is analog, the other 8 are of type 'logic'. */
|
||||||
|
/* TODO. */
|
||||||
|
|
||||||
sr_source_add(devc->serial->fd, G_IO_IN, -1, mso_receive_data, cb_data);
|
sr_source_add(devc->serial->fd, G_IO_IN, -1, mso_receive_data, cb_data);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -346,6 +346,7 @@ SR_PRIV int mso_check_trigger(struct sr_serial_dev_inst *serial, uint8_t * info)
|
||||||
uint8_t buf = 0;
|
uint8_t buf = 0;
|
||||||
if (serial_read(serial, &buf, 1) != 1) /* FIXME: Need timeout */
|
if (serial_read(serial, &buf, 1) != 1) /* FIXME: Need timeout */
|
||||||
ret = SR_ERR;
|
ret = SR_ERR;
|
||||||
|
if (!info)
|
||||||
*info = buf;
|
*info = buf;
|
||||||
|
|
||||||
sr_dbg("Trigger state is: 0x%x.", *info);
|
sr_dbg("Trigger state is: 0x%x.", *info);
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
#define USB_VENDOR "3195"
|
#define USB_VENDOR "3195"
|
||||||
#define USB_PRODUCT "f190"
|
#define USB_PRODUCT "f190"
|
||||||
|
|
||||||
#define NUM_PROBES 8
|
#define NUM_PROBES (1 + 8)
|
||||||
#define NUM_TRIGGER_STAGES 4
|
#define NUM_TRIGGER_STAGES 4
|
||||||
#define TRIGGER_TYPE "01" //the first r/f is used for the whole group
|
#define TRIGGER_TYPE "01" //the first r/f is used for the whole group
|
||||||
#define SERIALCOMM "460800/8n1/flow=2"
|
#define SERIALCOMM "460800/8n1/flow=2"
|
||||||
|
|
Loading…
Reference in New Issue