2019-07-22 13:32:39 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 HAW Hamburg
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @author Jose I. Alamos <jose.alamos@haw-hamburg.de>
|
|
|
|
*/
|
|
|
|
|
2020-10-21 15:58:33 +02:00
|
|
|
#include <assert.h>
|
2022-06-02 12:36:15 +02:00
|
|
|
#include <errno.h>
|
|
|
|
#include <stdio.h>
|
2019-07-22 13:32:39 +02:00
|
|
|
#include <string.h>
|
|
|
|
|
2021-02-02 16:45:21 +01:00
|
|
|
#include "irq.h"
|
2022-06-02 12:36:15 +02:00
|
|
|
#include "kernel_defines.h"
|
2019-07-22 13:32:39 +02:00
|
|
|
#include "net/netif.h"
|
|
|
|
#include "utlist.h"
|
|
|
|
|
|
|
|
static list_node_t netif_list;
|
|
|
|
|
|
|
|
int netif_register(netif_t *netif)
|
|
|
|
{
|
2021-02-02 16:45:21 +01:00
|
|
|
if (netif == NULL) {
|
2019-07-22 13:32:39 +02:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2021-02-02 16:45:21 +01:00
|
|
|
unsigned state = irq_disable();
|
2019-07-22 13:32:39 +02:00
|
|
|
list_add(&netif_list, &netif->node);
|
2021-02-02 16:45:21 +01:00
|
|
|
irq_restore(state);
|
|
|
|
|
2019-07-22 13:32:39 +02:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-01-13 09:59:26 +01:00
|
|
|
netif_t *netif_iter(const netif_t *last)
|
2019-07-22 13:32:39 +02:00
|
|
|
{
|
|
|
|
if (last == NULL) {
|
|
|
|
return (netif_t *)netif_list.next;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (netif_t *)last->node.next;
|
|
|
|
}
|
|
|
|
|
2019-11-18 13:51:11 +01:00
|
|
|
__attribute__((weak)) int16_t netif_get_id(const netif_t *netif)
|
|
|
|
{
|
|
|
|
list_node_t *node = netif_list.next;
|
|
|
|
for (int16_t i = 0; node; i++, node = node->next) {
|
|
|
|
if (netif == (netif_t *)node) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2021-03-24 09:26:56 +01:00
|
|
|
netif_t *netif_get_by_name_buffer(const char *name, size_t name_len)
|
2019-07-22 13:32:39 +02:00
|
|
|
{
|
|
|
|
assert(name);
|
2021-03-24 09:26:56 +01:00
|
|
|
|
|
|
|
if (name_len > CONFIG_NETIF_NAMELENMAX) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-07-22 13:32:39 +02:00
|
|
|
list_node_t *node = netif_list.next;
|
|
|
|
|
2020-07-28 19:32:12 +02:00
|
|
|
char tmp[CONFIG_NETIF_NAMELENMAX];
|
2019-07-22 13:32:39 +02:00
|
|
|
|
2021-02-02 16:45:21 +01:00
|
|
|
while (node) {
|
2019-07-22 13:32:39 +02:00
|
|
|
netif_get_name((netif_t *)node, tmp);
|
2021-03-24 09:26:56 +01:00
|
|
|
size_t len = strlen(tmp);
|
|
|
|
if ((len == name_len) && (strncmp(name, tmp, name_len) == 0)) {
|
2019-07-22 13:32:39 +02:00
|
|
|
return (netif_t *)node;
|
|
|
|
}
|
|
|
|
node = node->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
2019-11-18 13:51:11 +01:00
|
|
|
|
|
|
|
__attribute__((weak)) netif_t *netif_get_by_id(int16_t id)
|
|
|
|
{
|
|
|
|
list_node_t *node = netif_list.next;
|
|
|
|
for (int16_t i = 0; node; i++, node = node->next) {
|
|
|
|
if (i == id) {
|
|
|
|
return (netif_t *)node;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2022-06-02 12:36:15 +02:00
|
|
|
ssize_t netifs_get_ipv6(ipv6_addr_t *dest, size_t numof)
|
|
|
|
{
|
|
|
|
ssize_t result = 0;
|
|
|
|
netif_t *netif = NULL;
|
|
|
|
while (((netif = netif_iter(netif)) != NULL) && (numof > 0)) {
|
|
|
|
ssize_t addrs_numof = netif_get_ipv6(netif, dest, numof);
|
|
|
|
if (addrs_numof <= 0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
result += addrs_numof;
|
|
|
|
dest += addrs_numof;
|
|
|
|
numof -= addrs_numof;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef NETIF_PRINT_IPV6_NUMOF
|
|
|
|
#define NETIF_PRINT_IPV6_NUMOF 4
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void netif_print_ipv6(netif_t *netif, const char *separator)
|
|
|
|
{
|
|
|
|
ipv6_addr_t addrs[NETIF_PRINT_IPV6_NUMOF];
|
|
|
|
ssize_t num = netif_get_ipv6(netif, addrs, ARRAY_SIZE(addrs));
|
|
|
|
if (num > 0) {
|
|
|
|
ipv6_addrs_print(addrs, num, separator);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void netifs_print_ipv6(const char *separator)
|
|
|
|
{
|
|
|
|
netif_t *netif = 0;
|
|
|
|
bool first = true;
|
|
|
|
while ((netif = netif_iter(netif)) != NULL) {
|
|
|
|
ipv6_addr_t addrs[NETIF_PRINT_IPV6_NUMOF];
|
|
|
|
ssize_t num = netif_get_ipv6(netif, addrs, ARRAY_SIZE(addrs));
|
|
|
|
if (num > 0) {
|
|
|
|
if (first) {
|
|
|
|
first = false;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("%s", separator);
|
|
|
|
}
|
|
|
|
ipv6_addrs_print(addrs, num, separator);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-07-22 13:32:39 +02:00
|
|
|
/** @} */
|