Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
|
Ethernet support functions. More...
Modules | |
Ethernet MII Support Functions | |
Ethernet MII (media independent interface) functions. | |
Data Structures | |
struct | ethernet_qav_param |
struct | ethernet_qbv_param |
struct | ethernet_qbu_param |
struct | ethernet_filter |
struct | ethernet_txtime_param |
struct | ethernet_api |
struct | ethernet_context |
Macros | |
#define | ETH_NET_DEVICE_INIT(dev_name, drv_name, init_fn, pm_control_fn, data, cfg, prio, api, mtu) |
Create an Ethernet network interface and bind it to network device. More... | |
#define | ETH_NET_DEVICE_DT_DEFINE(node_id, init_fn, pm_control_fn, data, cfg, prio, api, mtu) |
Like ETH_NET_DEVICE_INIT but taking metadata from a devicetree. Create an Ethernet network interface and bind it to network device. More... | |
#define | ETH_NET_DEVICE_DT_INST_DEFINE(inst, ...) ETH_NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__) |
Like ETH_NET_DEVICE_DT_DEFINE for an instance of a DT_DRV_COMPAT compatible. More... | |
Enumerations | |
enum | ethernet_hw_caps { ETHERNET_HW_TX_CHKSUM_OFFLOAD = BIT(0) , ETHERNET_HW_RX_CHKSUM_OFFLOAD = BIT(1) , ETHERNET_HW_VLAN = BIT(2) , ETHERNET_AUTO_NEGOTIATION_SET = BIT(3) , ETHERNET_LINK_10BASE_T = BIT(4) , ETHERNET_LINK_100BASE_T = BIT(5) , ETHERNET_LINK_1000BASE_T = BIT(6) , ETHERNET_DUPLEX_SET = BIT(7) , ETHERNET_PTP = BIT(8) , ETHERNET_QAV = BIT(9) , ETHERNET_PROMISC_MODE = BIT(10) , ETHERNET_PRIORITY_QUEUES = BIT(11) , ETHERNET_HW_FILTERING = BIT(12) , ETHERNET_LLDP = BIT(13) , ETHERNET_HW_VLAN_TAG_STRIP = BIT(14) , ETHERNET_DSA_SLAVE_PORT = BIT(15) , ETHERNET_DSA_MASTER_PORT = BIT(16) , ETHERNET_QBV = BIT(17) , ETHERNET_QBU = BIT(18) , ETHERNET_TXTIME = BIT(19) } |
enum | ethernet_flags { ETH_CARRIER_UP } |
Functions | |
void | ethernet_init (struct net_if *iface) |
Initialize Ethernet L2 stack for a given interface. More... | |
void | net_eth_ipv6_mcast_to_mac_addr (const struct in6_addr *ipv6_addr, struct net_eth_addr *mac_addr) |
Convert IPv6 multicast address to Ethernet address. More... | |
static enum ethernet_hw_caps | net_eth_get_hw_capabilities (struct net_if *iface) |
Return ethernet device hardware capability information. More... | |
static int | net_eth_vlan_enable (struct net_if *iface, uint16_t tag) |
Add VLAN tag to the interface. More... | |
static int | net_eth_vlan_disable (struct net_if *iface, uint16_t tag) |
Remove VLAN tag from the interface. More... | |
static uint16_t | net_eth_get_vlan_tag (struct net_if *iface) |
Return VLAN tag specified to network interface. More... | |
static struct net_if * | net_eth_get_vlan_iface (struct net_if *iface, uint16_t tag) |
Return network interface related to this VLAN tag. More... | |
static bool | net_eth_is_vlan_enabled (struct ethernet_context *ctx, struct net_if *iface) |
Check if VLAN is enabled for a specific network interface. More... | |
static bool | net_eth_get_vlan_status (struct net_if *iface) |
Get VLAN status for a given network interface (enabled or not). More... | |
void | net_eth_carrier_on (struct net_if *iface) |
Inform ethernet L2 driver that ethernet carrier is detected. This happens when cable is connected. More... | |
void | net_eth_carrier_off (struct net_if *iface) |
Inform ethernet L2 driver that ethernet carrier was lost. This happens when cable is disconnected. More... | |
int | net_eth_promisc_mode (struct net_if *iface, bool enable) |
Set promiscuous mode either ON or OFF. More... | |
static const struct device * | net_eth_get_ptp_clock (struct net_if *iface) |
Return PTP clock that is tied to this ethernet network interface. More... | |
const struct device * | net_eth_get_ptp_clock_by_index (int index) |
Return PTP clock that is tied to this ethernet network interface index. More... | |
static int | net_eth_get_ptp_port (struct net_if *iface) |
Return gPTP port number attached to this interface. More... | |
Ethernet support functions.
#define ETH_NET_DEVICE_DT_DEFINE | ( | node_id, | |
init_fn, | |||
pm_control_fn, | |||
data, | |||
cfg, | |||
prio, | |||
api, | |||
mtu | |||
) |
#include <include/net/ethernet.h>
Like ETH_NET_DEVICE_INIT but taking metadata from a devicetree. Create an Ethernet network interface and bind it to network device.
node_id | The devicetree node identifier. |
init_fn | Address to the init function of the driver. |
pm_control_fn | Pointer to pm_control function. Can be NULL if not implemented. |
data | Pointer to the device's private data. |
cfg | The address to the structure containing the configuration information for this instance of the driver. |
prio | The initialization level at which configuration occurs. |
api | Provides an initial pointer to the API function struct used by the driver. Can be NULL. |
mtu | Maximum transfer unit in bytes for this network interface. |
#define ETH_NET_DEVICE_DT_INST_DEFINE | ( | inst, | |
... | |||
) | ETH_NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__) |
#include <include/net/ethernet.h>
Like ETH_NET_DEVICE_DT_DEFINE for an instance of a DT_DRV_COMPAT compatible.
inst | instance number. This is replaced by DT_DRV_COMPAT(inst) in the call to ETH_NET_DEVICE_DT_DEFINE. |
... | other parameters as expected by ETH_NET_DEVICE_DT_DEFINE. |
#define ETH_NET_DEVICE_INIT | ( | dev_name, | |
drv_name, | |||
init_fn, | |||
pm_control_fn, | |||
data, | |||
cfg, | |||
prio, | |||
api, | |||
mtu | |||
) |
#include <include/net/ethernet.h>
Create an Ethernet network interface and bind it to network device.
dev_name | Network device name. |
drv_name | The name this instance of the driver exposes to the system. |
init_fn | Address to the init function of the driver. |
pm_control_fn | Pointer to pm_control function. Can be NULL if not implemented. |
data | Pointer to the device's private data. |
cfg | The address to the structure containing the configuration information for this instance of the driver. |
prio | The initialization level at which configuration occurs. |
api | Provides an initial pointer to the API function struct used by the driver. Can be NULL. |
mtu | Maximum transfer unit in bytes for this network interface. |
enum ethernet_flags |
#include <include/net/ethernet.h>
Enumerator | |
---|---|
ETH_CARRIER_UP |
enum ethernet_hw_caps |
#include <include/net/ethernet.h>
Ethernet hardware capabilities
#include <include/net/ethernet.h>
Initialize Ethernet L2 stack for a given interface.
iface | A valid pointer to a network interface |
#include <include/net/ethernet.h>
Inform ethernet L2 driver that ethernet carrier was lost. This happens when cable is disconnected.
iface | Network interface |
#include <include/net/ethernet.h>
Inform ethernet L2 driver that ethernet carrier is detected. This happens when cable is connected.
iface | Network interface |
|
inlinestatic |
#include <include/net/ethernet.h>
Return ethernet device hardware capability information.
iface | Network interface |
#include <include/net/ethernet.h>
Return PTP clock that is tied to this ethernet network interface.
iface | Network interface |
const struct device * net_eth_get_ptp_clock_by_index | ( | int | index | ) |
#include <include/net/ethernet.h>
Return PTP clock that is tied to this ethernet network interface index.
index | Network interface index |
|
inlinestatic |
#include <include/net/ethernet.h>
Return gPTP port number attached to this interface.
iface | Network interface |
#include <include/net/ethernet.h>
Return network interface related to this VLAN tag.
iface | Master network interface. This is used to get the pointer to ethernet L2 context |
tag | VLAN tag |
#include <include/net/ethernet.h>
Get VLAN status for a given network interface (enabled or not).
iface | Network interface |
#include <include/net/ethernet.h>
Return VLAN tag specified to network interface.
iface | Network interface. |
void net_eth_ipv6_mcast_to_mac_addr | ( | const struct in6_addr * | ipv6_addr, |
struct net_eth_addr * | mac_addr | ||
) |
#include <include/net/ethernet.h>
Convert IPv6 multicast address to Ethernet address.
ipv6_addr | IPv6 multicast address |
mac_addr | Output buffer for Ethernet address |
|
inlinestatic |
#include <include/net/ethernet.h>
Check if VLAN is enabled for a specific network interface.
ctx | Ethernet context |
iface | Network interface |
#include <include/net/ethernet.h>
Set promiscuous mode either ON or OFF.
iface | Network interface |
enable | on (true) or off (false) |
#include <include/net/ethernet.h>
Remove VLAN tag from the interface.
iface | Interface to use. |
tag | VLAN tag to remove |
#include <include/net/ethernet.h>
Add VLAN tag to the interface.
iface | Interface to use. |
tag | VLAN tag to add |