]> sigrok.org Git - libsigrok.git/blob - src/hardware/serial-dmm/protocol.h
serial-dmm: drop obsolete redundant 'baudrate' parameter value
[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         /** serialconn string. */
33         const char *conn;
34         /** Packet size in bytes. */
35         int packet_size;
36         /**
37          * Request timeout [ms] before request is considered lost and a new
38          * one is sent. Used only if device needs polling.
39          */
40         int64_t req_timeout_ms;
41         /**
42          * Delay between reception of packet and next request. Some DMMs
43          * need this. Used only if device needs polling.
44          */
45         int64_t req_delay_ms;
46         /** Packet request function. */
47         int (*packet_request)(struct sr_serial_dev_inst *);
48         /** Number of channels / displays. */
49         size_t channel_count;
50         /** (Optional) printf formats for channel names. */
51         const char **channel_formats;
52         /** Packet validation function. */
53         gboolean (*packet_valid)(const uint8_t *);
54         /** Packet parsing function. */
55         int (*packet_parse)(const uint8_t *, float *,
56                             struct sr_datafeed_analog *, void *);
57         /** */
58         void (*dmm_details)(struct sr_datafeed_analog *, void *);
59         /** Size of chipset info struct. */
60         gsize info_size;
61 };
62
63 #define DMM_BUFSIZE 256
64
65 struct dev_context {
66         struct sr_sw_limits limits;
67
68         uint8_t buf[DMM_BUFSIZE];
69         int bufoffset;
70         int buflen;
71
72         /**
73          * The timestamp [µs] to send the next request.
74          * Used only if device needs polling.
75          */
76         int64_t req_next_at;
77 };
78
79 SR_PRIV int req_packet(struct sr_dev_inst *sdi);
80 SR_PRIV int receive_data(int fd, int revents, void *cb_data);
81
82 #endif