]> sigrok.org Git - libsigrok.git/blob - src/dmm/m2110.c
5863cef1e706e31d4923a51d02754f65c3c1cc32
[libsigrok.git] / src / dmm / m2110.c
1 /*
2  * This file is part of the libsigrok project.
3  *
4  * Copyright (C) 2013 Matthias Heidbrink <m-sigrok@heidbrink.biz>
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 /**
21  * @file
22  *
23  * BBC Goerz Metrawatt M2110 ASCII protocol parser.
24  *
25  * Most probably the simplest multimeter protocol ever ;-) .
26  */
27
28 #include <string.h>
29 #include <math.h>
30 #include <glib.h>
31 #include "libsigrok.h"
32 #include "libsigrok-internal.h"
33
34 #define LOG_PREFIX "m2110"
35
36 SR_PRIV gboolean sr_m2110_packet_valid(const uint8_t *buf)
37 {
38         float val;
39
40         if ((buf[7] != '\r') || (buf[8] != '\n'))
41                 return FALSE;
42
43         if (!strncmp((const char *)buf, "OVERRNG", 7))
44                 return TRUE;
45
46         if (sscanf((const char *)buf, "%f", &val) == 1)
47                 return TRUE;
48         else
49                 return FALSE;
50 }
51
52 SR_PRIV int sr_m2110_parse(const uint8_t *buf, float *floatval,
53                                 struct sr_datafeed_analog *analog, void *info)
54 {
55         float val;
56
57         (void)info;
58
59         /* We don't know the unit, so that's the best we can do. */
60         analog->mq = SR_MQ_GAIN;
61         analog->unit = SR_UNIT_UNITLESS;
62         analog->mqflags = 0;
63
64         if (!strncmp((const char *)buf, "OVERRNG", 7))
65                 *floatval = INFINITY;
66         else if (sscanf((const char *)buf, "%f", &val) == 1)
67                 *floatval = val;
68
69         return SR_OK;
70 }