Linux Audio

Check our new training course

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