|
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 |