xref: /qemu/include/hw/net/mii.h (revision a1a62ced)
13e230569SGreg Ungerer /*
23e230569SGreg Ungerer  * Common network MII address and register definitions.
33e230569SGreg Ungerer  *
43e230569SGreg Ungerer  * Copyright (C) 2014 Beniamino Galvani <b.galvani@gmail.com>
53e230569SGreg Ungerer  *
63e230569SGreg Ungerer  * Allwinner EMAC register definitions from Linux kernel are:
73e230569SGreg Ungerer  *   Copyright 2012 Stefan Roese <sr@denx.de>
83e230569SGreg Ungerer  *   Copyright 2013 Maxime Ripard <maxime.ripard@free-electrons.com>
93e230569SGreg Ungerer  *   Copyright 1997 Sten Wang
103e230569SGreg Ungerer  *
113e230569SGreg Ungerer  * This program is free software; you can redistribute it and/or
123e230569SGreg Ungerer  * modify it under the terms of the GNU General Public License
133e230569SGreg Ungerer  * version 2 as published by the Free Software Foundation.
143e230569SGreg Ungerer  *
153e230569SGreg Ungerer  * This program is distributed in the hope that it will be useful,
163e230569SGreg Ungerer  * but WITHOUT ANY WARRANTY; without even the implied warranty of
173e230569SGreg Ungerer  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
183e230569SGreg Ungerer  * GNU General Public License for more details.
193e230569SGreg Ungerer  *
203e230569SGreg Ungerer  */
213e230569SGreg Ungerer #ifndef MII_H
223e230569SGreg Ungerer #define MII_H
233e230569SGreg Ungerer 
243e230569SGreg Ungerer /* PHY registers */
2530adcc8fSCédric Le Goater #define MII_BMCR            0  /* Basic mode control register */
2630adcc8fSCédric Le Goater #define MII_BMSR            1  /* Basic mode status register */
2730adcc8fSCédric Le Goater #define MII_PHYID1          2  /* ID register 1 */
2830adcc8fSCédric Le Goater #define MII_PHYID2          3  /* ID register 2 */
2930adcc8fSCédric Le Goater #define MII_ANAR            4  /* Autonegotiation advertisement */
3030adcc8fSCédric Le Goater #define MII_ANLPAR          5  /* Autonegotiation lnk partner abilities */
3130adcc8fSCédric Le Goater #define MII_ANER            6  /* Autonegotiation expansion */
3230adcc8fSCédric Le Goater #define MII_ANNP            7  /* Autonegotiation next page */
3330adcc8fSCédric Le Goater #define MII_ANLPRNP         8  /* Autonegotiation link partner rx next page */
3430adcc8fSCédric Le Goater #define MII_CTRL1000        9  /* 1000BASE-T control */
3530adcc8fSCédric Le Goater #define MII_STAT1000        10 /* 1000BASE-T status */
3630adcc8fSCédric Le Goater #define MII_MDDACR          13 /* MMD access control */
3730adcc8fSCédric Le Goater #define MII_MDDAADR         14 /* MMD access address data */
3830adcc8fSCédric Le Goater #define MII_EXTSTAT         15 /* Extended Status */
393e230569SGreg Ungerer #define MII_NSR             16
403e230569SGreg Ungerer #define MII_LBREMR          17
413e230569SGreg Ungerer #define MII_REC             18
423e230569SGreg Ungerer #define MII_SNRDR           19
433e230569SGreg Ungerer #define MII_TEST            25
443e230569SGreg Ungerer 
453e230569SGreg Ungerer /* PHY registers fields */
463e230569SGreg Ungerer #define MII_BMCR_RESET      (1 << 15)
473e230569SGreg Ungerer #define MII_BMCR_LOOPBACK   (1 << 14)
4830adcc8fSCédric Le Goater #define MII_BMCR_SPEED100   (1 << 13)  /* LSB of Speed (100) */
4930adcc8fSCédric Le Goater #define MII_BMCR_SPEED      MII_BMCR_SPEED100
5030adcc8fSCédric Le Goater #define MII_BMCR_AUTOEN     (1 << 12) /* Autonegotiation enable */
5130adcc8fSCédric Le Goater #define MII_BMCR_PDOWN      (1 << 11) /* Enable low power state */
5230adcc8fSCédric Le Goater #define MII_BMCR_ISOLATE    (1 << 10) /* Isolate data paths from MII */
5330adcc8fSCédric Le Goater #define MII_BMCR_ANRESTART  (1 << 9)  /* Auto negotiation restart */
5430adcc8fSCédric Le Goater #define MII_BMCR_FD         (1 << 8)  /* Set duplex mode */
5530adcc8fSCédric Le Goater #define MII_BMCR_CTST       (1 << 7)  /* Collision test */
5630adcc8fSCédric Le Goater #define MII_BMCR_SPEED1000  (1 << 6)  /* MSB of Speed (1000) */
573e230569SGreg Ungerer 
586684bef1SAkihiko Odaki #define MII_BMSR_100T4      (1 << 15) /* Can do 100mbps T4 */
5930adcc8fSCédric Le Goater #define MII_BMSR_100TX_FD   (1 << 14) /* Can do 100mbps, full-duplex */
6030adcc8fSCédric Le Goater #define MII_BMSR_100TX_HD   (1 << 13) /* Can do 100mbps, half-duplex */
6130adcc8fSCédric Le Goater #define MII_BMSR_10T_FD     (1 << 12) /* Can do 10mbps, full-duplex */
6230adcc8fSCédric Le Goater #define MII_BMSR_10T_HD     (1 << 11) /* Can do 10mbps, half-duplex */
6330adcc8fSCédric Le Goater #define MII_BMSR_100T2_FD   (1 << 10) /* Can do 100mbps T2, full-duplex */
6430adcc8fSCédric Le Goater #define MII_BMSR_100T2_HD   (1 << 9)  /* Can do 100mbps T2, half-duplex */
6530adcc8fSCédric Le Goater #define MII_BMSR_EXTSTAT    (1 << 8)  /* Extended status in register 15 */
6630adcc8fSCédric Le Goater #define MII_BMSR_MFPS       (1 << 6)  /* MII Frame Preamble Suppression */
6730adcc8fSCédric Le Goater #define MII_BMSR_AN_COMP    (1 << 5)  /* Auto-negotiation complete */
6830adcc8fSCédric Le Goater #define MII_BMSR_RFAULT     (1 << 4)  /* Remote fault */
6930adcc8fSCédric Le Goater #define MII_BMSR_AUTONEG    (1 << 3)  /* Able to do auto-negotiation */
7030adcc8fSCédric Le Goater #define MII_BMSR_LINK_ST    (1 << 2)  /* Link status */
7130adcc8fSCédric Le Goater #define MII_BMSR_JABBER     (1 << 1)  /* Jabber detected */
7230adcc8fSCédric Le Goater #define MII_BMSR_EXTCAP     (1 << 0)  /* Ext-reg capability */
733e230569SGreg Ungerer 
74a1a62cedSMichael Tokarev #define MII_ANAR_PAUSE_ASYM (1 << 11) /* Try for asymmetric pause */
7530adcc8fSCédric Le Goater #define MII_ANAR_PAUSE      (1 << 10) /* Try for pause */
763e230569SGreg Ungerer #define MII_ANAR_TXFD       (1 << 8)
773e230569SGreg Ungerer #define MII_ANAR_TX         (1 << 7)
783e230569SGreg Ungerer #define MII_ANAR_10FD       (1 << 6)
793e230569SGreg Ungerer #define MII_ANAR_10         (1 << 5)
803e230569SGreg Ungerer #define MII_ANAR_CSMACD     (1 << 0)
813e230569SGreg Ungerer 
823634869bSGreg Ungerer #define MII_ANLPAR_ACK      (1 << 14)
8330adcc8fSCédric Le Goater #define MII_ANLPAR_PAUSEASY (1 << 11) /* can pause asymmetrically */
8430adcc8fSCédric Le Goater #define MII_ANLPAR_PAUSE    (1 << 10) /* can pause */
851a9a4949SAkihiko Odaki #define MII_ANLPAR_T4       (1 << 9)
863634869bSGreg Ungerer #define MII_ANLPAR_TXFD     (1 << 8)
873634869bSGreg Ungerer #define MII_ANLPAR_TX       (1 << 7)
883634869bSGreg Ungerer #define MII_ANLPAR_10FD     (1 << 6)
893634869bSGreg Ungerer #define MII_ANLPAR_10       (1 << 5)
903634869bSGreg Ungerer #define MII_ANLPAR_CSMACD   (1 << 0)
913634869bSGreg Ungerer 
921a9a4949SAkihiko Odaki #define MII_ANER_NP         (1 << 2)  /* Next Page Able */
9330adcc8fSCédric Le Goater #define MII_ANER_NWAY       (1 << 0)  /* Can do N-way auto-nego */
9430adcc8fSCédric Le Goater 
951a9a4949SAkihiko Odaki #define MII_ANNP_MP         (1 << 13) /* Message Page */
961a9a4949SAkihiko Odaki 
971a9a4949SAkihiko Odaki #define MII_CTRL1000_MASTER (1 << 11) /* MASTER-SLAVE Manual Configuration Value */
981a9a4949SAkihiko Odaki #define MII_CTRL1000_PORT   (1 << 10) /* T2_Repeater/DTE bit */
9930adcc8fSCédric Le Goater #define MII_CTRL1000_FULL   (1 << 9)  /* 1000BASE-T full duplex */
10030adcc8fSCédric Le Goater #define MII_CTRL1000_HALF   (1 << 8)  /* 1000BASE-T half duplex */
10130adcc8fSCédric Le Goater 
1021a9a4949SAkihiko Odaki #define MII_STAT1000_LOK    (1 << 13) /* Local Receiver Status */
1031a9a4949SAkihiko Odaki #define MII_STAT1000_ROK    (1 << 12) /* Remote Receiver Status */
10430adcc8fSCédric Le Goater #define MII_STAT1000_FULL   (1 << 11) /* 1000BASE-T full duplex */
10530adcc8fSCédric Le Goater #define MII_STAT1000_HALF   (1 << 10) /* 1000BASE-T half duplex */
10630adcc8fSCédric Le Goater 
1071a9a4949SAkihiko Odaki #define MII_EXTSTAT_1000T_FD (1 << 13) /* 1000BASE-T Full Duplex */
1081a9a4949SAkihiko Odaki #define MII_EXTSTAT_1000T_HD (1 << 12) /* 1000BASE-T Half Duplex */
1091a9a4949SAkihiko Odaki 
1103e230569SGreg Ungerer /* List of vendor identifiers */
111299f7becSGreg Ungerer /* RealTek 8201 */
1123e230569SGreg Ungerer #define RTL8201CP_PHYID1    0x0000
1133e230569SGreg Ungerer #define RTL8201CP_PHYID2    0x8201
1143e230569SGreg Ungerer 
11530adcc8fSCédric Le Goater /* RealTek 8211E */
11630adcc8fSCédric Le Goater #define RTL8211E_PHYID1     0x001c
11730adcc8fSCédric Le Goater #define RTL8211E_PHYID2     0xc915
11830adcc8fSCédric Le Goater 
119c110425dSMark Cave-Ayland /* National Semiconductor DP83840 */
120c110425dSMark Cave-Ayland #define DP83840_PHYID1      0x2000
121c110425dSMark Cave-Ayland #define DP83840_PHYID2      0x5c01
122c110425dSMark Cave-Ayland 
123299f7becSGreg Ungerer /* National Semiconductor DP83848 */
124299f7becSGreg Ungerer #define DP83848_PHYID1      0x2000
125299f7becSGreg Ungerer #define DP83848_PHYID2      0x5c90
126299f7becSGreg Ungerer 
1273e230569SGreg Ungerer #endif /* MII_H */
128