mii.h (4925B)
1/* 2 * Common network MII address and register definitions. 3 * 4 * Copyright (C) 2014 Beniamino Galvani <b.galvani@gmail.com> 5 * 6 * Allwinner EMAC register definitions from Linux kernel are: 7 * Copyright 2012 Stefan Roese <sr@denx.de> 8 * Copyright 2013 Maxime Ripard <maxime.ripard@free-electrons.com> 9 * Copyright 1997 Sten Wang 10 * 11 * This program is free software; you can redistribute it and/or 12 * modify it under the terms of the GNU General Public License 13 * version 2 as published by the Free Software Foundation. 14 * 15 * This program is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU General Public License for more details. 19 * 20 */ 21#ifndef MII_H 22#define MII_H 23 24/* PHY registers */ 25#define MII_BMCR 0 /* Basic mode control register */ 26#define MII_BMSR 1 /* Basic mode status register */ 27#define MII_PHYID1 2 /* ID register 1 */ 28#define MII_PHYID2 3 /* ID register 2 */ 29#define MII_ANAR 4 /* Autonegotiation advertisement */ 30#define MII_ANLPAR 5 /* Autonegotiation lnk partner abilities */ 31#define MII_ANER 6 /* Autonegotiation expansion */ 32#define MII_ANNP 7 /* Autonegotiation next page */ 33#define MII_ANLPRNP 8 /* Autonegotiation link partner rx next page */ 34#define MII_CTRL1000 9 /* 1000BASE-T control */ 35#define MII_STAT1000 10 /* 1000BASE-T status */ 36#define MII_MDDACR 13 /* MMD access control */ 37#define MII_MDDAADR 14 /* MMD access address data */ 38#define MII_EXTSTAT 15 /* Extended Status */ 39#define MII_NSR 16 40#define MII_LBREMR 17 41#define MII_REC 18 42#define MII_SNRDR 19 43#define MII_TEST 25 44 45/* PHY registers fields */ 46#define MII_BMCR_RESET (1 << 15) 47#define MII_BMCR_LOOPBACK (1 << 14) 48#define MII_BMCR_SPEED100 (1 << 13) /* LSB of Speed (100) */ 49#define MII_BMCR_SPEED MII_BMCR_SPEED100 50#define MII_BMCR_AUTOEN (1 << 12) /* Autonegotiation enable */ 51#define MII_BMCR_PDOWN (1 << 11) /* Enable low power state */ 52#define MII_BMCR_ISOLATE (1 << 10) /* Isolate data paths from MII */ 53#define MII_BMCR_ANRESTART (1 << 9) /* Auto negotiation restart */ 54#define MII_BMCR_FD (1 << 8) /* Set duplex mode */ 55#define MII_BMCR_CTST (1 << 7) /* Collision test */ 56#define MII_BMCR_SPEED1000 (1 << 6) /* MSB of Speed (1000) */ 57 58#define MII_BMSR_100TX_FD (1 << 14) /* Can do 100mbps, full-duplex */ 59#define MII_BMSR_100TX_HD (1 << 13) /* Can do 100mbps, half-duplex */ 60#define MII_BMSR_10T_FD (1 << 12) /* Can do 10mbps, full-duplex */ 61#define MII_BMSR_10T_HD (1 << 11) /* Can do 10mbps, half-duplex */ 62#define MII_BMSR_100T2_FD (1 << 10) /* Can do 100mbps T2, full-duplex */ 63#define MII_BMSR_100T2_HD (1 << 9) /* Can do 100mbps T2, half-duplex */ 64#define MII_BMSR_EXTSTAT (1 << 8) /* Extended status in register 15 */ 65#define MII_BMSR_MFPS (1 << 6) /* MII Frame Preamble Suppression */ 66#define MII_BMSR_AN_COMP (1 << 5) /* Auto-negotiation complete */ 67#define MII_BMSR_RFAULT (1 << 4) /* Remote fault */ 68#define MII_BMSR_AUTONEG (1 << 3) /* Able to do auto-negotiation */ 69#define MII_BMSR_LINK_ST (1 << 2) /* Link status */ 70#define MII_BMSR_JABBER (1 << 1) /* Jabber detected */ 71#define MII_BMSR_EXTCAP (1 << 0) /* Ext-reg capability */ 72 73#define MII_ANAR_PAUSE_ASYM (1 << 11) /* Try for asymetric pause */ 74#define MII_ANAR_PAUSE (1 << 10) /* Try for pause */ 75#define MII_ANAR_TXFD (1 << 8) 76#define MII_ANAR_TX (1 << 7) 77#define MII_ANAR_10FD (1 << 6) 78#define MII_ANAR_10 (1 << 5) 79#define MII_ANAR_CSMACD (1 << 0) 80 81#define MII_ANLPAR_ACK (1 << 14) 82#define MII_ANLPAR_PAUSEASY (1 << 11) /* can pause asymmetrically */ 83#define MII_ANLPAR_PAUSE (1 << 10) /* can pause */ 84#define MII_ANLPAR_TXFD (1 << 8) 85#define MII_ANLPAR_TX (1 << 7) 86#define MII_ANLPAR_10FD (1 << 6) 87#define MII_ANLPAR_10 (1 << 5) 88#define MII_ANLPAR_CSMACD (1 << 0) 89 90#define MII_ANER_NWAY (1 << 0) /* Can do N-way auto-nego */ 91 92#define MII_CTRL1000_FULL (1 << 9) /* 1000BASE-T full duplex */ 93#define MII_CTRL1000_HALF (1 << 8) /* 1000BASE-T half duplex */ 94 95#define MII_STAT1000_FULL (1 << 11) /* 1000BASE-T full duplex */ 96#define MII_STAT1000_HALF (1 << 10) /* 1000BASE-T half duplex */ 97 98/* List of vendor identifiers */ 99/* RealTek 8201 */ 100#define RTL8201CP_PHYID1 0x0000 101#define RTL8201CP_PHYID2 0x8201 102 103/* RealTek 8211E */ 104#define RTL8211E_PHYID1 0x001c 105#define RTL8211E_PHYID2 0xc915 106 107/* National Semiconductor DP83840 */ 108#define DP83840_PHYID1 0x2000 109#define DP83840_PHYID2 0x5c01 110 111/* National Semiconductor DP83848 */ 112#define DP83848_PHYID1 0x2000 113#define DP83848_PHYID2 0x5c90 114 115#endif /* MII_H */