blob: c3a63e15d5f9ad5d6c720554bacd735abab9a044 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
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_MII_H__
20#define _UAPI__LINUX_MII_H__
21#include <linux/types.h>
22#include <linux/ethtool.h>
23/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
24#define MII_BMCR 0x00
25#define MII_BMSR 0x01
26#define MII_PHYSID1 0x02
27#define MII_PHYSID2 0x03
28/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
29#define MII_ADVERTISE 0x04
30#define MII_LPA 0x05
31#define MII_EXPANSION 0x06
32#define MII_CTRL1000 0x09
33/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
34#define MII_STAT1000 0x0a
35#define MII_MMD_CTRL 0x0d
36#define MII_MMD_DATA 0x0e
37#define MII_ESTATUS 0x0f
38/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
39#define MII_DCOUNTER 0x12
40#define MII_FCSCOUNTER 0x13
41#define MII_NWAYTEST 0x14
42#define MII_RERRCOUNTER 0x15
43/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
44#define MII_SREVISION 0x16
45#define MII_RESV1 0x17
46#define MII_LBRERROR 0x18
47#define MII_PHYADDR 0x19
48/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
49#define MII_RESV2 0x1a
50#define MII_TPISTATUS 0x1b
51#define MII_NCONFIG 0x1c
52#define BMCR_RESV 0x003f
53/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
54#define BMCR_SPEED1000 0x0040
55#define BMCR_CTST 0x0080
56#define BMCR_FULLDPLX 0x0100
57#define BMCR_ANRESTART 0x0200
58/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
59#define BMCR_ISOLATE 0x0400
60#define BMCR_PDOWN 0x0800
61#define BMCR_ANENABLE 0x1000
62#define BMCR_SPEED100 0x2000
63/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
64#define BMCR_LOOPBACK 0x4000
65#define BMCR_RESET 0x8000
Christopher Ferris6a9755d2017-01-13 14:09:31 -080066#define BMCR_SPEED10 0x0000
Ben Cheng655a7c02013-10-16 16:09:24 -070067#define BMSR_ERCAP 0x0001
Ben Cheng655a7c02013-10-16 16:09:24 -070068/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080069#define BMSR_JCD 0x0002
Ben Cheng655a7c02013-10-16 16:09:24 -070070#define BMSR_LSTATUS 0x0004
71#define BMSR_ANEGCAPABLE 0x0008
72#define BMSR_RFAULT 0x0010
Ben Cheng655a7c02013-10-16 16:09:24 -070073/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080074#define BMSR_ANEGCOMPLETE 0x0020
Ben Cheng655a7c02013-10-16 16:09:24 -070075#define BMSR_RESV 0x00c0
76#define BMSR_ESTATEN 0x0100
77#define BMSR_100HALF2 0x0200
Ben Cheng655a7c02013-10-16 16:09:24 -070078/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080079#define BMSR_100FULL2 0x0400
Ben Cheng655a7c02013-10-16 16:09:24 -070080#define BMSR_10HALF 0x0800
81#define BMSR_10FULL 0x1000
82#define BMSR_100HALF 0x2000
Ben Cheng655a7c02013-10-16 16:09:24 -070083/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080084#define BMSR_100FULL 0x4000
Ben Cheng655a7c02013-10-16 16:09:24 -070085#define BMSR_100BASE4 0x8000
86#define ADVERTISE_SLCT 0x001f
87#define ADVERTISE_CSMA 0x0001
Ben Cheng655a7c02013-10-16 16:09:24 -070088/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080089#define ADVERTISE_10HALF 0x0020
Ben Cheng655a7c02013-10-16 16:09:24 -070090#define ADVERTISE_1000XFULL 0x0020
91#define ADVERTISE_10FULL 0x0040
92#define ADVERTISE_1000XHALF 0x0040
Ben Cheng655a7c02013-10-16 16:09:24 -070093/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080094#define ADVERTISE_100HALF 0x0080
Ben Cheng655a7c02013-10-16 16:09:24 -070095#define ADVERTISE_1000XPAUSE 0x0080
96#define ADVERTISE_100FULL 0x0100
97#define ADVERTISE_1000XPSE_ASYM 0x0100
Ben Cheng655a7c02013-10-16 16:09:24 -070098/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -080099#define ADVERTISE_100BASE4 0x0200
Ben Cheng655a7c02013-10-16 16:09:24 -0700100#define ADVERTISE_PAUSE_CAP 0x0400
101#define ADVERTISE_PAUSE_ASYM 0x0800
102#define ADVERTISE_RESV 0x1000
Ben Cheng655a7c02013-10-16 16:09:24 -0700103/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800104#define ADVERTISE_RFAULT 0x2000
Ben Cheng655a7c02013-10-16 16:09:24 -0700105#define ADVERTISE_LPACK 0x4000
106#define ADVERTISE_NPAGE 0x8000
Tao Baod7db5942015-01-28 10:07:51 -0800107#define ADVERTISE_FULL (ADVERTISE_100FULL | ADVERTISE_10FULL | ADVERTISE_CSMA)
Ben Cheng655a7c02013-10-16 16:09:24 -0700108/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800109#define ADVERTISE_ALL (ADVERTISE_10HALF | ADVERTISE_10FULL | ADVERTISE_100HALF | ADVERTISE_100FULL)
Ben Cheng655a7c02013-10-16 16:09:24 -0700110#define LPA_SLCT 0x001f
111#define LPA_10HALF 0x0020
112#define LPA_1000XFULL 0x0020
Ben Cheng655a7c02013-10-16 16:09:24 -0700113/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800114#define LPA_10FULL 0x0040
Ben Cheng655a7c02013-10-16 16:09:24 -0700115#define LPA_1000XHALF 0x0040
116#define LPA_100HALF 0x0080
117#define LPA_1000XPAUSE 0x0080
Ben Cheng655a7c02013-10-16 16:09:24 -0700118/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800119#define LPA_100FULL 0x0100
Ben Cheng655a7c02013-10-16 16:09:24 -0700120#define LPA_1000XPAUSE_ASYM 0x0100
121#define LPA_100BASE4 0x0200
122#define LPA_PAUSE_CAP 0x0400
Ben Cheng655a7c02013-10-16 16:09:24 -0700123/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800124#define LPA_PAUSE_ASYM 0x0800
Ben Cheng655a7c02013-10-16 16:09:24 -0700125#define LPA_RESV 0x1000
126#define LPA_RFAULT 0x2000
127#define LPA_LPACK 0x4000
Ben Cheng655a7c02013-10-16 16:09:24 -0700128/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800129#define LPA_NPAGE 0x8000
Ben Cheng655a7c02013-10-16 16:09:24 -0700130#define LPA_DUPLEX (LPA_10FULL | LPA_100FULL)
131#define LPA_100 (LPA_100FULL | LPA_100HALF | LPA_100BASE4)
132#define EXPANSION_NWAY 0x0001
Ben Cheng655a7c02013-10-16 16:09:24 -0700133/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800134#define EXPANSION_LCWP 0x0002
Ben Cheng655a7c02013-10-16 16:09:24 -0700135#define EXPANSION_ENABLENPAGE 0x0004
136#define EXPANSION_NPCAPABLE 0x0008
137#define EXPANSION_MFAULTS 0x0010
Ben Cheng655a7c02013-10-16 16:09:24 -0700138/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800139#define EXPANSION_RESV 0xffe0
Ben Cheng655a7c02013-10-16 16:09:24 -0700140#define ESTATUS_1000_TFULL 0x2000
141#define ESTATUS_1000_THALF 0x1000
142#define NWAYTEST_RESV1 0x00ff
Ben Cheng655a7c02013-10-16 16:09:24 -0700143/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800144#define NWAYTEST_LOOPBACK 0x0100
Ben Cheng655a7c02013-10-16 16:09:24 -0700145#define NWAYTEST_RESV2 0xfe00
146#define ADVERTISE_1000FULL 0x0200
147#define ADVERTISE_1000HALF 0x0100
Ben Cheng655a7c02013-10-16 16:09:24 -0700148/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800149#define CTL1000_AS_MASTER 0x0800
Ben Cheng655a7c02013-10-16 16:09:24 -0700150#define CTL1000_ENABLE_MASTER 0x1000
151#define LPA_1000LOCALRXOK 0x2000
152#define LPA_1000REMRXOK 0x1000
Ben Cheng655a7c02013-10-16 16:09:24 -0700153/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800154#define LPA_1000FULL 0x0800
Ben Cheng655a7c02013-10-16 16:09:24 -0700155#define LPA_1000HALF 0x0400
156#define FLOW_CTRL_TX 0x01
157#define FLOW_CTRL_RX 0x02
Ben Cheng655a7c02013-10-16 16:09:24 -0700158/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800159#define MII_MMD_CTRL_DEVAD_MASK 0x1f
Ben Cheng655a7c02013-10-16 16:09:24 -0700160#define MII_MMD_CTRL_ADDR 0x0000
161#define MII_MMD_CTRL_NOINCR 0x4000
162#define MII_MMD_CTRL_INCR_RDWT 0x8000
Ben Cheng655a7c02013-10-16 16:09:24 -0700163/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800164#define MII_MMD_CTRL_INCR_ON_WT 0xC000
Ben Cheng655a7c02013-10-16 16:09:24 -0700165struct mii_ioctl_data {
Tao Baod7db5942015-01-28 10:07:51 -0800166 __u16 phy_id;
167 __u16 reg_num;
Ben Cheng655a7c02013-10-16 16:09:24 -0700168/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800169 __u16 val_in;
Tao Baod7db5942015-01-28 10:07:51 -0800170 __u16 val_out;
Ben Cheng655a7c02013-10-16 16:09:24 -0700171};
172#endif
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800173/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */