mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
ec5f686cd0
Moving to a pointer-based API simplifies a lot, since there is no need for an internal pool of entries anymore. Therefore, a lot of organizational overhead and some restrictions (e.g. an upper limit on entries) are dropped. The entries can be stored in the stack of the respective thread.
135 lines
3.9 KiB
C
135 lines
3.9 KiB
C
/*
|
|
* Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @defgroup net_ng_netreg Network protocol registry
|
|
* @ingroup net
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Definitions to register network protocol PIDs to use with
|
|
* @ref net_ng_netapi.
|
|
*
|
|
* @author Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
*/
|
|
#ifndef NETREG_H_
|
|
#define NETREG_H_
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include "kernel_types.h"
|
|
#include "net/ng_nettype.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Demux context value to get all packets of a certain type.
|
|
*
|
|
* @see ng_netreg_entry_t::demux_ctx
|
|
*/
|
|
#define NG_NETREG_DEMUX_CTX_ALL (0xffff0000)
|
|
|
|
/**
|
|
* @brief Entry to the @ref net_ng_netreg
|
|
*/
|
|
typedef struct ng_netreg_entry {
|
|
/**
|
|
* @brief next element in list
|
|
*
|
|
* @internal
|
|
*/
|
|
struct ng_netreg_entry *next;
|
|
|
|
/**
|
|
* @brief The demultiplexing context for the registering thread.
|
|
*
|
|
* @details This can be defined by the network protocol themselves.
|
|
* E. g. protocol numbers / next header numbers in IPv4/IPv6,
|
|
* ports in UDP/TCP, or similar.
|
|
*/
|
|
uint32_t demux_ctx;
|
|
kernel_pid_t pid; /**< The PID of the registering thread */
|
|
} ng_netreg_entry_t;
|
|
|
|
/**
|
|
* @brief Initializes module.
|
|
*/
|
|
void ng_netreg_init(void);
|
|
|
|
/**
|
|
* @brief Registers a thread to the registry.
|
|
*
|
|
* @details The semantics are: Thread ng_netreg_entry_t::pid is interested in
|
|
* packets of protocol @p type with context ng_netreg_entry_t::demux_ctx.
|
|
*
|
|
* @param[in] type Type of the protocol. Must not be <= NG_NETTYPE_UNDEF or
|
|
* >= NG_NETTYPE_NUMOF.
|
|
* @param[in] entry An entry you want to add to the registry with
|
|
* ng_netreg_entry_t::pid and ng_netreg_entry_t::demux_ctx set.
|
|
*
|
|
* @return 0 on success
|
|
* @return -EINVAL if @p type was <= NG_NETTYPE_UNDEF or >= NG_NETTYPE_NUMOF
|
|
*/
|
|
int ng_netreg_register(ng_nettype_t type, ng_netreg_entry_t *entry);
|
|
|
|
/**
|
|
* @brief Removes a thread from the registry.
|
|
*
|
|
* @param[in] type Type of the protocol.
|
|
* @param[in] entry An entry you want to remove from the registry.
|
|
*/
|
|
void ng_netreg_unregister(ng_nettype_t type, ng_netreg_entry_t *entry);
|
|
|
|
/**
|
|
* @brief Searches for entries with given parameters in the registry and
|
|
* returns the first found.
|
|
*
|
|
* @param[in] type Type of the protocol.
|
|
* @param[in] demux_ctx The demultiplexing context for the registered thread.
|
|
* See ng_netreg_entry_t::demux_ctx.
|
|
*
|
|
* @return The first entry fitting the given parameters on success
|
|
* @return NULL if no entry can be found.
|
|
*/
|
|
ng_netreg_entry_t *ng_netreg_lookup(ng_nettype_t type, uint32_t demux_ctx);
|
|
|
|
/**
|
|
* @brief Returns number of entries with the same ng_netreg_entry_t::type and
|
|
* ng_netreg_entry_t::demux_ctx.
|
|
*
|
|
* @param[in] type Type of the protocol.
|
|
* @param[in] demux_ctx The demultiplexing context for the registered thread.
|
|
* See ng_netreg_entry_t::demux_ctx.
|
|
*
|
|
* @return Number of entries with the same ng_netreg_entry_t::type and
|
|
* ng_netreg_entry_t::demux_ctx as the given parameters.
|
|
*/
|
|
int ng_netreg_num(ng_nettype_t type, uint32_t demux_ctx);
|
|
|
|
/**
|
|
* @brief Returns the next entry after @p entry with the same
|
|
* ng_netreg_entry_t::type and ng_netreg_entry_t::demux_ctx as the
|
|
* given entry.
|
|
*
|
|
* @param[in] entry A registry entry retrieved by ng_netreg_lookup() or
|
|
* ng_netreg_getnext(). Must not be NULL.
|
|
*
|
|
* @return The next entry after @p entry fitting the given parameters on success
|
|
* @return NULL if no entry new entry can be found.
|
|
*/
|
|
ng_netreg_entry_t *ng_netreg_getnext(ng_netreg_entry_t *entry);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NETREG_H_ */
|
|
/** @} */
|