2015-11-18 16:11:50 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-02-13 10:33:34 +01:00
|
|
|
/**
|
2015-11-18 16:11:50 +01:00
|
|
|
* @ingroup sys_shell_commands
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief SAUL registry shell commands
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2018-07-21 08:50:07 +02:00
|
|
|
#include <stddef.h>
|
2015-11-18 16:11:50 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "saul_reg.h"
|
2022-05-31 23:27:27 +02:00
|
|
|
#include "shell.h"
|
2015-11-18 16:11:50 +01:00
|
|
|
|
2021-03-22 21:53:49 +01:00
|
|
|
static const char *_devname(saul_reg_t *dev) {
|
|
|
|
if (dev->name == NULL) {
|
|
|
|
return "(no name)";
|
|
|
|
} else {
|
|
|
|
return dev->name;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-18 16:11:50 +01:00
|
|
|
/* this function does not check, if the given device is valid */
|
|
|
|
static void probe(int num, saul_reg_t *dev)
|
|
|
|
{
|
|
|
|
int dim;
|
|
|
|
phydat_t res;
|
|
|
|
|
|
|
|
dim = saul_reg_read(dev, &res);
|
|
|
|
if (dim <= 0) {
|
|
|
|
printf("error: failed to read from device #%i\n", num);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
/* print results */
|
2021-03-22 21:53:49 +01:00
|
|
|
printf("Reading from #%i (%s|%s)\n", num, _devname(dev),
|
2015-11-18 16:11:50 +01:00
|
|
|
saul_class_to_str(dev->driver->type));
|
|
|
|
phydat_dump(&res, dim);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void probe_all(void)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *dev = saul_reg;
|
2015-11-18 16:11:50 +01:00
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
while (dev) {
|
|
|
|
probe(i++, dev);
|
|
|
|
puts("");
|
|
|
|
dev = dev->next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void list(void)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *dev = saul_reg;
|
2015-11-18 16:11:50 +01:00
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
if (dev) {
|
|
|
|
puts("ID\tClass\t\tName");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
puts("No devices found");
|
|
|
|
}
|
|
|
|
while (dev) {
|
|
|
|
printf("#%i\t%s\t%s\n",
|
2021-03-22 21:53:49 +01:00
|
|
|
i++, saul_class_to_str(dev->driver->type), _devname(dev));
|
2015-11-18 16:11:50 +01:00
|
|
|
dev = dev->next;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void read(int argc, char **argv)
|
|
|
|
{
|
|
|
|
int num;
|
|
|
|
saul_reg_t *dev;
|
|
|
|
|
|
|
|
if (argc < 3) {
|
|
|
|
printf("usage: %s %s <device id>|all\n", argv[0], argv[1]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (strcmp(argv[2], "all") == 0) {
|
|
|
|
probe_all();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
/* get device id */
|
|
|
|
num = atoi(argv[2]);
|
|
|
|
dev = saul_reg_find_nth(num);
|
|
|
|
if (dev == NULL) {
|
|
|
|
puts("error: undefined device id given");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
probe(num, dev);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void write(int argc, char **argv)
|
|
|
|
{
|
|
|
|
int num, dim;
|
|
|
|
saul_reg_t *dev;
|
|
|
|
phydat_t data;
|
|
|
|
|
|
|
|
if (argc < 4) {
|
|
|
|
printf("usage: %s %s <device id> <value 0> [<value 1> [<value 2]]\n",
|
|
|
|
argv[0], argv[1]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
num = atoi(argv[2]);
|
|
|
|
dev = saul_reg_find_nth(num);
|
|
|
|
if (dev == NULL) {
|
|
|
|
puts("error: undefined device given");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
/* parse value(s) */
|
|
|
|
memset(&data, 0, sizeof(data));
|
|
|
|
dim = ((argc - 3) > (int)PHYDAT_DIM) ? (int)PHYDAT_DIM : (argc - 3);
|
|
|
|
for (int i = 0; i < dim; i++) {
|
2017-05-13 12:39:48 +02:00
|
|
|
data.val[i] = atoi(argv[i + 3]);
|
2015-11-18 16:11:50 +01:00
|
|
|
}
|
|
|
|
/* print values before writing */
|
2021-03-22 21:53:49 +01:00
|
|
|
printf("Writing to device #%i - %s\n", num, _devname(dev));
|
2015-11-18 16:11:50 +01:00
|
|
|
phydat_dump(&data, dim);
|
|
|
|
/* write values to device */
|
|
|
|
dim = saul_reg_write(dev, &data);
|
|
|
|
if (dim <= 0) {
|
|
|
|
if (dim == -ENOTSUP) {
|
|
|
|
printf("error: device #%i is not writable\n", num);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("error: failure to write to device #%i\n", num);
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
printf("data successfully written to device #%i\n", num);
|
|
|
|
}
|
|
|
|
|
2022-06-08 08:51:38 +02:00
|
|
|
static int _saul(int argc, char **argv)
|
2015-11-18 16:11:50 +01:00
|
|
|
{
|
|
|
|
if (argc < 2) {
|
|
|
|
list();
|
|
|
|
}
|
2016-12-21 14:30:42 +01:00
|
|
|
else {
|
2015-11-18 16:11:50 +01:00
|
|
|
if (strcmp(argv[1], "read") == 0) {
|
|
|
|
read(argc, argv);
|
|
|
|
}
|
|
|
|
else if (strcmp(argv[1], "write") == 0) {
|
|
|
|
write(argc, argv);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("usage: %s read|write\n", argv[0]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
2022-05-31 23:27:27 +02:00
|
|
|
|
|
|
|
SHELL_COMMAND(saul, "interact with sensors and actuators using SAUL", _saul);
|