libiio  1.0
Library for interfacing with IIO devices
iio_reg.c

Part of the libiio-utilites, iio_reg is a utility for debugging local IIO devices. It should not be used by normal users, and is normally used by driver developers during development, or by end users debugging a driver, or sending in a feature request. It provides a mechanism to read or write SPI or I2C registers for IIO devices.

// SPDX-License-Identifier: GPL-2.0-or-later
/*
* iio_reg - Part of the industrial I/O (IIO) utilities
*
* Copyright (C) 2015 Analog Devices, Inc.
* Author: Paul Cercueil <paul.cercueil@analog.com>
* */
#include <errno.h>
#include <iio/iio.h>
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
#include "iio_common.h"
#define MY_NAME "iio_reg"
static const struct option options[] = {
{0, 0, 0, 0},
};
static const char *options_descriptions[] = {
"<device> <register> [<value>]\n"
};
static int write_reg(struct iio_device *dev, uint32_t addr, uint32_t val)
{
int ret;
ret = iio_device_reg_write(dev, addr, val);
if (ret < 0) {
errno = -ret;
perror("Unable to write register");
goto err_destroy_context;
}
return EXIT_SUCCESS;
err_destroy_context:
return EXIT_FAILURE;
}
static int read_reg(struct iio_device *dev, unsigned long addr)
{
uint32_t val;
int ret;
ret = iio_device_reg_read(dev, addr, &val);
if (ret < 0) {
errno = -ret;
perror("Unable to read register");
goto err_destroy_context;
}
printf("0x%x\n", val);
return EXIT_SUCCESS;
err_destroy_context:
return EXIT_FAILURE;
}
int main(int argc, char **argv)
{
char **argw;
unsigned long addr;
struct iio_context *ctx;
struct iio_device *dev;
int c, ret = EXIT_FAILURE;
char * name;
struct option *opts;
argw = dup_argv(MY_NAME, argc, argv);
ctx = handle_common_opts(MY_NAME, argc, argw, "",
options, options_descriptions, &ret);
opts = add_common_options(options);
if (!opts) {
fprintf(stderr, "Failed to add common options\n");
return EXIT_FAILURE;
}
while ((c = getopt_long(argc, argw, "+" COMMON_OPTIONS, /* Flawfinder: ignore */
opts, NULL)) != -1) {
switch (c) {
/* All these are handled in the common */
case 'h':
case 'V':
case 'n':
case 'x':
case 'u':
case 'T':
break;
case 'S':
case 'a':
if (!optarg && argc > optind && argv[optind] != NULL
&& argv[optind][0] != '-')
optind++;
break;
case '?':
printf("Unknown argument '%c'\n", c);
return EXIT_FAILURE;
}
}
free(opts);
if ((argc - optind) < 2 || (argc - optind) > 3) {
usage(MY_NAME, options, options_descriptions);
return EXIT_SUCCESS;
}
if (!ctx)
return ret;
name = cmn_strndup(argw[optind], NAME_MAX);
dev = iio_context_find_device(ctx, name);
if (!dev) {
perror("Unable to find device");
goto err_destroy_context;
}
addr = sanitize_clamp("register address", argw[optind + 1], 0, UINT32_MAX);
if ((argc - optind) == 2) {
return read_reg(dev, addr);
} else {
uint32_t val = sanitize_clamp("register value", argw[optind + 2], 0, UINT32_MAX);
return write_reg(dev, addr, val);
}
err_destroy_context:
free(name);
iio_context_destroy(ctx);
free_argw(argc, argw);
return EXIT_SUCCESS;
}