X-Git-Url: https://sigrok.org/gitweb/?p=libsigrok.git;a=blobdiff_plain;f=src%2Fhardware%2Fscpi-dmm%2Fprotocol.h;h=04b8e683155bde2516d0113d58f63110f8a96419;hp=fe6138d4c1de3e3b63a023ffb86997565dc41aa4;hb=5bf642dbf80b8070b238ec1d83454e677cb2336b;hpb=4c80a272842271ace8f8a44f027615903ba8baee diff --git a/src/hardware/scpi-dmm/protocol.h b/src/hardware/scpi-dmm/protocol.h index fe6138d4..04b8e683 100644 --- a/src/hardware/scpi-dmm/protocol.h +++ b/src/hardware/scpi-dmm/protocol.h @@ -41,6 +41,10 @@ enum scpi_dmm_cmdcode { DMM_CMD_QUERY_VALUE, DMM_CMD_QUERY_PREC, DMM_CMD_SETUP_LOCAL, + DMM_CMD_QUERY_RANGE_AUTO, + DMM_CMD_QUERY_RANGE, + DMM_CMD_SETUP_RANGE_AUTO, + DMM_CMD_SETUP_RANGE, }; struct mqopt_item { @@ -49,8 +53,11 @@ struct mqopt_item { const char *scpi_func_setup; const char *scpi_func_query; int default_precision; + uint32_t drv_flags; }; #define NO_DFLT_PREC -99 +#define FLAGS_NONE 0 +#define FLAG_NO_RANGE (1 << 0) struct scpi_dmm_model { const char *vendor; @@ -64,6 +71,12 @@ struct scpi_dmm_model { const uint32_t *devopts; size_t devopts_size; unsigned int read_timeout_us; /* If zero, use default from src/scpi/scpi.c. */ + float infinity_limit; /* If zero, use default from protocol.c */ + gboolean check_opc; + const char *(*get_range_text)(const struct sr_dev_inst *sdi); + int (*set_range_from_text)(const struct sr_dev_inst *sdi, + const char *range); + GVariant *(*get_range_text_list)(const struct sr_dev_inst *sdi); }; struct dev_context { @@ -85,6 +98,7 @@ struct dev_context { struct sr_analog_spec spec[SCPI_DMM_MAX_CHANNELS]; } run_acq_info; gchar *precision; + char range_text[32]; }; SR_PRIV void scpi_dmm_cmd_delay(struct sr_scpi_dev_inst *scpi); @@ -97,6 +111,10 @@ SR_PRIV int scpi_dmm_get_mq(const struct sr_dev_inst *sdi, const struct mqopt_item **mqitem); SR_PRIV int scpi_dmm_set_mq(const struct sr_dev_inst *sdi, enum sr_mq mq, enum sr_mqflag flag); +SR_PRIV const char *scpi_dmm_get_range_text(const struct sr_dev_inst *sdi); +SR_PRIV int scpi_dmm_set_range_from_text(const struct sr_dev_inst *sdi, + const char *range); +SR_PRIV GVariant *scpi_dmm_get_range_text_list(const struct sr_dev_inst *sdi); SR_PRIV int scpi_dmm_get_meas_agilent(const struct sr_dev_inst *sdi, size_t ch); SR_PRIV int scpi_dmm_get_meas_gwinstek(const struct sr_dev_inst *sdi, size_t ch); SR_PRIV int scpi_dmm_receive_data(int fd, int revents, void *cb_data);