]> sigrok.org Git - libsigrok.git/blob - src/hardware/serial-dmm/protocol.h
serial-dmm: more DMM parser callbacks (open, var length, config, start)
[libsigrok.git] / src / hardware / serial-dmm / protocol.h
1 /*
2  * This file is part of the libsigrok project.
3  *
4  * Copyright (C) 2012 Alexandru Gagniuc <mr.nuke.me@gmail.com>
5  *
6  * This program is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 #ifndef LIBSIGROK_HARDWARE_SERIAL_DMM_PROTOCOL_H
21 #define LIBSIGROK_HARDWARE_SERIAL_DMM_PROTOCOL_H
22
23 #define LOG_PREFIX "serial-dmm"
24
25 struct dmm_info {
26         /** libsigrok driver info struct. */
27         struct sr_dev_driver di;
28         /** Manufacturer/brand. */
29         const char *vendor;
30         /** Model. */
31         const char *device;
32         /** conn string. */
33         const char *conn;
34         /** serialcomm string. */
35         const char *serialcomm;
36         /** Packet size in bytes. */
37         size_t packet_size;
38         /**
39          * Request timeout [ms] before request is considered lost and a new
40          * one is sent. Used only if device needs polling.
41          */
42         uint64_t req_timeout_ms;
43         /**
44          * Delay between reception of packet and next request. Some DMMs
45          * need this. Used only if device needs polling.
46          */
47         uint64_t req_delay_ms;
48         /** Packet request function. */
49         int (*packet_request)(struct sr_serial_dev_inst *);
50         /** Number of channels / displays. */
51         size_t channel_count;
52         /** (Optional) printf formats for channel names. */
53         const char **channel_formats;
54         /** Packet validation function. */
55         gboolean (*packet_valid)(const uint8_t *);
56         /** Packet parsing function. */
57         int (*packet_parse)(const uint8_t *, float *,
58                             struct sr_datafeed_analog *, void *);
59         /** */
60         void (*dmm_details)(struct sr_datafeed_analog *, void *);
61         /** Size of chipset info struct. */
62         gsize info_size;
63         /* Serial-dmm items "with state" and variable length packets. */
64         void *dmm_state;
65         void *(*dmm_state_init)(void);
66         void (*dmm_state_free)(void *state);
67         int (*after_open)(struct sr_serial_dev_inst *serial);
68         int (*packet_valid_len)(void *state, const uint8_t *data, size_t dlen,
69                 size_t *pkt_len);
70         int (*packet_parse_len)(void *state, const uint8_t *data, size_t dlen,
71                 double *val, struct sr_datafeed_analog *analog, void *info);
72         int (*config_get)(void *state, uint32_t key, GVariant **data,
73                 const struct sr_dev_inst *sdi, const struct sr_channel_group *cg);
74         int (*config_set)(void *state, uint32_t key, GVariant *data,
75                 const struct sr_dev_inst *sdi, const struct sr_channel_group *cg);
76         int (*config_list)(void *state, uint32_t key, GVariant **data,
77                 const struct sr_dev_inst *sdi, const struct sr_channel_group *cg);
78         /** Hook at acquisition start. Can re-route the receive routine. */
79         int (*acquire_start)(void *state, const struct sr_dev_inst *sdi,
80                 sr_receive_data_callback *cb, void **cb_data);
81 };
82
83 #define DMM_BUFSIZE 256
84
85 struct dev_context {
86         struct sr_sw_limits limits;
87
88         uint8_t buf[DMM_BUFSIZE];
89         size_t buflen;
90
91         /**
92          * The timestamp [µs] to send the next request.
93          * Used only if device needs polling.
94          */
95         uint64_t req_next_at;
96 };
97
98 SR_PRIV int req_packet(struct sr_dev_inst *sdi);
99 SR_PRIV int receive_data(int fd, int revents, void *cb_data);
100
101 #endif