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 74*a1a62cedSMichael 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