Zephyr API Documentation 4.4.99
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_TXINJECTION_MODE,
230 ETHERNET_CONFIG_TYPE_RX_CHECKSUM_SUPPORT,
231 ETHERNET_CONFIG_TYPE_TX_CHECKSUM_SUPPORT,
232 ETHERNET_CONFIG_TYPE_EXTRA_TX_PKT_HEADROOM,
233};
234
235enum ethernet_qav_param_type {
236 ETHERNET_QAV_PARAM_TYPE_DELTA_BANDWIDTH,
237 ETHERNET_QAV_PARAM_TYPE_IDLE_SLOPE,
238 ETHERNET_QAV_PARAM_TYPE_OPER_IDLE_SLOPE,
239 ETHERNET_QAV_PARAM_TYPE_TRAFFIC_CLASS,
240 ETHERNET_QAV_PARAM_TYPE_STATUS,
241};
242
244
250 enum ethernet_qav_param_type type;
251 union {
255 unsigned int delta_bandwidth;
257 unsigned int idle_slope;
259 unsigned int oper_idle_slope;
261 unsigned int traffic_class;
262 } ;
263};
264
266
267enum ethernet_qbv_param_type {
268 ETHERNET_QBV_PARAM_TYPE_STATUS,
269 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST,
270 ETHERNET_QBV_PARAM_TYPE_GATE_CONTROL_LIST_LEN,
271 ETHERNET_QBV_PARAM_TYPE_TIME,
272};
273
274enum ethernet_qbv_state_type {
275 ETHERNET_QBV_STATE_TYPE_ADMIN,
276 ETHERNET_QBV_STATE_TYPE_OPER,
277};
278
279enum ethernet_gate_state_operation {
280 ETHERNET_SET_GATE_STATE,
281 ETHERNET_SET_AND_HOLD_MAC_STATE,
282 ETHERNET_SET_AND_RELEASE_MAC_STATE,
283};
284
286
292 enum ethernet_qbv_param_type type;
294 enum ethernet_qbv_state_type state;
295 union {
298
300 struct {
302 bool gate_status[NET_TC_TX_COUNT];
303
305 enum ethernet_gate_state_operation operation;
306
309
313
316
321 struct {
324
327
330 };
331 } ;
332};
333
335
336enum ethernet_qbu_param_type {
337 ETHERNET_QBU_PARAM_TYPE_STATUS,
338 ETHERNET_QBU_PARAM_TYPE_RELEASE_ADVANCE,
339 ETHERNET_QBU_PARAM_TYPE_HOLD_ADVANCE,
340 ETHERNET_QBU_PARAM_TYPE_PREEMPTION_STATUS_TABLE,
341
342 /* Some preemption settings are from Qbr spec. */
343 ETHERNET_QBR_PARAM_TYPE_LINK_PARTNER_STATUS,
344 ETHERNET_QBR_PARAM_TYPE_ADDITIONAL_FRAGMENT_SIZE,
345};
346
347enum ethernet_qbu_preempt_status {
348 ETHERNET_QBU_STATUS_EXPRESS,
349 ETHERNET_QBU_STATUS_PREEMPTABLE
350} __packed;
351
353
359 enum ethernet_qbu_param_type type;
360 union {
363
366
368 enum ethernet_qbu_preempt_status
369 frame_preempt_statuses[NET_TC_TX_COUNT];
370
373
376
382 } ;
383};
384
386
387enum ethernet_filter_type {
388 ETHERNET_FILTER_TYPE_SRC_MAC_ADDRESS,
389 ETHERNET_FILTER_TYPE_DST_MAC_ADDRESS,
390};
391
393
402
406 enum ethernet_filter_type type;
410 bool set;
411};
412
414
415enum ethernet_txtime_param_type {
416 ETHERNET_TXTIME_PARAM_TYPE_ENABLE_QUEUES,
417};
418
420
424 enum ethernet_txtime_param_type type;
429};
430
434 ETHERNET_CHECKSUM_SUPPORT_NONE = NET_IF_CHECKSUM_NONE_BIT,
436 ETHERNET_CHECKSUM_SUPPORT_IPV4_HEADER = NET_IF_CHECKSUM_IPV4_HEADER_BIT,
438 ETHERNET_CHECKSUM_SUPPORT_IPV4_ICMP = NET_IF_CHECKSUM_IPV4_ICMP_BIT,
440 ETHERNET_CHECKSUM_SUPPORT_IPV6_HEADER = NET_IF_CHECKSUM_IPV6_HEADER_BIT,
442 ETHERNET_CHECKSUM_SUPPORT_IPV6_ICMP = NET_IF_CHECKSUM_IPV6_ICMP_BIT,
444 ETHERNET_CHECKSUM_SUPPORT_TCP = NET_IF_CHECKSUM_TCP_BIT,
446 ETHERNET_CHECKSUM_SUPPORT_UDP = NET_IF_CHECKSUM_UDP_BIT,
447};
448
450
451struct ethernet_config {
452 union {
453 bool promisc_mode;
454 bool txinjection_mode;
455
456 struct net_eth_addr mac_address;
457
458 struct ethernet_qav_param qav_param;
459 struct ethernet_qbv_param qbv_param;
460 struct ethernet_qbu_param qbu_param;
461 struct ethernet_txtime_param txtime_param;
462
463 int priority_queues_num;
464 int ports_num;
465
466 enum ethernet_checksum_support chksum_support;
467
468 struct ethernet_filter filter;
469
470 uint16_t extra_tx_pkt_headroom;
471 } ;
472};
473
475
485
492 struct net_if_api iface_api;
493
498#if defined(CONFIG_NET_STATISTICS_ETHERNET)
499 struct net_stats_eth *(*get_stats)(const struct device *dev, struct net_if *iface);
500
506 struct net_stats_eth *(*get_stats_type)(const struct device *dev,
507 struct net_if *iface,
508 uint32_t type);
509#endif
510
512 int (*start)(const struct device *dev, struct net_if *iface);
513
515 int (*stop)(const struct device *dev, struct net_if *iface);
516
518 enum ethernet_hw_caps (*get_capabilities)(const struct device *dev, struct net_if *iface);
519
521 int (*set_config)(const struct device *dev,
522 struct net_if *iface,
523 enum ethernet_config_type type,
524 const struct ethernet_config *config);
525
527 int (*get_config)(const struct device *dev,
528 struct net_if *iface,
529 enum ethernet_config_type type,
530 struct ethernet_config *config);
531
537#if defined(CONFIG_NET_VLAN)
538 int (*vlan_setup)(const struct device *dev, struct net_if *iface,
539 uint16_t tag, bool enable);
540#endif /* CONFIG_NET_VLAN */
541
543#if defined(CONFIG_PTP_CLOCK)
544 const struct device *(*get_ptp_clock)(const struct device *dev, struct net_if *iface);
545#endif /* CONFIG_PTP_CLOCK */
546
548 const struct device *(*get_phy)(const struct device *dev, struct net_if *iface);
549
551 int (*send)(const struct device *dev, struct net_pkt *pkt);
552};
553
555
556/* Make sure that the network interface API is properly setup inside
557 * Ethernet API struct (it is the first one).
558 */
559BUILD_ASSERT(offsetof(struct ethernet_api, iface_api) == 0);
560
561struct net_eth_hdr {
562 struct net_eth_addr dst;
563 struct net_eth_addr src;
564 uint16_t type;
565} __packed;
566
567struct ethernet_vlan {
569 struct net_if *iface;
570
572 uint16_t tag;
573};
574
575#if defined(CONFIG_NET_VLAN_COUNT)
576#define NET_VLAN_MAX_COUNT CONFIG_NET_VLAN_COUNT
577#else
578#define NET_VLAN_MAX_COUNT 0
579#endif
580
582
603
605
606enum ethernet_flags {
607 ETH_CARRIER_UP,
608};
609
611struct ethernet_context {
616
617#if defined(CONFIG_NET_ETHERNET_BRIDGE)
618 struct net_if *bridge;
619#endif
620
627 struct k_work carrier_work;
628
630 struct net_if *iface;
631
632#if defined(CONFIG_NET_LLDP)
634 struct ethernet_lldp lldp;
635#endif
636
640 enum net_l2_flags ethernet_l2_flags;
641
642#if defined(CONFIG_NET_L2_PTP)
647 int port;
648#endif
649
650#if defined(CONFIG_NET_DSA)
652 enum dsa_port_type dsa_port;
653
655 void *dsa_switch_ctx;
656#endif
657
659 bool is_net_carrier_up : 1;
660
662 bool is_init : 1;
663
665 enum ethernet_if_types eth_if_type;
666};
667
673void ethernet_init(struct net_if *iface);
674
675#define ETHERNET_L2_CTX_TYPE struct ethernet_context
676
677/* Separate header for VLAN as some of device interfaces might not
678 * support VLAN.
679 */
680struct net_eth_vlan_hdr {
681 struct net_eth_addr dst;
682 struct net_eth_addr src;
683 struct {
684 uint16_t tpid; /* tag protocol id */
685 uint16_t tci; /* tag control info */
686 } vlan;
687 uint16_t type;
688} __packed;
689
691
699static inline bool net_eth_is_addr_broadcast(struct net_eth_addr *addr)
700{
701 if (addr->addr[0] == 0xff &&
702 addr->addr[1] == 0xff &&
703 addr->addr[2] == 0xff &&
704 addr->addr[3] == 0xff &&
705 addr->addr[4] == 0xff &&
706 addr->addr[5] == 0xff) {
707 return true;
708 }
709
710 return false;
711}
712
720static inline bool net_eth_is_addr_all_zeroes(struct net_eth_addr *addr)
721{
722 if (addr->addr[0] == 0x00 &&
723 addr->addr[1] == 0x00 &&
724 addr->addr[2] == 0x00 &&
725 addr->addr[3] == 0x00 &&
726 addr->addr[4] == 0x00 &&
727 addr->addr[5] == 0x00) {
728 return true;
729 }
730
731 return false;
732}
733
741static inline bool net_eth_is_addr_unspecified(struct net_eth_addr *addr)
742{
743 if (addr->addr[0] == 0x00 &&
744 addr->addr[1] == 0x00 &&
745 addr->addr[2] == 0x00 &&
746 addr->addr[3] == 0x00 &&
747 addr->addr[4] == 0x00 &&
748 addr->addr[5] == 0x00) {
749 return true;
750 }
751
752 return false;
753}
754
762static inline bool net_eth_is_addr_multicast(struct net_eth_addr *addr)
763{
764 return addr->addr[0] & 0x01;
765}
766
774static inline bool net_eth_is_addr_unicast(struct net_eth_addr *addr)
775{
777}
778
786static inline bool net_eth_is_addr_valid(struct net_eth_addr *addr)
787{
789}
790
798static inline bool net_eth_is_addr_lldp_multicast(struct net_eth_addr *addr)
799{
800 if (addr->addr[0] == 0x01 &&
801 addr->addr[1] == 0x80 &&
802 addr->addr[2] == 0xc2 &&
803 addr->addr[3] == 0x00 &&
804 addr->addr[4] == 0x00 &&
805 addr->addr[5] == 0x0e) {
806 return true;
807 }
808
809 return false;
810}
811
819static inline bool net_eth_is_addr_ptp_multicast(struct net_eth_addr *addr)
820{
821 if (addr->addr[0] == 0x01 &&
822 addr->addr[1] == 0x1b &&
823 addr->addr[2] == 0x19 &&
824 addr->addr[3] == 0x00 &&
825 addr->addr[4] == 0x00 &&
826 addr->addr[5] == 0x00) {
827 return true;
828 }
829
830 return false;
831}
832
839
846void net_eth_ipv4_mcast_to_mac_addr(const struct net_in_addr *ipv4_addr,
847 struct net_eth_addr *mac_addr);
848
855void net_eth_ipv6_mcast_to_mac_addr(const struct net_in6_addr *ipv6_addr,
856 struct net_eth_addr *mac_addr);
857
865static inline
867{
868 const struct device *dev = net_if_get_device(iface);
869 const struct ethernet_api *api = (struct ethernet_api *)dev->api;
870 enum ethernet_hw_caps caps = (enum ethernet_hw_caps)0;
871#if defined(CONFIG_NET_DSA)
872 struct ethernet_context *eth_ctx = net_if_l2_data(iface);
873
874 if (eth_ctx->dsa_port == DSA_CONDUIT_PORT) {
876 } else if (eth_ctx->dsa_port == DSA_USER_PORT) {
878 }
879#endif
880 if (api == NULL || api->get_capabilities == NULL) {
881 return caps;
882 }
883
884 return (enum ethernet_hw_caps)(caps | api->get_capabilities(dev, iface));
885}
886
896static inline
897int net_eth_get_hw_config(struct net_if *iface, enum ethernet_config_type type,
898 struct ethernet_config *config)
899{
900 const struct device *dev = net_if_get_device(iface);
901 const struct ethernet_api *eth = (struct ethernet_api *)dev->api;
902
903 if (!eth->get_config) {
904 return -ENOTSUP;
905 }
906
907 return eth->get_config(dev, iface, type, config);
908}
909
910
919#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
920int net_eth_vlan_enable(struct net_if *iface, uint16_t tag);
921#else
922static inline int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
923{
924 ARG_UNUSED(iface);
925 ARG_UNUSED(tag);
926
927 return -EINVAL;
928}
929#endif
930
939#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
940int net_eth_vlan_disable(struct net_if *iface, uint16_t tag);
941#else
942static inline int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
943{
944 ARG_UNUSED(iface);
945 ARG_UNUSED(tag);
946
947 return -EINVAL;
948}
949#endif
950
962#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
964#else
965static inline uint16_t net_eth_get_vlan_tag(struct net_if *iface)
966{
967 ARG_UNUSED(iface);
968
969 return NET_VLAN_TAG_UNSPEC;
970}
971#endif
972
982#if defined(CONFIG_NET_VLAN)
983struct net_if *net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag);
984#else
985static inline
986struct net_if *net_eth_get_vlan_iface(struct net_if *iface, uint16_t tag)
987{
988 ARG_UNUSED(iface);
989 ARG_UNUSED(tag);
990
991 return NULL;
992}
993#endif
994
1004#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1005struct net_if *net_eth_get_vlan_main(struct net_if *iface);
1006#else
1007static inline
1009{
1010 ARG_UNUSED(iface);
1011
1012 return NULL;
1013}
1014#endif
1015
1029#if defined(CONFIG_NET_VLAN)
1030bool net_eth_is_vlan_enabled(struct ethernet_context *ctx,
1031 struct net_if *iface);
1032#else
1033static inline bool net_eth_is_vlan_enabled(struct ethernet_context *ctx,
1034 struct net_if *iface)
1035{
1036 ARG_UNUSED(ctx);
1037 ARG_UNUSED(iface);
1038
1039 return false;
1040}
1041#endif
1042
1050#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1051bool net_eth_get_vlan_status(struct net_if *iface);
1052#else
1053static inline bool net_eth_get_vlan_status(struct net_if *iface)
1054{
1055 ARG_UNUSED(iface);
1056
1057 return false;
1058}
1059#endif
1060
1068#if defined(CONFIG_NET_VLAN) && NET_VLAN_MAX_COUNT > 0
1069bool net_eth_is_vlan_interface(struct net_if *iface);
1070#else
1071static inline bool net_eth_is_vlan_interface(struct net_if *iface)
1072{
1073 ARG_UNUSED(iface);
1074
1075 return false;
1076}
1077#endif
1078
1080
1081#if !defined(CONFIG_ETH_DRIVER_RAW_MODE)
1082
1083#define Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1084 init_fn, pm, data, config, prio, \
1085 api, mtu) \
1086 Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1087 init_fn, pm, data, config, prio, \
1088 api, ETHERNET_L2, \
1089 NET_L2_GET_CTX_TYPE(ETHERNET_L2), mtu)
1090
1091#else /* CONFIG_ETH_DRIVER_RAW_MODE */
1092
1093#define Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
1094 init_fn, pm, data, config, prio, \
1095 api, mtu) \
1096 Z_DEVICE_STATE_DEFINE(dev_id); \
1097 Z_DEVICE_DEFINE(node_id, dev_id, name, init_fn, NULL, \
1098 Z_DEVICE_DT_FLAGS(node_id), pm, data, \
1099 config, POST_KERNEL, prio, api, \
1100 &Z_DEVICE_STATE_NAME(dev_id));
1101
1102#endif /* CONFIG_ETH_DRIVER_RAW_MODE */
1103
1104#define Z_ETH_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
1105 config, prio, api, mtu) \
1106 Z_ETH_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, 0, \
1107 init_fn, pm, data, config, prio, \
1108 api, mtu)
1109
1111
1129#define ETH_NET_DEVICE_INIT(dev_id, name, init_fn, pm, data, config, \
1130 prio, api, mtu) \
1131 Z_ETH_NET_DEVICE_INIT(DT_INVALID_NODE, dev_id, name, init_fn, \
1132 pm, data, config, prio, api, mtu)
1133
1156#define ETH_NET_DEVICE_INIT_INSTANCE(dev_id, name, instance, init_fn, \
1157 pm, data, config, prio, api, mtu) \
1158 Z_ETH_NET_DEVICE_INIT_INSTANCE(DT_INVALID_NODE, dev_id, name, \
1159 instance, init_fn, pm, data, \
1160 config, prio, api, mtu)
1161
1178#define ETH_NET_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, config, \
1179 prio, api, mtu) \
1180 Z_ETH_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
1181 DEVICE_DT_NAME(node_id), init_fn, pm, \
1182 data, config, prio, api, mtu)
1183
1193#define ETH_NET_DEVICE_DT_INST_DEFINE(inst, ...) \
1194 ETH_NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
1195
1203#define ETH_NET_L3_REGISTER(name, ptype, handler) \
1204 NET_L3_REGISTER(&NET_L2_GET_NAME(ETHERNET), name, ptype, handler)
1205
1220
1234#if defined(CONFIG_NVMEM) || defined(__DOXYGEN__)
1240#endif
1241};
1242
1257static inline int net_eth_mac_load(const struct net_eth_mac_config *cfg, uint8_t *mac_addr)
1258{
1259 if (cfg == NULL || cfg->type == NET_ETH_MAC_DEFAULT) {
1260 return -ENODATA;
1261 }
1262
1263 /* Copy the static part */
1264 memcpy(mac_addr, cfg->addr, cfg->addr_len);
1265
1266 if (cfg->type == NET_ETH_MAC_RANDOM) {
1267 sys_rand_get(&mac_addr[cfg->addr_len], NET_ETH_ADDR_LEN - cfg->addr_len);
1268
1269 /* Clear group bit, multicast (I/G) */
1270 mac_addr[0] &= ~0x01;
1271 /* Set MAC address locally administered, unicast (LAA) */
1272 mac_addr[0] |= 0x02;
1273
1274 return 0;
1275 }
1276
1277#if defined(CONFIG_NVMEM)
1278 if (cfg->type == NET_ETH_MAC_NVMEM) {
1279 return nvmem_cell_read(&cfg->cell, &mac_addr[cfg->addr_len], 0,
1280 NET_ETH_ADDR_LEN - cfg->addr_len);
1281 }
1282#endif
1283
1284 if (cfg->type == NET_ETH_MAC_STATIC) {
1285 return 0;
1286 }
1287
1288 return -ENODATA;
1289}
1290
1292
1293#if defined(CONFIG_NVMEM) || defined(__DOXYGEN__)
1300#define Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id) \
1301 .cell = NVMEM_CELL_GET_BY_NAME_OR(node_id, mac_address, {0}),
1302#else
1303#define Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id)
1304#endif
1305
1306#define Z_NET_ETH_MAC_DT_CONFIG_INIT_RANDOM(node_id) \
1307 { \
1308 .type = NET_ETH_MAC_RANDOM, \
1309 .addr = DT_PROP_OR(node_id, zephyr_mac_address_prefix, {0}), \
1310 .addr_len = DT_PROP_LEN_OR(node_id, zephyr_mac_address_prefix, 0), \
1311 }
1312
1313#define Z_NET_ETH_MAC_DT_CONFIG_INIT_NVMEM(node_id) \
1314 { \
1315 .type = NET_ETH_MAC_NVMEM, \
1316 .addr = DT_PROP_OR(node_id, zephyr_mac_address_prefix, {0}), \
1317 .addr_len = DT_PROP_LEN_OR(node_id, zephyr_mac_address_prefix, 0), \
1318 Z_NET_ETH_MAC_DEV_CONFIG_INIT_CELL(node_id) \
1319 }
1320
1321#define Z_NET_ETH_MAC_DT_CONFIG_INIT_STATIC(node_id) \
1322 { \
1323 .type = NET_ETH_MAC_STATIC, \
1324 .addr = DT_PROP(node_id, local_mac_address), \
1325 .addr_len = DT_PROP_LEN(node_id, local_mac_address), \
1326 }
1327
1328#define Z_NET_ETH_MAC_DT_CONFIG_INIT_DEFAULT(node_id) \
1329 { \
1330 .type = NET_ETH_MAC_DEFAULT, \
1331 }
1332
1334
1340#define NET_ETH_MAC_DT_CONFIG_INIT(node_id) \
1341 COND_CASE_1(DT_PROP(node_id, zephyr_random_mac_address), \
1342 (Z_NET_ETH_MAC_DT_CONFIG_INIT_RANDOM(node_id)), \
1343 DT_NVMEM_CELLS_HAS_NAME(node_id, mac_address), \
1344 (Z_NET_ETH_MAC_DT_CONFIG_INIT_NVMEM(node_id)), \
1345 DT_NODE_HAS_PROP(node_id, local_mac_address), \
1346 (Z_NET_ETH_MAC_DT_CONFIG_INIT_STATIC(node_id)), \
1347 (Z_NET_ETH_MAC_DT_CONFIG_INIT_DEFAULT(node_id)))
1348
1356#define NET_ETH_MAC_DT_INST_CONFIG_INIT(inst) \
1357 NET_ETH_MAC_DT_CONFIG_INIT(DT_DRV_INST(inst))
1358
1365void net_eth_carrier_on(struct net_if *iface);
1366
1373void net_eth_carrier_off(struct net_if *iface);
1374
1384int net_eth_promisc_mode(struct net_if *iface, bool enable);
1385
1395int net_eth_txinjection_mode(struct net_if *iface, bool enable);
1396
1407int net_eth_mac_filter(struct net_if *iface, struct net_eth_addr *mac,
1408 enum ethernet_filter_type type, bool enable);
1409
1417const struct device *net_eth_get_phy(struct net_if *iface);
1418
1427#if defined(CONFIG_PTP_CLOCK)
1428const struct device *net_eth_get_ptp_clock(struct net_if *iface);
1429#else
1430static inline const struct device *net_eth_get_ptp_clock(struct net_if *iface)
1431{
1432 ARG_UNUSED(iface);
1433
1434 return NULL;
1435}
1436#endif
1437
1447__syscall const struct device *net_eth_get_ptp_clock_by_index(int index);
1448
1456#if defined(CONFIG_NET_L2_PTP)
1457int net_eth_get_ptp_port(struct net_if *iface);
1458#else
1459static inline int net_eth_get_ptp_port(struct net_if *iface)
1460{
1461 ARG_UNUSED(iface);
1462
1463 return -ENODEV;
1464}
1465#endif /* CONFIG_NET_L2_PTP */
1466
1473#if defined(CONFIG_NET_L2_PTP)
1474void net_eth_set_ptp_port(struct net_if *iface, int port);
1475#else
1476static inline void net_eth_set_ptp_port(struct net_if *iface, int port)
1477{
1478 ARG_UNUSED(iface);
1479 ARG_UNUSED(port);
1480}
1481#endif /* CONFIG_NET_L2_PTP */
1482
1490static inline bool net_eth_type_is_wifi(struct net_if *iface)
1491{
1492 const struct ethernet_context *ctx = (struct ethernet_context *)
1493 net_if_l2_data(iface);
1494
1495 return ctx->eth_if_type == L2_ETH_IF_TYPE_WIFI;
1496}
1497
1505static inline bool net_eth_type_is_ethernet(struct net_if *iface)
1506{
1507 const struct ethernet_context *ctx = (struct ethernet_context *)net_if_l2_data(iface);
1508
1509 return ctx->eth_if_type == L2_ETH_IF_TYPE_ETHERNET;
1510}
1511
1515
1516#ifdef __cplusplus
1517}
1518#endif
1519
1520#include <zephyr/syscalls/ethernet.h>
1521
1522#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:1008
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:897
ethernet_if_types
Types of Ethernet L2.
Definition ethernet.h:395
static void net_eth_set_ptp_port(struct net_if *iface, int port)
Set PTP port number attached to this interface.
Definition ethernet.h:1476
static int net_eth_vlan_enable(struct net_if *iface, uint16_t tag)
Add VLAN tag to the interface.
Definition ethernet.h:922
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:720
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:762
static int net_eth_get_ptp_port(struct net_if *iface)
Return PTP port number attached to this interface.
Definition ethernet.h:1459
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:1430
#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:965
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:1490
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:699
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:1053
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:741
static bool net_eth_is_vlan_interface(struct net_if *iface)
Check if the given interface is a VLAN interface.
Definition ethernet.h:1071
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:1257
static enum ethernet_hw_caps net_eth_get_hw_capabilities(struct net_if *iface)
Return ethernet device hardware capability information.
Definition ethernet.h:866
static int net_eth_vlan_disable(struct net_if *iface, uint16_t tag)
Remove VLAN tag from the interface.
Definition ethernet.h:942
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:432
ethernet_stats_type
Ethernet statistics type (bitmap).
Definition ethernet.h:477
net_eth_mac_type
MAC address configuration types.
Definition ethernet.h:1207
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:1033
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:986
static bool net_eth_type_is_ethernet(struct net_if *iface)
Check if the Ethernet L2 network interface is cabled ethernet.
Definition ethernet.h:1505
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:774
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:798
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:819
static bool net_eth_is_addr_valid(struct net_eth_addr *addr)
Check if the Ethernet MAC address is valid.
Definition ethernet.h:786
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:397
@ L2_ETH_IF_TYPE_WIFI
IEEE 802.11 Wi-Fi.
Definition ethernet.h:400
@ 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:446
@ ETHERNET_CHECKSUM_SUPPORT_TCP
Device supports TCP checksum offloading for all supported IP protocols.
Definition ethernet.h:444
@ ETHERNET_CHECKSUM_SUPPORT_IPV6_HEADER
Device supports checksum offloading for the IPv6 header.
Definition ethernet.h:440
@ ETHERNET_CHECKSUM_SUPPORT_IPV4_ICMP
Device supports checksum offloading for ICMPv4 payload (implies IPv4 header).
Definition ethernet.h:438
@ ETHERNET_CHECKSUM_SUPPORT_IPV4_HEADER
Device supports checksum offloading for the IPv4 header.
Definition ethernet.h:436
@ ETHERNET_CHECKSUM_SUPPORT_NONE
Device does not support any L3/L4 checksum offloading.
Definition ethernet.h:434
@ ETHERNET_CHECKSUM_SUPPORT_IPV6_ICMP
Device supports checksum offloading for ICMPv6 payload (implies IPv6 header).
Definition ethernet.h:442
@ ETHERNET_STATS_TYPE_VENDOR
Vendor statistics only.
Definition ethernet.h:481
@ ETHERNET_STATS_TYPE_ALL
All statistics.
Definition ethernet.h:483
@ ETHERNET_STATS_TYPE_COMMON
Common statistics only (excludes vendor statistics).
Definition ethernet.h:479
@ NET_ETH_MAC_RANDOM
A random MAC address is generated during initialization.
Definition ethernet.h:1211
@ NET_ETH_MAC_NVMEM
The MAC address is read from an NVMEM cell.
Definition ethernet.h:1216
@ NET_ETH_MAC_DEFAULT
MAC address is handled by the driver (backwards compatible case).
Definition ethernet.h:1209
@ NET_ETH_MAC_STATIC
A static MAC address is provided in the device tree.
Definition ethernet.h:1218
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:1067
static const struct device * net_if_get_device(struct net_if *iface)
Get an network interface's device.
Definition net_if.h:1085
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:487
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:492
int(* start)(const struct device *dev, struct net_if *iface)
Collect optional ethernet specific statistics.
Definition ethernet.h:512
int(* stop)(const struct device *dev, struct net_if *iface)
Stop the device.
Definition ethernet.h:515
int(* send)(const struct device *dev, struct net_pkt *pkt)
Send a network packet.
Definition ethernet.h:551
int(* set_config)(const struct device *dev, struct net_if *iface, enum ethernet_config_type type, const struct ethernet_config *config)
Set specific hardware configuration.
Definition ethernet.h:521
int(* get_config)(const struct device *dev, struct net_if *iface, enum ethernet_config_type type, struct ethernet_config *config)
Get hardware specific configuration.
Definition ethernet.h:527
enum ethernet_hw_caps(* get_capabilities)(const struct device *dev, struct net_if *iface)
Get the device capabilities.
Definition ethernet.h:518
Ethernet filter description.
Definition ethernet.h:404
struct net_eth_addr mac_address
MAC address to filter.
Definition ethernet.h:408
bool set
Set (true) or unset (false) the filter.
Definition ethernet.h:410
enum ethernet_filter_type type
Type of filter.
Definition ethernet.h:406
Ethernet LLDP specific parameters.
Definition ethernet.h:584
const uint8_t * optional_du
LLDP Data Unit optional TLVs for the interface.
Definition ethernet.h:592
sys_snode_t node
Used for track timers.
Definition ethernet.h:586
net_lldp_recv_cb_t cb
LLDP RX callback function.
Definition ethernet.h:601
k_timepoint_t tx_timer_timeout
LLDP TX timer timeout.
Definition ethernet.h:598
size_t optional_len
Length of the optional Data Unit TLVs.
Definition ethernet.h:595
const struct net_lldpdu * lldpdu
LLDP Data Unit mandatory TLVs for the interface.
Definition ethernet.h:589
Ethernet Qav specific parameters.
Definition ethernet.h:246
bool enabled
True if Qav is enabled for queue.
Definition ethernet.h:253
unsigned int oper_idle_slope
Oper Idle Slope (bits per second).
Definition ethernet.h:259
enum ethernet_qav_param_type type
Type of Qav parameter.
Definition ethernet.h:250
unsigned int traffic_class
Traffic class the queue is bound to.
Definition ethernet.h:261
int queue_id
ID of the priority queue to use.
Definition ethernet.h:248
unsigned int idle_slope
Idle Slope (bits per second).
Definition ethernet.h:257
unsigned int delta_bandwidth
Delta Bandwidth (percentage of bandwidth).
Definition ethernet.h:255
Ethernet Qbu specific parameters.
Definition ethernet.h:355
enum ethernet_qbu_preempt_status frame_preempt_statuses[NET_TC_TX_COUNT]
sequence of framePreemptionAdminStatus values
Definition ethernet.h:368
uint32_t release_advance
Release advance (nanoseconds).
Definition ethernet.h:365
enum ethernet_qbu_param_type type
Type of Qbu parameter.
Definition ethernet.h:359
uint32_t hold_advance
Hold advance (nanoseconds).
Definition ethernet.h:362
bool enabled
True if Qbu is enabled or not.
Definition ethernet.h:372
bool link_partner_status
Link partner status (from Qbr).
Definition ethernet.h:375
int port_id
Port id.
Definition ethernet.h:357
uint8_t additional_fragment_size
Additional fragment size (from Qbr).
Definition ethernet.h:381
Ethernet Qbv specific parameters.
Definition ethernet.h:288
int port_id
Port id.
Definition ethernet.h:290
bool enabled
True if Qbv is enabled or not.
Definition ethernet.h:297
struct ethernet_qbv_param::@055246010323023270273151373302031315361103011354::@066201007326270006176246045126267167014036102070 gate_control
Gate control information.
enum ethernet_qbv_param_type type
Type of Qbv parameter.
Definition ethernet.h:292
uint16_t row
Gate control list row.
Definition ethernet.h:311
enum ethernet_qbv_state_type state
What state (Admin/Oper) parameters are these.
Definition ethernet.h:294
bool gate_status[NET_TC_TX_COUNT]
True = open, False = closed.
Definition ethernet.h:302
struct net_ptp_extended_time base_time
Base time.
Definition ethernet.h:323
uint32_t extension_time
Extension time (nanoseconds).
Definition ethernet.h:329
enum ethernet_gate_state_operation operation
GateState operation.
Definition ethernet.h:305
uint32_t time_interval
Time interval ticks (nanoseconds).
Definition ethernet.h:308
struct net_ptp_time cycle_time
Cycle time.
Definition ethernet.h:326
uint32_t gate_control_list_len
Number of entries in gate control list.
Definition ethernet.h:315
Ethernet TXTIME specific parameters.
Definition ethernet.h:422
bool enable_txtime
Enable or disable TXTIME per queue.
Definition ethernet.h:428
int queue_id
Queue number for configuring TXTIME.
Definition ethernet.h:426
enum ethernet_txtime_param_type type
Type of TXTIME parameter.
Definition ethernet.h:424
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:1222
enum net_eth_mac_type type
The configuration type.
Definition ethernet.h:1224
struct nvmem_cell cell
The NVMEM cell to read the MAC address from.
Definition ethernet.h:1239
uint8_t addr[6U]
The static MAC address part.
Definition ethernet.h:1231
uint8_t addr_len
The length of the statically provided part.
Definition ethernet.h:1233
Network Interface structure.
Definition net_if.h:735
IPv6 address struct.
Definition net_ip.h:144
IPv4 address struct.
Definition net_ip.h:156
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:95
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:647
Non-Volatile Memory cell representation.
Definition nvmem.h:37
Misc utilities.