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