Home | History | Annotate | Line # | Download | only in mii
miidevs.h revision 1.155
      1 /*	$NetBSD: miidevs.h,v 1.155 2019/09/19 14:39:08 msaitoh Exp $	*/
      2 
      3 /*
      4  * THIS FILE AUTOMATICALLY GENERATED.  DO NOT EDIT.
      5  *
      6  * generated from:
      7  *	NetBSD: miidevs,v 1.157 2019/09/19 14:38:45 msaitoh Exp
      8  */
      9 
     10 /*-
     11  * Copyright (c) 1998, 1999 The NetBSD Foundation, Inc.
     12  * All rights reserved.
     13  *
     14  * This code is derived from software contributed to The NetBSD Foundation
     15  * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility,
     16  * NASA Ames Research Center.
     17  *
     18  * Redistribution and use in source and binary forms, with or without
     19  * modification, are permitted provided that the following conditions
     20  * are met:
     21  * 1. Redistributions of source code must retain the above copyright
     22  *    notice, this list of conditions and the following disclaimer.
     23  * 2. Redistributions in binary form must reproduce the above copyright
     24  *    notice, this list of conditions and the following disclaimer in the
     25  *    documentation and/or other materials provided with the distribution.
     26  *
     27  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     28  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     29  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     30  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     31  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     32  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     33  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     34  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     35  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     36  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     37  * POSSIBILITY OF SUCH DAMAGE.
     38  */
     39 
     40 /*
     41  * List of known MII OUIs.
     42  * For a complete list see http://standards.ieee.org/regauth/oui/
     43  *
     44  * XXX Vendors do obviously not agree how OUIs (24 bit) are mapped
     45  * to the 22 bits available in the id registers.
     46  * IEEE 802.3u-1995, subclause 22.2.4.3.1, figure 22-12, depicts the right
     47  * mapping; the bit positions are defined in IEEE 802-1990, figure 5.2.
     48  * (There is a formal 802.3 interpretation, number 1-07/98 of July 09 1998,
     49  * about this.)
     50  * The MII_OUI() macro in "miivar.h" reflects this.
     51  * If a vendor uses a different mapping, an "xx" prefixed OUI is defined here
     52  * which is mangled accordingly to compensate.
     53  */
     54 
     55 /*
     56  * Use "make -f Makefile.miidevs" to regenerate miidevs.h and miidevs_data.h
     57  */
     58 
     59 #define	MII_OUI_AMD	0x00001a	/* Advanced Micro Devices */
     60 #define	MII_OUI_VITESSE	0x0001c1	/* Vitesse */
     61 #define	MII_OUI_TRIDIUM	0x0001f0	/* Tridium */
     62 #define	MII_OUI_DATATRACK	0x0002c6	/* Data Track Technology */
     63 #define	MII_OUI_CICADA	0x0003f1	/* Cicada Semiconductor */
     64 #define	MII_OUI_AGERE	0x00053d	/* Agere */
     65 #define	MII_OUI_BANKSPEED	0x0006b8	/* Bankspeed Pty */
     66 #define	MII_OUI_NETEXCELL	0x0008bb	/* NetExcell */
     67 #define	MII_OUI_NETAS	0x0009c3	/* Netas */
     68 #define	MII_OUI_BROADCOM2	0x000af7	/* Broadcom Corporation */
     69 #define	MII_OUI_RALINK	0x000c43	/* Ralink Technology */
     70 #define	MII_OUI_ASIX	0x000ec6	/* ASIX */
     71 #define	MII_OUI_BROADCOM	0x001018	/* Broadcom Corporation */
     72 #define	MII_OUI_MICREL	0x0010a1	/* Micrel */
     73 #define	MII_OUI_ALTIMA	0x0010a9	/* Altima Communications */
     74 #define	MII_OUI_ENABLESEMI	0x0010dd	/* Enable Semiconductor */
     75 #define	MII_OUI_SUNPLUS	0x001105	/* Sunplus Technology */
     76 #define	MII_OUI_ATHEROS	0x001374	/* Atheros */
     77 #define	MII_OUI_TERANETICS	0x0014a6	/* Teranetics */
     78 #define	MII_OUI_RALINK2	0x0017a5	/* Ralink Technology */
     79 #define	MII_OUI_AQUANTIA	0x0017b6	/* Aquantia Corporation */
     80 #define	MII_OUI_BROADCOM3	0x001be9	/* Broadcom Corporation */
     81 #define	MII_OUI_LEVEL1	0x00207b	/* Level 1 */
     82 #define	MII_OUI_VIA	0x004063	/* VIA Technologies */
     83 #define	MII_OUI_MARVELL	0x005043	/* Marvell Semiconductor */
     84 #define	MII_OUI_QUALSEMI	0x006051	/* Quality Semiconductor */
     85 #define	MII_OUI_AMLOGIC	0x006051	/* Amlogic */
     86 #define	MII_OUI_DAVICOM	0x00606e	/* Davicom Semiconductor */
     87 #define	MII_OUI_SMSC	0x00800f	/* SMSC */
     88 #define	MII_OUI_SEEQ	0x00a07d	/* Seeq */
     89 #define	MII_OUI_ICS	0x00a0be	/* Integrated Circuit Systems */
     90 #define	MII_OUI_INTEL	0x00aa00	/* Intel */
     91 #define	MII_OUI_TSC	0x00c039	/* TDK Semiconductor */
     92 #define	MII_OUI_MYSON	0x00c0b4	/* Myson Technology */
     93 #define	MII_OUI_ATTANSIC	0x00c82e	/* Attansic Technology */
     94 #define	MII_OUI_RDC	0x00d02d	/* RDC Semiconductor */
     95 #define	MII_OUI_JMICRON	0x00d831	/* JMicron */
     96 #define	MII_OUI_PMCSIERRA	0x00e004	/* PMC-Sierra */
     97 #define	MII_OUI_SIS	0x00e006	/* Silicon Integrated Systems */
     98 #define	MII_OUI_REALTEK	0x00e04c	/* RealTek */
     99 #define	MII_OUI_ADMTEK	0x00e092	/* ADMtek */
    100 #define	MII_OUI_XAQTI	0x00e0ae	/* XaQti Corp. */
    101 #define	MII_OUI_NATSEMI	0x080017	/* National Semiconductor */
    102 #define	MII_OUI_TI	0x080028	/* Texas Instruments */
    103 #define	MII_OUI_BROADCOM4	0x18c086	/* Broadcom Corporation */
    104 #define	MII_OUI_RENESAS	0x749050	/* Renesas */
    105 
    106 /* Unregisterd or wrong OUI */
    107 #define	MII_OUI_yyREALTEK	0x000004	/* Realtek */
    108 #define	MII_OUI_yyAMD	0x000058	/* Advanced Micro Devices */
    109 #define	MII_OUI_xxMYSON	0x00032d	/* Myson Technology */
    110 #define	MII_OUI_xxTSC	0x00039c	/* TDK Semiconductor */
    111 #define	MII_OUI_xxASIX	0x000674	/* Asix Semiconductor */
    112 #define	MII_OUI_xxDAVICOM	0x000676	/* Davicom Semiconductor */
    113 #define	MII_OUI_xxAMLOGIC	0x00068a	/* Amlogic */
    114 #define	MII_OUI_xxQUALSEMI	0x00068a	/* Quality Semiconductor */
    115 #define	MII_OUI_xxREALTEK	0x000732	/* Realtek */
    116 #define	MII_OUI_xxBROADCOM	0x000818	/* Broadcom Corporation */
    117 #define	MII_OUI_xxPMCSIERRA	0x0009c0	/* PMC-Sierra */
    118 #define	MII_OUI_xxICPLUS	0x0009c3	/* IC Plus Corp. */
    119 #define	MII_OUI_xxMARVELL	0x000ac2	/* Marvell Semiconductor */
    120 #define	MII_OUI_xxINTEL	0x001f00	/* Intel */
    121 #define	MII_OUI_xxBROADCOM_ALT1	0x0050ef	/* Broadcom Corporation */
    122 #define	MII_OUI_yyINTEL	0x005500	/* Intel */
    123 #define	MII_OUI_yyASIX	0x007063	/* Asix Semiconductor */
    124 #define	MII_OUI_xxPMCSIERRA2	0x009057	/* PMC-Sierra */
    125 #define	MII_OUI_xxCICADA	0x00c08f	/* Cicada Semiconductor */
    126 #define	MII_OUI_xxNATSEMI	0x1000e8	/* National Semiconductor */
    127 #define	MII_OUI_xxLEVEL1	0x782000	/* Level 1 */
    128 #define	MII_OUI_xxXAQTI	0xace000	/* XaQti Corp. */
    129 
    130 /*
    131  * List of known models.  Grouped by oui.
    132  */
    133 
    134 /*
    135  * Agere PHYs
    136  */
    137 #define	MII_MODEL_AGERE_ET1011	0x0001
    138 #define	MII_STR_AGERE_ET1011	"ET1011 10/100/1000baseT PHY"
    139 #define	MII_MODEL_AGERE_ET1011C	0x0004
    140 #define	MII_STR_AGERE_ET1011C	"ET1011C 10/100/1000baseT PHY"
    141 
    142 /* Asix semiconductor PHYs */
    143 #define	MII_MODEL_xxASIX_AX88X9X	0x0031
    144 #define	MII_STR_xxASIX_AX88X9X	"Ax88x9x internal PHY"
    145 #define	MII_MODEL_yyASIX_AX88772	0x0001
    146 #define	MII_STR_yyASIX_AX88772	"AX88772 internal PHY"
    147 #define	MII_MODEL_yyASIX_AX88772A	0x0006
    148 #define	MII_STR_yyASIX_AX88772A	"AX88772A internal PHY"
    149 #define	MII_MODEL_yyASIX_AX88772B	0x0008
    150 #define	MII_STR_yyASIX_AX88772B	"AX88772B internal PHY"
    151 
    152 /* Altima Communications PHYs */
    153 /* Don't know the model for ACXXX */
    154 #define	MII_MODEL_ALTIMA_ACXXX	0x0001
    155 #define	MII_STR_ALTIMA_ACXXX	"ACXXX 10/100 media interface"
    156 #define	MII_MODEL_ALTIMA_AC101L	0x0012
    157 #define	MII_STR_ALTIMA_AC101L	"AC101L 10/100 media interface"
    158 #define	MII_MODEL_ALTIMA_AC101	0x0021
    159 #define	MII_STR_ALTIMA_AC101	"AC101 10/100 media interface"
    160 /* AMD Am79C87[45] have ALTIMA OUI */
    161 #define	MII_MODEL_ALTIMA_Am79C875	0x0014
    162 #define	MII_STR_ALTIMA_Am79C875	"Am79C875 10/100 media interface"
    163 #define	MII_MODEL_ALTIMA_Am79C874	0x0021
    164 #define	MII_STR_ALTIMA_Am79C874	"Am79C874 10/100 media interface"
    165 
    166 /* Amlogic PHYs */
    167 #define	MII_MODEL_AMLOGIC_GXL	0x0000
    168 #define	MII_STR_AMLOGIC_GXL	"Meson GXL internal PHY"
    169 #define	MII_MODEL_xxAMLOGIC_GXL	0x0000
    170 #define	MII_STR_xxAMLOGIC_GXL	"Meson GXL internal PHY"
    171 
    172 /* Atheros PHYs */
    173 #define	MII_MODEL_ATHEROS_F1	0x0001
    174 #define	MII_STR_ATHEROS_F1	"F1 10/100/1000 PHY"
    175 #define	MII_MODEL_ATHEROS_F2	0x0002
    176 #define	MII_STR_ATHEROS_F2	"F2 10/100 PHY"
    177 
    178 /* Attansic PHYs */
    179 #define	MII_MODEL_ATTANSIC_L1	0x0001
    180 #define	MII_STR_ATTANSIC_L1	"L1 10/100/1000 PHY"
    181 #define	MII_MODEL_ATTANSIC_L2	0x0002
    182 #define	MII_STR_ATTANSIC_L2	"L2 10/100 PHY"
    183 #define	MII_MODEL_ATTANSIC_AR8021	0x0004
    184 #define	MII_STR_ATTANSIC_AR8021	"Atheros AR8021 10/100/1000 PHY"
    185 #define	MII_MODEL_ATTANSIC_AR8035	0x0007
    186 #define	MII_STR_ATTANSIC_AR8035	"Atheros AR8035 10/100/1000 PHY"
    187 
    188 /* Advanced Micro Devices PHYs */
    189 /* see Davicom DM9101 for Am79C873 */
    190 #define	MII_MODEL_yyAMD_79C972_10T	0x0001
    191 #define	MII_STR_yyAMD_79C972_10T	"Am79C972 internal 10BASE-T interface"
    192 #define	MII_MODEL_yyAMD_79c973phy	0x0036
    193 #define	MII_STR_yyAMD_79c973phy	"Am79C973 internal 10/100 media interface"
    194 #define	MII_MODEL_yyAMD_79c901	0x0037
    195 #define	MII_STR_yyAMD_79c901	"Am79C901 10BASE-T interface"
    196 #define	MII_MODEL_yyAMD_79c901home	0x0039
    197 #define	MII_STR_yyAMD_79c901home	"Am79C901 HomePNA 1.0 interface"
    198 
    199 /* Broadcom Corp. PHYs */
    200 #define	MII_MODEL_xxBROADCOM_3C905B	0x0012
    201 #define	MII_STR_xxBROADCOM_3C905B	"Broadcom 3c905B internal PHY"
    202 #define	MII_MODEL_xxBROADCOM_3C905C	0x0017
    203 #define	MII_STR_xxBROADCOM_3C905C	"Broadcom 3c905C internal PHY"
    204 #define	MII_MODEL_xxBROADCOM_BCM5221	0x001e
    205 #define	MII_STR_xxBROADCOM_BCM5221	"BCM5221 10/100 media interface"
    206 #define	MII_MODEL_xxBROADCOM_BCM5201	0x0021
    207 #define	MII_STR_xxBROADCOM_BCM5201	"BCM5201 10/100 media interface"
    208 #define	MII_MODEL_xxBROADCOM_BCM5214	0x0028
    209 #define	MII_STR_xxBROADCOM_BCM5214	"BCM5214 Quad 10/100 media interface"
    210 #define	MII_MODEL_xxBROADCOM_BCM5222	0x0032
    211 #define	MII_STR_xxBROADCOM_BCM5222	"BCM5222 Dual 10/100 media interface"
    212 #define	MII_MODEL_xxBROADCOM_BCM4401	0x0036
    213 #define	MII_STR_xxBROADCOM_BCM4401	"BCM4401 10/100 media interface"
    214 #define	MII_MODEL_xxBROADCOM_BCM5365	0x0037
    215 #define	MII_STR_xxBROADCOM_BCM5365	"BCM5365 10/100 5-port PHY switch"
    216 #define	MII_MODEL_BROADCOM_BCM5400	0x0004
    217 #define	MII_STR_BROADCOM_BCM5400	"BCM5400 1000BASE-T media interface"
    218 #define	MII_MODEL_BROADCOM_BCM5401	0x0005
    219 #define	MII_STR_BROADCOM_BCM5401	"BCM5401 1000BASE-T media interface"
    220 #define	MII_MODEL_BROADCOM_BCM5402	0x0006
    221 #define	MII_STR_BROADCOM_BCM5402	"BCM5402 1000BASE-T media interface"
    222 #define	MII_MODEL_BROADCOM_BCM5411	0x0007
    223 #define	MII_STR_BROADCOM_BCM5411	"BCM5411 1000BASE-T media interface"
    224 #define	MII_MODEL_BROADCOM_BCM5404	0x0008
    225 #define	MII_STR_BROADCOM_BCM5404	"BCM5404 1000BASE-T media interface"
    226 #define	MII_MODEL_BROADCOM_BCM5424	0x000a
    227 #define	MII_STR_BROADCOM_BCM5424	"BCM5424/BCM5234 1000BASE-T media interface"
    228 #define	MII_MODEL_BROADCOM_BCM5464	0x000b
    229 #define	MII_STR_BROADCOM_BCM5464	"BCM5464 1000BASE-T media interface"
    230 #define	MII_MODEL_BROADCOM_BCM5461	0x000c
    231 #define	MII_STR_BROADCOM_BCM5461	"BCM5461 1000BASE-T media interface"
    232 #define	MII_MODEL_BROADCOM_BCM5462	0x000d
    233 #define	MII_STR_BROADCOM_BCM5462	"BCM5462 1000BASE-T media interface"
    234 #define	MII_MODEL_BROADCOM_BCM5421	0x000e
    235 #define	MII_STR_BROADCOM_BCM5421	"BCM5421 1000BASE-T media interface"
    236 #define	MII_MODEL_BROADCOM_BCM5752	0x0010
    237 #define	MII_STR_BROADCOM_BCM5752	"BCM5752 1000BASE-T media interface"
    238 #define	MII_MODEL_BROADCOM_BCM5701	0x0011
    239 #define	MII_STR_BROADCOM_BCM5701	"BCM5701 1000BASE-T media interface"
    240 #define	MII_MODEL_BROADCOM_BCM5706	0x0015
    241 #define	MII_STR_BROADCOM_BCM5706	"BCM5706 1000BASE-T/SX media interface"
    242 #define	MII_MODEL_BROADCOM_BCM5703	0x0016
    243 #define	MII_STR_BROADCOM_BCM5703	"BCM5703 1000BASE-T media interface"
    244 #define	MII_MODEL_BROADCOM_BCM5750	0x0018
    245 #define	MII_STR_BROADCOM_BCM5750	"BCM5750 1000BASE-T media interface"
    246 #define	MII_MODEL_BROADCOM_BCM5704	0x0019
    247 #define	MII_STR_BROADCOM_BCM5704	"BCM5704 1000BASE-T media interface"
    248 #define	MII_MODEL_BROADCOM_BCM5705	0x001a
    249 #define	MII_STR_BROADCOM_BCM5705	"BCM5705 1000BASE-T media interface"
    250 #define	MII_MODEL_BROADCOM_BCM54K2	0x002e
    251 #define	MII_STR_BROADCOM_BCM54K2	"BCM54K2 1000BASE-T media interface"
    252 #define	MII_MODEL_BROADCOM_BCM5714	0x0034
    253 #define	MII_STR_BROADCOM_BCM5714	"BCM5714 1000BASE-T/X media interface"
    254 #define	MII_MODEL_BROADCOM_BCM5780	0x0035
    255 #define	MII_STR_BROADCOM_BCM5780	"BCM5780 1000BASE-T/X media interface"
    256 #define	MII_MODEL_BROADCOM_BCM5708C	0x0036
    257 #define	MII_STR_BROADCOM_BCM5708C	"BCM5708C 1000BASE-T media interface"
    258 #define	MII_MODEL_BROADCOM_BCM5466	0x003b
    259 #define	MII_STR_BROADCOM_BCM5466	"BCM5466 1000BASE-T media interface"
    260 #define	MII_MODEL_BROADCOM2_BCM5325	0x0003
    261 #define	MII_STR_BROADCOM2_BCM5325	"BCM5325 10/100 5-port PHY switch"
    262 #define	MII_MODEL_BROADCOM2_BCM5906	0x0004
    263 #define	MII_STR_BROADCOM2_BCM5906	"BCM5906 10/100baseTX media interface"
    264 #define	MII_MODEL_BROADCOM2_BCM5478	0x0008
    265 #define	MII_STR_BROADCOM2_BCM5478	"BCM5478 1000BASE-T media interface"
    266 #define	MII_MODEL_BROADCOM2_BCM5488	0x0009
    267 #define	MII_STR_BROADCOM2_BCM5488	"BCM5488 1000BASE-T media interface"
    268 #define	MII_MODEL_BROADCOM2_BCM5481	0x000a
    269 #define	MII_STR_BROADCOM2_BCM5481	"BCM5481 1000BASE-T media interface"
    270 #define	MII_MODEL_BROADCOM2_BCM5482	0x000b
    271 #define	MII_STR_BROADCOM2_BCM5482	"BCM5482 1000BASE-T media interface"
    272 #define	MII_MODEL_BROADCOM2_BCM5755	0x000c
    273 #define	MII_STR_BROADCOM2_BCM5755	"BCM5755 1000BASE-T media interface"
    274 #define	MII_MODEL_BROADCOM2_BCM5756	0x000d
    275 #define	MII_STR_BROADCOM2_BCM5756	"BCM5756 1000BASE-T media interface XXX"
    276 #define	MII_MODEL_BROADCOM2_BCM5754	0x000e
    277 #define	MII_STR_BROADCOM2_BCM5754	"BCM5754/5787 1000BASE-T media interface"
    278 #define	MII_MODEL_BROADCOM2_BCM5708S	0x0015
    279 #define	MII_STR_BROADCOM2_BCM5708S	"BCM5708S 1000/2500baseSX PHY"
    280 #define	MII_MODEL_BROADCOM2_BCM5785	0x0016
    281 #define	MII_STR_BROADCOM2_BCM5785	"BCM5785 1000BASE-T media interface"
    282 #define	MII_MODEL_BROADCOM2_BCM5709CAX	0x002c
    283 #define	MII_STR_BROADCOM2_BCM5709CAX	"BCM5709CAX 10/100/1000baseT PHY"
    284 #define	MII_MODEL_BROADCOM2_BCM5722	0x002d
    285 #define	MII_STR_BROADCOM2_BCM5722	"BCM5722 1000BASE-T media interface"
    286 #define	MII_MODEL_BROADCOM2_BCM5784	0x003a
    287 #define	MII_STR_BROADCOM2_BCM5784	"BCM5784 10/100/1000baseT PHY"
    288 #define	MII_MODEL_BROADCOM2_BCM5709C	0x003c
    289 #define	MII_STR_BROADCOM2_BCM5709C	"BCM5709 10/100/1000baseT PHY"
    290 #define	MII_MODEL_BROADCOM2_BCM5761	0x003d
    291 #define	MII_STR_BROADCOM2_BCM5761	"BCM5761 10/100/1000baseT PHY"
    292 #define	MII_MODEL_BROADCOM2_BCM5709S	0x003f
    293 #define	MII_STR_BROADCOM2_BCM5709S	"BCM5709S 1000/2500baseSX PHY"
    294 #define	MII_MODEL_BROADCOM3_BCM57780	0x0019
    295 #define	MII_STR_BROADCOM3_BCM57780	"BCM57780 1000BASE-T media interface"
    296 #define	MII_MODEL_BROADCOM3_BCM5717C	0x0020
    297 #define	MII_STR_BROADCOM3_BCM5717C	"BCM5717C 1000BASE-T media interface"
    298 #define	MII_MODEL_BROADCOM3_BCM5719C	0x0022
    299 #define	MII_STR_BROADCOM3_BCM5719C	"BCM5719C 1000BASE-T media interface"
    300 #define	MII_MODEL_BROADCOM3_BCM57765	0x0024
    301 #define	MII_STR_BROADCOM3_BCM57765	"BCM57765 1000BASE-T media interface"
    302 #define	MII_MODEL_BROADCOM3_BCM53125	0x0032
    303 #define	MII_STR_BROADCOM3_BCM53125	"BCM53125 1000BASE-T switch"
    304 #define	MII_MODEL_BROADCOM3_BCM5720C	0x0036
    305 #define	MII_STR_BROADCOM3_BCM5720C	"BCM5720C 1000BASE-T media interface"
    306 #define	MII_MODEL_BROADCOM4_BCM5725C	0x0038
    307 #define	MII_STR_BROADCOM4_BCM5725C	"BCM5725C 1000BASE-T media interface"
    308 #define	MII_MODEL_xxBROADCOM_ALT1_BCM5906	0x0004
    309 #define	MII_STR_xxBROADCOM_ALT1_BCM5906	"BCM5906 10/100baseTX media interface"
    310 
    311 /* Cicada Semiconductor PHYs (now owned by Vitesse?) */
    312 #define	MII_MODEL_CICADA_CS8201	0x0001
    313 #define	MII_STR_CICADA_CS8201	"Cicada CS8201 10/100/1000TX PHY"
    314 #define	MII_MODEL_CICADA_CS8204	0x0004
    315 #define	MII_STR_CICADA_CS8204	"Cicada CS8204 10/100/1000TX PHY"
    316 #define	MII_MODEL_CICADA_VSC8211	0x000b
    317 #define	MII_STR_CICADA_VSC8211	"Cicada VSC8211 10/100/1000TX PHY"
    318 #define	MII_MODEL_CICADA_CS8201A	0x0020
    319 #define	MII_STR_CICADA_CS8201A	"Cicada CS8201 10/100/1000TX PHY"
    320 #define	MII_MODEL_CICADA_CS8201B	0x0021
    321 #define	MII_STR_CICADA_CS8201B	"Cicada CS8201 10/100/1000TX PHY"
    322 #define	MII_MODEL_CICADA_CS8244	0x002c
    323 #define	MII_STR_CICADA_CS8244	"Vitesse VSC8244 Quad 10/100/1000BASE-T PHY"
    324 #define	MII_MODEL_xxCICADA_VSC8221	0x0015
    325 #define	MII_STR_xxCICADA_VSC8221	"Vitesse VSC8221 10/100/1000BASE-T PHY"
    326 #define	MII_MODEL_xxCICADA_CS8201B	0x0021
    327 #define	MII_STR_xxCICADA_CS8201B	"Cicada CS8201 10/100/1000TX PHY"
    328 
    329 /* Davicom Semiconductor PHYs */
    330 /* AMD Am79C873 seems to be a relabeled DM9101 */
    331 #define	MII_MODEL_DAVICOM_DM9101	0x0000
    332 #define	MII_STR_DAVICOM_DM9101	"DM9101 (AMD Am79C873) 10/100 media interface"
    333 #define	MII_MODEL_xxDAVICOM_DM9101	0x0000
    334 #define	MII_STR_xxDAVICOM_DM9101	"DM9101 (AMD Am79C873) 10/100 media interface"
    335 #define	MII_MODEL_xxDAVICOM_DM9102	0x0004
    336 #define	MII_STR_xxDAVICOM_DM9102	"DM9102 10/100 media interface"
    337 #define	MII_MODEL_xxDAVICOM_DM9161	0x0008
    338 #define	MII_STR_xxDAVICOM_DM9161	"DM9161 10/100 media interface"
    339 #define	MII_MODEL_xxDAVICOM_DM9161A	0x000a
    340 #define	MII_STR_xxDAVICOM_DM9161A	"DM9161A 10/100 media interface"
    341 #define	MII_MODEL_xxDAVICOM_DM9161B	0x000b
    342 #define	MII_STR_xxDAVICOM_DM9161B	"DM9161[BC] 10/100 media interface"
    343 #define	MII_MODEL_xxDAVICOM_DM9601	0x000c
    344 #define	MII_STR_xxDAVICOM_DM9601	"DM9601 internal 10/100 media interface"
    345 
    346 /* IC Plus Corp. PHYs */
    347 #define	MII_MODEL_xxICPLUS_IP100	0x0004
    348 #define	MII_STR_xxICPLUS_IP100	"IP100 10/100 PHY"
    349 #define	MII_MODEL_xxICPLUS_IP101	0x0005
    350 #define	MII_STR_xxICPLUS_IP101	"IP101 10/100 PHY"
    351 #define	MII_MODEL_xxICPLUS_IP1000A	0x0008
    352 #define	MII_STR_xxICPLUS_IP1000A	"IP1000A 10/100/1000 PHY"
    353 #define	MII_MODEL_xxICPLUS_IP1001	0x0019
    354 #define	MII_STR_xxICPLUS_IP1001	"IP1001 10/100/1000 PHY"
    355 
    356 /* Integrated Circuit Systems PHYs */
    357 #define	MII_MODEL_ICS_1889	0x0001
    358 #define	MII_STR_ICS_1889	"ICS1889 10/100 media interface"
    359 #define	MII_MODEL_ICS_1890	0x0002
    360 #define	MII_STR_ICS_1890	"ICS1890 10/100 media interface"
    361 #define	MII_MODEL_ICS_1892	0x0003
    362 #define	MII_STR_ICS_1892	"ICS1892 10/100 media interface"
    363 #define	MII_MODEL_ICS_1893	0x0004
    364 #define	MII_STR_ICS_1893	"ICS1893 10/100 media interface"
    365 #define	MII_MODEL_ICS_1893C	0x0005
    366 #define	MII_STR_ICS_1893C	"ICS1893C 10/100 media interface"
    367 
    368 /* Intel PHYs */
    369 #define	MII_MODEL_xxINTEL_I82553	0x0000
    370 #define	MII_STR_xxINTEL_I82553	"i82553 10/100 media interface"
    371 #define	MII_MODEL_yyINTEL_I82555	0x0015
    372 #define	MII_STR_yyINTEL_I82555	"i82555 10/100 media interface"
    373 #define	MII_MODEL_yyINTEL_I82562EH	0x0017
    374 #define	MII_STR_yyINTEL_I82562EH	"i82562EH HomePNA interface"
    375 #define	MII_MODEL_yyINTEL_I82562G	0x0031
    376 #define	MII_STR_yyINTEL_I82562G	"i82562G 10/100 media interface"
    377 #define	MII_MODEL_yyINTEL_I82562EM	0x0032
    378 #define	MII_STR_yyINTEL_I82562EM	"i82562EM 10/100 media interface"
    379 #define	MII_MODEL_yyINTEL_I82562ET	0x0033
    380 #define	MII_STR_yyINTEL_I82562ET	"i82562ET 10/100 media interface"
    381 #define	MII_MODEL_yyINTEL_I82553	0x0035
    382 #define	MII_STR_yyINTEL_I82553	"i82553 10/100 media interface"
    383 #define	MII_MODEL_yyINTEL_IGP01E1000	0x0038
    384 #define	MII_STR_yyINTEL_IGP01E1000	"Intel IGP01E1000 Gigabit PHY"
    385 #define	MII_MODEL_yyINTEL_I82566	0x0039
    386 #define	MII_STR_yyINTEL_I82566	"i82566 10/100/1000 media interface"
    387 #define	MII_MODEL_INTEL_I82577	0x0005
    388 #define	MII_STR_INTEL_I82577	"i82577 10/100/1000 media interface"
    389 #define	MII_MODEL_INTEL_I82579	0x0009
    390 #define	MII_STR_INTEL_I82579	"i82579 10/100/1000 media interface"
    391 #define	MII_MODEL_INTEL_I217	0x000a
    392 #define	MII_STR_INTEL_I217	"i217 10/100/1000 media interface"
    393 #define	MII_MODEL_INTEL_X540	0x0020
    394 #define	MII_STR_INTEL_X540	"X540 100M/1G/10G media interface"
    395 #define	MII_MODEL_INTEL_X550	0x0022
    396 #define	MII_STR_INTEL_X550	"X550 100M/1G/10G media interface"
    397 #define	MII_MODEL_INTEL_X557	0x0024
    398 #define	MII_STR_INTEL_X557	"X557 100M/1G/10G media interface"
    399 #define	MII_MODEL_INTEL_I82580	0x003a
    400 #define	MII_STR_INTEL_I82580	"82580 10/100/1000 media interface"
    401 #define	MII_MODEL_INTEL_I350	0x003b
    402 #define	MII_STR_INTEL_I350	"I350 10/100/1000 media interface"
    403 #define	MII_MODEL_xxMARVELL_I210	0x0000
    404 #define	MII_STR_xxMARVELL_I210	"I210 10/100/1000 media interface"
    405 #define	MII_MODEL_xxMARVELL_I82563	0x000a
    406 #define	MII_STR_xxMARVELL_I82563	"i82563 10/100/1000 media interface"
    407 #define	MII_MODEL_ATTANSIC_I82578	0x0004
    408 #define	MII_STR_ATTANSIC_I82578	"Intel 82578 10/100/1000 media interface"
    409 
    410 
    411 /* JMicron PHYs */
    412 #define	MII_MODEL_JMICRON_JMC250	0x0021
    413 #define	MII_STR_JMICRON_JMC250	"JMC250 10/100/1000 media interface"
    414 #define	MII_MODEL_JMICRON_JMC260	0x0022
    415 #define	MII_STR_JMICRON_JMC260	"JMC260 10/100 media interface"
    416 
    417 /* Level 1 PHYs */
    418 #define	MII_MODEL_xxLEVEL1_LXT970	0x0000
    419 #define	MII_STR_xxLEVEL1_LXT970	"LXT970 10/100 media interface"
    420 #define	MII_MODEL_LEVEL1_LXT1000_OLD	0x0003
    421 #define	MII_STR_LEVEL1_LXT1000_OLD	"LXT1000 1000BASE-T media interface"
    422 #define	MII_MODEL_LEVEL1_LXT974	0x0004
    423 #define	MII_STR_LEVEL1_LXT974	"LXT974 10/100 Quad PHY"
    424 #define	MII_MODEL_LEVEL1_LXT975	0x0005
    425 #define	MII_STR_LEVEL1_LXT975	"LXT975 10/100 Quad PHY"
    426 #define	MII_MODEL_LEVEL1_LXT1000	0x000c
    427 #define	MII_STR_LEVEL1_LXT1000	"LXT1000 1000BASE-T media interface"
    428 #define	MII_MODEL_LEVEL1_LXT971	0x000e
    429 #define	MII_STR_LEVEL1_LXT971	"LXT971/2 10/100 media interface"
    430 #define	MII_MODEL_LEVEL1_LXT973	0x0021
    431 #define	MII_STR_LEVEL1_LXT973	"LXT973 10/100 Dual PHY"
    432 
    433 /* Marvell Semiconductor PHYs */
    434 #define	MII_MODEL_xxMARVELL_E1000	0x0000
    435 #define	MII_STR_xxMARVELL_E1000	"Marvell 88E1000 Gigabit PHY"
    436 #define	MII_MODEL_xxMARVELL_E1011	0x0002
    437 #define	MII_STR_xxMARVELL_E1011	"Marvell 88E1011 Gigabit PHY"
    438 #define	MII_MODEL_xxMARVELL_E1000_3	0x0003
    439 #define	MII_STR_xxMARVELL_E1000_3	"Marvell 88E1000 Gigabit PHY"
    440 #define	MII_MODEL_xxMARVELL_E1000S	0x0004
    441 #define	MII_STR_xxMARVELL_E1000S	"Marvell 88E1000S Gigabit PHY"
    442 #define	MII_MODEL_xxMARVELL_E1000_5	0x0005
    443 #define	MII_STR_xxMARVELL_E1000_5	"Marvell 88E1000 Gigabit PHY"
    444 #define	MII_MODEL_xxMARVELL_E1101	0x0006
    445 #define	MII_STR_xxMARVELL_E1101	"Marvell 88E1101 Gigabit PHY"
    446 #define	MII_MODEL_xxMARVELL_E3082	0x0008
    447 #define	MII_STR_xxMARVELL_E3082	"Marvell 88E3082 10/100 Fast Ethernet PHY"
    448 #define	MII_MODEL_xxMARVELL_E1112	0x0009
    449 #define	MII_STR_xxMARVELL_E1112	"Marvell 88E1112 Gigabit PHY"
    450 #define	MII_MODEL_xxMARVELL_E1149	0x000b
    451 #define	MII_STR_xxMARVELL_E1149	"Marvell 88E1149 Gigabit PHY"
    452 #define	MII_MODEL_xxMARVELL_E1111	0x000c
    453 #define	MII_STR_xxMARVELL_E1111	"Marvell 88E1111 Gigabit PHY"
    454 #define	MII_MODEL_xxMARVELL_E1145	0x000d
    455 #define	MII_STR_xxMARVELL_E1145	"Marvell 88E1145 Quad Gigabit PHY"
    456 #define	MII_MODEL_xxMARVELL_E6060	0x0010
    457 #define	MII_STR_xxMARVELL_E6060	"Marvell 88E6060 6-Port 10/100 Fast Ethernet Switch"
    458 #define	MII_MODEL_xxMARVELL_I347	0x001c
    459 #define	MII_STR_xxMARVELL_I347	"Intel I347-AT4 Gigabit PHY"
    460 #define	MII_MODEL_xxMARVELL_E1512	0x001d
    461 #define	MII_STR_xxMARVELL_E1512	"Marvell 88E151[0248] Gigabit PHY"
    462 #define	MII_MODEL_xxMARVELL_E1340M	0x001f
    463 #define	MII_STR_xxMARVELL_E1340M	"Marvell 88E1340 Gigabit PHY"
    464 #define	MII_MODEL_xxMARVELL_E1116	0x0021
    465 #define	MII_STR_xxMARVELL_E1116	"Marvell 88E1116 Gigabit PHY"
    466 #define	MII_MODEL_xxMARVELL_E1118	0x0022
    467 #define	MII_STR_xxMARVELL_E1118	"Marvell 88E1118 Gigabit PHY"
    468 #define	MII_MODEL_xxMARVELL_E1240	0x0023
    469 #define	MII_STR_xxMARVELL_E1240	"Marvell 88E1240 Gigabit PHY"
    470 #define	MII_MODEL_xxMARVELL_E1116R	0x0024
    471 #define	MII_STR_xxMARVELL_E1116R	"Marvell 88E1116R Gigabit PHY"
    472 #define	MII_MODEL_xxMARVELL_E1149R	0x0025
    473 #define	MII_STR_xxMARVELL_E1149R	"Marvell 88E1149R Quad Gigabit PHY"
    474 #define	MII_MODEL_xxMARVELL_E3016	0x0026
    475 #define	MII_STR_xxMARVELL_E3016	"Marvell 88E3016 10/100 Fast Ethernet PHY"
    476 #define	MII_MODEL_xxMARVELL_PHYG65G	0x0027
    477 #define	MII_STR_xxMARVELL_PHYG65G	"Marvell PHYG65G Gigabit PHY"
    478 #define	MII_MODEL_xxMARVELL_E1318S	0x0029
    479 #define	MII_STR_xxMARVELL_E1318S	"Marvell 88E1318S Gigabit PHY"
    480 #define	MII_MODEL_xxMARVELL_E1543	0x002a
    481 #define	MII_STR_xxMARVELL_E1543	"Marvell 88E154[358] Alaska Quad Port Gb PHY"
    482 #define	MII_MODEL_MARVELL_E1000_0	0x0000
    483 #define	MII_STR_MARVELL_E1000_0	"Marvell 88E1000 Gigabit PHY"
    484 #define	MII_MODEL_MARVELL_E1011	0x0002
    485 #define	MII_STR_MARVELL_E1011	"Marvell 88E1011 Gigabit PHY"
    486 #define	MII_MODEL_MARVELL_E1000_3	0x0003
    487 #define	MII_STR_MARVELL_E1000_3	"Marvell 88E1000 Gigabit PHY"
    488 #define	MII_MODEL_MARVELL_E1000_5	0x0005
    489 #define	MII_STR_MARVELL_E1000_5	"Marvell 88E1000 Gigabit PHY"
    490 #define	MII_MODEL_MARVELL_E1000_6	0x0006
    491 #define	MII_STR_MARVELL_E1000_6	"Marvell 88E1000 Gigabit PHY"
    492 #define	MII_MODEL_MARVELL_E1111	0x000c
    493 #define	MII_STR_MARVELL_E1111	"Marvell 88E1111 Gigabit PHY"
    494 
    495 /* Micrel PHYs */
    496 #define	MII_MODEL_MICREL_KSZ8081	0x0016
    497 #define	MII_STR_MICREL_KSZ8081	"Micrel KSZ8081 10/100 PHY"
    498 #define	MII_MODEL_MICREL_KSZ9021RNI	0x0021
    499 #define	MII_STR_MICREL_KSZ9021RNI	"Micrel KSZ9021RNI 10/100/1000 PHY"
    500 #define	MII_MODEL_MICREL_KSZ9031	0x0022
    501 #define	MII_STR_MICREL_KSZ9031	"Micrel KSZ9031 10/100/1000 PHY"
    502 
    503 /* Myson Technology PHYs */
    504 #define	MII_MODEL_xxMYSON_MTD972	0x0000
    505 #define	MII_STR_xxMYSON_MTD972	"MTD972 10/100 media interface"
    506 #define	MII_MODEL_MYSON_MTD803	0x0000
    507 #define	MII_STR_MYSON_MTD803	"MTD803 3-in-1 media interface"
    508 
    509 /* National Semiconductor PHYs */
    510 #define	MII_MODEL_xxNATSEMI_DP83840	0x0000
    511 #define	MII_STR_xxNATSEMI_DP83840	"DP83840 10/100 media interface"
    512 #define	MII_MODEL_xxNATSEMI_DP83843	0x0001
    513 #define	MII_STR_xxNATSEMI_DP83843	"DP83843 10/100 media interface"
    514 #define	MII_MODEL_xxNATSEMI_DP83815	0x0002
    515 #define	MII_STR_xxNATSEMI_DP83815	"DP83815/DP83846A 10/100 media interface"
    516 #define	MII_MODEL_xxNATSEMI_DP83847	0x0003
    517 #define	MII_STR_xxNATSEMI_DP83847	"DP83847 10/100 media interface"
    518 #define	MII_MODEL_xxNATSEMI_DP83891	0x0005
    519 #define	MII_STR_xxNATSEMI_DP83891	"DP83891 1000BASE-T media interface"
    520 #define	MII_MODEL_xxNATSEMI_DP83861	0x0006
    521 #define	MII_STR_xxNATSEMI_DP83861	"DP83861 1000BASE-T media interface"
    522 #define	MII_MODEL_xxNATSEMI_DP83865	0x0007
    523 #define	MII_STR_xxNATSEMI_DP83865	"DP83865 1000BASE-T media interface"
    524 #define	MII_MODEL_xxNATSEMI_DP83849	0x000a
    525 #define	MII_STR_xxNATSEMI_DP83849	"DP83849 10/100 media interface"
    526 
    527 /* PMC Sierra PHYs */
    528 #define	MII_MODEL_xxPMCSIERRA_PM8351	0x0000
    529 #define	MII_STR_xxPMCSIERRA_PM8351	"PM8351 OctalPHY Gigabit interface"
    530 #define	MII_MODEL_xxPMCSIERRA2_PM8352	0x0002
    531 #define	MII_STR_xxPMCSIERRA2_PM8352	"PM8352 OctalPHY Gigabit interface"
    532 #define	MII_MODEL_xxPMCSIERRA2_PM8353	0x0003
    533 #define	MII_STR_xxPMCSIERRA2_PM8353	"PM8353 QuadPHY Gigabit interface"
    534 #define	MII_MODEL_PMCSIERRA_PM8354	0x0004
    535 #define	MII_STR_PMCSIERRA_PM8354	"PM8354 QuadPHY Gigabit interface"
    536 
    537 /* Quality Semiconductor PHYs */
    538 #define	MII_MODEL_xxQUALSEMI_QS6612	0x0000
    539 #define	MII_STR_xxQUALSEMI_QS6612	"QS6612 10/100 media interface"
    540 
    541 /* RDC Semiconductor PHYs */
    542 #define	MII_MODEL_RDC_R6040	0x0003
    543 #define	MII_STR_RDC_R6040	"R6040 10/100 media interface"
    544 
    545 /* RealTek PHYs */
    546 #define	MII_MODEL_xxREALTEK_RTL8169S	0x0011
    547 #define	MII_STR_xxREALTEK_RTL8169S	"RTL8169S/8110S/8211 1000BASE-T media interface"
    548 #define	MII_MODEL_yyREALTEK_RTL8201L	0x0020
    549 #define	MII_STR_yyREALTEK_RTL8201L	"RTL8201L 10/100 media interface"
    550 #define	MII_MODEL_REALTEK_RTL8251	0x0000
    551 #define	MII_STR_REALTEK_RTL8251	"RTL8251 1000BASE-T media interface"
    552 #define	MII_MODEL_REALTEK_RTL8201E	0x0008
    553 #define	MII_STR_REALTEK_RTL8201E	"RTL8201E 10/100 media interface"
    554 #define	MII_MODEL_REALTEK_RTL8169S	0x0011
    555 #define	MII_STR_REALTEK_RTL8169S	"RTL8169S/8110S/8211 1000BASE-T media interface"
    556 
    557 /* Seeq PHYs */
    558 #define	MII_MODEL_SEEQ_80220	0x0003
    559 #define	MII_STR_SEEQ_80220	"Seeq 80220 10/100 media interface"
    560 #define	MII_MODEL_SEEQ_84220	0x0004
    561 #define	MII_STR_SEEQ_84220	"Seeq 84220 10/100 media interface"
    562 #define	MII_MODEL_SEEQ_80225	0x0008
    563 #define	MII_STR_SEEQ_80225	"Seeq 80225 10/100 media interface"
    564 
    565 /* Silicon Integrated Systems PHYs */
    566 #define	MII_MODEL_SIS_900	0x0000
    567 #define	MII_STR_SIS_900	"SiS 900 10/100 media interface"
    568 
    569 /* SMSC PHYs */
    570 #define	MII_MODEL_SMSC_LAN83C185	0x000a
    571 #define	MII_STR_SMSC_LAN83C185	"SMSC LAN83C185 10/100 PHY"
    572 #define	MII_MODEL_SMSC_LAN8700	0x000c
    573 #define	MII_STR_SMSC_LAN8700	"SMSC LAN8700 10/100 Ethernet Transceiver"
    574 #define	MII_MODEL_SMSC_LAN911X	0x000d
    575 #define	MII_STR_SMSC_LAN911X	"SMSC LAN911X internal 10/100 PHY"
    576 #define	MII_MODEL_SMSC_LAN75XX	0x000e
    577 #define	MII_STR_SMSC_LAN75XX	"SMSC LAN75XX internal 10/100 PHY"
    578 #define	MII_MODEL_SMSC_LAN8710_LAN8720	0x000f
    579 #define	MII_STR_SMSC_LAN8710_LAN8720	"SMSC LAN8710/LAN8720 10/100 Ethernet Transceiver"
    580 #define	MII_MODEL_SMSC_LAN8740	0x0011
    581 #define	MII_STR_SMSC_LAN8740	"SMSC LAN8740 10/100 media interface"
    582 #define	MII_MODEL_SMSC_LAN8741A	0x0012
    583 #define	MII_STR_SMSC_LAN8741A	"SMSC LAN8741A 10/100 media interface"
    584 #define	MII_MODEL_SMSC_LAN8742	0x0013
    585 #define	MII_STR_SMSC_LAN8742	"SMSC LAN8742 10/100 media interface"
    586 
    587 /* Texas Instruments PHYs */
    588 #define	MII_MODEL_TI_TLAN10T	0x0001
    589 #define	MII_STR_TI_TLAN10T	"ThunderLAN 10BASE-T media interface"
    590 #define	MII_MODEL_TI_100VGPMI	0x0002
    591 #define	MII_STR_TI_100VGPMI	"ThunderLAN 100VG-AnyLan media interface"
    592 #define	MII_MODEL_TI_TNETE2101	0x0003
    593 #define	MII_STR_TI_TNETE2101	"TNETE2101 media interface"
    594 
    595 /* TDK Semiconductor PHYs */
    596 #define	MII_MODEL_xxTSC_78Q2120	0x0014
    597 #define	MII_STR_xxTSC_78Q2120	"78Q2120 10/100 media interface"
    598 #define	MII_MODEL_xxTSC_78Q2121	0x0015
    599 #define	MII_STR_xxTSC_78Q2121	"78Q2121 100BASE-TX media interface"
    600 
    601 /* VIA Technologies PHYs */
    602 #define	MII_MODEL_VIA_VT6103	0x0032
    603 #define	MII_STR_VIA_VT6103	"VT6103 10/100 PHY"
    604 #define	MII_MODEL_VIA_VT6103_2	0x0034
    605 #define	MII_STR_VIA_VT6103_2	"VT6103 10/100 PHY"
    606 
    607 /* Vitesse PHYs */
    608 #define	MII_MODEL_VITESSE_VSC8601	0x0002
    609 #define	MII_STR_VITESSE_VSC8601	"VSC8601 10/100/1000 PHY"
    610 
    611 /* XaQti Corp. PHYs */
    612 #define	MII_MODEL_xxXAQTI_XMACII	0x0000
    613 #define	MII_STR_xxXAQTI_XMACII	"XaQti Corp. XMAC II gigabit interface"
    614