mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 14:32:43 +01:00
80 lines
2.2 KiB
C
80 lines
2.2 KiB
C
|
/*
|
||
|
* Copyright (C) 2021 Benjamin Valentin
|
||
|
*
|
||
|
* This file is subject to the terms and conditions of the GNU General Public
|
||
|
* License v2. See the file LICENSE for more details.
|
||
|
*/
|
||
|
|
||
|
#ifndef TOPOLOGY_H
|
||
|
#define TOPOLOGY_H
|
||
|
|
||
|
#include "list.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief Struct describing a graph of nodes and their connections
|
||
|
*/
|
||
|
typedef struct {
|
||
|
bool flat; /**< flat topology, all nodes are connected to each other */
|
||
|
list_node_t nodes; /**< list of nodes */
|
||
|
list_node_t edges; /**< list of connections between nodes. Unused if topology is flat */
|
||
|
} topology_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Parse a file with topology information
|
||
|
*
|
||
|
* @param[in] file Filename to open & parse
|
||
|
* May be "-" to use stdin
|
||
|
* @param[out] out Topology from file
|
||
|
*
|
||
|
* @return 0 on success, error otherwise
|
||
|
*/
|
||
|
int topology_parse(const char *file, topology_t *out);
|
||
|
|
||
|
/**
|
||
|
* @brief Print topology as Graphviz diagram
|
||
|
*
|
||
|
* @param[in] file_out Filename to write to
|
||
|
* May be "-" to use stdout
|
||
|
* @param[in] t The topology to render
|
||
|
*
|
||
|
* @return 0 on success, error otherwise
|
||
|
*/
|
||
|
int topology_print(const char *file_out, const topology_t *t);
|
||
|
|
||
|
/**
|
||
|
* @brief Populate a spot in the topology with a connected node
|
||
|
*
|
||
|
* @param[in, out] t topology to use
|
||
|
* @param[in] mac ZEP l2 address of the new node
|
||
|
* @param[in] mac_len ZEP l2 address length
|
||
|
* @param[in] addr real address of the virtual node
|
||
|
*
|
||
|
* @return true if the node could be added to the topology
|
||
|
*/
|
||
|
bool topology_add(topology_t *t, const uint8_t *mac, uint8_t mac_len,
|
||
|
struct sockaddr_in6 *addr);
|
||
|
|
||
|
/**
|
||
|
* @brief Send a buffer to all nodes connected to a source node
|
||
|
*
|
||
|
* @param[in] t topology to use
|
||
|
* @param[in] sock socket to use for sending
|
||
|
* @param[in] mac_src ZEP source l2 address
|
||
|
* @param[in] mac_src_len ZEP source l2 address length
|
||
|
* @param[in] buffer ZEP frame to send
|
||
|
* @param[in] len ZEP frame length
|
||
|
*/
|
||
|
void topology_send(const topology_t *t, int sock,
|
||
|
const uint8_t *mac_src, size_t mac_src_len,
|
||
|
void *buffer, size_t len);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* TOPOLOGY_H */
|