]> sigrok.org Git - libsigrok.git/blob - src/hardware/ipdbg-logic-analyser/protocol.h
ipdbg-la: add edge trigger option
[libsigrok.git] / src / hardware / ipdbg-logic-analyser / protocol.h
1 /*
2  * This file is part of the libsigrok project.
3  *
4  * Copyright (C) 2016 danselmi <da@da>
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_IPDBG_ORG_LA_PROTOCOL_H
21 #define LIBSIGROK_HARDWARE_IPDBG_ORG_LA_PROTOCOL_H
22
23 #include <stdint.h>
24 #include <glib.h>
25 #include <libsigrok/libsigrok.h>
26 #include "libsigrok-internal.h"
27
28 #define LOG_PREFIX "ipdbg-org-la"
29
30
31 struct ipdbg_org_la_tcp {
32     char *address;
33     char *port;
34     int socket;
35 };
36
37 /** Private, per-device-instance driver context. */
38 struct ipdbg_org_la_dev_context
39 {
40     unsigned int DATA_WIDTH;
41     unsigned int DATA_WIDTH_BYTES;
42     unsigned int ADDR_WIDTH;
43     unsigned int ADDR_WIDTH_BYTES ;
44
45     unsigned int limit_samples;
46     unsigned int limit_samples_max;
47     char capture_ratio;
48     char *trigger_mask;
49     char *trigger_value;
50     char *trigger_mask_last;
51     char *trigger_value_last;
52     char *trigger_edge_mask;
53     unsigned int delay_value;
54     int num_stages; //always 0
55     unsigned int num_transfers;
56     unsigned char *raw_sample_buf;
57 };
58
59 SR_PRIV struct ipdbg_org_la_tcp *ipdbg_org_la_new_tcp(void);
60 SR_PRIV int ipdbg_org_la_tcp_open(struct ipdbg_org_la_tcp *tcp);
61 SR_PRIV int ipdbg_org_la_tcp_close(struct ipdbg_org_la_tcp *tcp);
62 SR_PRIV void ipdbg_org_la_tcp_free(struct ipdbg_org_la_tcp *tcp);
63 SR_PRIV int ipdbg_org_la_tcp_send(struct ipdbg_org_la_tcp *tcp, const uint8_t *buf, size_t len);
64 SR_PRIV int ipdbg_org_la_tcp_receive(struct ipdbg_org_la_tcp *tcp, uint8_t *buf, int bufsize);
65
66 SR_PRIV struct ipdbg_org_la_dev_context *ipdbg_org_la_dev_new(void);
67 SR_PRIV void ipdbg_org_la_get_addrwidth_and_datawidth(struct ipdbg_org_la_tcp *tcp, struct ipdbg_org_la_dev_context *devc);
68 SR_PRIV int ipdbg_org_la_sendReset(struct ipdbg_org_la_tcp *tcp);
69 SR_PRIV int ipdbg_org_la_requestID(struct ipdbg_org_la_tcp *tcp);
70 SR_PRIV int ipdbg_org_la_sendStart(struct ipdbg_org_la_tcp *tcp);
71 SR_PRIV int ipdbg_org_la_sendTrigger(struct ipdbg_org_la_dev_context *devc, struct ipdbg_org_la_tcp *tcp);
72 SR_PRIV int ipdbg_org_la_sendDelay(struct ipdbg_org_la_dev_context *devc, struct ipdbg_org_la_tcp *tcp);
73 SR_PRIV int ipdbg_org_la_convert_trigger(const struct sr_dev_inst *sdi);
74 SR_PRIV int ipdbg_org_la_receive_data(int fd, int revents, void *cb_data);
75 SR_PRIV void ipdbg_org_la_abort_acquisition(const struct sr_dev_inst *sdi);
76
77 #endif