mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 14:32:43 +01:00
87 lines
2.2 KiB
C
87 lines
2.2 KiB
C
/*
|
|
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.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 drivers_netdev_eth Ethernet drivers
|
|
* @ingroup drivers_netdev_api
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Definitions for netdev common ethernet code
|
|
*
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
*/
|
|
|
|
#ifndef NET_NETDEV_ETH_H
|
|
#define NET_NETDEV_ETH_H
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "net/netdev.h"
|
|
#include "net/netopt.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name Flags for use in @ref netdev_eth_rx_info_t::flags
|
|
* @{
|
|
*/
|
|
#define NETDEV_ETH_RX_INFO_FLAG_TIMESTAMP (0x01) /**< Timestamp valid */
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief Received frame status information for Ethernet devices
|
|
*/
|
|
typedef struct {
|
|
/**
|
|
* @brief Time of the reception of the start of frame delimiter in
|
|
* nanoseconds since epoch
|
|
*/
|
|
uint64_t timestamp;
|
|
uint8_t flags; /**< Flags e.g. used to mark other fields as valid */
|
|
} netdev_eth_rx_info_t;
|
|
|
|
/**
|
|
* @brief Fallback function for netdev ethernet devices' _get function
|
|
*
|
|
* Supposed to be used by netdev drivers as default case.
|
|
*
|
|
* @warning Driver *MUST* implement NETOPT_ADDRESS case!
|
|
*
|
|
* @param[in] dev network device descriptor
|
|
* @param[in] opt option type
|
|
* @param[out] value pointer to store the option's value in
|
|
* @param[in] max_len maximal amount of byte that fit into @p value
|
|
*
|
|
* @return number of bytes written to @p value
|
|
* @return <0 on error
|
|
*/
|
|
int netdev_eth_get(netdev_t *dev, netopt_t opt, void *value, size_t max_len);
|
|
|
|
/**
|
|
* @brief Fallback function for netdev ethernet devices' _set function
|
|
*
|
|
* @param[in] dev network device descriptor
|
|
* @param[in] opt option type
|
|
* @param[in] value value to set
|
|
* @param[in] value_len the length of @p value
|
|
*
|
|
* @return number of bytes used from @p value
|
|
* @return <0 on error
|
|
*/
|
|
int netdev_eth_set(netdev_t *dev, netopt_t opt, const void *value, size_t value_len);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* NET_NETDEV_ETH_H */
|
|
/** @} */
|