1/****************************************************************************
2 ****************************************************************************
3 ***
4 ***   This header was automatically generated from a Linux kernel header
5 ***   of the same name, to make information necessary for userspace to
6 ***   call into the kernel available to libc.  It contains only constants,
7 ***   structures, and macros generated from the original header, and thus,
8 ***   contains no copyrightable information.
9 ***
10 ***   To edit the content of this header, modify the corresponding
11 ***   source file (e.g. under external/kernel-headers/original/) then
12 ***   run bionic/libc/kernel/tools/update_all.py
13 ***
14 ***   Any manual change here will be lost the next time this script will
15 ***   be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_LINUX_ETHTOOL_H
20#define _UAPI_LINUX_ETHTOOL_H
21#include <linux/kernel.h>
22#include <linux/types.h>
23#include <linux/if_ether.h>
24#include <limits.h>
25struct ethtool_cmd {
26  __u32 cmd;
27  __u32 supported;
28  __u32 advertising;
29  __u16 speed;
30  __u8 duplex;
31  __u8 port;
32  __u8 phy_address;
33  __u8 transceiver;
34  __u8 autoneg;
35  __u8 mdio_support;
36  __u32 maxtxpkt;
37  __u32 maxrxpkt;
38  __u16 speed_hi;
39  __u8 eth_tp_mdix;
40  __u8 eth_tp_mdix_ctrl;
41  __u32 lp_advertising;
42  __u32 reserved[2];
43};
44#define ETH_MDIO_SUPPORTS_C22 1
45#define ETH_MDIO_SUPPORTS_C45 2
46#define ETHTOOL_FWVERS_LEN 32
47#define ETHTOOL_BUSINFO_LEN 32
48#define ETHTOOL_EROMVERS_LEN 32
49struct ethtool_drvinfo {
50  __u32 cmd;
51  char driver[32];
52  char version[32];
53  char fw_version[ETHTOOL_FWVERS_LEN];
54  char bus_info[ETHTOOL_BUSINFO_LEN];
55  char erom_version[ETHTOOL_EROMVERS_LEN];
56  char reserved2[12];
57  __u32 n_priv_flags;
58  __u32 n_stats;
59  __u32 testinfo_len;
60  __u32 eedump_len;
61  __u32 regdump_len;
62};
63#define SOPASS_MAX 6
64struct ethtool_wolinfo {
65  __u32 cmd;
66  __u32 supported;
67  __u32 wolopts;
68  __u8 sopass[SOPASS_MAX];
69};
70struct ethtool_value {
71  __u32 cmd;
72  __u32 data;
73};
74enum tunable_id {
75  ETHTOOL_ID_UNSPEC,
76  ETHTOOL_RX_COPYBREAK,
77  ETHTOOL_TX_COPYBREAK,
78  __ETHTOOL_TUNABLE_COUNT,
79};
80enum tunable_type_id {
81  ETHTOOL_TUNABLE_UNSPEC,
82  ETHTOOL_TUNABLE_U8,
83  ETHTOOL_TUNABLE_U16,
84  ETHTOOL_TUNABLE_U32,
85  ETHTOOL_TUNABLE_U64,
86  ETHTOOL_TUNABLE_STRING,
87  ETHTOOL_TUNABLE_S8,
88  ETHTOOL_TUNABLE_S16,
89  ETHTOOL_TUNABLE_S32,
90  ETHTOOL_TUNABLE_S64,
91};
92struct ethtool_tunable {
93  __u32 cmd;
94  __u32 id;
95  __u32 type_id;
96  __u32 len;
97  void * data[0];
98};
99#define DOWNSHIFT_DEV_DEFAULT_COUNT 0xff
100#define DOWNSHIFT_DEV_DISABLE 0
101enum phy_tunable_id {
102  ETHTOOL_PHY_ID_UNSPEC,
103  ETHTOOL_PHY_DOWNSHIFT,
104  __ETHTOOL_PHY_TUNABLE_COUNT,
105};
106struct ethtool_regs {
107  __u32 cmd;
108  __u32 version;
109  __u32 len;
110  __u8 data[0];
111};
112struct ethtool_eeprom {
113  __u32 cmd;
114  __u32 magic;
115  __u32 offset;
116  __u32 len;
117  __u8 data[0];
118};
119struct ethtool_eee {
120  __u32 cmd;
121  __u32 supported;
122  __u32 advertised;
123  __u32 lp_advertised;
124  __u32 eee_active;
125  __u32 eee_enabled;
126  __u32 tx_lpi_enabled;
127  __u32 tx_lpi_timer;
128  __u32 reserved[2];
129};
130struct ethtool_modinfo {
131  __u32 cmd;
132  __u32 type;
133  __u32 eeprom_len;
134  __u32 reserved[8];
135};
136struct ethtool_coalesce {
137  __u32 cmd;
138  __u32 rx_coalesce_usecs;
139  __u32 rx_max_coalesced_frames;
140  __u32 rx_coalesce_usecs_irq;
141  __u32 rx_max_coalesced_frames_irq;
142  __u32 tx_coalesce_usecs;
143  __u32 tx_max_coalesced_frames;
144  __u32 tx_coalesce_usecs_irq;
145  __u32 tx_max_coalesced_frames_irq;
146  __u32 stats_block_coalesce_usecs;
147  __u32 use_adaptive_rx_coalesce;
148  __u32 use_adaptive_tx_coalesce;
149  __u32 pkt_rate_low;
150  __u32 rx_coalesce_usecs_low;
151  __u32 rx_max_coalesced_frames_low;
152  __u32 tx_coalesce_usecs_low;
153  __u32 tx_max_coalesced_frames_low;
154  __u32 pkt_rate_high;
155  __u32 rx_coalesce_usecs_high;
156  __u32 rx_max_coalesced_frames_high;
157  __u32 tx_coalesce_usecs_high;
158  __u32 tx_max_coalesced_frames_high;
159  __u32 rate_sample_interval;
160};
161struct ethtool_ringparam {
162  __u32 cmd;
163  __u32 rx_max_pending;
164  __u32 rx_mini_max_pending;
165  __u32 rx_jumbo_max_pending;
166  __u32 tx_max_pending;
167  __u32 rx_pending;
168  __u32 rx_mini_pending;
169  __u32 rx_jumbo_pending;
170  __u32 tx_pending;
171};
172struct ethtool_channels {
173  __u32 cmd;
174  __u32 max_rx;
175  __u32 max_tx;
176  __u32 max_other;
177  __u32 max_combined;
178  __u32 rx_count;
179  __u32 tx_count;
180  __u32 other_count;
181  __u32 combined_count;
182};
183struct ethtool_pauseparam {
184  __u32 cmd;
185  __u32 autoneg;
186  __u32 rx_pause;
187  __u32 tx_pause;
188};
189#define ETH_GSTRING_LEN 32
190enum ethtool_stringset {
191  ETH_SS_TEST = 0,
192  ETH_SS_STATS,
193  ETH_SS_PRIV_FLAGS,
194  ETH_SS_NTUPLE_FILTERS,
195  ETH_SS_FEATURES,
196  ETH_SS_RSS_HASH_FUNCS,
197  ETH_SS_TUNABLES,
198  ETH_SS_PHY_STATS,
199  ETH_SS_PHY_TUNABLES,
200};
201struct ethtool_gstrings {
202  __u32 cmd;
203  __u32 string_set;
204  __u32 len;
205  __u8 data[0];
206};
207struct ethtool_sset_info {
208  __u32 cmd;
209  __u32 reserved;
210  __u64 sset_mask;
211  __u32 data[0];
212};
213enum ethtool_test_flags {
214  ETH_TEST_FL_OFFLINE = (1 << 0),
215  ETH_TEST_FL_FAILED = (1 << 1),
216  ETH_TEST_FL_EXTERNAL_LB = (1 << 2),
217  ETH_TEST_FL_EXTERNAL_LB_DONE = (1 << 3),
218};
219struct ethtool_test {
220  __u32 cmd;
221  __u32 flags;
222  __u32 reserved;
223  __u32 len;
224  __u64 data[0];
225};
226struct ethtool_stats {
227  __u32 cmd;
228  __u32 n_stats;
229  __u64 data[0];
230};
231struct ethtool_perm_addr {
232  __u32 cmd;
233  __u32 size;
234  __u8 data[0];
235};
236enum ethtool_flags {
237  ETH_FLAG_TXVLAN = (1 << 7),
238  ETH_FLAG_RXVLAN = (1 << 8),
239  ETH_FLAG_LRO = (1 << 15),
240  ETH_FLAG_NTUPLE = (1 << 27),
241  ETH_FLAG_RXHASH = (1 << 28),
242};
243struct ethtool_tcpip4_spec {
244  __be32 ip4src;
245  __be32 ip4dst;
246  __be16 psrc;
247  __be16 pdst;
248  __u8 tos;
249};
250struct ethtool_ah_espip4_spec {
251  __be32 ip4src;
252  __be32 ip4dst;
253  __be32 spi;
254  __u8 tos;
255};
256#define ETH_RX_NFC_IP4 1
257struct ethtool_usrip4_spec {
258  __be32 ip4src;
259  __be32 ip4dst;
260  __be32 l4_4_bytes;
261  __u8 tos;
262  __u8 ip_ver;
263  __u8 proto;
264};
265struct ethtool_tcpip6_spec {
266  __be32 ip6src[4];
267  __be32 ip6dst[4];
268  __be16 psrc;
269  __be16 pdst;
270  __u8 tclass;
271};
272struct ethtool_ah_espip6_spec {
273  __be32 ip6src[4];
274  __be32 ip6dst[4];
275  __be32 spi;
276  __u8 tclass;
277};
278struct ethtool_usrip6_spec {
279  __be32 ip6src[4];
280  __be32 ip6dst[4];
281  __be32 l4_4_bytes;
282  __u8 tclass;
283  __u8 l4_proto;
284};
285union ethtool_flow_union {
286  struct ethtool_tcpip4_spec tcp_ip4_spec;
287  struct ethtool_tcpip4_spec udp_ip4_spec;
288  struct ethtool_tcpip4_spec sctp_ip4_spec;
289  struct ethtool_ah_espip4_spec ah_ip4_spec;
290  struct ethtool_ah_espip4_spec esp_ip4_spec;
291  struct ethtool_usrip4_spec usr_ip4_spec;
292  struct ethtool_tcpip6_spec tcp_ip6_spec;
293  struct ethtool_tcpip6_spec udp_ip6_spec;
294  struct ethtool_tcpip6_spec sctp_ip6_spec;
295  struct ethtool_ah_espip6_spec ah_ip6_spec;
296  struct ethtool_ah_espip6_spec esp_ip6_spec;
297  struct ethtool_usrip6_spec usr_ip6_spec;
298  struct ethhdr ether_spec;
299  __u8 hdata[52];
300};
301struct ethtool_flow_ext {
302  __u8 padding[2];
303  unsigned char h_dest[ETH_ALEN];
304  __be16 vlan_etype;
305  __be16 vlan_tci;
306  __be32 data[2];
307};
308struct ethtool_rx_flow_spec {
309  __u32 flow_type;
310  union ethtool_flow_union h_u;
311  struct ethtool_flow_ext h_ext;
312  union ethtool_flow_union m_u;
313  struct ethtool_flow_ext m_ext;
314  __u64 ring_cookie;
315  __u32 location;
316};
317#define ETHTOOL_RX_FLOW_SPEC_RING 0x00000000FFFFFFFFLL
318#define ETHTOOL_RX_FLOW_SPEC_RING_VF 0x000000FF00000000LL
319#define ETHTOOL_RX_FLOW_SPEC_RING_VF_OFF 32
320struct ethtool_rxfh_indir {
321  __u32 cmd;
322  __u32 size;
323  __u32 ring_index[0];
324};
325struct ethtool_rxfh {
326  __u32 cmd;
327  __u32 rss_context;
328  __u32 indir_size;
329  __u32 key_size;
330  __u8 hfunc;
331  __u8 rsvd8[3];
332  __u32 rsvd32;
333  __u32 rss_config[0];
334};
335#define ETH_RXFH_INDIR_NO_CHANGE 0xffffffff
336struct ethtool_rx_ntuple_flow_spec {
337  __u32 flow_type;
338  union {
339    struct ethtool_tcpip4_spec tcp_ip4_spec;
340    struct ethtool_tcpip4_spec udp_ip4_spec;
341    struct ethtool_tcpip4_spec sctp_ip4_spec;
342    struct ethtool_ah_espip4_spec ah_ip4_spec;
343    struct ethtool_ah_espip4_spec esp_ip4_spec;
344    struct ethtool_usrip4_spec usr_ip4_spec;
345    struct ethhdr ether_spec;
346    __u8 hdata[72];
347  } h_u, m_u;
348  __u16 vlan_tag;
349  __u16 vlan_tag_mask;
350  __u64 data;
351  __u64 data_mask;
352  __s32 action;
353#define ETHTOOL_RXNTUPLE_ACTION_DROP (- 1)
354#define ETHTOOL_RXNTUPLE_ACTION_CLEAR (- 2)
355};
356struct ethtool_rx_ntuple {
357  __u32 cmd;
358  struct ethtool_rx_ntuple_flow_spec fs;
359};
360#define ETHTOOL_FLASH_MAX_FILENAME 128
361enum ethtool_flash_op_type {
362  ETHTOOL_FLASH_ALL_REGIONS = 0,
363};
364struct ethtool_flash {
365  __u32 cmd;
366  __u32 region;
367  char data[ETHTOOL_FLASH_MAX_FILENAME];
368};
369struct ethtool_dump {
370  __u32 cmd;
371  __u32 version;
372  __u32 flag;
373  __u32 len;
374  __u8 data[0];
375};
376#define ETH_FW_DUMP_DISABLE 0
377struct ethtool_get_features_block {
378  __u32 available;
379  __u32 requested;
380  __u32 active;
381  __u32 never_changed;
382};
383struct ethtool_gfeatures {
384  __u32 cmd;
385  __u32 size;
386  struct ethtool_get_features_block features[0];
387};
388struct ethtool_set_features_block {
389  __u32 valid;
390  __u32 requested;
391};
392struct ethtool_sfeatures {
393  __u32 cmd;
394  __u32 size;
395  struct ethtool_set_features_block features[0];
396};
397struct ethtool_ts_info {
398  __u32 cmd;
399  __u32 so_timestamping;
400  __s32 phc_index;
401  __u32 tx_types;
402  __u32 tx_reserved[3];
403  __u32 rx_filters;
404  __u32 rx_reserved[3];
405};
406enum ethtool_sfeatures_retval_bits {
407  ETHTOOL_F_UNSUPPORTED__BIT,
408  ETHTOOL_F_WISH__BIT,
409  ETHTOOL_F_COMPAT__BIT,
410};
411#define ETHTOOL_F_UNSUPPORTED (1 << ETHTOOL_F_UNSUPPORTED__BIT)
412#define ETHTOOL_F_WISH (1 << ETHTOOL_F_WISH__BIT)
413#define ETHTOOL_F_COMPAT (1 << ETHTOOL_F_COMPAT__BIT)
414#define MAX_NUM_QUEUE 4096
415struct ethtool_per_queue_op {
416  __u32 cmd;
417  __u32 sub_command;
418  __u32 queue_mask[__KERNEL_DIV_ROUND_UP(MAX_NUM_QUEUE, 32)];
419  char data[];
420};
421#define ETHTOOL_GSET 0x00000001
422#define ETHTOOL_SSET 0x00000002
423#define ETHTOOL_GDRVINFO 0x00000003
424#define ETHTOOL_GREGS 0x00000004
425#define ETHTOOL_GWOL 0x00000005
426#define ETHTOOL_SWOL 0x00000006
427#define ETHTOOL_GMSGLVL 0x00000007
428#define ETHTOOL_SMSGLVL 0x00000008
429#define ETHTOOL_NWAY_RST 0x00000009
430#define ETHTOOL_GLINK 0x0000000a
431#define ETHTOOL_GEEPROM 0x0000000b
432#define ETHTOOL_SEEPROM 0x0000000c
433#define ETHTOOL_GCOALESCE 0x0000000e
434#define ETHTOOL_SCOALESCE 0x0000000f
435#define ETHTOOL_GRINGPARAM 0x00000010
436#define ETHTOOL_SRINGPARAM 0x00000011
437#define ETHTOOL_GPAUSEPARAM 0x00000012
438#define ETHTOOL_SPAUSEPARAM 0x00000013
439#define ETHTOOL_GRXCSUM 0x00000014
440#define ETHTOOL_SRXCSUM 0x00000015
441#define ETHTOOL_GTXCSUM 0x00000016
442#define ETHTOOL_STXCSUM 0x00000017
443#define ETHTOOL_GSG 0x00000018
444#define ETHTOOL_SSG 0x00000019
445#define ETHTOOL_TEST 0x0000001a
446#define ETHTOOL_GSTRINGS 0x0000001b
447#define ETHTOOL_PHYS_ID 0x0000001c
448#define ETHTOOL_GSTATS 0x0000001d
449#define ETHTOOL_GTSO 0x0000001e
450#define ETHTOOL_STSO 0x0000001f
451#define ETHTOOL_GPERMADDR 0x00000020
452#define ETHTOOL_GUFO 0x00000021
453#define ETHTOOL_SUFO 0x00000022
454#define ETHTOOL_GGSO 0x00000023
455#define ETHTOOL_SGSO 0x00000024
456#define ETHTOOL_GFLAGS 0x00000025
457#define ETHTOOL_SFLAGS 0x00000026
458#define ETHTOOL_GPFLAGS 0x00000027
459#define ETHTOOL_SPFLAGS 0x00000028
460#define ETHTOOL_GRXFH 0x00000029
461#define ETHTOOL_SRXFH 0x0000002a
462#define ETHTOOL_GGRO 0x0000002b
463#define ETHTOOL_SGRO 0x0000002c
464#define ETHTOOL_GRXRINGS 0x0000002d
465#define ETHTOOL_GRXCLSRLCNT 0x0000002e
466#define ETHTOOL_GRXCLSRULE 0x0000002f
467#define ETHTOOL_GRXCLSRLALL 0x00000030
468#define ETHTOOL_SRXCLSRLDEL 0x00000031
469#define ETHTOOL_SRXCLSRLINS 0x00000032
470#define ETHTOOL_FLASHDEV 0x00000033
471#define ETHTOOL_RESET 0x00000034
472#define ETHTOOL_SRXNTUPLE 0x00000035
473#define ETHTOOL_GRXNTUPLE 0x00000036
474#define ETHTOOL_GSSET_INFO 0x00000037
475#define ETHTOOL_GRXFHINDIR 0x00000038
476#define ETHTOOL_SRXFHINDIR 0x00000039
477#define ETHTOOL_GFEATURES 0x0000003a
478#define ETHTOOL_SFEATURES 0x0000003b
479#define ETHTOOL_GCHANNELS 0x0000003c
480#define ETHTOOL_SCHANNELS 0x0000003d
481#define ETHTOOL_SET_DUMP 0x0000003e
482#define ETHTOOL_GET_DUMP_FLAG 0x0000003f
483#define ETHTOOL_GET_DUMP_DATA 0x00000040
484#define ETHTOOL_GET_TS_INFO 0x00000041
485#define ETHTOOL_GMODULEINFO 0x00000042
486#define ETHTOOL_GMODULEEEPROM 0x00000043
487#define ETHTOOL_GEEE 0x00000044
488#define ETHTOOL_SEEE 0x00000045
489#define ETHTOOL_GRSSH 0x00000046
490#define ETHTOOL_SRSSH 0x00000047
491#define ETHTOOL_GTUNABLE 0x00000048
492#define ETHTOOL_STUNABLE 0x00000049
493#define ETHTOOL_GPHYSTATS 0x0000004a
494#define ETHTOOL_PERQUEUE 0x0000004b
495#define ETHTOOL_GLINKSETTINGS 0x0000004c
496#define ETHTOOL_SLINKSETTINGS 0x0000004d
497#define ETHTOOL_PHY_GTUNABLE 0x0000004e
498#define ETHTOOL_PHY_STUNABLE 0x0000004f
499#define SPARC_ETH_GSET ETHTOOL_GSET
500#define SPARC_ETH_SSET ETHTOOL_SSET
501enum ethtool_link_mode_bit_indices {
502  ETHTOOL_LINK_MODE_10baseT_Half_BIT = 0,
503  ETHTOOL_LINK_MODE_10baseT_Full_BIT = 1,
504  ETHTOOL_LINK_MODE_100baseT_Half_BIT = 2,
505  ETHTOOL_LINK_MODE_100baseT_Full_BIT = 3,
506  ETHTOOL_LINK_MODE_1000baseT_Half_BIT = 4,
507  ETHTOOL_LINK_MODE_1000baseT_Full_BIT = 5,
508  ETHTOOL_LINK_MODE_Autoneg_BIT = 6,
509  ETHTOOL_LINK_MODE_TP_BIT = 7,
510  ETHTOOL_LINK_MODE_AUI_BIT = 8,
511  ETHTOOL_LINK_MODE_MII_BIT = 9,
512  ETHTOOL_LINK_MODE_FIBRE_BIT = 10,
513  ETHTOOL_LINK_MODE_BNC_BIT = 11,
514  ETHTOOL_LINK_MODE_10000baseT_Full_BIT = 12,
515  ETHTOOL_LINK_MODE_Pause_BIT = 13,
516  ETHTOOL_LINK_MODE_Asym_Pause_BIT = 14,
517  ETHTOOL_LINK_MODE_2500baseX_Full_BIT = 15,
518  ETHTOOL_LINK_MODE_Backplane_BIT = 16,
519  ETHTOOL_LINK_MODE_1000baseKX_Full_BIT = 17,
520  ETHTOOL_LINK_MODE_10000baseKX4_Full_BIT = 18,
521  ETHTOOL_LINK_MODE_10000baseKR_Full_BIT = 19,
522  ETHTOOL_LINK_MODE_10000baseR_FEC_BIT = 20,
523  ETHTOOL_LINK_MODE_20000baseMLD2_Full_BIT = 21,
524  ETHTOOL_LINK_MODE_20000baseKR2_Full_BIT = 22,
525  ETHTOOL_LINK_MODE_40000baseKR4_Full_BIT = 23,
526  ETHTOOL_LINK_MODE_40000baseCR4_Full_BIT = 24,
527  ETHTOOL_LINK_MODE_40000baseSR4_Full_BIT = 25,
528  ETHTOOL_LINK_MODE_40000baseLR4_Full_BIT = 26,
529  ETHTOOL_LINK_MODE_56000baseKR4_Full_BIT = 27,
530  ETHTOOL_LINK_MODE_56000baseCR4_Full_BIT = 28,
531  ETHTOOL_LINK_MODE_56000baseSR4_Full_BIT = 29,
532  ETHTOOL_LINK_MODE_56000baseLR4_Full_BIT = 30,
533  ETHTOOL_LINK_MODE_25000baseCR_Full_BIT = 31,
534  ETHTOOL_LINK_MODE_25000baseKR_Full_BIT = 32,
535  ETHTOOL_LINK_MODE_25000baseSR_Full_BIT = 33,
536  ETHTOOL_LINK_MODE_50000baseCR2_Full_BIT = 34,
537  ETHTOOL_LINK_MODE_50000baseKR2_Full_BIT = 35,
538  ETHTOOL_LINK_MODE_100000baseKR4_Full_BIT = 36,
539  ETHTOOL_LINK_MODE_100000baseSR4_Full_BIT = 37,
540  ETHTOOL_LINK_MODE_100000baseCR4_Full_BIT = 38,
541  ETHTOOL_LINK_MODE_100000baseLR4_ER4_Full_BIT = 39,
542  ETHTOOL_LINK_MODE_50000baseSR2_Full_BIT = 40,
543  ETHTOOL_LINK_MODE_1000baseX_Full_BIT = 41,
544  ETHTOOL_LINK_MODE_10000baseCR_Full_BIT = 42,
545  ETHTOOL_LINK_MODE_10000baseSR_Full_BIT = 43,
546  ETHTOOL_LINK_MODE_10000baseLR_Full_BIT = 44,
547  ETHTOOL_LINK_MODE_10000baseLRM_Full_BIT = 45,
548  ETHTOOL_LINK_MODE_10000baseER_Full_BIT = 46,
549  ETHTOOL_LINK_MODE_2500baseT_Full_BIT = 47,
550  ETHTOOL_LINK_MODE_5000baseT_Full_BIT = 48,
551  __ETHTOOL_LINK_MODE_LAST = ETHTOOL_LINK_MODE_5000baseT_Full_BIT,
552};
553#define __ETHTOOL_LINK_MODE_LEGACY_MASK(base_name) (1UL << (ETHTOOL_LINK_MODE_ ##base_name ##_BIT))
554#define SUPPORTED_10baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(10baseT_Half)
555#define SUPPORTED_10baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10baseT_Full)
556#define SUPPORTED_100baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(100baseT_Half)
557#define SUPPORTED_100baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(100baseT_Full)
558#define SUPPORTED_1000baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseT_Half)
559#define SUPPORTED_1000baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseT_Full)
560#define SUPPORTED_Autoneg __ETHTOOL_LINK_MODE_LEGACY_MASK(Autoneg)
561#define SUPPORTED_TP __ETHTOOL_LINK_MODE_LEGACY_MASK(TP)
562#define SUPPORTED_AUI __ETHTOOL_LINK_MODE_LEGACY_MASK(AUI)
563#define SUPPORTED_MII __ETHTOOL_LINK_MODE_LEGACY_MASK(MII)
564#define SUPPORTED_FIBRE __ETHTOOL_LINK_MODE_LEGACY_MASK(FIBRE)
565#define SUPPORTED_BNC __ETHTOOL_LINK_MODE_LEGACY_MASK(BNC)
566#define SUPPORTED_10000baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseT_Full)
567#define SUPPORTED_Pause __ETHTOOL_LINK_MODE_LEGACY_MASK(Pause)
568#define SUPPORTED_Asym_Pause __ETHTOOL_LINK_MODE_LEGACY_MASK(Asym_Pause)
569#define SUPPORTED_2500baseX_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(2500baseX_Full)
570#define SUPPORTED_Backplane __ETHTOOL_LINK_MODE_LEGACY_MASK(Backplane)
571#define SUPPORTED_1000baseKX_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseKX_Full)
572#define SUPPORTED_10000baseKX4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseKX4_Full)
573#define SUPPORTED_10000baseKR_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseKR_Full)
574#define SUPPORTED_10000baseR_FEC __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseR_FEC)
575#define SUPPORTED_20000baseMLD2_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(20000baseMLD2_Full)
576#define SUPPORTED_20000baseKR2_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(20000baseKR2_Full)
577#define SUPPORTED_40000baseKR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseKR4_Full)
578#define SUPPORTED_40000baseCR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseCR4_Full)
579#define SUPPORTED_40000baseSR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseSR4_Full)
580#define SUPPORTED_40000baseLR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseLR4_Full)
581#define SUPPORTED_56000baseKR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseKR4_Full)
582#define SUPPORTED_56000baseCR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseCR4_Full)
583#define SUPPORTED_56000baseSR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseSR4_Full)
584#define SUPPORTED_56000baseLR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseLR4_Full)
585#define ADVERTISED_10baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(10baseT_Half)
586#define ADVERTISED_10baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10baseT_Full)
587#define ADVERTISED_100baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(100baseT_Half)
588#define ADVERTISED_100baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(100baseT_Full)
589#define ADVERTISED_1000baseT_Half __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseT_Half)
590#define ADVERTISED_1000baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseT_Full)
591#define ADVERTISED_Autoneg __ETHTOOL_LINK_MODE_LEGACY_MASK(Autoneg)
592#define ADVERTISED_TP __ETHTOOL_LINK_MODE_LEGACY_MASK(TP)
593#define ADVERTISED_AUI __ETHTOOL_LINK_MODE_LEGACY_MASK(AUI)
594#define ADVERTISED_MII __ETHTOOL_LINK_MODE_LEGACY_MASK(MII)
595#define ADVERTISED_FIBRE __ETHTOOL_LINK_MODE_LEGACY_MASK(FIBRE)
596#define ADVERTISED_BNC __ETHTOOL_LINK_MODE_LEGACY_MASK(BNC)
597#define ADVERTISED_10000baseT_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseT_Full)
598#define ADVERTISED_Pause __ETHTOOL_LINK_MODE_LEGACY_MASK(Pause)
599#define ADVERTISED_Asym_Pause __ETHTOOL_LINK_MODE_LEGACY_MASK(Asym_Pause)
600#define ADVERTISED_2500baseX_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(2500baseX_Full)
601#define ADVERTISED_Backplane __ETHTOOL_LINK_MODE_LEGACY_MASK(Backplane)
602#define ADVERTISED_1000baseKX_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(1000baseKX_Full)
603#define ADVERTISED_10000baseKX4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseKX4_Full)
604#define ADVERTISED_10000baseKR_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseKR_Full)
605#define ADVERTISED_10000baseR_FEC __ETHTOOL_LINK_MODE_LEGACY_MASK(10000baseR_FEC)
606#define ADVERTISED_20000baseMLD2_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(20000baseMLD2_Full)
607#define ADVERTISED_20000baseKR2_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(20000baseKR2_Full)
608#define ADVERTISED_40000baseKR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseKR4_Full)
609#define ADVERTISED_40000baseCR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseCR4_Full)
610#define ADVERTISED_40000baseSR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseSR4_Full)
611#define ADVERTISED_40000baseLR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(40000baseLR4_Full)
612#define ADVERTISED_56000baseKR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseKR4_Full)
613#define ADVERTISED_56000baseCR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseCR4_Full)
614#define ADVERTISED_56000baseSR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseSR4_Full)
615#define ADVERTISED_56000baseLR4_Full __ETHTOOL_LINK_MODE_LEGACY_MASK(56000baseLR4_Full)
616#define SPEED_10 10
617#define SPEED_100 100
618#define SPEED_1000 1000
619#define SPEED_2500 2500
620#define SPEED_5000 5000
621#define SPEED_10000 10000
622#define SPEED_20000 20000
623#define SPEED_25000 25000
624#define SPEED_40000 40000
625#define SPEED_50000 50000
626#define SPEED_56000 56000
627#define SPEED_100000 100000
628#define SPEED_UNKNOWN - 1
629#define DUPLEX_HALF 0x00
630#define DUPLEX_FULL 0x01
631#define DUPLEX_UNKNOWN 0xff
632#define PORT_TP 0x00
633#define PORT_AUI 0x01
634#define PORT_MII 0x02
635#define PORT_FIBRE 0x03
636#define PORT_BNC 0x04
637#define PORT_DA 0x05
638#define PORT_NONE 0xef
639#define PORT_OTHER 0xff
640#define XCVR_INTERNAL 0x00
641#define XCVR_EXTERNAL 0x01
642#define XCVR_DUMMY1 0x02
643#define XCVR_DUMMY2 0x03
644#define XCVR_DUMMY3 0x04
645#define AUTONEG_DISABLE 0x00
646#define AUTONEG_ENABLE 0x01
647#define ETH_TP_MDI_INVALID 0x00
648#define ETH_TP_MDI 0x01
649#define ETH_TP_MDI_X 0x02
650#define ETH_TP_MDI_AUTO 0x03
651#define WAKE_PHY (1 << 0)
652#define WAKE_UCAST (1 << 1)
653#define WAKE_MCAST (1 << 2)
654#define WAKE_BCAST (1 << 3)
655#define WAKE_ARP (1 << 4)
656#define WAKE_MAGIC (1 << 5)
657#define WAKE_MAGICSECURE (1 << 6)
658#define TCP_V4_FLOW 0x01
659#define UDP_V4_FLOW 0x02
660#define SCTP_V4_FLOW 0x03
661#define AH_ESP_V4_FLOW 0x04
662#define TCP_V6_FLOW 0x05
663#define UDP_V6_FLOW 0x06
664#define SCTP_V6_FLOW 0x07
665#define AH_ESP_V6_FLOW 0x08
666#define AH_V4_FLOW 0x09
667#define ESP_V4_FLOW 0x0a
668#define AH_V6_FLOW 0x0b
669#define ESP_V6_FLOW 0x0c
670#define IPV4_USER_FLOW 0x0d
671#define IP_USER_FLOW IPV4_USER_FLOW
672#define IPV6_USER_FLOW 0x0e
673#define IPV4_FLOW 0x10
674#define IPV6_FLOW 0x11
675#define ETHER_FLOW 0x12
676#define FLOW_EXT 0x80000000
677#define FLOW_MAC_EXT 0x40000000
678#define RXH_L2DA (1 << 1)
679#define RXH_VLAN (1 << 2)
680#define RXH_L3_PROTO (1 << 3)
681#define RXH_IP_SRC (1 << 4)
682#define RXH_IP_DST (1 << 5)
683#define RXH_L4_B_0_1 (1 << 6)
684#define RXH_L4_B_2_3 (1 << 7)
685#define RXH_DISCARD (1 << 31)
686#define RX_CLS_FLOW_DISC 0xffffffffffffffffULL
687#define RX_CLS_LOC_SPECIAL 0x80000000
688#define RX_CLS_LOC_ANY 0xffffffff
689#define RX_CLS_LOC_FIRST 0xfffffffe
690#define RX_CLS_LOC_LAST 0xfffffffd
691#define ETH_MODULE_SFF_8079 0x1
692#define ETH_MODULE_SFF_8079_LEN 256
693#define ETH_MODULE_SFF_8472 0x2
694#define ETH_MODULE_SFF_8472_LEN 512
695#define ETH_MODULE_SFF_8636 0x3
696#define ETH_MODULE_SFF_8636_LEN 256
697#define ETH_MODULE_SFF_8436 0x4
698#define ETH_MODULE_SFF_8436_LEN 256
699enum ethtool_reset_flags {
700  ETH_RESET_MGMT = 1 << 0,
701  ETH_RESET_IRQ = 1 << 1,
702  ETH_RESET_DMA = 1 << 2,
703  ETH_RESET_FILTER = 1 << 3,
704  ETH_RESET_OFFLOAD = 1 << 4,
705  ETH_RESET_MAC = 1 << 5,
706  ETH_RESET_PHY = 1 << 6,
707  ETH_RESET_RAM = 1 << 7,
708  ETH_RESET_DEDICATED = 0x0000ffff,
709  ETH_RESET_ALL = 0xffffffff,
710};
711#define ETH_RESET_SHARED_SHIFT 16
712struct ethtool_link_settings {
713  __u32 cmd;
714  __u32 speed;
715  __u8 duplex;
716  __u8 port;
717  __u8 phy_address;
718  __u8 autoneg;
719  __u8 mdio_support;
720  __u8 eth_tp_mdix;
721  __u8 eth_tp_mdix_ctrl;
722  __s8 link_mode_masks_nwords;
723  __u32 reserved[8];
724  __u32 link_mode_masks[0];
725};
726#endif
727