2015-11-18 16:07:44 +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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup sys_saul_reg
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief SAUL registry implementation
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2018-07-21 08:50:07 +02:00
|
|
|
#include <stddef.h>
|
2015-11-18 16:07:44 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "saul_reg.h"
|
|
|
|
|
|
|
|
/**
|
2016-02-26 16:37:02 +01:00
|
|
|
* @brief Keep the head of the device list as global variable
|
2015-11-18 16:07:44 +01:00
|
|
|
*/
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *saul_reg = NULL;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
|
|
|
|
|
|
|
int saul_reg_add(saul_reg_t *dev)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *tmp = saul_reg;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
|
|
|
if (dev == NULL) {
|
|
|
|
return -ENODEV;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* prepare new entry */
|
|
|
|
dev->next = NULL;
|
|
|
|
/* add to registry */
|
2016-02-26 16:37:02 +01:00
|
|
|
if (saul_reg == NULL) {
|
|
|
|
saul_reg = dev;
|
2015-11-18 16:07:44 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
while (tmp->next != NULL) {
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
tmp->next = dev;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int saul_reg_rm(saul_reg_t *dev)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *tmp = saul_reg;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
2016-02-26 16:37:02 +01:00
|
|
|
if (saul_reg == NULL || dev == NULL) {
|
2016-04-15 15:06:25 +02:00
|
|
|
return -ENODEV;
|
2015-11-18 16:07:44 +01:00
|
|
|
}
|
2016-02-26 16:37:02 +01:00
|
|
|
if (saul_reg == dev) {
|
|
|
|
saul_reg = dev->next;
|
2018-02-18 11:30:46 +01:00
|
|
|
return 0;
|
2015-11-18 16:07:44 +01:00
|
|
|
}
|
|
|
|
while (tmp->next && (tmp->next != dev)) {
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
if (tmp->next == dev) {
|
|
|
|
tmp->next = dev->next;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return -ENODEV;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
saul_reg_t *saul_reg_find_nth(int pos)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *tmp = saul_reg;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
|
|
|
for (int i = 0; (i < pos) && tmp; i++) {
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
saul_reg_t *saul_reg_find_type(uint8_t type)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *tmp = saul_reg;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
|
|
|
while (tmp) {
|
|
|
|
if (tmp->driver->type == type) {
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
saul_reg_t *saul_reg_find_name(const char *name)
|
|
|
|
{
|
2016-02-26 16:37:02 +01:00
|
|
|
saul_reg_t *tmp = saul_reg;
|
2015-11-18 16:07:44 +01:00
|
|
|
|
|
|
|
while (tmp) {
|
|
|
|
if (strcmp(tmp->name, name) == 0) {
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2021-01-18 22:25:19 +01:00
|
|
|
saul_reg_t *saul_reg_find_type_and_name(uint8_t type, const char *name)
|
|
|
|
{
|
|
|
|
saul_reg_t *tmp = saul_reg;
|
|
|
|
|
|
|
|
while (tmp) {
|
|
|
|
if (tmp->driver->type == type && strcmp(tmp->name, name) == 0) {
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2015-11-18 16:07:44 +01:00
|
|
|
int saul_reg_read(saul_reg_t *dev, phydat_t *res)
|
|
|
|
{
|
|
|
|
if (dev == NULL) {
|
|
|
|
return -ENODEV;
|
|
|
|
}
|
|
|
|
return dev->driver->read(dev->dev, res);
|
|
|
|
}
|
|
|
|
|
|
|
|
int saul_reg_write(saul_reg_t *dev, phydat_t *data)
|
|
|
|
{
|
|
|
|
if (dev == NULL) {
|
|
|
|
return -ENODEV;
|
|
|
|
}
|
|
|
|
return dev->driver->write(dev->dev, data);
|
|
|
|
}
|