X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=src%2Fscpi.h;h=256aa4c1ceb9ba6b08d36b6c90ccecfebcd4051a;hb=39e19723475d4394739530d3f843d215e4a6742a;hp=13b2d3011d543149d80ad56cfb45fe1a0e290527;hpb=a019bc48fd683667ee32e33d872b5d7037a16acf;p=libsigrok.git diff --git a/src/scpi.h b/src/scpi.h index 13b2d301..256aa4c1 100644 --- a/src/scpi.h +++ b/src/scpi.h @@ -33,36 +33,45 @@ #define SCPI_CMD_OPC "*OPC?" enum { - SCPI_CMD_SET_TRIGGER_SOURCE = 1, + SCPI_CMD_GET_TIMEBASE = 1, SCPI_CMD_SET_TIMEBASE, + SCPI_CMD_GET_VERTICAL_DIV, SCPI_CMD_SET_VERTICAL_DIV, + SCPI_CMD_GET_TRIGGER_SLOPE, SCPI_CMD_SET_TRIGGER_SLOPE, + SCPI_CMD_GET_TRIGGER_PATTERN, + SCPI_CMD_SET_TRIGGER_PATTERN, + SCPI_CMD_GET_TRIGGER_SOURCE, + SCPI_CMD_SET_TRIGGER_SOURCE, + SCPI_CMD_GET_COUPLING, SCPI_CMD_SET_COUPLING, + SCPI_CMD_GET_HORIZ_TRIGGERPOS, SCPI_CMD_SET_HORIZ_TRIGGERPOS, SCPI_CMD_GET_ANALOG_CHAN_STATE, - SCPI_CMD_GET_DIG_CHAN_STATE, - SCPI_CMD_GET_TIMEBASE, - SCPI_CMD_GET_VERTICAL_DIV, - SCPI_CMD_GET_VERTICAL_OFFSET, - SCPI_CMD_GET_TRIGGER_SOURCE, - SCPI_CMD_GET_HORIZ_TRIGGERPOS, - SCPI_CMD_GET_TRIGGER_SLOPE, - SCPI_CMD_GET_COUPLING, SCPI_CMD_SET_ANALOG_CHAN_STATE, + SCPI_CMD_GET_DIG_CHAN_STATE, SCPI_CMD_SET_DIG_CHAN_STATE, + SCPI_CMD_GET_VERTICAL_OFFSET, SCPI_CMD_GET_DIG_POD_STATE, SCPI_CMD_SET_DIG_POD_STATE, SCPI_CMD_GET_ANALOG_DATA, SCPI_CMD_GET_DIG_DATA, SCPI_CMD_GET_SAMPLE_RATE, - SCPI_CMD_GET_SAMPLE_RATE_LIVE, - SCPI_CMD_GET_DATA_FORMAT, - SCPI_CMD_GET_PROBE_FACTOR, - SCPI_CMD_SET_PROBE_FACTOR, SCPI_CMD_GET_PROBE_UNIT, - SCPI_CMD_SET_PROBE_UNIT, - SCPI_CMD_GET_ANALOG_CHAN_NAME, - SCPI_CMD_GET_DIG_CHAN_NAME, + SCPI_CMD_GET_DIG_POD_THRESHOLD, + SCPI_CMD_SET_DIG_POD_THRESHOLD, + SCPI_CMD_GET_DIG_POD_USER_THRESHOLD, + SCPI_CMD_SET_DIG_POD_USER_THRESHOLD, +}; + +enum scpi_transport_layer { + SCPI_TRANSPORT_LIBGPIB, + SCPI_TRANSPORT_SERIAL, + SCPI_TRANSPORT_RAW_TCP, + SCPI_TRANSPORT_RIGOL_TCP, + SCPI_TRANSPORT_USBTMC, + SCPI_TRANSPORT_VISA, + SCPI_TRANSPORT_VXI, }; struct scpi_command { @@ -80,11 +89,13 @@ struct sr_scpi_hw_info { struct sr_scpi_dev_inst { const char *name; const char *prefix; + enum scpi_transport_layer transport; int priv_size; GSList *(*scan)(struct drv_context *drvc); int (*dev_inst_new)(void *priv, struct drv_context *drvc, const char *resource, char **params, const char *serialcomm); int (*open)(struct sr_scpi_dev_inst *scpi); + int (*connection_id)(struct sr_scpi_dev_inst *scpi, char **connection_id); int (*source_add)(struct sr_session *session, void *priv, int events, int timeout, sr_receive_data_callback cb, void *cb_data); int (*source_remove)(struct sr_session *session, void *priv); @@ -108,6 +119,8 @@ SR_PRIV GSList *sr_scpi_scan(struct drv_context *drvc, GSList *options, SR_PRIV struct sr_scpi_dev_inst *scpi_dev_inst_new(struct drv_context *drvc, const char *resource, const char *serialcomm); SR_PRIV int sr_scpi_open(struct sr_scpi_dev_inst *scpi); +SR_PRIV int sr_scpi_connection_id(struct sr_scpi_dev_inst *scpi, + char **connection_id); SR_PRIV int sr_scpi_source_add(struct sr_session *session, struct sr_scpi_dev_inst *scpi, int events, int timeout, sr_receive_data_callback cb, void *cb_data); @@ -163,4 +176,10 @@ SR_PRIV int sr_scpi_cmd_resp(const struct sr_dev_inst *sdi, int channel_command, const char *channel_name, GVariant **gvar, const GVariantType *gvtype, int command, ...); +/*--- GPIB only functions ---------------------------------------------------*/ + +#ifdef HAVE_LIBGPIB +SR_PRIV int sr_scpi_gpib_spoll(struct sr_scpi_dev_inst *scpi, char *buf); +#endif + #endif