X-Git-Url: https://sigrok.org/gitweb/?p=libsigrok.git;a=blobdiff_plain;f=hardware%2Ffluke-dmm%2Ffluke-dmm.h;h=d162bdd0e921d7525cb42c1c3ee8b33f9048c492;hp=7174531c4ee8df49fa030076a083704ff537bd16;hb=43cd4637285833706f8a404ca027bcf0ee75b9ae;hpb=acd29accb3a458ab6a494e3f6c42dacc56a4c7a8 diff --git a/hardware/fluke-dmm/fluke-dmm.h b/hardware/fluke-dmm/fluke-dmm.h index 7174531c..d162bdd0 100644 --- a/hardware/fluke-dmm/fluke-dmm.h +++ b/hardware/fluke-dmm/fluke-dmm.h @@ -1,5 +1,5 @@ /* - * This file is part of the sigrok project. + * This file is part of the libsigrok project. * * Copyright (C) 2012 Bert Vermeulen * @@ -17,27 +17,29 @@ * along with this program. If not, see . */ +#ifndef LIBSIGROK_HARDWARE_FLUKE_DMM_FLUKE_DMM_H +#define LIBSIGROK_HARDWARE_FLUKE_DMM_FLUKE_DMM_H -#ifndef LIBSIGROK_FLUKE_DMM_H -#define LIBSIGROK_FLUKE_DMM_H +#define LOG_PREFIX "fluke-dmm" #define FLUKEDMM_BUFSIZE 256 /* Supported models */ enum { FLUKE_187 = 1, + FLUKE_189, FLUKE_287, + FLUKE_190, }; /* Supported device profiles */ struct flukedmm_profile { int model; const char *modelname; -}; - -/* Private driver context. */ -struct drv_context { - GSList *instances; + /* How often to poll, in ms. */ + int poll_period; + /* If no response received, how long to wait before retrying. */ + int timeout; }; /* Private, per-device-instance driver context. */ @@ -45,16 +47,23 @@ struct dev_context { const struct flukedmm_profile *profile; uint64_t limit_samples; uint64_t limit_msec; - struct sr_serial_dev_inst *serial; - char *serialcomm; /* Opaque pointer passed in by the frontend. */ void *cb_data; /* Runtime. */ uint64_t num_samples; - unsigned char buf[FLUKEDMM_BUFSIZE]; + char buf[FLUKEDMM_BUFSIZE]; int buflen; + int64_t cmd_sent_at; + int expect_response; + int meas_type; + int is_relative; + int mq; + int unit; + int mqflags; }; -#endif /* LIBSIGROK_FLUKE_DMM_H */ +SR_PRIV int fluke_receive_data(int fd, int revents, void *cb_data); + +#endif