X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=hardware%2Funi-t-dmm%2Fprotocol.h;h=08fb537317ad3a7de4b0de76c0a0e864dbff126b;hb=cf9f4bc5b0bf5ceef6ccfff7bdbf6b4ac2fd7486;hp=51128f6db5e786827c39942f58967f6639768ddd;hpb=b6bad47c91a7cbc19571cbe49918a0612ad2babe;p=libsigrok.git diff --git a/hardware/uni-t-dmm/protocol.h b/hardware/uni-t-dmm/protocol.h index 51128f6d..08fb5373 100644 --- a/hardware/uni-t-dmm/protocol.h +++ b/hardware/uni-t-dmm/protocol.h @@ -27,32 +27,29 @@ #include "libsigrok.h" #include "libsigrok-internal.h" -/* Message logging helpers with driver-specific prefix string. */ -#define DRIVER_LOG_DOMAIN "uni-t-dmm: " -#define sr_log(l, s, args...) sr_log(l, DRIVER_LOG_DOMAIN s, ## args) -#define sr_spew(s, args...) sr_spew(DRIVER_LOG_DOMAIN s, ## args) -#define sr_dbg(s, args...) sr_dbg(DRIVER_LOG_DOMAIN s, ## args) -#define sr_info(s, args...) sr_info(DRIVER_LOG_DOMAIN s, ## args) -#define sr_warn(s, args...) sr_warn(DRIVER_LOG_DOMAIN s, ## args) -#define sr_err(s, args...) sr_err(DRIVER_LOG_DOMAIN s, ## args) - -/* Note: When adding entries here, don't forget to update DMM_COUNT. */ +#define LOG_PREFIX "uni-t-dmm" + enum { TECPEL_DMM_8061, + UNI_T_UT60A, + UNI_T_UT60E, + UNI_T_UT60G, + UNI_T_UT61B, + UNI_T_UT61C, UNI_T_UT61D, UNI_T_UT61E, VOLTCRAFT_VC820, + VOLTCRAFT_VC830, VOLTCRAFT_VC840, + TENMA_72_7745, + TENMA_72_7750, }; -#define DMM_COUNT 5 - struct dmm_info { char *vendor; char *device; uint32_t baudrate; int packet_size; - int (*packet_request)(struct sr_serial_dev_inst *); gboolean (*packet_valid)(const uint8_t *); int (*packet_parse)(const uint8_t *, float *, struct sr_datafeed_analog *, void *); @@ -61,8 +58,6 @@ struct dmm_info { int (*receive_data)(int, int, void *); }; -extern SR_PRIV struct dmm_info udmms[DMM_COUNT]; - #define CHUNK_SIZE 8 #define DMM_BUFSIZE 256 @@ -81,6 +76,8 @@ struct dev_context { /** The current number of already received samples. */ uint64_t num_samples; + int64_t starttime; + gboolean first_run; uint8_t protocol_buf[DMM_BUFSIZE]; @@ -89,9 +86,17 @@ struct dev_context { }; SR_PRIV int receive_data_TECPEL_DMM_8061(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_UNI_T_UT60A(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_UNI_T_UT60E(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_UNI_T_UT60G(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_UNI_T_UT61B(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_UNI_T_UT61C(int fd, int revents, void *cb_data); SR_PRIV int receive_data_UNI_T_UT61D(int fd, int revents, void *cb_data); SR_PRIV int receive_data_UNI_T_UT61E(int fd, int revents, void *cb_data); SR_PRIV int receive_data_VOLTCRAFT_VC820(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_VOLTCRAFT_VC830(int fd, int revents, void *cb_data); SR_PRIV int receive_data_VOLTCRAFT_VC840(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_TENMA_72_7745(int fd, int revents, void *cb_data); +SR_PRIV int receive_data_TENMA_72_7750(int fd, int revents, void *cb_data); #endif