]> Git Repo - linux.git/blame - tools/iio/lsiio.c
Merge tag 'i3c/for-6.7' of git://git.kernel.org/pub/scm/linux/kernel/git/i3c/linux
[linux.git] / tools / iio / lsiio.c
CommitLineData
d2912cb1 1// SPDX-License-Identifier: GPL-2.0-only
49d916ec
MS
2/*
3 * Industrial I/O utilities - lsiio.c
4 *
5 * Copyright (c) 2010 Manuel Stahl <[email protected]>
49d916ec
MS
6 */
7
8#include <string.h>
9#include <dirent.h>
10#include <stdio.h>
11#include <errno.h>
12#include <stdint.h>
13#include <stdlib.h>
14#include <unistd.h>
15#include <sys/types.h>
16#include <sys/stat.h>
17#include <sys/dir.h>
18#include "iio_utils.h"
19
49d916ec
MS
20static enum verbosity {
21 VERBLEVEL_DEFAULT, /* 0 gives lspci behaviour */
22 VERBLEVEL_SENSORS, /* 1 lists sensors */
23} verblevel = VERBLEVEL_DEFAULT;
24
25const char *type_device = "iio:device";
26const char *type_trigger = "trigger";
27
49d916ec
MS
28static inline int check_prefix(const char *str, const char *prefix)
29{
30 return strlen(str) > strlen(prefix) &&
7663a4aa 31 strncmp(str, prefix, strlen(prefix)) == 0;
49d916ec
MS
32}
33
34static inline int check_postfix(const char *str, const char *postfix)
35{
36 return strlen(str) > strlen(postfix) &&
7663a4aa 37 strcmp(str + strlen(str) - strlen(postfix), postfix) == 0;
49d916ec
MS
38}
39
40static int dump_channels(const char *dev_dir_name)
41{
42 DIR *dp;
43 const struct dirent *ent;
d1e50413 44
49d916ec 45 dp = opendir(dev_dir_name);
ff1ac639 46 if (!dp)
49d916ec 47 return -errno;
7663a4aa 48
ff1ac639 49 while (ent = readdir(dp), ent)
49d916ec 50 if (check_prefix(ent->d_name, "in_") &&
6df1dc05
MR
51 (check_postfix(ent->d_name, "_raw") ||
52 check_postfix(ent->d_name, "_input")))
49d916ec 53 printf(" %-10s\n", ent->d_name);
49d916ec 54
f96d055e 55 return (closedir(dp) == -1) ? -errno : 0;
49d916ec
MS
56}
57
58static int dump_one_device(const char *dev_dir_name)
59{
60 char name[IIO_MAX_NAME_LENGTH];
61 int dev_idx;
a9d7acc8 62 int ret;
49d916ec 63
a9d7acc8
HK
64 ret = sscanf(dev_dir_name + strlen(iio_dir) + strlen(type_device), "%i",
65 &dev_idx);
66 if (ret != 1)
d0e68ce1 67 return -EINVAL;
7663a4aa 68
a9d7acc8 69 ret = read_sysfs_string("name", dev_dir_name, name);
af255cd5 70 if (ret < 0)
a9d7acc8 71 return ret;
acf50b35 72
49d916ec
MS
73 printf("Device %03d: %s\n", dev_idx, name);
74
edead9b1
HS
75 if (verblevel >= VERBLEVEL_SENSORS)
76 return dump_channels(dev_dir_name);
7663a4aa 77
49d916ec
MS
78 return 0;
79}
80
81static int dump_one_trigger(const char *dev_dir_name)
82{
83 char name[IIO_MAX_NAME_LENGTH];
84 int dev_idx;
a9d7acc8 85 int ret;
49d916ec 86
a9d7acc8
HK
87 ret = sscanf(dev_dir_name + strlen(iio_dir) + strlen(type_trigger),
88 "%i", &dev_idx);
89 if (ret != 1)
d0e68ce1 90 return -EINVAL;
7663a4aa 91
a9d7acc8 92 ret = read_sysfs_string("name", dev_dir_name, name);
af255cd5 93 if (ret < 0)
a9d7acc8 94 return ret;
acf50b35 95
49d916ec 96 printf("Trigger %03d: %s\n", dev_idx, name);
7663a4aa 97
49d916ec
MS
98 return 0;
99}
100
acf50b35 101static int dump_devices(void)
49d916ec
MS
102{
103 const struct dirent *ent;
acf50b35 104 int ret;
49d916ec 105 DIR *dp;
49d916ec
MS
106
107 dp = opendir(iio_dir);
ff1ac639 108 if (!dp) {
d9abc615 109 fprintf(stderr, "No industrial I/O devices available\n");
acf50b35 110 return -ENODEV;
49d916ec
MS
111 }
112
ff1ac639 113 while (ent = readdir(dp), ent) {
49d916ec
MS
114 if (check_prefix(ent->d_name, type_device)) {
115 char *dev_dir_name;
d1e50413 116
e9e45b43
HK
117 if (asprintf(&dev_dir_name, "%s%s", iio_dir,
118 ent->d_name) < 0) {
acf50b35
HK
119 ret = -ENOMEM;
120 goto error_close_dir;
121 }
122
123 ret = dump_one_device(dev_dir_name);
124 if (ret) {
125 free(dev_dir_name);
e9e45b43
HK
126 goto error_close_dir;
127 }
128
49d916ec
MS
129 free(dev_dir_name);
130 if (verblevel >= VERBLEVEL_SENSORS)
131 printf("\n");
132 }
133 }
134 rewinddir(dp);
ff1ac639 135 while (ent = readdir(dp), ent) {
49d916ec
MS
136 if (check_prefix(ent->d_name, type_trigger)) {
137 char *dev_dir_name;
d1e50413 138
e9e45b43
HK
139 if (asprintf(&dev_dir_name, "%s%s", iio_dir,
140 ent->d_name) < 0) {
acf50b35
HK
141 ret = -ENOMEM;
142 goto error_close_dir;
143 }
144
145 ret = dump_one_trigger(dev_dir_name);
146 if (ret) {
147 free(dev_dir_name);
e9e45b43
HK
148 goto error_close_dir;
149 }
150
49d916ec
MS
151 free(dev_dir_name);
152 }
153 }
7663a4aa 154
acf50b35
HK
155 return (closedir(dp) == -1) ? -errno : 0;
156
e9e45b43 157error_close_dir:
acf50b35
HK
158 if (closedir(dp) == -1)
159 perror("dump_devices(): Failed to close directory");
160
161 return ret;
49d916ec
MS
162}
163
164int main(int argc, char **argv)
165{
166 int c, err = 0;
167
e06e3d71 168 while ((c = getopt(argc, argv, "v")) != EOF) {
49d916ec
MS
169 switch (c) {
170 case 'v':
171 verblevel++;
172 break;
173
174 case '?':
175 default:
176 err++;
177 break;
178 }
179 }
180 if (err || argc > optind) {
181 fprintf(stderr, "Usage: lsiio [options]...\n"
182 "List industrial I/O devices\n"
e06e3d71 183 " -v Increase verbosity (may be given multiple times)\n");
49d916ec
MS
184 exit(1);
185 }
186
acf50b35 187 return dump_devices();
49d916ec 188}
This page took 0.6724 seconds and 4 git commands to generate.