]> sigrok.org Git - libsigrok.git/blame - libsigrok-internal.h
Code drop from DreamSourceLabs first source release.
[libsigrok.git] / libsigrok-internal.h
CommitLineData
1483577e 1/*
50985c20 2 * This file is part of the libsigrok project.
1483577e 3 *
13d8e03c 4 * Copyright (C) 2013 Bert Vermeulen <bert@biot.com>
1483577e
UH
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
0f8522bf
UH
20#ifndef LIBSIGROK_SIGROK_INTERNAL_H
21#define LIBSIGROK_SIGROK_INTERNAL_H
1483577e 22
b08024a8 23#include <stdarg.h>
cc8a7d25 24#include <glib.h>
1a081ca6 25#include "config.h" /* Needed for HAVE_LIBUSB_1_0 and others. */
69890f73
UH
26#ifdef HAVE_LIBUSB_1_0
27#include <libusb.h>
28#endif
b08024a8 29
393fb9cb
UH
30/**
31 * @file
32 *
33 * libsigrok private header file, only to be used internally.
34 */
35
4cea9eb2
UH
36/*--- Macros ----------------------------------------------------------------*/
37
38#ifndef ARRAY_SIZE
39#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
40#endif
41
42#ifndef ARRAY_AND_SIZE
43#define ARRAY_AND_SIZE(a) (a), ARRAY_SIZE(a)
44#endif
45
b8072700 46struct sr_context {
785b9ff2
PS
47#ifdef HAVE_LIBUSB_1_0
48 libusb_context *libusb_ctx;
49#endif
b8072700
PS
50};
51
69890f73 52#ifdef HAVE_LIBUSB_1_0
d68e2d1a 53struct sr_usb_dev_inst {
69890f73
UH
54 uint8_t bus;
55 uint8_t address;
56 struct libusb_device_handle *devhdl;
57};
58#endif
59
f8c1fcda
BV
60#define SERIAL_PARITY_NONE 0
61#define SERIAL_PARITY_EVEN 1
62#define SERIAL_PARITY_ODD 2
d68e2d1a 63struct sr_serial_dev_inst {
69890f73 64 char *port;
299bdb24 65 char *serialcomm;
69890f73
UH
66 int fd;
67};
68
026c822d
UH
69/* Private driver context. */
70struct drv_context {
1ebe4b4e 71 struct sr_context *sr_ctx;
026c822d
UH
72 GSList *instances;
73};
74
48a486cd
BV
75/*--- log.c -----------------------------------------------------------------*/
76
77SR_PRIV int sr_log(int loglevel, const char *format, ...);
78SR_PRIV int sr_spew(const char *format, ...);
79SR_PRIV int sr_dbg(const char *format, ...);
80SR_PRIV int sr_info(const char *format, ...);
81SR_PRIV int sr_warn(const char *format, ...);
82SR_PRIV int sr_err(const char *format, ...);
83
84/*--- device.c --------------------------------------------------------------*/
85
86SR_PRIV struct sr_probe *sr_probe_new(int index, int type,
f1b296fc
BV
87 gboolean enabled, const char *name);
88SR_PRIV void sr_dev_probes_free(struct sr_dev_inst *sdi);
48a486cd
BV
89
90/* Generic device instances */
f1b296fc
BV
91SR_PRIV struct sr_dev_inst *sr_dev_inst_new(int mode, int index, int status,
92 const char *vendor, const char *model, const char *version);
48a486cd 93SR_PRIV void sr_dev_inst_free(struct sr_dev_inst *sdi);
48a486cd 94
545f9786 95#ifdef HAVE_LIBUSB_1_0
69890f73 96/* USB-specific instances */
d68e2d1a 97SR_PRIV struct sr_usb_dev_inst *sr_usb_dev_inst_new(uint8_t bus,
69890f73 98 uint8_t address, struct libusb_device_handle *hdl);
91162629 99SR_PRIV GSList *sr_usb_find_usbtmc(libusb_context *usb_ctx);
d68e2d1a 100SR_PRIV void sr_usb_dev_inst_free(struct sr_usb_dev_inst *usb);
69890f73
UH
101#endif
102
103/* Serial-specific instances */
299bdb24
BV
104SR_PRIV struct sr_serial_dev_inst *sr_serial_dev_inst_new(const char *port,
105 const char *serialcomm);
d68e2d1a 106SR_PRIV void sr_serial_dev_inst_free(struct sr_serial_dev_inst *serial);
69890f73 107
b08024a8 108
c09f0b57 109/*--- hwdriver.c ------------------------------------------------------------*/
996b0c72 110
93a04e3b 111SR_PRIV void sr_hw_cleanup_all(void);
bc1c2f00 112SR_PRIV struct sr_config *sr_config_new(int key, GVariant *data);
722db131 113SR_PRIV void sr_config_free(struct sr_config *src);
48a486cd
BV
114SR_PRIV int sr_source_remove(int fd);
115SR_PRIV int sr_source_add(int fd, int events, int timeout,
f1b296fc 116 sr_receive_data_callback_t cb, void *cb_data);
996b0c72 117
a1645fcd
BV
118/*--- session.c -------------------------------------------------------------*/
119
de4d3f99 120SR_PRIV int sr_session_send(const struct sr_dev_inst *sdi,
ae5859ff 121 const struct sr_datafeed_packet *packet);
33c6e4c5 122SR_PRIV int sr_session_stop_sync(void);
a1645fcd 123
063e7aef
UH
124/*--- std.c -----------------------------------------------------------------*/
125
cd2f0fe2 126typedef int (*dev_close_t)(struct sr_dev_inst *sdi);
ae5859ff 127typedef void (*std_dev_clear_t)(void *priv);
cd2f0fe2 128
063e7aef 129SR_PRIV int std_hw_init(struct sr_context *sr_ctx, struct sr_dev_driver *di,
ae5859ff 130 const char *prefix);
cd2f0fe2 131SR_PRIV int std_hw_dev_acquisition_stop_serial(struct sr_dev_inst *sdi,
ae5859ff
BV
132 void *cb_data, dev_close_t hw_dev_close_fn,
133 struct sr_serial_dev_inst *serial, const char *prefix);
4afdfd46 134SR_PRIV int std_session_send_df_header(const struct sr_dev_inst *sdi,
ae5859ff
BV
135 const char *prefix);
136SR_PRIV int std_dev_clear(const struct sr_dev_driver *driver,
137 std_dev_clear_t clear_private);
4afdfd46 138
f1b296fc
BV
139/*--- trigger.c -------------------------------------------------*/
140SR_PRIV uint64_t sr_trigger_get_mask0(uint16_t stage);
141SR_PRIV uint64_t sr_trigger_get_mask1(uint16_t stage);
142SR_PRIV uint64_t sr_trigger_get_value0(uint16_t stage);
143SR_PRIV uint64_t sr_trigger_get_value1(uint16_t stage);
144SR_PRIV uint64_t sr_trigger_get_edge0(uint16_t stage);
145SR_PRIV uint64_t sr_trigger_get_edge1(uint16_t stage);
146
058b7035
UH
147/*--- hardware/common/serial.c ----------------------------------------------*/
148
a54dd31e
UH
149enum {
150 SERIAL_RDWR = 1,
151 SERIAL_RDONLY = 2,
152 SERIAL_NONBLOCK = 4,
153};
154
766456be
UH
155typedef gboolean (*packet_valid_t)(const uint8_t *buf);
156
299bdb24
BV
157SR_PRIV int serial_open(struct sr_serial_dev_inst *serial, int flags);
158SR_PRIV int serial_close(struct sr_serial_dev_inst *serial);
159SR_PRIV int serial_flush(struct sr_serial_dev_inst *serial);
160SR_PRIV int serial_write(struct sr_serial_dev_inst *serial,
161 const void *buf, size_t count);
162SR_PRIV int serial_read(struct sr_serial_dev_inst *serial, void *buf,
163 size_t count);
164SR_PRIV int serial_set_params(struct sr_serial_dev_inst *serial, int baudrate,
71caaad4 165 int bits, int parity, int stopbits, int flowcontrol, int rts, int dtr);
299bdb24
BV
166SR_PRIV int serial_set_paramstr(struct sr_serial_dev_inst *serial,
167 const char *paramstr);
168SR_PRIV int serial_readline(struct sr_serial_dev_inst *serial, char **buf,
169 int *buflen, gint64 timeout_ms);
766456be
UH
170SR_PRIV int serial_stream_detect(struct sr_serial_dev_inst *serial,
171 uint8_t *buf, size_t *buflen,
172 size_t packet_size, packet_valid_t is_valid,
173 uint64_t timeout_ms, int baudrate);
1483577e 174
058b7035
UH
175/*--- hardware/common/ezusb.c -----------------------------------------------*/
176
22b02383 177#ifdef HAVE_LIBUSB_1_0
1a081ca6
UH
178SR_PRIV int ezusb_reset(struct libusb_device_handle *hdl, int set_clear);
179SR_PRIV int ezusb_install_firmware(libusb_device_handle *hdl,
180 const char *filename);
181SR_PRIV int ezusb_upload_firmware(libusb_device *dev, int configuration,
182 const char *filename);
22b02383 183#endif
058b7035 184
0c632d36
UH
185/*--- hardware/common/usb.c -------------------------------------------------*/
186
187#ifdef HAVE_LIBUSB_1_0
7ae6a758 188SR_PRIV GSList *sr_usb_find(libusb_context *usb_ctx, const char *conn);
0c632d36
UH
189SR_PRIV int sr_usb_open(libusb_context *usb_ctx, struct sr_usb_dev_inst *usb);
190#endif
191
e7ed87a4 192
05f134ab 193
1483577e 194#endif