Zephyr API Documentation  3.6.0
A Scalable Open Source RTOS
3.6.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
ethernet.h
Go to the documentation of this file.
1
7/*
8 * Copyright (c) 2016 Intel Corporation
9 *
10 * SPDX-License-Identifier: Apache-2.0
11 */
12
13#ifndef ZEPHYR_INCLUDE_NET_ETHERNET_H_
14#define ZEPHYR_INCLUDE_NET_ETHERNET_H_
15
16#include <zephyr/kernel.h>
17#include <zephyr/types.h>
18#include <stdbool.h>
19#include <zephyr/sys/atomic.h>
20
21#include <zephyr/net/net_ip.h>
22#include <zephyr/net/net_pkt.h>
23
24#if defined(CONFIG_NET_LLDP)
25#include <zephyr/net/lldp.h>
26#endif
27
28#include <zephyr/sys/util.h>
29#include <zephyr/net/net_if.h>
31#include <zephyr/net/ptp_time.h>
32
33#if defined(CONFIG_NET_DSA)
34#include <zephyr/net/dsa.h>
35#endif
36
37#if defined(CONFIG_NET_ETHERNET_BRIDGE)
39#endif
40
41#ifdef __cplusplus
42extern "C" {
43#endif
44
54struct net_eth_addr {
55 uint8_t addr[6];
56};
57
58#define NET_ETH_HDR(pkt) ((struct net_eth_hdr *)net_pkt_data(pkt))
59
60#define NET_ETH_PTYPE_ARP 0x0806
61#define NET_ETH_PTYPE_IP 0x0800
62#define NET_ETH_PTYPE_TSN 0x22f0 /* TSN (IEEE 1722) packet */
63#define NET_ETH_PTYPE_IPV6 0x86dd
64#define NET_ETH_PTYPE_VLAN 0x8100
65#define NET_ETH_PTYPE_PTP 0x88f7
66#define NET_ETH_PTYPE_LLDP 0x88cc
67#define NET_ETH_PTYPE_ALL 0x0003 /* from linux/if_ether.h */
68#define NET_ETH_PTYPE_ECAT 0x88a4
69#define NET_ETH_PTYPE_EAPOL 0x888e
70#define NET_ETH_PTYPE_IEEE802154 0x00F6 /* from linux/if_ether.h: IEEE802.15.4 frame */
71
72#if !defined(ETH_P_ALL)
73#define ETH_P_ALL NET_ETH_PTYPE_ALL
74#endif
75#if !defined(ETH_P_IP)
76#define ETH_P_IP NET_ETH_PTYPE_IP
77#endif
78#if !defined(ETH_P_ARP)
79#define ETH_P_ARP NET_ETH_PTYPE_ARP
80#endif
81#if !defined(ETH_P_IPV6)
82#define ETH_P_IPV6 NET_ETH_PTYPE_IPV6
83#endif
84#if !defined(ETH_P_8021Q)
85#define ETH_P_8021Q NET_ETH_PTYPE_VLAN
86#endif
87#if !defined(ETH_P_TSN)
88#define ETH_P_TSN NET_ETH_PTYPE_TSN
89#endif
90#if !defined(ETH_P_ECAT)
91#define ETH_P_ECAT NET_ETH_PTYPE_ECAT
92#endif
93#if !defined(ETH_P_IEEE802154)
94#define ETH_P_IEEE802154 NET_ETH_PTYPE_IEEE802154
95#endif
96
97#define NET_ETH_MINIMAL_FRAME_SIZE 60
98#define NET_ETH_MTU 1500
99
100#if defined(CONFIG_NET_VLAN)
101#define _NET_ETH_MAX_HDR_SIZE (sizeof(struct net_eth_vlan_hdr))
102#else
103#define _NET_ETH_MAX_HDR_SIZE (sizeof(struct net_eth_hdr))
104#endif
105
106#define _NET_ETH_MAX_FRAME_SIZE (NET_ETH_MTU + _NET_ETH_MAX_HDR_SIZE)
107/*
108 * Extend the max frame size for DSA (KSZ8794) by one byte (to 1519) to
109 * store tail tag.
110 */
111#if defined(CONFIG_NET_DSA)
112#define NET_ETH_MAX_FRAME_SIZE (_NET_ETH_MAX_FRAME_SIZE + DSA_TAG_SIZE)
113#define NET_ETH_MAX_HDR_SIZE (_NET_ETH_MAX_HDR_SIZE + DSA_TAG_SIZE)
114#else
115#define NET_ETH_MAX_FRAME_SIZE (_NET_ETH_MAX_FRAME_SIZE)
116#define NET_ETH_MAX_HDR_SIZE (_NET_ETH_MAX_HDR_SIZE)
117#endif
118
119#define NET_ETH_VLAN_HDR_SIZE 4
120
127
130
133
136
139
142
145
148
151
154
157
160
163
166
169
173
176
179
182
185};
186
189enum ethernet_config_type {
190 ETHERNET_CONFIG_TYPE_AUTO_NEG,
191 ETHERNET_CONFIG_TYPE_LINK,
192 ETHERNET_CONFIG_TYPE_DUPLEX,
193 ETHERNET_CONFIG_TYPE_MAC_ADDRESS,
194 ETHERNET_CONFIG_TYPE_QAV_PARAM,
195 ETHERNET_CONFIG_TYPE_QBV_PARAM,
196 ETHERNET_CONFIG_TYPE_QBU_PARAM,
197 ETHERNET_CONFIG_TYPE_TXTIME_PARAM,
198 ETHERNET_CONFIG_TYPE_PROMISC_MODE,
199 ETHERNET_CONFIG_TYPE_PRIORITY_QUEUES_NUM,
200 ETHERNET_CONFIG_TYPE_FILTER,
201 ETHERNET_CONFIG_TYPE_PORTS_NUM,
202 ETHERNET_CONFIG_TYPE_T1S_PARAM,
203 ETHERNET_CONFIG_TYPE_TXINJECTION_MODE,
204};
205
206enum ethernet_qav_param_type {
207 ETHERNET_QAV_PARAM_TYPE_DELTA_BANDWIDTH,
208 ETHERNET_QAV_PARAM_TYPE_IDLE_SLOPE,
209 ETHERNET_QAV_PARAM_TYPE_OPER_IDLE_SLOPE,
210 ETHERNET_QAV_PARAM_TYPE_TRAFFIC_CLASS,
211 ETHERNET_QAV_PARAM_TYPE_STATUS,
212};
213
214enum ethernet_t1s_param_type {
215 ETHERNET_T1S_PARAM_TYPE_PLCA_CONFIG,
216};
217
221 enum ethernet_t1s_param_type type;
222 union {
223 /* PLCA is the Physical Layer (PHY) Collision
224 * Avoidance technique employed with multidrop
225 * 10Base-T1S standard.
226 *
227 * The PLCA parameters are described in standard [1]
228 * as registers in memory map 4 (MMS = 4) (point 9.6).
229 *
230 * IDVER (PLCA ID Version)
231 * CTRL0 (PLCA Control 0)
232 * CTRL1 (PLCA Control 1)
233 * STATUS (PLCA Status)
234 * TOTMR (PLCA TO Control)
235 * BURST (PLCA Burst Control)
236 *
237 * Those registers are implemented by each OA TC6
238 * compliant vendor (like for e.g. LAN865x - e.g. [2]).
239 *
240 * Documents:
241 * [1] - "OPEN Alliance 10BASE-T1x MAC-PHY Serial
242 * Interface" (ver. 1.1)
243 * [2] - "DS60001734C" - LAN865x data sheet
244 */
245 struct {
247 bool enable;
259 };
260};
261
266 enum ethernet_qav_param_type type;
267 union {
271 unsigned int delta_bandwidth;
273 unsigned int idle_slope;
275 unsigned int oper_idle_slope;
277 unsigned int traffic_class;
278 };
279};
280
283enum ethernet_qbv_param_type {
284 ETHERNET_QBV_PARAM_TYPE_STATUS,
285 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST,
286 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST_LEN,
287 ETHERNET_QBV_PARAM_TYPE_TIME,
288};
289
290enum ethernet_qbv_state_type {
291 ETHERNET_QBV_STATE_TYPE_ADMIN,
292 ETHERNET_QBV_STATE_TYPE_OPER,
293};
294
295enum ethernet_gate_state_operation {
296 ETHERNET_SET_GATE_STATE,
297 ETHERNET_SET_AND_HOLD_MAC_STATE,
298 ETHERNET_SET_AND_RELEASE_MAC_STATE,
299};
300
307 enum ethernet_qbv_param_type type;
309 enum ethernet_qbv_state_type state;
310 union {
313
314 struct {
316 bool gate_status[NET_TC_TX_COUNT];
317
319 enum ethernet_gate_state_operation operation;
320
323
327
330
331 /* The time values are set in one go when type is set to
332 * ETHERNET_QBV_PARAM_TYPE_TIME
333 */
334 struct {
337
340
343 };
344 };
345};
346
349enum ethernet_qbu_param_type {
350 ETHERNET_QBU_PARAM_TYPE_STATUS,
351 ETHERNET_QBU_PARAM_TYPE_RELEASE_ADVANCE,
352 ETHERNET_QBU_PARAM_TYPE_HOLD_ADVANCE,
353 ETHERNET_QBU_PARAM_TYPE_PREEMPTION_STATUS_TABLE,
354
355 /* Some preemption settings are from Qbr spec. */
356 ETHERNET_QBR_PARAM_TYPE_LINK_PARTNER_STATUS,
357 ETHERNET_QBR_PARAM_TYPE_ADDITIONAL_FRAGMENT_SIZE,
358};
359
360enum ethernet_qbu_preempt_status {
361 ETHERNET_QBU_STATUS_EXPRESS,
362 ETHERNET_QBU_STATUS_PREEMPTABLE
363} __packed;
364
371 enum ethernet_qbu_param_type type;
372 union {
375
378
381 enum ethernet_qbu_preempt_status
382 frame_preempt_statuses[NET_TC_TX_COUNT];
383
386
389
394 };
395};
396
397
400enum ethernet_filter_type {
401 ETHERNET_FILTER_TYPE_SRC_MAC_ADDRESS,
402 ETHERNET_FILTER_TYPE_DST_MAC_ADDRESS,
403};
404
411
414} __packed;
415
416
419 enum ethernet_filter_type type;
421 struct net_eth_addr mac_address;
423 bool set;
424};
425
428enum ethernet_txtime_param_type {
429 ETHERNET_TXTIME_PARAM_TYPE_ENABLE_QUEUES,
430};
431
436 enum ethernet_txtime_param_type type;
441};
442
444struct ethernet_config {
445 union {
446 bool auto_negotiation;
447 bool full_duplex;
448 bool promisc_mode;
449 bool txinjection_mode;
450
451 struct {
452 bool link_10bt;
453 bool link_100bt;
454 bool link_1000bt;
455 } l;
456
457 struct net_eth_addr mac_address;
458
459 struct ethernet_t1s_param t1s_param;
460 struct ethernet_qav_param qav_param;
461 struct ethernet_qbv_param qbv_param;
462 struct ethernet_qbu_param qbu_param;
463 struct ethernet_txtime_param txtime_param;
464
465 int priority_queues_num;
466 int ports_num;
467
468 struct ethernet_filter filter;
469 };
470};
478 struct net_if_api iface_api;
479
480#if defined(CONFIG_NET_STATISTICS_ETHERNET)
485 struct net_stats_eth *(*get_stats)(const struct device *dev);
486#endif
487
489 int (*start)(const struct device *dev);
490
492 int (*stop)(const struct device *dev);
493
495 enum ethernet_hw_caps (*get_capabilities)(const struct device *dev);
496
498 int (*set_config)(const struct device *dev,
499 enum ethernet_config_type type,
500 const struct ethernet_config *config);
501
503 int (*get_config)(const struct device *dev,
504 enum ethernet_config_type type,
505 struct ethernet_config *config);
506
507#if defined(CONFIG_NET_VLAN)
513 int (*vlan_setup)(const struct device *dev, struct net_if *iface,
514 uint16_t tag, bool enable);
515#endif /* CONFIG_NET_VLAN */
516
517#if defined(CONFIG_PTP_CLOCK)
519 const struct device *(*get_ptp_clock)(const struct device *dev);
520#endif /* CONFIG_PTP_CLOCK */
521
523 int (*send)(const struct device *dev, struct net_pkt *pkt);
524};
525
526/* Make sure that the network interface API is properly setup inside
527 * Ethernet API struct (it is the first one).
528 */
529BUILD_ASSERT(offsetof(struct ethernet_api, iface_api) == 0);
530
532struct net_eth_hdr {
533 struct net_eth_addr dst;
534 struct net_eth_addr src;
535 uint16_t type;
536} __packed;
537
538struct ethernet_vlan {
540 struct net_if *iface;
541
543 uint16_t tag;
544};
545
546#if defined(CONFIG_NET_VLAN_COUNT)
547#define NET_VLAN_MAX_COUNT CONFIG_NET_VLAN_COUNT
548#else
549/* Even thou there are no VLAN support, the minimum count must be set to 1.
550 */
551#define NET_VLAN_MAX_COUNT 1
552#endif
553
556#if defined(CONFIG_NET_LLDP)
557struct ethernet_lldp {
559 sys_snode_t node;
560
562 const struct net_lldpdu *lldpdu;
563
565 const uint8_t *optional_du;
566
568 size_t optional_len;
569
571 struct net_if *iface;
572
574 int64_t tx_timer_start;
575
577 uint32_t tx_timer_timeout;
578
581};
582#endif /* CONFIG_NET_LLDP */
583
586};
587
594
595#if defined(CONFIG_NET_VLAN)
596 struct ethernet_vlan vlan[NET_VLAN_MAX_COUNT];
597
603 ATOMIC_DEFINE(interfaces, NET_VLAN_MAX_COUNT);
604#endif
605
606#if defined(CONFIG_NET_ETHERNET_BRIDGE)
607 struct eth_bridge_iface_context bridge;
608#endif
609
617
619 struct net_if *iface;
620
621#if defined(CONFIG_NET_LLDP)
622 struct ethernet_lldp lldp[NET_VLAN_MAX_COUNT];
623#endif
624
629
630#if defined(CONFIG_NET_L2_PTP)
635 int port;
636#endif
637
638#if defined(CONFIG_NET_DSA)
642 dsa_net_recv_cb_t dsa_recv_cb;
643
645 uint8_t dsa_port_idx;
646
648 struct dsa_context *dsa_ctx;
649
651 dsa_send_t dsa_send;
652#endif
653
654#if defined(CONFIG_NET_VLAN)
659 int8_t vlan_enabled;
660#endif
661
664
666 bool is_init : 1;
667
670};
671
677void ethernet_init(struct net_if *iface);
678
681#define ETHERNET_L2_CTX_TYPE struct ethernet_context
682
683/* Separate header for VLAN as some of device interfaces might not
684 * support VLAN.
685 */
686struct net_eth_vlan_hdr {
687 struct net_eth_addr dst;
688 struct net_eth_addr src;
689 struct {
690 uint16_t tpid; /* tag protocol id */
691 uint16_t tci; /* tag control info */
692 } vlan;
693 uint16_t type;
694} __packed;
695
696
697static inline bool net_eth_is_addr_broadcast(struct net_eth_addr *addr)
698{
699 if (addr->addr[0] == 0xff &&
700 addr->addr[1] == 0xff &&
701 addr->addr[2] == 0xff &&
702 addr->addr[3] == 0xff &&
703 addr->addr[4] == 0xff &&
704 addr->addr[5] == 0xff) {
705 return true;
706 }
707
708 return false;
709}
710
711static inline bool net_eth_is_addr_unspecified(struct net_eth_addr *addr)
712{
713 if (addr->addr[0] == 0x00 &&
714 addr->addr[1] == 0x00 &&
715 addr->addr[2] == 0x00 &&
716 addr->addr[3] == 0x00 &&
717 addr->addr[4] == 0x00 &&
718 addr->addr[5] == 0x00) {
719 return true;
720 }
721
722 return false;
723}
724
725static inline bool net_eth_is_addr_multicast(struct net_eth_addr *addr)
726{
727#if defined(CONFIG_NET_IPV6)
728 if (addr->addr[0] == 0x33 &&
729 addr->addr[1] == 0x33) {
730 return true;
731 }
732#endif
733
734#if defined(CONFIG_NET_IPV4)
735 if (addr->addr[0] == 0x01 &&
736 addr->addr[1] == 0x00 &&
737 addr->addr[2] == 0x5e) {
738 return true;
739 }
740#endif
741
742 return false;
743}
744
745static inline bool net_eth_is_addr_group(struct net_eth_addr *addr)
746{
747 return addr->addr[0] & 0x01;
748}
749
750static inline bool net_eth_is_addr_valid(struct net_eth_addr *addr)
751{
752 return !net_eth_is_addr_unspecified(addr) && !net_eth_is_addr_group(addr);
753}
754
755static inline bool net_eth_is_addr_lldp_multicast(struct net_eth_addr *addr)
756{
757#if defined(CONFIG_NET_GPTP) || defined(CONFIG_NET_LLDP)
758 if (addr->addr[0] == 0x01 &&
759 addr->addr[1] == 0x80 &&
760 addr->addr[2] == 0xc2 &&
761 addr->addr[3] == 0x00 &&
762 addr->addr[4] == 0x00 &&
763 addr->addr[5] == 0x0e) {
764 return true;
765 }
766#endif
767
768 return false;
769}
770
771static inline bool net_eth_is_addr_ptp_multicast(struct net_eth_addr *addr)
772{
773#if defined(CONFIG_NET_GPTP)
774 if (addr->addr[0] == 0x01 &&
775 addr->addr[1] == 0x1b &&
776 addr->addr[2] == 0x19 &&
777 addr->addr[3] == 0x00 &&
778 addr->addr[4] == 0x00 &&
779 addr->addr[5] == 0x00) {
780 return true;
781 }
782#endif
783
784 return false;
785}
786
787const struct net_eth_addr *net_eth_broadcast_addr(void);
788
797void net_eth_ipv4_mcast_to_mac_addr(const struct in_addr *ipv4_addr,
798 struct net_eth_addr *mac_addr);
799
806void net_eth_ipv6_mcast_to_mac_addr(const struct in6_addr *ipv6_addr,
807 struct net_eth_addr *mac_addr);
808
816static inline
818{
819 const struct ethernet_api *eth =
820 (struct ethernet_api *)net_if_get_device(iface)->api;
821
822 if (!eth->get_capabilities) {
823 return (enum ethernet_hw_caps)0;
824 }
825
826 return eth->get_capabilities(net_if_get_device(iface));
827}
828
837#if defined(CONFIG_NET_VLAN)
838int net_eth_vlan_enable(struct net_if *iface, uint16_t tag);
839#else
840static inline int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
841{
842 return -EINVAL;
843}
844#endif
845
854#if defined(CONFIG_NET_VLAN)
855int net_eth_vlan_disable(struct net_if *iface, uint16_t tag);
856#else
857static inline int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
858{
859 return -EINVAL;
860}
861#endif
862
871#if defined(CONFIG_NET_VLAN)
873#else
874static inline uint16_t net_eth_get_vlan_tag(struct net_if *iface)
875{
876 return NET_VLAN_TAG_UNSPEC;
877}
878#endif
879
890#if defined(CONFIG_NET_VLAN)
891struct net_if *net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag);
892#else
893static inline
894struct net_if *net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag)
895{
896 return NULL;
897}
898#endif
899
908#if defined(CONFIG_NET_VLAN)
910 struct net_if *iface);
911#else
912static inline bool net_eth_is_vlan_enabled(struct ethernet_context *ctx,
913 struct net_if *iface)
914{
915 return false;
916}
917#endif
918
926#if defined(CONFIG_NET_VLAN)
927bool net_eth_get_vlan_status(struct net_if *iface);
928#else
929static inline bool net_eth_get_vlan_status(struct net_if *iface)
930{
931 return false;
932}
933#endif
934
935#if defined(CONFIG_NET_VLAN)
936#define Z_ETH_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
937 config, prio, api, mtu) \
938 Z_DEVICE_STATE_DEFINE(dev_id); \
939 Z_DEVICE_DEFINE(node_id, dev_id, name, init_fn, pm, data, \
940 config, POST_KERNEL, prio, api, \
941 &Z_DEVICE_STATE_NAME(dev_id)); \
942 NET_L2_DATA_INIT(dev_id, 0, NET_L2_GET_CTX_TYPE(ETHERNET_L2)); \
943 NET_IF_INIT(dev_id, 0, ETHERNET_L2, mtu, NET_VLAN_MAX_COUNT)
944
945#else /* CONFIG_NET_VLAN */
946
947#define Z_ETH_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
948 config, prio, api, mtu) \
949 Z_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
950 config, prio, api, ETHERNET_L2, \
951 NET_L2_GET_CTX_TYPE(ETHERNET_L2), mtu)
952#endif /* CONFIG_NET_VLAN */
953
971#define ETH_NET_DEVICE_INIT(dev_id, name, init_fn, pm, data, config, \
972 prio, api, mtu) \
973 Z_ETH_NET_DEVICE_INIT(DT_INVALID_NODE, dev_id, name, init_fn, \
974 pm, data, config, prio, api, mtu)
975
992#define ETH_NET_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, \
993 prio, api, mtu) \
994 Z_ETH_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
995 DEVICE_DT_NAME(node_id), init_fn, pm, \
996 data, config, prio, api, mtu)
997
1007#define ETH_NET_DEVICE_DT_INST_DEFINE(inst, ...) \
1008 ETH_NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
1009
1016void net_eth_carrier_on(struct net_if *iface);
1017
1024void net_eth_carrier_off(struct net_if *iface);
1025
1035int net_eth_promisc_mode(struct net_if *iface, bool enable);
1036
1046int net_eth_txinjection_mode(struct net_if *iface, bool enable);
1047
1056#if defined(CONFIG_PTP_CLOCK)
1057const struct device *net_eth_get_ptp_clock(struct net_if *iface);
1058#else
1059static inline const struct device *net_eth_get_ptp_clock(struct net_if *iface)
1060{
1061 ARG_UNUSED(iface);
1062
1063 return NULL;
1064}
1065#endif
1066
1076__syscall const struct device *net_eth_get_ptp_clock_by_index(int index);
1077
1085#if defined(CONFIG_NET_L2_PTP)
1086int net_eth_get_ptp_port(struct net_if *iface);
1087#else
1088static inline int net_eth_get_ptp_port(struct net_if *iface)
1089{
1090 ARG_UNUSED(iface);
1091
1092 return -ENODEV;
1093}
1094#endif /* CONFIG_NET_L2_PTP */
1095
1102#if defined(CONFIG_NET_L2_PTP)
1103void net_eth_set_ptp_port(struct net_if *iface, int port);
1104#else
1105static inline void net_eth_set_ptp_port(struct net_if *iface, int port)
1106{
1107 ARG_UNUSED(iface);
1108 ARG_UNUSED(port);
1109}
1110#endif /* CONFIG_NET_L2_PTP */
1111
1119static inline bool net_eth_type_is_wifi(struct net_if *iface)
1120{
1121 const struct ethernet_context *ctx = (struct ethernet_context *)
1123
1124 return ctx->eth_if_type == L2_ETH_IF_TYPE_WIFI;
1125}
1126
1131#ifdef __cplusplus
1132}
1133#endif
1134
1135#include <syscalls/ethernet.h>
1136
1137#endif /* ZEPHYR_INCLUDE_NET_ETHERNET_H_ */
long atomic_t
Definition: atomic_types.h:15
DSA definitions and handlers.
Ethernet Bridge public header file.
VLAN specific definitions.
enum net_verdict(* dsa_net_recv_cb_t)(struct net_if *iface, struct net_pkt *pkt)
DSA (MGMT) Receive packet callback.
Definition: dsa.h:68
int(* dsa_send_t)(const struct device *dev, struct net_pkt *pkt)
Pointer to master interface send function.
Definition: dsa.h:94
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition: atomic.h:111
ethernet_if_types
Types of Ethernet L2.
Definition: ethernet.h:408
static void net_eth_set_ptp_port(struct net_if *iface, int port)
Set PTP port number attached to this interface.
Definition: ethernet.h:1105
static int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
Add VLAN tag to the interface.
Definition: ethernet.h:840
static int net_eth_get_ptp_port(struct net_if *iface)
Return PTP port number attached to this interface.
Definition: ethernet.h:1088
static const struct device * net_eth_get_ptp_clock(struct net_if *iface)
Return PTP clock that is tied to this ethernet network interface.
Definition: ethernet.h:1059
int net_eth_promisc_mode(struct net_if *iface, bool enable)
Set promiscuous mode either ON or OFF.
void net_eth_carrier_off(struct net_if *iface)
Inform ethernet L2 driver that ethernet carrier was lost.
static uint16_t net_eth_get_vlan_tag(struct net_if *iface)
Return VLAN tag specified to network interface.
Definition: ethernet.h:874
static bool net_eth_type_is_wifi(struct net_if *iface)
Check if the Ethernet L2 network interface can perform Wi-Fi.
Definition: ethernet.h:1119
static bool net_eth_get_vlan_status(struct net_if *iface)
Get VLAN status for a given network interface (enabled or not).
Definition: ethernet.h:929
const struct device * net_eth_get_ptp_clock_by_index(int index)
Return PTP clock that is tied to this ethernet network interface index.
ethernet_hw_caps
Ethernet hardware capabilities.
Definition: ethernet.h:124
ethernet_flags
Definition: ethernet.h:584
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.
static enum ethernet_hw_caps net_eth_get_hw_capabilities(struct net_if *iface)
Return ethernet device hardware capability information.
Definition: ethernet.h:817
static int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
Remove VLAN tag from the interface.
Definition: ethernet.h:857
void net_eth_carrier_on(struct net_if *iface)
Inform ethernet L2 driver that ethernet carrier is detected.
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.
Definition: ethernet.h:912
void ethernet_init(struct net_if *iface)
Initialize Ethernet L2 stack for a given interface.
static struct net_if * net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag)
Return network interface related to this VLAN tag.
Definition: ethernet.h:894
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.
int net_eth_txinjection_mode(struct net_if *iface, bool enable)
Set TX-Injection mode either ON or OFF.
@ L2_ETH_IF_TYPE_ETHERNET
IEEE 802.3 Ethernet (default)
Definition: ethernet.h:410
@ L2_ETH_IF_TYPE_WIFI
IEEE 802.11 Wi-Fi.
Definition: ethernet.h:413
@ ETHERNET_HW_VLAN
VLAN supported.
Definition: ethernet.h:132
@ ETHERNET_PRIORITY_QUEUES
Priority queues available.
Definition: ethernet.h:159
@ ETHERNET_DUPLEX_SET
Changing duplex (half/full) supported.
Definition: ethernet.h:147
@ ETHERNET_HW_VLAN_TAG_STRIP
VLAN Tag stripping.
Definition: ethernet.h:168
@ ETHERNET_LINK_10BASE_T
10 Mbits link supported
Definition: ethernet.h:138
@ ETHERNET_HW_FILTERING
MAC address filtering supported.
Definition: ethernet.h:162
@ ETHERNET_PTP
IEEE 802.1AS (gPTP) clock supported.
Definition: ethernet.h:150
@ ETHERNET_QBU
IEEE 802.1Qbu (frame preemption) supported.
Definition: ethernet.h:178
@ ETHERNET_LINK_100BASE_T
100 Mbits link supported
Definition: ethernet.h:141
@ ETHERNET_DSA_MASTER_PORT
Definition: ethernet.h:172
@ ETHERNET_DSA_SLAVE_PORT
DSA switch.
Definition: ethernet.h:171
@ ETHERNET_TXINJECTION_MODE
TX-Injection supported.
Definition: ethernet.h:184
@ ETHERNET_QAV
IEEE 802.1Qav (credit-based shaping) supported.
Definition: ethernet.h:153
@ ETHERNET_HW_RX_CHKSUM_OFFLOAD
RX Checksum offloading supported for all of IPv4, UDP, TCP.
Definition: ethernet.h:129
@ ETHERNET_LINK_1000BASE_T
1 Gbits link supported
Definition: ethernet.h:144
@ ETHERNET_LLDP
Link Layer Discovery Protocol supported.
Definition: ethernet.h:165
@ ETHERNET_AUTO_NEGOTIATION_SET
Enabling/disabling auto negotiation supported.
Definition: ethernet.h:135
@ ETHERNET_TXTIME
TXTIME supported.
Definition: ethernet.h:181
@ ETHERNET_QBV
IEEE 802.1Qbv (scheduled traffic) supported.
Definition: ethernet.h:175
@ ETHERNET_PROMISC_MODE
Promiscuous mode supported.
Definition: ethernet.h:156
@ ETHERNET_HW_TX_CHKSUM_OFFLOAD
TX Checksum offloading supported for all of IPv4, UDP, TCP.
Definition: ethernet.h:126
@ ETH_CARRIER_UP
Definition: ethernet.h:585
enum net_verdict(* net_lldp_recv_cb_t)(struct net_if *iface, struct net_pkt *pkt)
LLDP Receive packet callback.
Definition: lldp.h:213
static void * net_if_l2_data(struct net_if *iface)
Get a pointer to the interface L2 private data.
Definition: net_if.h:842
static const struct device * net_if_get_device(struct net_if *iface)
Get an network interface's device.
Definition: net_if.h:857
net_l2_flags
L2 flags.
Definition: net_l2.h:34
struct _snode sys_snode_t
Single-linked list node structure.
Definition: slist.h:39
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition: util_macro.h:44
#define EINVAL
Invalid argument.
Definition: errno.h:61
#define ENODEV
No such device.
Definition: errno.h:58
#define NET_VLAN_TAG_UNSPEC
Unspecified VLAN tag value.
Definition: ethernet_vlan.h:30
Public kernel APIs.
LLDP definitions and handler.
Public API for network interface.
IPv6 and IPv4 definitions.
Network packet buffer descriptor API.
Public functions for the Precision Time Protocol time specification.
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
__INT64_TYPE__ int64_t
Definition: stdint.h:75
__INT8_TYPE__ int8_t
Definition: stdint.h:72
Runtime device structure (in ROM) per driver instance.
Definition: device.h:387
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:393
Definition: ethernet_bridge.h:59
Definition: ethernet.h:473
struct net_if_api iface_api
The net_if_api must be placed in first position in this struct so that we are compatible with network...
Definition: ethernet.h:478
int(* start)(const struct device *dev)
Start the device.
Definition: ethernet.h:489
int(* get_config)(const struct device *dev, enum ethernet_config_type type, struct ethernet_config *config)
Get hardware specific configuration.
Definition: ethernet.h:503
int(* stop)(const struct device *dev)
Stop the device.
Definition: ethernet.h:492
enum ethernet_hw_caps(* get_capabilities)(const struct device *dev)
Get the device capabilities.
Definition: ethernet.h:495
int(* send)(const struct device *dev, struct net_pkt *pkt)
Send a network packet.
Definition: ethernet.h:523
int(* set_config)(const struct device *dev, enum ethernet_config_type type, const struct ethernet_config *config)
Set specific hardware configuration.
Definition: ethernet.h:498
Ethernet L2 context that is needed for VLAN.
Definition: ethernet.h:589
struct net_if * iface
Network interface.
Definition: ethernet.h:619
bool is_net_carrier_up
Is network carrier up.
Definition: ethernet.h:663
enum net_l2_flags ethernet_l2_flags
This tells what L2 features does ethernet support.
Definition: ethernet.h:628
struct k_work carrier_work
Carrier ON/OFF handler worker.
Definition: ethernet.h:616
atomic_t flags
Flags representing ethernet state, which are accessed from multiple threads.
Definition: ethernet.h:593
enum ethernet_if_types eth_if_type
Types of Ethernet network interfaces.
Definition: ethernet.h:669
bool is_init
Is this context already initialized.
Definition: ethernet.h:666
Definition: ethernet.h:417
struct net_eth_addr mac_address
MAC address to filter.
Definition: ethernet.h:421
bool set
Set (true) or unset (false) the filter.
Definition: ethernet.h:423
enum ethernet_filter_type type
Type of filter.
Definition: ethernet.h:419
Definition: ethernet.h:262
bool enabled
True if Qav is enabled for queue.
Definition: ethernet.h:269
unsigned int oper_idle_slope
Oper Idle Slope (bits per second)
Definition: ethernet.h:275
enum ethernet_qav_param_type type
Type of Qav parameter.
Definition: ethernet.h:266
unsigned int traffic_class
Traffic class the queue is bound to.
Definition: ethernet.h:277
int queue_id
ID of the priority queue to use.
Definition: ethernet.h:264
unsigned int idle_slope
Idle Slope (bits per second)
Definition: ethernet.h:273
unsigned int delta_bandwidth
Delta Bandwidth (percentage of bandwidth)
Definition: ethernet.h:271
Definition: ethernet.h:367
enum ethernet_qbu_preempt_status frame_preempt_statuses[NET_TC_TX_COUNT]
sequence of framePreemptionAdminStatus values.
Definition: ethernet.h:381
uint32_t release_advance
Release advance (nanoseconds)
Definition: ethernet.h:377
enum ethernet_qbu_param_type type
Type of Qbu parameter.
Definition: ethernet.h:371
uint32_t hold_advance
Hold advance (nanoseconds)
Definition: ethernet.h:374
bool enabled
True if Qbu is enabled or not.
Definition: ethernet.h:385
bool link_partner_status
Link partner status (from Qbr)
Definition: ethernet.h:388
int port_id
Port id.
Definition: ethernet.h:369
uint8_t additional_fragment_size
Additional fragment size (from Qbr).
Definition: ethernet.h:393
Definition: ethernet.h:303
int port_id
Port id.
Definition: ethernet.h:305
bool enabled
True if Qbv is enabled or not.
Definition: ethernet.h:312
enum ethernet_qbv_param_type type
Type of Qbv parameter.
Definition: ethernet.h:307
uint16_t row
Gate control list row.
Definition: ethernet.h:325
enum ethernet_qbv_state_type state
What state (Admin/Oper) parameters are these.
Definition: ethernet.h:309
bool gate_status[NET_TC_TX_COUNT]
True = open, False = closed.
Definition: ethernet.h:316
struct net_ptp_extended_time base_time
Base time.
Definition: ethernet.h:336
uint32_t extension_time
Extension time (nanoseconds)
Definition: ethernet.h:342
enum ethernet_gate_state_operation operation
GateState operation.
Definition: ethernet.h:319
uint32_t time_interval
Time interval ticks (nanoseconds)
Definition: ethernet.h:322
struct net_ptp_time cycle_time
Cycle time.
Definition: ethernet.h:339
struct ethernet_qbv_param::@279::@281 gate_control
uint32_t gate_control_list_len
Number of entries in gate control list.
Definition: ethernet.h:329
Definition: ethernet.h:219
uint8_t burst_count
T1S PLCA burst count range: 0x0 to 0xFF.
Definition: ethernet.h:253
uint8_t node_count
T1S PLCA node count range: 1 to 255.
Definition: ethernet.h:251
uint8_t to_timer
T1S PLCA TO value.
Definition: ethernet.h:257
uint8_t burst_timer
T1S PLCA burst timer.
Definition: ethernet.h:255
uint8_t node_id
T1S PLCA node id range: 0 to 254.
Definition: ethernet.h:249
struct ethernet_t1s_param::@274::@276 plca
enum ethernet_t1s_param_type type
Type of T1S parameter.
Definition: ethernet.h:221
bool enable
T1S PLCA enabled.
Definition: ethernet.h:247
Definition: ethernet.h:434
bool enable_txtime
Enable or disable TXTIME per queue.
Definition: ethernet.h:440
int queue_id
Queue number for configuring TXTIME.
Definition: ethernet.h:438
enum ethernet_txtime_param_type type
Type of TXTIME parameter.
Definition: ethernet.h:436
IPv6 address struct.
Definition: net_ip.h:139
IPv4 address struct.
Definition: net_ip.h:151
A structure used to submit work.
Definition: kernel.h:3861
Network Interface structure.
Definition: net_if.h:615
LLDP Data Unit (LLDPDU) shall contain the following ordered TLVs as stated in "8.2 LLDPDU format" fro...
Definition: lldp.h:167
Network packet.
Definition: net_pkt.h:63
Generalized Precision Time Protocol Extended Timestamp format.
Definition: ptp_time.h:147
(Generalized) Precision Time Protocol Timestamp format.
Definition: ptp_time.h:109
All Ethernet specific statistics.
Definition: net_stats.h:441
Misc utilities.