| 
    Zephyr Project API
    3.3.0
    
   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_id, name, init_fn, pm, data, config, 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, data, config, 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_ipv4_mcast_to_mac_addr (const struct in_addr *ipv4_addr, struct net_eth_addr *mac_addr) | 
| Convert IPv4 multicast address to Ethernet address.  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 PTP port number attached to this interface.  More... | |
Ethernet support functions.
#include <include/zephyr/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 | Reference to struct pm_device associated with the device. (optional). | 
| data | Pointer to the device's private data. | 
| config | 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/zephyr/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. | 
#include <include/zephyr/net/ethernet.h>
Create an Ethernet network interface and bind it to network device.
| dev_id | Network device id. | 
| name | The name this instance of the driver exposes to the system. | 
| init_fn | Address to the init function of the driver. | 
| pm | Reference to struct pm_device associated with the device. (optional). | 
| data | Pointer to the device's private data. | 
| config | 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/zephyr/net/ethernet.h>
| Enumerator | |
|---|---|
| ETH_CARRIER_UP | |
| enum ethernet_hw_caps | 
#include <include/zephyr/net/ethernet.h>
Ethernet hardware capabilities
| void ethernet_init | ( | struct net_if * | iface | ) | 
#include <include/zephyr/net/ethernet.h>
Initialize Ethernet L2 stack for a given interface.
| iface | A valid pointer to a network interface | 
| void net_eth_carrier_off | ( | struct net_if * | iface | ) | 
#include <include/zephyr/net/ethernet.h>
Inform ethernet L2 driver that ethernet carrier was lost. This happens when cable is disconnected.
| iface | Network interface | 
| void net_eth_carrier_on | ( | struct net_if * | iface | ) | 
#include <include/zephyr/net/ethernet.h>
Inform ethernet L2 driver that ethernet carrier is detected. This happens when cable is connected.
| iface | Network interface | 
      
  | 
  inlinestatic | 
#include <include/zephyr/net/ethernet.h>
Return ethernet device hardware capability information.
| iface | Network interface | 
#include <include/zephyr/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/zephyr/net/ethernet.h>
Return PTP clock that is tied to this ethernet network interface index.
| index | Network interface index | 
      
  | 
  inlinestatic | 
#include <include/zephyr/net/ethernet.h>
Return PTP port number attached to this interface.
| iface | Network interface | 
#include <include/zephyr/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/zephyr/net/ethernet.h>
Get VLAN status for a given network interface (enabled or not).
| iface | Network interface | 
#include <include/zephyr/net/ethernet.h>
Return VLAN tag specified to network interface.
| iface | Network interface. | 
| void net_eth_ipv4_mcast_to_mac_addr | ( | const struct in_addr * | ipv4_addr, | 
| struct net_eth_addr * | mac_addr | ||
| ) | 
#include <include/zephyr/net/ethernet.h>
Convert IPv4 multicast address to Ethernet address.
| ipv4_addr | IPv4 multicast address | 
| mac_addr | Output buffer for Ethernet address | 
| void net_eth_ipv6_mcast_to_mac_addr | ( | const struct in6_addr * | ipv6_addr, | 
| struct net_eth_addr * | mac_addr | ||
| ) | 
#include <include/zephyr/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/zephyr/net/ethernet.h>
Check if VLAN is enabled for a specific network interface.
| ctx | Ethernet context | 
| iface | Network interface | 
#include <include/zephyr/net/ethernet.h>
Set promiscuous mode either ON or OFF.
| iface | Network interface | 
| enable | on (true) or off (false) | 
#include <include/zephyr/net/ethernet.h>
Remove VLAN tag from the interface.
| iface | Interface to use. | 
| tag | VLAN tag to remove | 
#include <include/zephyr/net/ethernet.h>
Add VLAN tag to the interface.
| iface | Interface to use. | 
| tag | VLAN tag to add |