miidevs.h revision 1.35 1 1.1 thorpej /* $NetBSD: miidevs.h,v 1.35 2002/03/14 04:41:09 chs Exp $ */
2 1.1 thorpej
3 1.1 thorpej /*
4 1.1 thorpej * THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.
5 1.1 thorpej *
6 1.1 thorpej * generated from:
7 1.35 chs * NetBSD: miidevs,v 1.35 2002/03/14 04:40:27 chs Exp
8 1.1 thorpej */
9 1.1 thorpej
10 1.1 thorpej /*-
11 1.5 thorpej * Copyright (c) 1998, 1999 The NetBSD Foundation, Inc.
12 1.1 thorpej * All rights reserved.
13 1.1 thorpej *
14 1.1 thorpej * This code is derived from software contributed to The NetBSD Foundation
15 1.1 thorpej * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
16 1.1 thorpej * NASA Ames Research Center.
17 1.1 thorpej *
18 1.1 thorpej * Redistribution and use in source and binary forms, with or without
19 1.1 thorpej * modification, are permitted provided that the following conditions
20 1.1 thorpej * are met:
21 1.1 thorpej * 1. Redistributions of source code must retain the above copyright
22 1.1 thorpej * notice, this list of conditions and the following disclaimer.
23 1.1 thorpej * 2. Redistributions in binary form must reproduce the above copyright
24 1.1 thorpej * notice, this list of conditions and the following disclaimer in the
25 1.1 thorpej * documentation and/or other materials provided with the distribution.
26 1.1 thorpej * 3. All advertising materials mentioning features or use of this software
27 1.1 thorpej * must display the following acknowledgement:
28 1.1 thorpej * This product includes software developed by the NetBSD
29 1.1 thorpej * Foundation, Inc. and its contributors.
30 1.1 thorpej * 4. Neither the name of The NetBSD Foundation nor the names of its
31 1.1 thorpej * contributors may be used to endorse or promote products derived
32 1.1 thorpej * from this software without specific prior written permission.
33 1.1 thorpej *
34 1.1 thorpej * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
35 1.1 thorpej * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
36 1.1 thorpej * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
37 1.1 thorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
38 1.1 thorpej * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
39 1.1 thorpej * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
40 1.1 thorpej * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
41 1.1 thorpej * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
42 1.1 thorpej * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
43 1.1 thorpej * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
44 1.1 thorpej * POSSIBILITY OF SUCH DAMAGE.
45 1.1 thorpej */
46 1.1 thorpej
47 1.1 thorpej /*
48 1.6 drochner * List of known MII OUIs.
49 1.6 drochner * For a complete list see http://standards.ieee.org/regauth/oui/
50 1.6 drochner *
51 1.15 drochner * XXX Vendors do obviously not agree how OUIs (24 bit) are mapped
52 1.15 drochner * to the 22 bits available in the id registers.
53 1.15 drochner * IEEE 802.3u-1995, subclause 22.2.4.3.1, figure 22-12, depicts the right
54 1.15 drochner * mapping; the bit positions are defined in IEEE 802-1990, figure 5.2.
55 1.15 drochner * (There is a formal 802.3 interpretation, number 1-07/98 of July 09 1998,
56 1.15 drochner * about this.)
57 1.15 drochner * The MII_OUI() macro in "mii.h" reflects this.
58 1.15 drochner * If a vendor uses a different mapping, an "xx" prefixed OUI is defined here
59 1.15 drochner * which is mangled accordingly to compensate.
60 1.1 thorpej */
61 1.1 thorpej
62 1.14 augustss #define MII_OUI_ALTIMA 0x0010a9 /* Altima Communications */
63 1.6 drochner #define MII_OUI_AMD 0x00001a /* Advanced Micro Devices */
64 1.12 augustss #define MII_OUI_BROADCOM 0x001018 /* Broadcom Corporation */
65 1.14 augustss #define MII_OUI_DAVICOM 0x00606e /* Davicom Semiconductor */
66 1.9 thorpej #define MII_OUI_ENABLESEMI 0x0010dd /* Enable Semiconductor */
67 1.6 drochner #define MII_OUI_ICS 0x00a0be /* Integrated Circuit Systems */
68 1.1 thorpej #define MII_OUI_INTEL 0x00aa00 /* Intel */
69 1.6 drochner #define MII_OUI_LEVEL1 0x00207b /* Level 1 */
70 1.26 thorpej #define MII_OUI_MARVELL 0x005043 /* Marvell Semiconductor */
71 1.12 augustss #define MII_OUI_MYSON 0x00c0b4 /* Myson Technology */
72 1.1 thorpej #define MII_OUI_NATSEMI 0x080017 /* National Semiconductor */
73 1.19 drochner #define MII_OUI_PMCSIERRA 0x00e004 /* PMC-Sierra */
74 1.1 thorpej #define MII_OUI_QUALSEMI 0x006051 /* Quality Semiconductor */
75 1.6 drochner #define MII_OUI_SEEQ 0x00a07d /* Seeq */
76 1.6 drochner #define MII_OUI_SIS 0x00e006 /* Silicon Integrated Systems */
77 1.6 drochner #define MII_OUI_TI 0x080028 /* Texas Instruments */
78 1.7 soren #define MII_OUI_TSC 0x00c039 /* TDK Semiconductor */
79 1.12 augustss #define MII_OUI_XAQTI 0x00e0ae /* XaQti Corp. */
80 1.6 drochner
81 1.15 drochner /* in the 79c873, AMD uses another OUI (which matches reversed Davicom!) */
82 1.15 drochner #define MII_OUI_xxAMD 0x000676 /* Advanced Micro Devices */
83 1.6 drochner
84 1.7 soren /* Some Intel 82553's use an alternative OUI. */
85 1.15 drochner #define MII_OUI_xxINTEL 0x001f00 /* Intel */
86 1.7 soren
87 1.15 drochner /* bad bitorder (bits "g" and "h" (= MSBs byte 1) lost) */
88 1.15 drochner #define MII_OUI_yyAMD 0x000058 /* Advanced Micro Devices */
89 1.12 augustss #define MII_OUI_xxBROADCOM 0x000818 /* Broadcom Corporation */
90 1.15 drochner #define MII_OUI_yyINTEL 0x005500 /* Intel */
91 1.15 drochner #define MII_OUI_xxMYSON 0x00032d /* Myson Technology */
92 1.15 drochner #define MII_OUI_xxNATSEMI 0x1000e8 /* National Semiconductor */
93 1.15 drochner #define MII_OUI_xxQUALSEMI 0x00068a /* Quality Semiconductor */
94 1.15 drochner #define MII_OUI_xxTSC 0x00039c /* TDK Semiconductor */
95 1.15 drochner
96 1.15 drochner /* bad byteorder (bits "q" and "r" (= LSBs byte 3) lost) */
97 1.15 drochner #define MII_OUI_xxLEVEL1 0x782000 /* Level 1 */
98 1.15 drochner #define MII_OUI_xxXAQTI 0xace000 /* XaQti Corp. */
99 1.6 drochner
100 1.6 drochner /* Don't know what's going on here. */
101 1.15 drochner #define MII_OUI_xxDAVICOM 0x000602 /* Davicom Semiconductor */
102 1.19 drochner #define MII_OUI_xxPMCSIERRA 0x0009c0 /* PMC-Sierra */
103 1.6 drochner
104 1.26 thorpej #define MII_OUI_xxMARVELL 0x000ac2 /* Marvell Semiconductor */
105 1.1 thorpej
106 1.1 thorpej /*
107 1.1 thorpej * List of known models. Grouped by oui.
108 1.1 thorpej */
109 1.14 augustss
110 1.14 augustss /* Altima Communications PHYs */
111 1.32 augustss /* Don't know the model for ACXXX */
112 1.32 augustss #define MII_MODEL_ALTIMA_ACXXX 0x0001
113 1.32 augustss #define MII_STR_ALTIMA_ACXXX "ACXXX 10/100 media interface"
114 1.15 drochner #define MII_MODEL_ALTIMA_AC101 0x0021
115 1.15 drochner #define MII_STR_ALTIMA_AC101 "AC101 10/100 media interface"
116 1.3 thorpej
117 1.3 thorpej /* Advanced Micro Devices PHYs */
118 1.6 drochner #define MII_MODEL_xxAMD_79C873 0x0000
119 1.6 drochner #define MII_STR_xxAMD_79C873 "Am79C873 10/100 media interface"
120 1.28 thorpej #define MII_MODEL_yyAMD_79C972_10T 0x0001
121 1.28 thorpej #define MII_STR_yyAMD_79C972_10T "Am79C972 internal 10BASE-T interface"
122 1.15 drochner #define MII_MODEL_yyAMD_79c973phy 0x0036
123 1.29 thorpej #define MII_STR_yyAMD_79c973phy "Am79C973 internal 10/100 media interface"
124 1.15 drochner #define MII_MODEL_yyAMD_79c901 0x0037
125 1.29 thorpej #define MII_STR_yyAMD_79c901 "Am79C901 10BASE-T interface"
126 1.15 drochner #define MII_MODEL_yyAMD_79c901home 0x0039
127 1.29 thorpej #define MII_STR_yyAMD_79c901home "Am79C901 HomePNA 1.0 interface"
128 1.10 augustss
129 1.12 augustss /* Broadcom Corp. PHYs */
130 1.27 thorpej #define MII_MODEL_xxBROADCOM_3C905B 0x0012
131 1.27 thorpej #define MII_STR_xxBROADCOM_3C905B "Broadcom 3c905B internal PHY"
132 1.15 drochner #define MII_MODEL_xxBROADCOM_3C905C 0x0017
133 1.27 thorpej #define MII_STR_xxBROADCOM_3C905C "Broadcom 3c905C internal PHY"
134 1.15 drochner #define MII_MODEL_xxBROADCOM_BCM5201 0x0021
135 1.15 drochner #define MII_STR_xxBROADCOM_BCM5201 "BCM5201 10/100 media interface"
136 1.27 thorpej #define MII_MODEL_xxBROADCOM_BCM5221 0x001e
137 1.27 thorpej #define MII_STR_xxBROADCOM_BCM5221 "BCM5221 10/100 media interface"
138 1.15 drochner #define MII_MODEL_BROADCOM_BCM5400 0x0004
139 1.25 thorpej #define MII_STR_BROADCOM_BCM5400 "BCM5400 1000BASE-T media interface"
140 1.22 thorpej #define MII_MODEL_BROADCOM_BCM5401 0x0005
141 1.25 thorpej #define MII_STR_BROADCOM_BCM5401 "BCM5401 1000BASE-T media interface"
142 1.22 thorpej #define MII_MODEL_BROADCOM_BCM5411 0x0007
143 1.25 thorpej #define MII_STR_BROADCOM_BCM5411 "BCM5411 1000BASE-T media interface"
144 1.4 thorpej
145 1.4 thorpej /* Davicom Semiconductor PHYs */
146 1.6 drochner #define MII_MODEL_xxDAVICOM_DM9101 0x0000
147 1.6 drochner #define MII_STR_xxDAVICOM_DM9101 "DM9101 10/100 media interface"
148 1.1 thorpej
149 1.1 thorpej /* Integrated Circuit Systems PHYs */
150 1.15 drochner #define MII_MODEL_ICS_1890 0x0002
151 1.15 drochner #define MII_STR_ICS_1890 "ICS1890 10/100 media interface"
152 1.34 wiz #define MII_MODEL_ICS_1893 0x0004
153 1.34 wiz #define MII_STR_ICS_1893 "ICS1893 10/100 media interface"
154 1.1 thorpej
155 1.1 thorpej /* Intel PHYs */
156 1.7 soren #define MII_MODEL_xxINTEL_I82553 0x0000
157 1.7 soren #define MII_STR_xxINTEL_I82553 "i82553 10/100 media interface"
158 1.15 drochner #define MII_MODEL_yyINTEL_I82555 0x0015
159 1.15 drochner #define MII_STR_yyINTEL_I82555 "i82555 10/100 media interface"
160 1.16 drochner #define MII_MODEL_yyINTEL_I82562EH 0x0017
161 1.16 drochner #define MII_STR_yyINTEL_I82562EH "i82562EH HomePNA interface"
162 1.16 drochner #define MII_MODEL_yyINTEL_I82562EM 0x0032
163 1.16 drochner #define MII_STR_yyINTEL_I82562EM "i82562EM 10/100 media interface"
164 1.20 soren #define MII_MODEL_yyINTEL_I82562ET 0x0033
165 1.20 soren #define MII_STR_yyINTEL_I82562ET "i82562ET 10/100 media interface"
166 1.15 drochner #define MII_MODEL_yyINTEL_I82553 0x0035
167 1.15 drochner #define MII_STR_yyINTEL_I82553 "i82553 10/100 media interface"
168 1.1 thorpej
169 1.1 thorpej /* Level 1 PHYs */
170 1.6 drochner #define MII_MODEL_xxLEVEL1_LXT970 0x0000
171 1.6 drochner #define MII_STR_xxLEVEL1_LXT970 "LXT970 10/100 media interface"
172 1.35 chs #define MII_MODEL_LEVEL1_LXT971 0x000e
173 1.35 chs #define MII_STR_LEVEL1_LXT971 "LXT971 10/100 media interface"
174 1.25 thorpej #define MII_MODEL_LEVEL1_LXT1000_OLD 0x0003
175 1.25 thorpej #define MII_STR_LEVEL1_LXT1000_OLD "LXT1000 1000BASE-T media interface"
176 1.25 thorpej #define MII_MODEL_LEVEL1_LXT1000 0x000c
177 1.25 thorpej #define MII_STR_LEVEL1_LXT1000 "LXT1000 1000BASE-T media interface"
178 1.1 thorpej
179 1.22 thorpej /* Marvell Semiconductor PHYs */
180 1.33 thorpej #define MII_MODEL_xxMARVELL_E1000_3 0x0003
181 1.33 thorpej #define MII_STR_xxMARVELL_E1000_3 "Marvell 88E1000 Gigabit PHY"
182 1.33 thorpej #define MII_MODEL_xxMARVELL_E1000_5 0x0005
183 1.33 thorpej #define MII_STR_xxMARVELL_E1000_5 "Marvell 88E1000 Gigabit PHY"
184 1.22 thorpej
185 1.12 augustss /* Myson Technology PHYs */
186 1.15 drochner #define MII_MODEL_xxMYSON_MTD972 0x0000
187 1.15 drochner #define MII_STR_xxMYSON_MTD972 "MTD972 10/100 media interface"
188 1.12 augustss
189 1.1 thorpej /* National Semiconductor PHYs */
190 1.15 drochner #define MII_MODEL_xxNATSEMI_DP83840 0x0000
191 1.15 drochner #define MII_STR_xxNATSEMI_DP83840 "DP83840 10/100 media interface"
192 1.15 drochner #define MII_MODEL_xxNATSEMI_DP83843 0x0001
193 1.15 drochner #define MII_STR_xxNATSEMI_DP83843 "DP83843 10/100 media interface"
194 1.22 thorpej #define MII_MODEL_xxNATSEMI_DP83815 0x0002
195 1.22 thorpej #define MII_STR_xxNATSEMI_DP83815 "DP83815 10/100 media interface"
196 1.21 thorpej #define MII_MODEL_xxNATSEMI_DP83891 0x0005
197 1.25 thorpej #define MII_STR_xxNATSEMI_DP83891 "DP83891 1000BASE-T media interface"
198 1.17 thorpej #define MII_MODEL_xxNATSEMI_DP83861 0x0006
199 1.25 thorpej #define MII_STR_xxNATSEMI_DP83861 "DP83861 1000BASE-T media interface"
200 1.18 matt
201 1.19 drochner /* PMC Sierra PHYs */
202 1.19 drochner #define MII_MODEL_xxPMCSIERRA_PM8351 0x0000
203 1.19 drochner #define MII_STR_xxPMCSIERRA_PM8351 "PM8351 OctalPHY Gigabit interface"
204 1.1 thorpej
205 1.1 thorpej /* Quality Semiconductor PHYs */
206 1.15 drochner #define MII_MODEL_xxQUALSEMI_QS6612 0x0000
207 1.15 drochner #define MII_STR_xxQUALSEMI_QS6612 "QS6612 10/100 media interface"
208 1.1 thorpej
209 1.1 thorpej /* Seeq PHYs */
210 1.15 drochner #define MII_MODEL_SEEQ_80220 0x0003
211 1.15 drochner #define MII_STR_SEEQ_80220 "Seeq 80220 10/100 media interface"
212 1.15 drochner #define MII_MODEL_SEEQ_84220 0x0004
213 1.15 drochner #define MII_STR_SEEQ_84220 "Seeq 84220 10/100 media interface"
214 1.23 thorpej #define MII_MODEL_SEEQ_80225 0x0008
215 1.23 thorpej #define MII_STR_SEEQ_80225 "Seeq 80225 10/100 media interface"
216 1.5 thorpej
217 1.5 thorpej /* Silicon Integrated Systems PHYs */
218 1.15 drochner #define MII_MODEL_SIS_900 0x0000
219 1.15 drochner #define MII_STR_SIS_900 "SiS 900 10/100 media interface"
220 1.1 thorpej
221 1.1 thorpej /* Texas Instruments PHYs */
222 1.15 drochner #define MII_MODEL_TI_TLAN10T 0x0001
223 1.25 thorpej #define MII_STR_TI_TLAN10T "ThunderLAN 10BASE-T media interface"
224 1.15 drochner #define MII_MODEL_TI_100VGPMI 0x0002
225 1.15 drochner #define MII_STR_TI_100VGPMI "ThunderLAN 100VG-AnyLan media interface"
226 1.15 drochner #define MII_MODEL_TI_TNETE2101 0x0003
227 1.15 drochner #define MII_STR_TI_TNETE2101 "TNETE2101 media interface"
228 1.7 soren
229 1.7 soren /* TDK Semiconductor PHYs */
230 1.15 drochner #define MII_MODEL_xxTSC_78Q2120 0x0014
231 1.15 drochner #define MII_STR_xxTSC_78Q2120 "78Q2120 10/100 media interface"
232 1.15 drochner #define MII_MODEL_xxTSC_78Q2121 0x0015
233 1.25 thorpej #define MII_STR_xxTSC_78Q2121 "78Q2121 100BASE-TX media interface"
234 1.12 augustss
235 1.12 augustss /* XaQti Corp. PHYs */
236 1.15 drochner #define MII_MODEL_xxXAQTI_XMACII 0x0000
237 1.15 drochner #define MII_STR_xxXAQTI_XMACII "XaQti Corp. XMAC II gigabit interface"
238