]> sigrok.org Git - libsigrok.git/blame - src/hardware/beaglelogic/beaglelogic_native.c
beaglelogic: No need to check g_free() argument.
[libsigrok.git] / src / hardware / beaglelogic / beaglelogic_native.c
CommitLineData
88d2037b
KA
1/*
2 * This file is part of the libsigrok project.
3 *
3124d3bc 4 * Copyright (C) 2014-17 Kumar Abhishek <abhishek@theembeddedkitchen.net>
88d2037b
KA
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#include "protocol.h"
21#include "beaglelogic.h"
22
a31010b3
KA
23static int beaglelogic_open_nonblock(struct dev_context *devc)
24{
88d2037b
KA
25 devc->fd = open(BEAGLELOGIC_DEV_NODE, O_RDONLY | O_NONBLOCK);
26 return (devc->fd == -1 ? SR_ERR : SR_OK);
27}
28
a31010b3
KA
29static int beaglelogic_close(struct dev_context *devc)
30{
88d2037b
KA
31 return close(devc->fd);
32}
33
a31010b3
KA
34static int beaglelogic_get_buffersize(struct dev_context *devc)
35{
88d2037b
KA
36 return ioctl(devc->fd, IOCTL_BL_GET_BUFFER_SIZE, &devc->buffersize);
37}
38
a31010b3
KA
39static int beaglelogic_set_buffersize(struct dev_context *devc)
40{
88d2037b
KA
41 return ioctl(devc->fd, IOCTL_BL_SET_BUFFER_SIZE, devc->buffersize);
42}
43
44/* This is treated differently as it gets a uint64_t while a uint32_t is read */
a31010b3
KA
45static int beaglelogic_get_samplerate(struct dev_context *devc)
46{
88d2037b
KA
47 uint32_t arg, err;
48 err = ioctl(devc->fd, IOCTL_BL_GET_SAMPLE_RATE, &arg);
49 devc->cur_samplerate = arg;
50 return err;
51}
52
a31010b3
KA
53static int beaglelogic_set_samplerate(struct dev_context *devc)
54{
88d2037b
KA
55 return ioctl(devc->fd, IOCTL_BL_SET_SAMPLE_RATE,
56 (uint32_t)devc->cur_samplerate);
57}
58
a31010b3
KA
59static int beaglelogic_get_sampleunit(struct dev_context *devc)
60{
88d2037b
KA
61 return ioctl(devc->fd, IOCTL_BL_GET_SAMPLE_UNIT, &devc->sampleunit);
62}
63
a31010b3
KA
64static int beaglelogic_set_sampleunit(struct dev_context *devc)
65{
88d2037b
KA
66 return ioctl(devc->fd, IOCTL_BL_SET_SAMPLE_UNIT, devc->sampleunit);
67}
68
a31010b3
KA
69static int beaglelogic_get_triggerflags(struct dev_context *devc)
70{
88d2037b
KA
71 return ioctl(devc->fd, IOCTL_BL_GET_TRIGGER_FLAGS, &devc->triggerflags);
72}
73
a31010b3
KA
74static int beaglelogic_set_triggerflags(struct dev_context *devc)
75{
88d2037b
KA
76 return ioctl(devc->fd, IOCTL_BL_SET_TRIGGER_FLAGS, devc->triggerflags);
77}
78
a31010b3
KA
79static int beaglelogic_get_lasterror(struct dev_context *devc)
80{
88d2037b
KA
81 int fd;
82 char buf[16];
83 int ret;
84
85 if ((fd = open(BEAGLELOGIC_SYSFS_ATTR(lasterror), O_RDONLY)) == -1)
86 return SR_ERR;
87
88 if ((ret = read(fd, buf, 16)) < 0)
89 return SR_ERR;
90
91 close(fd);
92 devc->last_error = strtoul(buf, NULL, 10);
93
94 return SR_OK;
95}
96
a31010b3
KA
97static int beaglelogic_start(struct dev_context *devc)
98{
88d2037b
KA
99 return ioctl(devc->fd, IOCTL_BL_START);
100}
101
a31010b3
KA
102static int beaglelogic_stop(struct dev_context *devc)
103{
88d2037b
KA
104 return ioctl(devc->fd, IOCTL_BL_STOP);
105}
106
a31010b3
KA
107static int beaglelogic_get_bufunitsize(struct dev_context *devc)
108{
88d2037b
KA
109 return ioctl(devc->fd, IOCTL_BL_GET_BUFUNIT_SIZE, &devc->bufunitsize);
110}
111
a31010b3
KA
112static int beaglelogic_set_bufunitsize(struct dev_context *devc)
113{
0bca2e75
KA
114 return ioctl(devc->fd, IOCTL_BL_SET_BUFUNIT_SIZE, devc->bufunitsize);
115}
116
a31010b3
KA
117static int beaglelogic_mmap(struct dev_context *devc)
118{
88d2037b
KA
119 if (!devc->buffersize)
120 beaglelogic_get_buffersize(devc);
121 devc->sample_buf = mmap(NULL, devc->buffersize,
122 PROT_READ, MAP_SHARED, devc->fd, 0);
123 return (devc->sample_buf == MAP_FAILED ? -1 : SR_OK);
124}
125
a31010b3
KA
126static int beaglelogic_munmap(struct dev_context *devc)
127{
88d2037b
KA
128 return munmap(devc->sample_buf, devc->buffersize);
129}
0bca2e75
KA
130
131SR_PRIV const struct beaglelogic_ops beaglelogic_native_ops = {
132 .open = beaglelogic_open_nonblock,
133 .close = beaglelogic_close,
134 .get_buffersize = beaglelogic_get_buffersize,
135 .set_buffersize = beaglelogic_set_buffersize,
136 .get_samplerate = beaglelogic_get_samplerate,
137 .set_samplerate = beaglelogic_set_samplerate,
138 .get_sampleunit = beaglelogic_get_sampleunit,
139 .set_sampleunit = beaglelogic_set_sampleunit,
140 .get_triggerflags = beaglelogic_get_triggerflags,
141 .set_triggerflags = beaglelogic_set_triggerflags,
142 .start = beaglelogic_start,
143 .stop = beaglelogic_stop,
144 .get_lasterror = beaglelogic_get_lasterror,
145 .get_bufunitsize = beaglelogic_get_bufunitsize,
146 .set_bufunitsize = beaglelogic_set_bufunitsize,
147 .mmap = beaglelogic_mmap,
148 .munmap = beaglelogic_munmap,
149};