/*
- * This file is part of the sigrok project.
+ * This file is part of the libsigrok project.
*
* Copyright (C) 2012 Bert Vermeulen <bert@biot.com>
*
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
+#ifndef LIBSIGROK_HARDWARE_AGILENT_DMM_AGILENT_DMM_H
+#define LIBSIGROK_HARDWARE_AGILENT_DMM_AGILENT_DMM_H
-#ifndef LIBSIGROK_AGILENT_DMM_H
-#define LIBSIGROK_AGILENT_DMM_H
+/* Message logging helpers with subsystem-specific prefix string. */
+#define LOG_PREFIX "agilent-dmm: "
+#define sr_log(l, s, args...) sr_log(l, LOG_PREFIX s, ## args)
+#define sr_spew(s, args...) sr_spew(LOG_PREFIX s, ## args)
+#define sr_dbg(s, args...) sr_dbg(LOG_PREFIX s, ## args)
+#define sr_info(s, args...) sr_info(LOG_PREFIX s, ## args)
+#define sr_warn(s, args...) sr_warn(LOG_PREFIX s, ## args)
+#define sr_err(s, args...) sr_err(LOG_PREFIX s, ## args)
#define AGDMM_BUFSIZE 256
/* Supported models */
enum {
- AGILENT_U1232A = 1,
+ AGILENT_U1231A = 1,
+ AGILENT_U1232A,
+ AGILENT_U1233A,
+ AGILENT_U1251A,
+ AGILENT_U1252A,
+ AGILENT_U1253A,
};
/* Supported device profiles */
struct agdmm_profile {
int model;
const char *modelname;
- int serial_speed;
const struct agdmm_job *jobs;
const struct agdmm_recv *recvs;
};
-/* Private driver context. */
-struct drv_context {
- GSList *instances;
-};
-
/* Private, per-device-instance driver context. */
struct dev_context {
const struct agdmm_profile *profile;
uint64_t limit_samples;
uint64_t limit_msec;
- struct sr_serial_dev_inst *serial;
/* Opaque pointer passed in by the frontend. */
void *cb_data;
unsigned char buf[AGDMM_BUFSIZE];
int buflen;
int cur_mq;
- int cur_mq_unit;
- int cur_mq_flags;
+ int cur_unit;
+ int cur_mqflags;
int cur_divider;
int cur_acdc;
+ int mode_tempaux;
+ int mode_continuity;
};
struct agdmm_job {
SR_PRIV int agdmm_receive_data(int fd, int revents, void *cb_data);
-#endif /* LIBSIGROK_AGILENT_DMM_H */
+#endif