Zephyr API Documentation 4.4.0-rc1
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
ethernet.h
Go to the documentation of this file.
1
6
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#include <zephyr/net/lldp.h>
24#include <zephyr/sys/clock.h>
25#include <zephyr/sys/util.h>
26#include <zephyr/net/net_if.h>
28#include <zephyr/net/ptp_time.h>
30
31#if defined(CONFIG_NVMEM)
32#include <zephyr/nvmem.h>
33#endif
34
35#ifdef __cplusplus
36extern "C" {
37#endif
38
47
48#define NET_ETH_ADDR_LEN 6U
49
54
56
57#define NET_ETH_HDR(pkt) ((struct net_eth_hdr *)net_pkt_data(pkt))
58
59/* zephyr-keep-sorted-start */
60#define NET_ETH_PTYPE_ALL 0x0003 /* from linux/if_ether.h */
61#define NET_ETH_PTYPE_ARP 0x0806
62#define NET_ETH_PTYPE_CAN 0x000C /* CAN: Controller Area Network */
63#define NET_ETH_PTYPE_CANFD 0x000D /* CANFD: CAN flexible data rate*/
64#define NET_ETH_PTYPE_EAPOL 0x888e
65#define NET_ETH_PTYPE_ECAT 0x88a4
66#define NET_ETH_PTYPE_HDLC 0x0019 /* HDLC frames (like in PPP) */
67#define NET_ETH_PTYPE_IEEE802154 0x00F6 /* from linux/if_ether.h: IEEE802.15.4 frame */
68#define NET_ETH_PTYPE_IP 0x0800
69#define NET_ETH_PTYPE_IPV6 0x86dd
70#define NET_ETH_PTYPE_LLDP 0x88cc
71#define NET_ETH_PTYPE_PTP 0x88f7
72#define NET_ETH_PTYPE_TSN 0x22f0 /* TSN (IEEE 1722) packet */
73#define NET_ETH_PTYPE_VLAN 0x8100
74/* zephyr-keep-sorted-stop */
75
76/* zephyr-keep-sorted-start re(^#define) */
77#if !defined(ETH_P_8021Q)
78#define ETH_P_8021Q NET_ETH_PTYPE_VLAN
79#endif
80#if !defined(ETH_P_ALL)
81#define ETH_P_ALL NET_ETH_PTYPE_ALL
82#endif
83#if !defined(ETH_P_ARP)
84#define ETH_P_ARP NET_ETH_PTYPE_ARP
85#endif
86#if !defined(ETH_P_CAN)
87#define ETH_P_CAN NET_ETH_PTYPE_CAN
88#endif
89#if !defined(ETH_P_CANFD)
90#define ETH_P_CANFD NET_ETH_PTYPE_CANFD
91#endif
92#if !defined(ETH_P_EAPOL)
93#define ETH_P_EAPOL NET_ETH_PTYPE_EAPOL
94#endif
95#if !defined(ETH_P_ECAT)
96#define ETH_P_ECAT NET_ETH_PTYPE_ECAT
97#endif
98#if !defined(ETH_P_HDLC)
99#define ETH_P_HDLC NET_ETH_PTYPE_HDLC
100#endif
101#if !defined(ETH_P_IEEE802154)
102#define ETH_P_IEEE802154 NET_ETH_PTYPE_IEEE802154
103#endif
104#if !defined(ETH_P_IP)
105#define ETH_P_IP NET_ETH_PTYPE_IP
106#endif
107#if !defined(ETH_P_IPV6)
108#define ETH_P_IPV6 NET_ETH_PTYPE_IPV6
109#endif
110#if !defined(ETH_P_TSN)
111#define ETH_P_TSN NET_ETH_PTYPE_TSN
112#endif
113/* zephyr-keep-sorted-stop */
114
116
117#define NET_ETH_MINIMAL_FRAME_SIZE 60
118#define NET_ETH_MTU 1500
119
121
122#if defined(CONFIG_NET_VLAN)
123#define _NET_ETH_MAX_HDR_SIZE (sizeof(struct net_eth_vlan_hdr))
124#else
125#define _NET_ETH_MAX_HDR_SIZE (sizeof(struct net_eth_hdr))
126#endif
127
128#define _NET_ETH_MAX_FRAME_SIZE (NET_ETH_MTU + _NET_ETH_MAX_HDR_SIZE)
129
130#if defined(CONFIG_DSA_TAG_SIZE)
131#define DSA_TAG_SIZE CONFIG_DSA_TAG_SIZE
132#else
133#define DSA_TAG_SIZE 0
134#endif
135
136#define NET_ETH_MAX_FRAME_SIZE (_NET_ETH_MAX_FRAME_SIZE + DSA_TAG_SIZE)
137#define NET_ETH_MAX_HDR_SIZE (_NET_ETH_MAX_HDR_SIZE + DSA_TAG_SIZE)
138
139#define NET_ETH_VLAN_HDR_SIZE 4
140
142
208
210
211enum dsa_port_type {
212 NON_DSA_PORT,
213 DSA_CONDUIT_PORT,
214 DSA_USER_PORT,
215 DSA_CPU_PORT,
216 DSA_PORT,
217};
218
219enum ethernet_config_type {
220 ETHERNET_CONFIG_TYPE_MAC_ADDRESS,
221 ETHERNET_CONFIG_TYPE_QAV_PARAM,
222 ETHERNET_CONFIG_TYPE_QBV_PARAM,
223 ETHERNET_CONFIG_TYPE_QBU_PARAM,
224 ETHERNET_CONFIG_TYPE_TXTIME_PARAM,
225 ETHERNET_CONFIG_TYPE_PROMISC_MODE,
226 ETHERNET_CONFIG_TYPE_PRIORITY_QUEUES_NUM,
227 ETHERNET_CONFIG_TYPE_FILTER,
228 ETHERNET_CONFIG_TYPE_PORTS_NUM,
229 ETHERNET_CONFIG_TYPE_T1S_PARAM,
230 ETHERNET_CONFIG_TYPE_TXINJECTION_MODE,
231 ETHERNET_CONFIG_TYPE_RX_CHECKSUM_SUPPORT,
232 ETHERNET_CONFIG_TYPE_TX_CHECKSUM_SUPPORT,
233 ETHERNET_CONFIG_TYPE_EXTRA_TX_PKT_HEADROOM,
234};
235
236enum ethernet_qav_param_type {
237 ETHERNET_QAV_PARAM_TYPE_DELTA_BANDWIDTH,
238 ETHERNET_QAV_PARAM_TYPE_IDLE_SLOPE,
239 ETHERNET_QAV_PARAM_TYPE_OPER_IDLE_SLOPE,
240 ETHERNET_QAV_PARAM_TYPE_TRAFFIC_CLASS,
241 ETHERNET_QAV_PARAM_TYPE_STATUS,
242};
243
244enum ethernet_t1s_param_type {
245 ETHERNET_T1S_PARAM_TYPE_PLCA_CONFIG,
246};
247
249
253 enum ethernet_t1s_param_type type;
254 union {
278 struct {
280 bool enable;
292 };
293};
294
300 enum ethernet_qav_param_type type;
301 union {
305 unsigned int delta_bandwidth;
307 unsigned int idle_slope;
309 unsigned int oper_idle_slope;
311 unsigned int traffic_class;
312 };
313};
314
316
317enum ethernet_qbv_param_type {
318 ETHERNET_QBV_PARAM_TYPE_STATUS,
319 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST,
320 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST_LEN,
321 ETHERNET_QBV_PARAM_TYPE_TIME,
322};
323
324enum ethernet_qbv_state_type {
325 ETHERNET_QBV_STATE_TYPE_ADMIN,
326 ETHERNET_QBV_STATE_TYPE_OPER,
327};
328
329enum ethernet_gate_state_operation {
330 ETHERNET_SET_GATE_STATE,
331 ETHERNET_SET_AND_HOLD_MAC_STATE,
332 ETHERNET_SET_AND_RELEASE_MAC_STATE,
333};
334
336
342 enum ethernet_qbv_param_type type;
344 enum ethernet_qbv_state_type state;
345 union {
348
350 struct {
352 bool gate_status[NET_TC_TX_COUNT];
353
355 enum ethernet_gate_state_operation operation;
356
359
363
366
371 struct {
374
377
380 };
381 };
382};
383
385
386enum ethernet_qbu_param_type {
387 ETHERNET_QBU_PARAM_TYPE_STATUS,
388 ETHERNET_QBU_PARAM_TYPE_RELEASE_ADVANCE,
389 ETHERNET_QBU_PARAM_TYPE_HOLD_ADVANCE,
390 ETHERNET_QBU_PARAM_TYPE_PREEMPTION_STATUS_TABLE,
391
392 /* Some preemption settings are from Qbr spec. */
393 ETHERNET_QBR_PARAM_TYPE_LINK_PARTNER_STATUS,
394 ETHERNET_QBR_PARAM_TYPE_ADDITIONAL_FRAGMENT_SIZE,
395};
396
397enum ethernet_qbu_preempt_status {
398 ETHERNET_QBU_STATUS_EXPRESS,
399 ETHERNET_QBU_STATUS_PREEMPTABLE
400} __packed;
401
403
409 enum ethernet_qbu_param_type type;
410 union {
413
416
418 enum ethernet_qbu_preempt_status
419 frame_preempt_statuses[NET_TC_TX_COUNT];
420
423
426
432 };
433};
434
436
437enum ethernet_filter_type {
438 ETHERNET_FILTER_TYPE_SRC_MAC_ADDRESS,
439 ETHERNET_FILTER_TYPE_DST_MAC_ADDRESS,
440};
441
443
452
456 enum ethernet_filter_type type;
460 bool set;
461};
462
464
465enum ethernet_txtime_param_type {
466 ETHERNET_TXTIME_PARAM_TYPE_ENABLE_QUEUES,
467};
468
470
474 enum ethernet_txtime_param_type type;
479};
480
484 ETHERNET_CHECKSUM_SUPPORT_NONE = NET_IF_CHECKSUM_NONE_BIT,
486 ETHERNET_CHECKSUM_SUPPORT_IPV4_HEADER = NET_IF_CHECKSUM_IPV4_HEADER_BIT,
488 ETHERNET_CHECKSUM_SUPPORT_IPV4_ICMP = NET_IF_CHECKSUM_IPV4_ICMP_BIT,
490 ETHERNET_CHECKSUM_SUPPORT_IPV6_HEADER = NET_IF_CHECKSUM_IPV6_HEADER_BIT,
492 ETHERNET_CHECKSUM_SUPPORT_IPV6_ICMP = NET_IF_CHECKSUM_IPV6_ICMP_BIT,
494 ETHERNET_CHECKSUM_SUPPORT_TCP = NET_IF_CHECKSUM_TCP_BIT,
496 ETHERNET_CHECKSUM_SUPPORT_UDP = NET_IF_CHECKSUM_UDP_BIT,
497};
498
500
501struct ethernet_config {
502 union {
503 bool promisc_mode;
504 bool txinjection_mode;
505
506 struct net_eth_addr mac_address;
507
508 struct ethernet_t1s_param t1s_param;
509 struct ethernet_qav_param qav_param;
510 struct ethernet_qbv_param qbv_param;
511 struct ethernet_qbu_param qbu_param;
512 struct ethernet_txtime_param txtime_param;
513
514 int priority_queues_num;
515 int ports_num;
516
517 enum ethernet_checksum_support chksum_support;
518
519 struct ethernet_filter filter;
520
521 uint16_t extra_tx_pkt_headroom;
522 };
523};
524
526
536
543 struct net_if_api iface_api;
544
549#if defined(CONFIG_NET_STATISTICS_ETHERNET)
550 struct net_stats_eth *(*get_stats)(const struct device *dev);
551
557 struct net_stats_eth *(*get_stats_type)(const struct device *dev,
558 uint32_t type);
559#endif
560
562 int (*start)(const struct device *dev);
563
565 int (*stop)(const struct device *dev);
566
568 enum ethernet_hw_caps (*get_capabilities)(const struct device *dev);
569
571 int (*set_config)(const struct device *dev,
572 enum ethernet_config_type type,
573 const struct ethernet_config *config);
574
576 int (*get_config)(const struct device *dev,
577 enum ethernet_config_type type,
578 struct ethernet_config *config);
579
585#if defined(CONFIG_NET_VLAN)
586 int (*vlan_setup)(const struct device *dev, struct net_if *iface,
587 uint16_t tag, bool enable);
588#endif /* CONFIG_NET_VLAN */
589
591#if defined(CONFIG_PTP_CLOCK)
592 const struct device *(*get_ptp_clock)(const struct device *dev);
593#endif /* CONFIG_PTP_CLOCK */
594
596 const struct device *(*get_phy)(const struct device *dev);
597
599 int (*send)(const struct device *dev, struct net_pkt *pkt);
600};
601
603
604/* Make sure that the network interface API is properly setup inside
605 * Ethernet API struct (it is the first one).
606 */
607BUILD_ASSERT(offsetof(struct ethernet_api, iface_api) == 0);
608
609struct net_eth_hdr {
610 struct net_eth_addr dst;
611 struct net_eth_addr src;
612 uint16_t type;
613} __packed;
614
615struct ethernet_vlan {
617 struct net_if *iface;
618
620 uint16_t tag;
621};
622
623#if defined(CONFIG_NET_VLAN_COUNT)
624#define NET_VLAN_MAX_COUNT CONFIG_NET_VLAN_COUNT
625#else
626#define NET_VLAN_MAX_COUNT 0
627#endif
628
630
651
653
654enum ethernet_flags {
655 ETH_CARRIER_UP,
656};
657
659struct ethernet_context {
664
665#if defined(CONFIG_NET_ETHERNET_BRIDGE)
666 struct net_if *bridge;
667#endif
668
675 struct k_work carrier_work;
676
678 struct net_if *iface;
679
680#if defined(CONFIG_NET_LLDP)
682 struct ethernet_lldp lldp;
683#endif
684
688 enum net_l2_flags ethernet_l2_flags;
689
690#if defined(CONFIG_NET_L2_PTP)
695 int port;
696#endif
697
698#if defined(CONFIG_NET_DSA)
700 enum dsa_port_type dsa_port;
701
703 void *dsa_switch_ctx;
704#endif
705
707 bool is_net_carrier_up : 1;
708
710 bool is_init : 1;
711
713 enum ethernet_if_types eth_if_type;
714};
715
721void ethernet_init(struct net_if *iface);
722
723#define ETHERNET_L2_CTX_TYPE struct ethernet_context
724
725/* Separate header for VLAN as some of device interfaces might not
726 * support VLAN.
727 */
728struct net_eth_vlan_hdr {
729 struct net_eth_addr dst;
730 struct net_eth_addr src;
731 struct {
732 uint16_t tpid; /* tag protocol id */
733 uint16_t tci; /* tag control info */
734 } vlan;
735 uint16_t type;
736} __packed;
737
739
747static inline bool net_eth_is_addr_broadcast(struct net_eth_addr *addr)
748{
749 if (addr->addr[0] == 0xff &&
750 addr->addr[1] == 0xff &&
751 addr->addr[2] == 0xff &&
752 addr->addr[3] == 0xff &&
753 addr->addr[4] == 0xff &&
754 addr->addr[5] == 0xff) {
755 return true;
756 }
757
758 return false;
759}
760
768static inline bool net_eth_is_addr_all_zeroes(struct net_eth_addr *addr)
769{
770 if (addr->addr[0] == 0x00 &&
771 addr->addr[1] == 0x00 &&
772 addr->addr[2] == 0x00 &&
773 addr->addr[3] == 0x00 &&
774 addr->addr[4] == 0x00 &&
775 addr->addr[5] == 0x00) {
776 return true;
777 }
778
779 return false;
780}
781
789static inline bool net_eth_is_addr_unspecified(struct net_eth_addr *addr)
790{
791 if (addr->addr[0] == 0x00 &&
792 addr->addr[1] == 0x00 &&
793 addr->addr[2] == 0x00 &&
794 addr->addr[3] == 0x00 &&
795 addr->addr[4] == 0x00 &&
796 addr->addr[5] == 0x00) {
797 return true;
798 }
799
800 return false;
801}
802
810static inline bool net_eth_is_addr_multicast(struct net_eth_addr *addr)
811{
812 return addr->addr[0] & 0x01;
813}
814
822static inline bool net_eth_is_addr_unicast(struct net_eth_addr *addr)
823{
825}
826
834static inline bool net_eth_is_addr_valid(struct net_eth_addr *addr)
835{
837}
838
846static inline bool net_eth_is_addr_lldp_multicast(struct net_eth_addr *addr)
847{
848 if (addr->addr[0] == 0x01 &&
849 addr->addr[1] == 0x80 &&
850 addr->addr[2] == 0xc2 &&
851 addr->addr[3] == 0x00 &&
852 addr->addr[4] == 0x00 &&
853 addr->addr[5] == 0x0e) {
854 return true;
855 }
856
857 return false;
858}
859
867static inline bool net_eth_is_addr_ptp_multicast(struct net_eth_addr *addr)
868{
869 if (addr->addr[0] == 0x01 &&
870 addr->addr[1] == 0x1b &&
871 addr->addr[2] == 0x19 &&
872 addr->addr[3] == 0x00 &&
873 addr->addr[4] == 0x00 &&
874 addr->addr[5] == 0x00) {
875 return true;
876 }
877
878 return false;
879}
880
887
894void net_eth_ipv4_mcast_to_mac_addr(const struct net_in_addr *ipv4_addr,
895 struct net_eth_addr *mac_addr);
896
903void net_eth_ipv6_mcast_to_mac_addr(const struct net_in6_addr *ipv6_addr,
904 struct net_eth_addr *mac_addr);
905
913static inline
915{
916 const struct device *dev = net_if_get_device(iface);
917 const struct ethernet_api *api = (struct ethernet_api *)dev->api;
918 enum ethernet_hw_caps caps = (enum ethernet_hw_caps)0;
919#if defined(CONFIG_NET_DSA)
920 struct ethernet_context *eth_ctx = net_if_l2_data(iface);
921
922 if (eth_ctx->dsa_port == DSA_CONDUIT_PORT) {
924 } else if (eth_ctx->dsa_port == DSA_USER_PORT) {
926 }
927#endif
928 if (api == NULL || api->get_capabilities == NULL) {
929 return caps;
930 }
931
932 return (enum ethernet_hw_caps)(caps | api->get_capabilities(dev));
933}
934
944static inline
945int net_eth_get_hw_config(struct net_if *iface, enum ethernet_config_type type,
946 struct ethernet_config *config)
947{
948 const struct device *dev = net_if_get_device(iface);
949 const struct ethernet_api *eth = dev->api;
950
951 if (!eth->get_config) {
952 return -ENOTSUP;
953 }
954
955 return eth->get_config(dev, type, config);
956}
957
958
967#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
968int net_eth_vlan_enable(struct net_if *iface, uint16_t tag);
969#else
970static inline int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
971{
972 ARG_UNUSED(iface);
973 ARG_UNUSED(tag);
974
975 return -EINVAL;
976}
977#endif
978
987#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
988int net_eth_vlan_disable(struct net_if *iface, uint16_t tag);
989#else
990static inline int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
991{
992 ARG_UNUSED(iface);
993 ARG_UNUSED(tag);
994
995 return -EINVAL;
996}
997#endif
998
1010#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1011uint16_t net_eth_get_vlan_tag(struct net_if *iface);
1012#else
1013static inline uint16_t net_eth_get_vlan_tag(struct net_if *iface)
1014{
1015 ARG_UNUSED(iface);
1016
1017 return NET_VLAN_TAG_UNSPEC;
1018}
1019#endif
1020
1030#if defined(CONFIG_NET_VLAN)
1031struct net_if *net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag);
1032#else
1033static inline
1035{
1036 ARG_UNUSED(iface);
1037 ARG_UNUSED(tag);
1038
1039 return NULL;
1040}
1041#endif
1042
1052#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1053struct net_if *net_eth_get_vlan_main(struct net_if *iface);
1054#else
1055static inline
1057{
1058 ARG_UNUSED(iface);
1059
1060 return NULL;
1061}
1062#endif
1063
1077#if defined(CONFIG_NET_VLAN)
1078bool net_eth_is_vlan_enabled(struct ethernet_context *ctx,
1079 struct net_if *iface);
1080#else
1081static inline bool net_eth_is_vlan_enabled(struct ethernet_context *ctx,
1082 struct net_if *iface)
1083{
1084 ARG_UNUSED(ctx);
1085 ARG_UNUSED(iface);
1086
1087 return false;
1088}
1089#endif
1090
1098#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1099bool net_eth_get_vlan_status(struct net_if *iface);
1100#else
1101static inline bool net_eth_get_vlan_status(struct net_if *iface)
1102{
1103 ARG_UNUSED(iface);
1104
1105 return false;
1106}
1107#endif
1108
1116#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1117bool net_eth_is_vlan_interface(struct net_if *iface);
1118#else
1119static inline bool net_eth_is_vlan_interface(struct net_if *iface)
1120{
1121 ARG_UNUSED(iface);
1122
1123 return false;
1124}
1125#endif
1126
1128
1129#if !defined(CONFIG_ETH_DRIVER_RAW_MODE)
1130
1131#define Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1132 init_fn, pm, data, config, prio, \
1133 api, mtu) \
1134 Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1135 init_fn, pm, data, config, prio, \
1136 api, ETHERNET_L2, \
1137 NET_L2_GET_CTX_TYPE(ETHERNET_L2), mtu)
1138
1139#else /* CONFIG_ETH_DRIVER_RAW_MODE */
1140
1141#define Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1142 init_fn, pm, data, config, prio, \
1143 api, mtu) \
1144 Z_DEVICE_STATE_DEFINE(dev_id); \
1145 Z_DEVICE_DEFINE(node_id, dev_id, name, init_fn, NULL, \
1146 Z_DEVICE_DT_FLAGS(node_id), pm, data, \
1147 config, POST_KERNEL, prio, api, \
1148 &Z_DEVICE_STATE_NAME(dev_id));
1149
1150#endif /* CONFIG_ETH_DRIVER_RAW_MODE */
1151
1152#define Z_ETH_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
1153 config, prio, api, mtu) \
1154 Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, 0, \
1155 init_fn, pm, data, config, prio, \
1156 api, mtu)
1157
1159
1177#define ETH_NET_DEVICE_INIT(dev_id, name, init_fn, pm, data, config, \
1178 prio, api, mtu) \
1179 Z_ETH_NET_DEVICE_INIT(DT_INVALID_NODE, dev_id, name, init_fn, \
1180 pm, data, config, prio, api, mtu)
1181
1204#define ETH_NET_DEVICE_INIT_INSTANCE(dev_id, name, instance, init_fn, \
1205 pm, data, config, prio, api, mtu) \
1206 Z_ETH_NET_DEVICE_INIT_INSTANCE(DT_INVALID_NODE, dev_id, name, \
1207 instance, init_fn, pm, data, \
1208 config, prio, api, mtu)
1209
1226#define ETH_NET_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, \
1227 prio, api, mtu) \
1228 Z_ETH_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
1229 DEVICE_DT_NAME(node_id), init_fn, pm, \
1230 data, config, prio, api, mtu)
1231
1241#define ETH_NET_DEVICE_DT_INST_DEFINE(inst, ...) \
1242 ETH_NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
1243
1251#define ETH_NET_L3_REGISTER(name, ptype, handler) \
1252 NET_L3_REGISTER(&NET_L2_GET_NAME(ETHERNET), name, ptype, handler)
1253
1268
1282#if defined(CONFIG_NVMEM) || defined(__DOXYGEN__)
1288#endif
1289};
1290
1305static inline int net_eth_mac_load(const struct net_eth_mac_config *cfg, uint8_t *mac_addr)
1306{
1307 if (cfg == NULL || cfg->type == NET_ETH_MAC_DEFAULT) {
1308 return -ENODATA;
1309 }
1310
1311 /* Copy the static part */
1312 memcpy(mac_addr, cfg->addr, cfg->addr_len);
1313
1314 if (cfg->type == NET_ETH_MAC_RANDOM) {
1315 sys_rand_get(&mac_addr[cfg->addr_len], NET_ETH_ADDR_LEN - cfg->addr_len);
1316
1317 /* Clear group bit, multicast (I/G) */
1318 mac_addr[0] &= ~0x01;
1319 /* Set MAC address locally administered, unicast (LAA) */
1320 mac_addr[0] |= 0x02;
1321
1322 return 0;
1323 }
1324
1325#if defined(CONFIG_NVMEM)
1326 if (cfg->type == NET_ETH_MAC_NVMEM) {
1327 return nvmem_cell_read(&cfg->cell, &mac_addr[cfg->addr_len], 0,
1328 NET_ETH_ADDR_LEN - cfg->addr_len);
1329 }
1330#endif
1331
1332 if (cfg->type == NET_ETH_MAC_STATIC) {
1333 return 0;
1334 }
1335
1336 return -ENODATA;
1337}
1338
1340
1341#if defined(CONFIG_NVMEM) || defined(__DOXYGEN__)
1348#define Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id) \
1349 .cell = NVMEM_CELL_GET_BY_NAME_OR(node_id, mac_address, {0}),
1350#else
1351#define Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id)
1352#endif
1353
1354#define Z_NET_ETH_MAC_DT_CONFIG_INIT_RANDOM(node_id) \
1355 { \
1356 .type = NET_ETH_MAC_RANDOM, \
1357 .addr = DT_PROP_OR(node_id, zephyr_mac_address_prefix, {0}), \
1358 .addr_len = DT_PROP_LEN_OR(node_id, zephyr_mac_address_prefix, 0), \
1359 }
1360
1361#define Z_NET_ETH_MAC_DT_CONFIG_INIT_NVMEM(node_id) \
1362 { \
1363 .type = NET_ETH_MAC_NVMEM, \
1364 .addr = DT_PROP_OR(node_id, zephyr_mac_address_prefix, {0}), \
1365 .addr_len = DT_PROP_LEN_OR(node_id, zephyr_mac_address_prefix, 0), \
1366 Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id) \
1367 }
1368
1369#define Z_NET_ETH_MAC_DT_CONFIG_INIT_STATIC(node_id) \
1370 { \
1371 .type = NET_ETH_MAC_STATIC, \
1372 .addr = DT_PROP(node_id, local_mac_address), \
1373 .addr_len = DT_PROP_LEN(node_id, local_mac_address), \
1374 }
1375
1376#define Z_NET_ETH_MAC_DT_CONFIG_INIT_DEFAULT(node_id) \
1377 { \
1378 .type = NET_ETH_MAC_DEFAULT, \
1379 }
1380
1382
1388#define NET_ETH_MAC_DT_CONFIG_INIT(node_id) \
1389 COND_CASE_1(DT_PROP(node_id, zephyr_random_mac_address), \
1390 (Z_NET_ETH_MAC_DT_CONFIG_INIT_RANDOM(node_id)), \
1391 DT_NVMEM_CELLS_HAS_NAME(node_id, mac_address), \
1392 (Z_NET_ETH_MAC_DT_CONFIG_INIT_NVMEM(node_id)), \
1393 DT_NODE_HAS_PROP(node_id, local_mac_address), \
1394 (Z_NET_ETH_MAC_DT_CONFIG_INIT_STATIC(node_id)), \
1395 (Z_NET_ETH_MAC_DT_CONFIG_INIT_DEFAULT(node_id)))
1396
1404#define NET_ETH_MAC_DT_INST_CONFIG_INIT(inst) \
1405 NET_ETH_MAC_DT_CONFIG_INIT(DT_DRV_INST(inst))
1406
1413void net_eth_carrier_on(struct net_if *iface);
1414
1421void net_eth_carrier_off(struct net_if *iface);
1422
1432int net_eth_promisc_mode(struct net_if *iface, bool enable);
1433
1443int net_eth_txinjection_mode(struct net_if *iface, bool enable);
1444
1455int net_eth_mac_filter(struct net_if *iface, struct net_eth_addr *mac,
1456 enum ethernet_filter_type type, bool enable);
1457
1465const struct device *net_eth_get_phy(struct net_if *iface);
1466
1475#if defined(CONFIG_PTP_CLOCK)
1476const struct device *net_eth_get_ptp_clock(struct net_if *iface);
1477#else
1478static inline const struct device *net_eth_get_ptp_clock(struct net_if *iface)
1479{
1480 ARG_UNUSED(iface);
1481
1482 return NULL;
1483}
1484#endif
1485
1495__syscall const struct device *net_eth_get_ptp_clock_by_index(int index);
1496
1504#if defined(CONFIG_NET_L2_PTP)
1505int net_eth_get_ptp_port(struct net_if *iface);
1506#else
1507static inline int net_eth_get_ptp_port(struct net_if *iface)
1508{
1509 ARG_UNUSED(iface);
1510
1511 return -ENODEV;
1512}
1513#endif /* CONFIG_NET_L2_PTP */
1514
1521#if defined(CONFIG_NET_L2_PTP)
1522void net_eth_set_ptp_port(struct net_if *iface, int port);
1523#else
1524static inline void net_eth_set_ptp_port(struct net_if *iface, int port)
1525{
1526 ARG_UNUSED(iface);
1527 ARG_UNUSED(port);
1528}
1529#endif /* CONFIG_NET_L2_PTP */
1530
1538static inline bool net_eth_type_is_wifi(struct net_if *iface)
1539{
1540 const struct ethernet_context *ctx = (struct ethernet_context *)
1541 net_if_l2_data(iface);
1542
1543 return ctx->eth_if_type == L2_ETH_IF_TYPE_WIFI;
1544}
1545
1549
1550#ifdef __cplusplus
1551}
1552#endif
1553
1554#include <zephyr/syscalls/ethernet.h>
1555
1556#endif /* ZEPHYR_INCLUDE_NET_ETHERNET_H_ */
long atomic_t
Definition atomic_types.h:15
System clock APIs.
VLAN specific definitions.
static struct net_if * net_eth_get_vlan_main(struct net_if *iface)
Return main network interface that is attached to this VLAN tag.
Definition ethernet.h:1056
static int net_eth_get_hw_config(struct net_if *iface, enum ethernet_config_type type, struct ethernet_config *config)
Return ethernet device hardware configuration information.
Definition ethernet.h:945
ethernet_if_types
Types of Ethernet L2.
Definition ethernet.h:445
static void net_eth_set_ptp_port(struct net_if *iface, int port)
Set PTP port number attached to this interface.
Definition ethernet.h:1524
static int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
Add VLAN tag to the interface.
Definition ethernet.h:970
static bool net_eth_is_addr_all_zeroes(struct net_eth_addr *addr)
Check if the Ethernet MAC address is a all zeroes address.
Definition ethernet.h:768
void net_eth_ipv4_mcast_to_mac_addr(const struct net_in_addr *ipv4_addr, struct net_eth_addr *mac_addr)
Convert IPv4 multicast address to Ethernet address.
static bool net_eth_is_addr_multicast(struct net_eth_addr *addr)
Check if the Ethernet MAC address is a multicast address.
Definition ethernet.h:810
static int net_eth_get_ptp_port(struct net_if *iface)
Return PTP port number attached to this interface.
Definition ethernet.h:1507
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:1478
#define NET_ETH_ADDR_LEN
Ethernet MAC address length.
Definition ethernet.h:48
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:1013
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:1538
const struct device * net_eth_get_phy(struct net_if *iface)
Return the PHY device that is tied to this ethernet network interface.
static bool net_eth_is_addr_broadcast(struct net_eth_addr *addr)
Check if the Ethernet MAC address is a broadcast address.
Definition ethernet.h:747
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:1101
const struct device * net_eth_get_ptp_clock_by_index(int index)
Return PTP clock that is tied to this ethernet network interface index.
static bool net_eth_is_addr_unspecified(struct net_eth_addr *addr)
Check if the Ethernet MAC address is unspecified.
Definition ethernet.h:789
static bool net_eth_is_vlan_interface(struct net_if *iface)
Check if the given interface is a VLAN interface.
Definition ethernet.h:1119
ethernet_hw_caps
Ethernet hardware capabilities.
Definition ethernet.h:144
int net_eth_mac_filter(struct net_if *iface, struct net_eth_addr *mac, enum ethernet_filter_type type, bool enable)
Set or unset HW filtering for MAC address mac.
void net_eth_ipv6_mcast_to_mac_addr(const struct net_in6_addr *ipv6_addr, struct net_eth_addr *mac_addr)
Convert IPv6 multicast address to Ethernet address.
static int net_eth_mac_load(const struct net_eth_mac_config *cfg, uint8_t *mac_addr)
Load a MAC address from a MAC address configuration structure with the specified type.
Definition ethernet.h:1305
static enum ethernet_hw_caps net_eth_get_hw_capabilities(struct net_if *iface)
Return ethernet device hardware capability information.
Definition ethernet.h:914
static int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
Remove VLAN tag from the interface.
Definition ethernet.h:990
void net_eth_carrier_on(struct net_if *iface)
Inform ethernet L2 driver that ethernet carrier is detected.
ethernet_checksum_support
Protocols that are supported by checksum offloading.
Definition ethernet.h:482
ethernet_stats_type
Ethernet statistics type (bitmap).
Definition ethernet.h:528
net_eth_mac_type
MAC address configuration types.
Definition ethernet.h:1255
static bool net_eth_is_vlan_enabled(struct ethernet_context *ctx, struct net_if *iface)
Check if there are any VLAN interfaces enabled to this specific Ethernet network interface.
Definition ethernet.h:1081
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:1034
const struct net_eth_addr * net_eth_broadcast_addr(void)
Return Ethernet broadcast address.
static bool net_eth_is_addr_unicast(struct net_eth_addr *addr)
Check if the Ethernet MAC address is an unicast address.
Definition ethernet.h:822
static bool net_eth_is_addr_lldp_multicast(struct net_eth_addr *addr)
Check if the Ethernet MAC address is a LLDP multicast address.
Definition ethernet.h:846
static bool net_eth_is_addr_ptp_multicast(struct net_eth_addr *addr)
Check if the Ethernet MAC address is a PTP multicast address.
Definition ethernet.h:867
static bool net_eth_is_addr_valid(struct net_eth_addr *addr)
Check if the Ethernet MAC address is valid.
Definition ethernet.h:834
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:447
@ L2_ETH_IF_TYPE_WIFI
IEEE 802.11 Wi-Fi.
Definition ethernet.h:450
@ ETHERNET_HW_VLAN
VLAN supported.
Definition ethernet.h:152
@ ETHERNET_DSA_USER_PORT
DSA switch user port.
Definition ethernet.h:191
@ ETHERNET_PRIORITY_QUEUES
Priority queues available.
Definition ethernet.h:179
@ ETHERNET_HW_VLAN_TAG_STRIP
VLAN Tag stripping.
Definition ethernet.h:188
@ ETHERNET_LINK_100BASE
100 Mbits link supported
Definition ethernet.h:158
@ ETHERNET_DSA_CONDUIT_PORT
DSA switch conduit port.
Definition ethernet.h:194
@ ETHERNET_LINK_10BASE
10 Mbits link supported
Definition ethernet.h:155
@ ETHERNET_HW_FILTERING
MAC address filtering supported.
Definition ethernet.h:182
@ ETHERNET_LINK_1000BASE
1 Gbits link supported
Definition ethernet.h:161
@ ETHERNET_PTP
IEEE 802.1AS (gPTP) clock supported.
Definition ethernet.h:170
@ ETHERNET_QBU
IEEE 802.1Qbu (frame preemption) supported.
Definition ethernet.h:200
@ ETHERNET_TXINJECTION_MODE
TX-Injection supported.
Definition ethernet.h:206
@ ETHERNET_QAV
IEEE 802.1Qav (credit-based shaping) supported.
Definition ethernet.h:173
@ ETHERNET_HW_RX_CHKSUM_OFFLOAD
RX Checksum offloading supported for all of IPv4, UDP, TCP.
Definition ethernet.h:149
@ ETHERNET_LLDP
Link Layer Discovery Protocol supported.
Definition ethernet.h:185
@ ETHERNET_LINK_5000BASE
5 Gbits link supported
Definition ethernet.h:167
@ ETHERNET_TXTIME
TXTIME supported.
Definition ethernet.h:203
@ ETHERNET_QBV
IEEE 802.1Qbv (scheduled traffic) supported.
Definition ethernet.h:197
@ ETHERNET_PROMISC_MODE
Promiscuous mode supported.
Definition ethernet.h:176
@ ETHERNET_HW_TX_CHKSUM_OFFLOAD
TX Checksum offloading supported for all of IPv4, UDP, TCP.
Definition ethernet.h:146
@ ETHERNET_LINK_2500BASE
2.5 Gbits link supported
Definition ethernet.h:164
@ ETHERNET_CHECKSUM_SUPPORT_UDP
Device supports UDP checksum offloading for all supported IP protocols.
Definition ethernet.h:496
@ ETHERNET_CHECKSUM_SUPPORT_TCP
Device supports TCP checksum offloading for all supported IP protocols.
Definition ethernet.h:494
@ ETHERNET_CHECKSUM_SUPPORT_IPV6_HEADER
Device supports checksum offloading for the IPv6 header.
Definition ethernet.h:490
@ ETHERNET_CHECKSUM_SUPPORT_IPV4_ICMP
Device supports checksum offloading for ICMPv4 payload (implies IPv4 header).
Definition ethernet.h:488
@ ETHERNET_CHECKSUM_SUPPORT_IPV4_HEADER
Device supports checksum offloading for the IPv4 header.
Definition ethernet.h:486
@ ETHERNET_CHECKSUM_SUPPORT_NONE
Device does not support any L3/L4 checksum offloading.
Definition ethernet.h:484
@ ETHERNET_CHECKSUM_SUPPORT_IPV6_ICMP
Device supports checksum offloading for ICMPv6 payload (implies IPv6 header).
Definition ethernet.h:492
@ ETHERNET_STATS_TYPE_VENDOR
Vendor statistics only.
Definition ethernet.h:532
@ ETHERNET_STATS_TYPE_ALL
All statistics.
Definition ethernet.h:534
@ ETHERNET_STATS_TYPE_COMMON
Common statistics only (excludes vendor statistics).
Definition ethernet.h:530
@ NET_ETH_MAC_RANDOM
A random MAC address is generated during initialization.
Definition ethernet.h:1259
@ NET_ETH_MAC_NVMEM
The MAC address is read from an NVMEM cell.
Definition ethernet.h:1264
@ NET_ETH_MAC_DEFAULT
MAC address is handled by the driver (backwards compatible case).
Definition ethernet.h:1257
@ NET_ETH_MAC_STATIC
A static MAC address is provided in the device tree.
Definition ethernet.h:1266
enum net_verdict(* net_lldp_recv_cb_t)(struct net_if *iface, struct net_pkt *pkt)
LLDP Receive packet callback.
Definition lldp.h:218
static void * net_if_l2_data(struct net_if *iface)
Get a pointer to the interface L2 private data.
Definition net_if.h:1039
static const struct device * net_if_get_device(struct net_if *iface)
Get an network interface's device.
Definition net_if.h:1055
net_l2_flags
L2 flags.
Definition net_l2.h:37
int nvmem_cell_read(const struct nvmem_cell *cell, void *data, off_t off, size_t len)
Read data from an NVMEM cell.
void sys_rand_get(void *dst, size_t len)
Fill the destination buffer with random data values that should pass general randomness tests.
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 ENODATA
Missing expected message data.
Definition errno.h:77
#define EINVAL
Invalid argument.
Definition errno.h:60
#define ENOTSUP
Unsupported value.
Definition errno.h:114
#define ENODEV
No such device.
Definition errno.h:57
#define NET_VLAN_TAG_UNSPEC
Unspecified VLAN tag value.
Definition ethernet_vlan.h:32
#define NULL
Definition iar_missing_defs.h:20
#define BUILD_ASSERT(EXPR, MSG...)
Definition llvm.h:51
Public kernel APIs.
LLDP definitions and handler.
Public API for network interface.
IPv6 and IPv4 definitions.
Network packet buffer descriptor API.
Public NVMEM header file.
flags
Definition parser.h:97
Public functions for the Precision Time Protocol time specification.
Random number generator header file.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
void * memcpy(void *ZRESTRICT d, const void *ZRESTRICT s, size_t n)
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:519
Ethernet L2 API operations.
Definition ethernet.h:538
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:543
int(* start)(const struct device *dev)
Collect optional ethernet specific statistics.
Definition ethernet.h:562
int(* get_config)(const struct device *dev, enum ethernet_config_type type, struct ethernet_config *config)
Get hardware specific configuration.
Definition ethernet.h:576
int(* stop)(const struct device *dev)
Stop the device.
Definition ethernet.h:565
enum ethernet_hw_caps(* get_capabilities)(const struct device *dev)
Get the device capabilities.
Definition ethernet.h:568
int(* send)(const struct device *dev, struct net_pkt *pkt)
Send a network packet.
Definition ethernet.h:599
int(* set_config)(const struct device *dev, enum ethernet_config_type type, const struct ethernet_config *config)
Set specific hardware configuration.
Definition ethernet.h:571
Ethernet filter description.
Definition ethernet.h:454
struct net_eth_addr mac_address
MAC address to filter.
Definition ethernet.h:458
bool set
Set (true) or unset (false) the filter.
Definition ethernet.h:460
enum ethernet_filter_type type
Type of filter.
Definition ethernet.h:456
Ethernet LLDP specific parameters.
Definition ethernet.h:632
const uint8_t * optional_du
LLDP Data Unit optional TLVs for the interface.
Definition ethernet.h:640
sys_snode_t node
Used for track timers.
Definition ethernet.h:634
net_lldp_recv_cb_t cb
LLDP RX callback function.
Definition ethernet.h:649
k_timepoint_t tx_timer_timeout
LLDP TX timer timeout.
Definition ethernet.h:646
size_t optional_len
Length of the optional Data Unit TLVs.
Definition ethernet.h:643
const struct net_lldpdu * lldpdu
LLDP Data Unit mandatory TLVs for the interface.
Definition ethernet.h:637
Ethernet Qav specific parameters.
Definition ethernet.h:296
bool enabled
True if Qav is enabled for queue.
Definition ethernet.h:303
unsigned int oper_idle_slope
Oper Idle Slope (bits per second).
Definition ethernet.h:309
enum ethernet_qav_param_type type
Type of Qav parameter.
Definition ethernet.h:300
unsigned int traffic_class
Traffic class the queue is bound to.
Definition ethernet.h:311
int queue_id
ID of the priority queue to use.
Definition ethernet.h:298
unsigned int idle_slope
Idle Slope (bits per second).
Definition ethernet.h:307
unsigned int delta_bandwidth
Delta Bandwidth (percentage of bandwidth).
Definition ethernet.h:305
Ethernet Qbu specific parameters.
Definition ethernet.h:405
enum ethernet_qbu_preempt_status frame_preempt_statuses[NET_TC_TX_COUNT]
sequence of framePreemptionAdminStatus values
Definition ethernet.h:418
uint32_t release_advance
Release advance (nanoseconds).
Definition ethernet.h:415
enum ethernet_qbu_param_type type
Type of Qbu parameter.
Definition ethernet.h:409
uint32_t hold_advance
Hold advance (nanoseconds).
Definition ethernet.h:412
bool enabled
True if Qbu is enabled or not.
Definition ethernet.h:422
bool link_partner_status
Link partner status (from Qbr).
Definition ethernet.h:425
int port_id
Port id.
Definition ethernet.h:407
uint8_t additional_fragment_size
Additional fragment size (from Qbr).
Definition ethernet.h:431
Ethernet Qbv specific parameters.
Definition ethernet.h:338
int port_id
Port id.
Definition ethernet.h:340
bool enabled
True if Qbv is enabled or not.
Definition ethernet.h:347
enum ethernet_qbv_param_type type
Type of Qbv parameter.
Definition ethernet.h:342
uint16_t row
Gate control list row.
Definition ethernet.h:361
enum ethernet_qbv_state_type state
What state (Admin/Oper) parameters are these.
Definition ethernet.h:344
bool gate_status[NET_TC_TX_COUNT]
True = open, False = closed.
Definition ethernet.h:352
struct net_ptp_extended_time base_time
Base time.
Definition ethernet.h:373
uint32_t extension_time
Extension time (nanoseconds).
Definition ethernet.h:379
enum ethernet_gate_state_operation operation
GateState operation.
Definition ethernet.h:355
struct ethernet_qbv_param::@121175361150174144233316376176000350036121201324::@102147251204031207263025171335370313217251102106 gate_control
Gate control information.
uint32_t time_interval
Time interval ticks (nanoseconds).
Definition ethernet.h:358
struct net_ptp_time cycle_time
Cycle time.
Definition ethernet.h:376
uint32_t gate_control_list_len
Number of entries in gate control list.
Definition ethernet.h:365
Ethernet T1S specific parameters.
Definition ethernet.h:251
uint8_t burst_count
T1S PLCA burst count range: 0x0 to 0xFF.
Definition ethernet.h:286
struct ethernet_t1s_param::@045104211027030365347006377040354240151366265336::@055246010323023270273151373302031315361103011354 plca
PLCA is the Physical Layer (PHY) Collision Avoidance technique employed with multidrop 10Base-T1S sta...
uint8_t node_count
T1S PLCA node count range: 1 to 255.
Definition ethernet.h:284
uint8_t to_timer
T1S PLCA TO value.
Definition ethernet.h:290
uint8_t burst_timer
T1S PLCA burst timer.
Definition ethernet.h:288
uint8_t node_id
T1S PLCA node id range: 0 to 254.
Definition ethernet.h:282
enum ethernet_t1s_param_type type
Type of T1S parameter.
Definition ethernet.h:253
bool enable
T1S PLCA enabled.
Definition ethernet.h:280
Ethernet TXTIME specific parameters.
Definition ethernet.h:472
bool enable_txtime
Enable or disable TXTIME per queue.
Definition ethernet.h:478
int queue_id
Queue number for configuring TXTIME.
Definition ethernet.h:476
enum ethernet_txtime_param_type type
Type of TXTIME parameter.
Definition ethernet.h:474
Kernel timepoint type.
Definition clock.h:291
Ethernet address.
Definition ethernet.h:51
uint8_t addr[6U]
Buffer storing the address.
Definition ethernet.h:52
MAC address configuration.
Definition ethernet.h:1270
enum net_eth_mac_type type
The configuration type.
Definition ethernet.h:1272
struct nvmem_cell cell
The NVMEM cell to read the MAC address from.
Definition ethernet.h:1287
uint8_t addr[6U]
The static MAC address part.
Definition ethernet.h:1279
uint8_t addr_len
The length of the statically provided part.
Definition ethernet.h:1281
Network Interface structure.
Definition net_if.h:731
IPv6 address struct.
Definition net_ip.h:143
IPv4 address struct.
Definition net_ip.h:155
LLDP Data Unit (LLDPDU) shall contain the following ordered TLVs as stated in "8.2 LLDPDU format" fro...
Definition lldp.h:172
Network packet.
Definition net_pkt.h:92
Generalized Precision Time Protocol Extended Timestamp format.
Definition ptp_time.h:154
(Generalized) Precision Time Protocol Timestamp format.
Definition ptp_time.h:111
All Ethernet specific statistics.
Definition net_stats.h:625
Non-Volatile Memory cell representation.
Definition nvmem.h:37
Misc utilities.