aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2011-08-26 13:13:04 -0400
committerDavid S. Miller <davem@davemloft.net>2011-08-26 13:13:04 -0400
commit3cd0999d134235d64b175edd2eb1d46ebc97b377 (patch)
tree7ae299a0d55bbdba0435563cacc1fc52f5a62490 /drivers
parent31c15a2f24ebdab14333d9bf5df49757842ae2ec (diff)
parentcd2967803617cd0a0bb8611e7d41c33a451207a5 (diff)
Merge branch 'davem-next.mii' of git://git.kernel.org/pub/scm/linux/kernel/git/romieu/netdev-2.6
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/ethernet/dlink/dl2k.c105
-rw-r--r--drivers/net/ethernet/dlink/dl2k.h110
-rw-r--r--drivers/net/ethernet/sun/sunbmac.c31
-rw-r--r--drivers/net/ethernet/sun/sunbmac.h17
4 files changed, 69 insertions, 194 deletions
diff --git a/drivers/net/ethernet/dlink/dl2k.c b/drivers/net/ethernet/dlink/dl2k.c
index 3fa91408532f..b2dc2c81a147 100644
--- a/drivers/net/ethernet/dlink/dl2k.c
+++ b/drivers/net/ethernet/dlink/dl2k.c
@@ -1428,7 +1428,7 @@ mii_wait_link (struct net_device *dev, int wait)
1428 1428
1429 do { 1429 do {
1430 bmsr = mii_read (dev, phy_addr, MII_BMSR); 1430 bmsr = mii_read (dev, phy_addr, MII_BMSR);
1431 if (bmsr & MII_BMSR_LINK_STATUS) 1431 if (bmsr & BMSR_LSTATUS)
1432 return 0; 1432 return 0;
1433 mdelay (1); 1433 mdelay (1);
1434 } while (--wait > 0); 1434 } while (--wait > 0);
@@ -1449,60 +1449,60 @@ mii_get_media (struct net_device *dev)
1449 1449
1450 bmsr = mii_read (dev, phy_addr, MII_BMSR); 1450 bmsr = mii_read (dev, phy_addr, MII_BMSR);
1451 if (np->an_enable) { 1451 if (np->an_enable) {
1452 if (!(bmsr & MII_BMSR_AN_COMPLETE)) { 1452 if (!(bmsr & BMSR_ANEGCOMPLETE)) {
1453 /* Auto-Negotiation not completed */ 1453 /* Auto-Negotiation not completed */
1454 return -1; 1454 return -1;
1455 } 1455 }
1456 negotiate = mii_read (dev, phy_addr, MII_ANAR) & 1456 negotiate = mii_read (dev, phy_addr, MII_ADVERTISE) &
1457 mii_read (dev, phy_addr, MII_ANLPAR); 1457 mii_read (dev, phy_addr, MII_LPA);
1458 mscr = mii_read (dev, phy_addr, MII_MSCR); 1458 mscr = mii_read (dev, phy_addr, MII_CTRL1000);
1459 mssr = mii_read (dev, phy_addr, MII_MSSR); 1459 mssr = mii_read (dev, phy_addr, MII_STAT1000);
1460 if (mscr & MII_MSCR_1000BT_FD && mssr & MII_MSSR_LP_1000BT_FD) { 1460 if (mscr & ADVERTISE_1000FULL && mssr & LPA_1000FULL) {
1461 np->speed = 1000; 1461 np->speed = 1000;
1462 np->full_duplex = 1; 1462 np->full_duplex = 1;
1463 printk (KERN_INFO "Auto 1000 Mbps, Full duplex\n"); 1463 printk (KERN_INFO "Auto 1000 Mbps, Full duplex\n");
1464 } else if (mscr & MII_MSCR_1000BT_HD && mssr & MII_MSSR_LP_1000BT_HD) { 1464 } else if (mscr & ADVERTISE_1000HALF && mssr & LPA_1000HALF) {
1465 np->speed = 1000; 1465 np->speed = 1000;
1466 np->full_duplex = 0; 1466 np->full_duplex = 0;
1467 printk (KERN_INFO "Auto 1000 Mbps, Half duplex\n"); 1467 printk (KERN_INFO "Auto 1000 Mbps, Half duplex\n");
1468 } else if (negotiate & MII_ANAR_100BX_FD) { 1468 } else if (negotiate & ADVERTISE_100FULL) {
1469 np->speed = 100; 1469 np->speed = 100;
1470 np->full_duplex = 1; 1470 np->full_duplex = 1;
1471 printk (KERN_INFO "Auto 100 Mbps, Full duplex\n"); 1471 printk (KERN_INFO "Auto 100 Mbps, Full duplex\n");
1472 } else if (negotiate & MII_ANAR_100BX_HD) { 1472 } else if (negotiate & ADVERTISE_100HALF) {
1473 np->speed = 100; 1473 np->speed = 100;
1474 np->full_duplex = 0; 1474 np->full_duplex = 0;
1475 printk (KERN_INFO "Auto 100 Mbps, Half duplex\n"); 1475 printk (KERN_INFO "Auto 100 Mbps, Half duplex\n");
1476 } else if (negotiate & MII_ANAR_10BT_FD) { 1476 } else if (negotiate & ADVERTISE_10FULL) {
1477 np->speed = 10; 1477 np->speed = 10;
1478 np->full_duplex = 1; 1478 np->full_duplex = 1;
1479 printk (KERN_INFO "Auto 10 Mbps, Full duplex\n"); 1479 printk (KERN_INFO "Auto 10 Mbps, Full duplex\n");
1480 } else if (negotiate & MII_ANAR_10BT_HD) { 1480 } else if (negotiate & ADVERTISE_10HALF) {
1481 np->speed = 10; 1481 np->speed = 10;
1482 np->full_duplex = 0; 1482 np->full_duplex = 0;
1483 printk (KERN_INFO "Auto 10 Mbps, Half duplex\n"); 1483 printk (KERN_INFO "Auto 10 Mbps, Half duplex\n");
1484 } 1484 }
1485 if (negotiate & MII_ANAR_PAUSE) { 1485 if (negotiate & ADVERTISE_PAUSE_CAP) {
1486 np->tx_flow &= 1; 1486 np->tx_flow &= 1;
1487 np->rx_flow &= 1; 1487 np->rx_flow &= 1;
1488 } else if (negotiate & MII_ANAR_ASYMMETRIC) { 1488 } else if (negotiate & ADVERTISE_PAUSE_ASYM) {
1489 np->tx_flow = 0; 1489 np->tx_flow = 0;
1490 np->rx_flow &= 1; 1490 np->rx_flow &= 1;
1491 } 1491 }
1492 /* else tx_flow, rx_flow = user select */ 1492 /* else tx_flow, rx_flow = user select */
1493 } else { 1493 } else {
1494 __u16 bmcr = mii_read (dev, phy_addr, MII_BMCR); 1494 __u16 bmcr = mii_read (dev, phy_addr, MII_BMCR);
1495 switch (bmcr & (MII_BMCR_SPEED_100 | MII_BMCR_SPEED_1000)) { 1495 switch (bmcr & (BMCR_SPEED100 | BMCR_SPEED1000)) {
1496 case MII_BMCR_SPEED_1000: 1496 case BMCR_SPEED1000:
1497 printk (KERN_INFO "Operating at 1000 Mbps, "); 1497 printk (KERN_INFO "Operating at 1000 Mbps, ");
1498 break; 1498 break;
1499 case MII_BMCR_SPEED_100: 1499 case BMCR_SPEED100:
1500 printk (KERN_INFO "Operating at 100 Mbps, "); 1500 printk (KERN_INFO "Operating at 100 Mbps, ");
1501 break; 1501 break;
1502 case 0: 1502 case 0:
1503 printk (KERN_INFO "Operating at 10 Mbps, "); 1503 printk (KERN_INFO "Operating at 10 Mbps, ");
1504 } 1504 }
1505 if (bmcr & MII_BMCR_DUPLEX_MODE) { 1505 if (bmcr & BMCR_FULLDPLX) {
1506 printk (KERN_CONT "Full duplex\n"); 1506 printk (KERN_CONT "Full duplex\n");
1507 } else { 1507 } else {
1508 printk (KERN_CONT "Half duplex\n"); 1508 printk (KERN_CONT "Half duplex\n");
@@ -1536,24 +1536,22 @@ mii_set_media (struct net_device *dev)
1536 if (np->an_enable) { 1536 if (np->an_enable) {
1537 /* Advertise capabilities */ 1537 /* Advertise capabilities */
1538 bmsr = mii_read (dev, phy_addr, MII_BMSR); 1538 bmsr = mii_read (dev, phy_addr, MII_BMSR);
1539 anar = mii_read (dev, phy_addr, MII_ANAR) & 1539 anar = mii_read (dev, phy_addr, MII_ADVERTISE) &
1540 ~MII_ANAR_100BX_FD & 1540 ~(ADVERTISE_100FULL | ADVERTISE_10FULL |
1541 ~MII_ANAR_100BX_HD & 1541 ADVERTISE_100HALF | ADVERTISE_10HALF |
1542 ~MII_ANAR_100BT4 & 1542 ADVERTISE_100BASE4);
1543 ~MII_ANAR_10BT_FD & 1543 if (bmsr & BMSR_100FULL)
1544 ~MII_ANAR_10BT_HD; 1544 anar |= ADVERTISE_100FULL;
1545 if (bmsr & MII_BMSR_100BX_FD) 1545 if (bmsr & BMSR_100HALF)
1546 anar |= MII_ANAR_100BX_FD; 1546 anar |= ADVERTISE_100HALF;
1547 if (bmsr & MII_BMSR_100BX_HD) 1547 if (bmsr & BMSR_100BASE4)
1548 anar |= MII_ANAR_100BX_HD; 1548 anar |= ADVERTISE_100BASE4;
1549 if (bmsr & MII_BMSR_100BT4) 1549 if (bmsr & BMSR_10FULL)
1550 anar |= MII_ANAR_100BT4; 1550 anar |= ADVERTISE_10FULL;
1551 if (bmsr & MII_BMSR_10BT_FD) 1551 if (bmsr & BMSR_10HALF)
1552 anar |= MII_ANAR_10BT_FD; 1552 anar |= ADVERTISE_10HALF;
1553 if (bmsr & MII_BMSR_10BT_HD) 1553 anar |= ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM;
1554 anar |= MII_ANAR_10BT_HD; 1554 mii_write (dev, phy_addr, MII_ADVERTISE, anar);
1555 anar |= MII_ANAR_PAUSE | MII_ANAR_ASYMMETRIC;
1556 mii_write (dev, phy_addr, MII_ANAR, anar);
1557 1555
1558 /* Enable Auto crossover */ 1556 /* Enable Auto crossover */
1559 pscr = mii_read (dev, phy_addr, MII_PHY_SCR); 1557 pscr = mii_read (dev, phy_addr, MII_PHY_SCR);
@@ -1561,8 +1559,8 @@ mii_set_media (struct net_device *dev)
1561 mii_write (dev, phy_addr, MII_PHY_SCR, pscr); 1559 mii_write (dev, phy_addr, MII_PHY_SCR, pscr);
1562 1560
1563 /* Soft reset PHY */ 1561 /* Soft reset PHY */
1564 mii_write (dev, phy_addr, MII_BMCR, MII_BMCR_RESET); 1562 mii_write (dev, phy_addr, MII_BMCR, BMCR_RESET);
1565 bmcr = MII_BMCR_AN_ENABLE | MII_BMCR_RESTART_AN | MII_BMCR_RESET; 1563 bmcr = BMCR_ANENABLE | BMCR_ANRESTART | BMCR_RESET;
1566 mii_write (dev, phy_addr, MII_BMCR, bmcr); 1564 mii_write (dev, phy_addr, MII_BMCR, bmcr);
1567 mdelay(1); 1565 mdelay(1);
1568 } else { 1566 } else {
@@ -1574,7 +1572,7 @@ mii_set_media (struct net_device *dev)
1574 1572
1575 /* 2) PHY Reset */ 1573 /* 2) PHY Reset */
1576 bmcr = mii_read (dev, phy_addr, MII_BMCR); 1574 bmcr = mii_read (dev, phy_addr, MII_BMCR);
1577 bmcr |= MII_BMCR_RESET; 1575 bmcr |= BMCR_RESET;
1578 mii_write (dev, phy_addr, MII_BMCR, bmcr); 1576 mii_write (dev, phy_addr, MII_BMCR, bmcr);
1579 1577
1580 /* 3) Power Down */ 1578 /* 3) Power Down */
@@ -1583,25 +1581,25 @@ mii_set_media (struct net_device *dev)
1583 mdelay (100); /* wait a certain time */ 1581 mdelay (100); /* wait a certain time */
1584 1582
1585 /* 4) Advertise nothing */ 1583 /* 4) Advertise nothing */
1586 mii_write (dev, phy_addr, MII_ANAR, 0); 1584 mii_write (dev, phy_addr, MII_ADVERTISE, 0);
1587 1585
1588 /* 5) Set media and Power Up */ 1586 /* 5) Set media and Power Up */
1589 bmcr = MII_BMCR_POWER_DOWN; 1587 bmcr = BMCR_PDOWN;
1590 if (np->speed == 100) { 1588 if (np->speed == 100) {
1591 bmcr |= MII_BMCR_SPEED_100; 1589 bmcr |= BMCR_SPEED100;
1592 printk (KERN_INFO "Manual 100 Mbps, "); 1590 printk (KERN_INFO "Manual 100 Mbps, ");
1593 } else if (np->speed == 10) { 1591 } else if (np->speed == 10) {
1594 printk (KERN_INFO "Manual 10 Mbps, "); 1592 printk (KERN_INFO "Manual 10 Mbps, ");
1595 } 1593 }
1596 if (np->full_duplex) { 1594 if (np->full_duplex) {
1597 bmcr |= MII_BMCR_DUPLEX_MODE; 1595 bmcr |= BMCR_FULLDPLX;
1598 printk (KERN_CONT "Full duplex\n"); 1596 printk (KERN_CONT "Full duplex\n");
1599 } else { 1597 } else {
1600 printk (KERN_CONT "Half duplex\n"); 1598 printk (KERN_CONT "Half duplex\n");
1601 } 1599 }
1602#if 0 1600#if 0
1603 /* Set 1000BaseT Master/Slave setting */ 1601 /* Set 1000BaseT Master/Slave setting */
1604 mscr = mii_read (dev, phy_addr, MII_MSCR); 1602 mscr = mii_read (dev, phy_addr, MII_CTRL1000);
1605 mscr |= MII_MSCR_CFG_ENABLE; 1603 mscr |= MII_MSCR_CFG_ENABLE;
1606 mscr &= ~MII_MSCR_CFG_VALUE = 0; 1604 mscr &= ~MII_MSCR_CFG_VALUE = 0;
1607#endif 1605#endif
@@ -1624,7 +1622,7 @@ mii_get_media_pcs (struct net_device *dev)
1624 1622
1625 bmsr = mii_read (dev, phy_addr, PCS_BMSR); 1623 bmsr = mii_read (dev, phy_addr, PCS_BMSR);
1626 if (np->an_enable) { 1624 if (np->an_enable) {
1627 if (!(bmsr & MII_BMSR_AN_COMPLETE)) { 1625 if (!(bmsr & BMSR_ANEGCOMPLETE)) {
1628 /* Auto-Negotiation not completed */ 1626 /* Auto-Negotiation not completed */
1629 return -1; 1627 return -1;
1630 } 1628 }
@@ -1649,7 +1647,7 @@ mii_get_media_pcs (struct net_device *dev)
1649 } else { 1647 } else {
1650 __u16 bmcr = mii_read (dev, phy_addr, PCS_BMCR); 1648 __u16 bmcr = mii_read (dev, phy_addr, PCS_BMCR);
1651 printk (KERN_INFO "Operating at 1000 Mbps, "); 1649 printk (KERN_INFO "Operating at 1000 Mbps, ");
1652 if (bmcr & MII_BMCR_DUPLEX_MODE) { 1650 if (bmcr & BMCR_FULLDPLX) {
1653 printk (KERN_CONT "Full duplex\n"); 1651 printk (KERN_CONT "Full duplex\n");
1654 } else { 1652 } else {
1655 printk (KERN_CONT "Half duplex\n"); 1653 printk (KERN_CONT "Half duplex\n");
@@ -1682,7 +1680,7 @@ mii_set_media_pcs (struct net_device *dev)
1682 if (np->an_enable) { 1680 if (np->an_enable) {
1683 /* Advertise capabilities */ 1681 /* Advertise capabilities */
1684 esr = mii_read (dev, phy_addr, PCS_ESR); 1682 esr = mii_read (dev, phy_addr, PCS_ESR);
1685 anar = mii_read (dev, phy_addr, MII_ANAR) & 1683 anar = mii_read (dev, phy_addr, MII_ADVERTISE) &
1686 ~PCS_ANAR_HALF_DUPLEX & 1684 ~PCS_ANAR_HALF_DUPLEX &
1687 ~PCS_ANAR_FULL_DUPLEX; 1685 ~PCS_ANAR_FULL_DUPLEX;
1688 if (esr & (MII_ESR_1000BT_HD | MII_ESR_1000BX_HD)) 1686 if (esr & (MII_ESR_1000BT_HD | MII_ESR_1000BX_HD))
@@ -1690,22 +1688,21 @@ mii_set_media_pcs (struct net_device *dev)
1690 if (esr & (MII_ESR_1000BT_FD | MII_ESR_1000BX_FD)) 1688 if (esr & (MII_ESR_1000BT_FD | MII_ESR_1000BX_FD))
1691 anar |= PCS_ANAR_FULL_DUPLEX; 1689 anar |= PCS_ANAR_FULL_DUPLEX;
1692 anar |= PCS_ANAR_PAUSE | PCS_ANAR_ASYMMETRIC; 1690 anar |= PCS_ANAR_PAUSE | PCS_ANAR_ASYMMETRIC;
1693 mii_write (dev, phy_addr, MII_ANAR, anar); 1691 mii_write (dev, phy_addr, MII_ADVERTISE, anar);
1694 1692
1695 /* Soft reset PHY */ 1693 /* Soft reset PHY */
1696 mii_write (dev, phy_addr, MII_BMCR, MII_BMCR_RESET); 1694 mii_write (dev, phy_addr, MII_BMCR, BMCR_RESET);
1697 bmcr = MII_BMCR_AN_ENABLE | MII_BMCR_RESTART_AN | 1695 bmcr = BMCR_ANENABLE | BMCR_ANRESTART | BMCR_RESET;
1698 MII_BMCR_RESET;
1699 mii_write (dev, phy_addr, MII_BMCR, bmcr); 1696 mii_write (dev, phy_addr, MII_BMCR, bmcr);
1700 mdelay(1); 1697 mdelay(1);
1701 } else { 1698 } else {
1702 /* Force speed setting */ 1699 /* Force speed setting */
1703 /* PHY Reset */ 1700 /* PHY Reset */
1704 bmcr = MII_BMCR_RESET; 1701 bmcr = BMCR_RESET;
1705 mii_write (dev, phy_addr, MII_BMCR, bmcr); 1702 mii_write (dev, phy_addr, MII_BMCR, bmcr);
1706 mdelay(10); 1703 mdelay(10);
1707 if (np->full_duplex) { 1704 if (np->full_duplex) {
1708 bmcr = MII_BMCR_DUPLEX_MODE; 1705 bmcr = BMCR_FULLDPLX;
1709 printk (KERN_INFO "Manual full duplex\n"); 1706 printk (KERN_INFO "Manual full duplex\n");
1710 } else { 1707 } else {
1711 bmcr = 0; 1708 bmcr = 0;
@@ -1715,7 +1712,7 @@ mii_set_media_pcs (struct net_device *dev)
1715 mdelay(10); 1712 mdelay(10);
1716 1713
1717 /* Advertise nothing */ 1714 /* Advertise nothing */
1718 mii_write (dev, phy_addr, MII_ANAR, 0); 1715 mii_write (dev, phy_addr, MII_ADVERTISE, 0);
1719 } 1716 }
1720 return 0; 1717 return 0;
1721} 1718}
diff --git a/drivers/net/ethernet/dlink/dl2k.h b/drivers/net/ethernet/dlink/dl2k.h
index 7caab3d26a9e..ba0adcafa55a 100644
--- a/drivers/net/ethernet/dlink/dl2k.h
+++ b/drivers/net/ethernet/dlink/dl2k.h
@@ -28,6 +28,7 @@
28#include <linux/init.h> 28#include <linux/init.h>
29#include <linux/crc32.h> 29#include <linux/crc32.h>
30#include <linux/ethtool.h> 30#include <linux/ethtool.h>
31#include <linux/mii.h>
31#include <linux/bitops.h> 32#include <linux/bitops.h>
32#include <asm/processor.h> /* Processor type for cache alignment. */ 33#include <asm/processor.h> /* Processor type for cache alignment. */
33#include <asm/io.h> 34#include <asm/io.h>
@@ -271,20 +272,9 @@ enum RFS_bits {
271#define MII_RESET_TIME_OUT 10000 272#define MII_RESET_TIME_OUT 10000
272/* MII register */ 273/* MII register */
273enum _mii_reg { 274enum _mii_reg {
274 MII_BMCR = 0,
275 MII_BMSR = 1,
276 MII_PHY_ID1 = 2,
277 MII_PHY_ID2 = 3,
278 MII_ANAR = 4,
279 MII_ANLPAR = 5,
280 MII_ANER = 6,
281 MII_ANNPT = 7,
282 MII_ANLPRNP = 8,
283 MII_MSCR = 9,
284 MII_MSSR = 10,
285 MII_ESR = 15,
286 MII_PHY_SCR = 16, 275 MII_PHY_SCR = 16,
287}; 276};
277
288/* PCS register */ 278/* PCS register */
289enum _pcs_reg { 279enum _pcs_reg {
290 PCS_BMCR = 0, 280 PCS_BMCR = 0,
@@ -297,102 +287,6 @@ enum _pcs_reg {
297 PCS_ESR = 15, 287 PCS_ESR = 15,
298}; 288};
299 289
300/* Basic Mode Control Register */
301enum _mii_bmcr {
302 MII_BMCR_RESET = 0x8000,
303 MII_BMCR_LOOP_BACK = 0x4000,
304 MII_BMCR_SPEED_LSB = 0x2000,
305 MII_BMCR_AN_ENABLE = 0x1000,
306 MII_BMCR_POWER_DOWN = 0x0800,
307 MII_BMCR_ISOLATE = 0x0400,
308 MII_BMCR_RESTART_AN = 0x0200,
309 MII_BMCR_DUPLEX_MODE = 0x0100,
310 MII_BMCR_COL_TEST = 0x0080,
311 MII_BMCR_SPEED_MSB = 0x0040,
312 MII_BMCR_SPEED_RESERVED = 0x003f,
313 MII_BMCR_SPEED_10 = 0,
314 MII_BMCR_SPEED_100 = MII_BMCR_SPEED_LSB,
315 MII_BMCR_SPEED_1000 = MII_BMCR_SPEED_MSB,
316};
317
318/* Basic Mode Status Register */
319enum _mii_bmsr {
320 MII_BMSR_100BT4 = 0x8000,
321 MII_BMSR_100BX_FD = 0x4000,
322 MII_BMSR_100BX_HD = 0x2000,
323 MII_BMSR_10BT_FD = 0x1000,
324 MII_BMSR_10BT_HD = 0x0800,
325 MII_BMSR_100BT2_FD = 0x0400,
326 MII_BMSR_100BT2_HD = 0x0200,
327 MII_BMSR_EXT_STATUS = 0x0100,
328 MII_BMSR_PREAMBLE_SUPP = 0x0040,
329 MII_BMSR_AN_COMPLETE = 0x0020,
330 MII_BMSR_REMOTE_FAULT = 0x0010,
331 MII_BMSR_AN_ABILITY = 0x0008,
332 MII_BMSR_LINK_STATUS = 0x0004,
333 MII_BMSR_JABBER_DETECT = 0x0002,
334 MII_BMSR_EXT_CAP = 0x0001,
335};
336
337/* ANAR */
338enum _mii_anar {
339 MII_ANAR_NEXT_PAGE = 0x8000,
340 MII_ANAR_REMOTE_FAULT = 0x4000,
341 MII_ANAR_ASYMMETRIC = 0x0800,
342 MII_ANAR_PAUSE = 0x0400,
343 MII_ANAR_100BT4 = 0x0200,
344 MII_ANAR_100BX_FD = 0x0100,
345 MII_ANAR_100BX_HD = 0x0080,
346 MII_ANAR_10BT_FD = 0x0020,
347 MII_ANAR_10BT_HD = 0x0010,
348 MII_ANAR_SELECTOR = 0x001f,
349 MII_IEEE8023_CSMACD = 0x0001,
350};
351
352/* ANLPAR */
353enum _mii_anlpar {
354 MII_ANLPAR_NEXT_PAGE = MII_ANAR_NEXT_PAGE,
355 MII_ANLPAR_REMOTE_FAULT = MII_ANAR_REMOTE_FAULT,
356 MII_ANLPAR_ASYMMETRIC = MII_ANAR_ASYMMETRIC,
357 MII_ANLPAR_PAUSE = MII_ANAR_PAUSE,
358 MII_ANLPAR_100BT4 = MII_ANAR_100BT4,
359 MII_ANLPAR_100BX_FD = MII_ANAR_100BX_FD,
360 MII_ANLPAR_100BX_HD = MII_ANAR_100BX_HD,
361 MII_ANLPAR_10BT_FD = MII_ANAR_10BT_FD,
362 MII_ANLPAR_10BT_HD = MII_ANAR_10BT_HD,
363 MII_ANLPAR_SELECTOR = MII_ANAR_SELECTOR,
364};
365
366/* Auto-Negotiation Expansion Register */
367enum _mii_aner {
368 MII_ANER_PAR_DETECT_FAULT = 0x0010,
369 MII_ANER_LP_NEXTPAGABLE = 0x0008,
370 MII_ANER_NETXTPAGABLE = 0x0004,
371 MII_ANER_PAGE_RECEIVED = 0x0002,
372 MII_ANER_LP_NEGOTIABLE = 0x0001,
373};
374
375/* MASTER-SLAVE Control Register */
376enum _mii_mscr {
377 MII_MSCR_TEST_MODE = 0xe000,
378 MII_MSCR_CFG_ENABLE = 0x1000,
379 MII_MSCR_CFG_VALUE = 0x0800,
380 MII_MSCR_PORT_VALUE = 0x0400,
381 MII_MSCR_1000BT_FD = 0x0200,
382 MII_MSCR_1000BT_HD = 0X0100,
383};
384
385/* MASTER-SLAVE Status Register */
386enum _mii_mssr {
387 MII_MSSR_CFG_FAULT = 0x8000,
388 MII_MSSR_CFG_RES = 0x4000,
389 MII_MSSR_LOCAL_RCV_STATUS = 0x2000,
390 MII_MSSR_REMOTE_RCVR = 0x1000,
391 MII_MSSR_LP_1000BT_FD = 0x0800,
392 MII_MSSR_LP_1000BT_HD = 0x0400,
393 MII_MSSR_IDLE_ERR_COUNT = 0x00ff,
394};
395
396/* IEEE Extened Status Register */ 290/* IEEE Extened Status Register */
397enum _mii_esr { 291enum _mii_esr {
398 MII_ESR_1000BX_FD = 0x8000, 292 MII_ESR_1000BX_FD = 0x8000,
diff --git a/drivers/net/ethernet/sun/sunbmac.c b/drivers/net/ethernet/sun/sunbmac.c
index c94f5ef348d4..0d8cfd9ea053 100644
--- a/drivers/net/ethernet/sun/sunbmac.c
+++ b/drivers/net/ethernet/sun/sunbmac.c
@@ -17,6 +17,7 @@
17#include <linux/crc32.h> 17#include <linux/crc32.h>
18#include <linux/errno.h> 18#include <linux/errno.h>
19#include <linux/ethtool.h> 19#include <linux/ethtool.h>
20#include <linux/mii.h>
20#include <linux/netdevice.h> 21#include <linux/netdevice.h>
21#include <linux/etherdevice.h> 22#include <linux/etherdevice.h>
22#include <linux/skbuff.h> 23#include <linux/skbuff.h>
@@ -500,13 +501,13 @@ static int try_next_permutation(struct bigmac *bp, void __iomem *tregs)
500 501
501 /* Reset the PHY. */ 502 /* Reset the PHY. */
502 bp->sw_bmcr = (BMCR_ISOLATE | BMCR_PDOWN | BMCR_LOOPBACK); 503 bp->sw_bmcr = (BMCR_ISOLATE | BMCR_PDOWN | BMCR_LOOPBACK);
503 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 504 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
504 bp->sw_bmcr = (BMCR_RESET); 505 bp->sw_bmcr = (BMCR_RESET);
505 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 506 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
506 507
507 timeout = 64; 508 timeout = 64;
508 while (--timeout) { 509 while (--timeout) {
509 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 510 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
510 if ((bp->sw_bmcr & BMCR_RESET) == 0) 511 if ((bp->sw_bmcr & BMCR_RESET) == 0)
511 break; 512 break;
512 udelay(20); 513 udelay(20);
@@ -514,11 +515,11 @@ static int try_next_permutation(struct bigmac *bp, void __iomem *tregs)
514 if (timeout == 0) 515 if (timeout == 0)
515 printk(KERN_ERR "%s: PHY reset failed.\n", bp->dev->name); 516 printk(KERN_ERR "%s: PHY reset failed.\n", bp->dev->name);
516 517
517 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 518 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
518 519
519 /* Now we try 10baseT. */ 520 /* Now we try 10baseT. */
520 bp->sw_bmcr &= ~(BMCR_SPEED100); 521 bp->sw_bmcr &= ~(BMCR_SPEED100);
521 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 522 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
522 return 0; 523 return 0;
523 } 524 }
524 525
@@ -534,8 +535,8 @@ static void bigmac_timer(unsigned long data)
534 535
535 bp->timer_ticks++; 536 bp->timer_ticks++;
536 if (bp->timer_state == ltrywait) { 537 if (bp->timer_state == ltrywait) {
537 bp->sw_bmsr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMSR); 538 bp->sw_bmsr = bigmac_tcvr_read(bp, tregs, MII_BMSR);
538 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 539 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
539 if (bp->sw_bmsr & BMSR_LSTATUS) { 540 if (bp->sw_bmsr & BMSR_LSTATUS) {
540 printk(KERN_INFO "%s: Link is now up at %s.\n", 541 printk(KERN_INFO "%s: Link is now up at %s.\n",
541 bp->dev->name, 542 bp->dev->name,
@@ -588,18 +589,18 @@ static void bigmac_begin_auto_negotiation(struct bigmac *bp)
588 int timeout; 589 int timeout;
589 590
590 /* Grab new software copies of PHY registers. */ 591 /* Grab new software copies of PHY registers. */
591 bp->sw_bmsr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMSR); 592 bp->sw_bmsr = bigmac_tcvr_read(bp, tregs, MII_BMSR);
592 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 593 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
593 594
594 /* Reset the PHY. */ 595 /* Reset the PHY. */
595 bp->sw_bmcr = (BMCR_ISOLATE | BMCR_PDOWN | BMCR_LOOPBACK); 596 bp->sw_bmcr = (BMCR_ISOLATE | BMCR_PDOWN | BMCR_LOOPBACK);
596 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 597 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
597 bp->sw_bmcr = (BMCR_RESET); 598 bp->sw_bmcr = (BMCR_RESET);
598 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 599 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
599 600
600 timeout = 64; 601 timeout = 64;
601 while (--timeout) { 602 while (--timeout) {
602 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 603 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
603 if ((bp->sw_bmcr & BMCR_RESET) == 0) 604 if ((bp->sw_bmcr & BMCR_RESET) == 0)
604 break; 605 break;
605 udelay(20); 606 udelay(20);
@@ -607,11 +608,11 @@ static void bigmac_begin_auto_negotiation(struct bigmac *bp)
607 if (timeout == 0) 608 if (timeout == 0)
608 printk(KERN_ERR "%s: PHY reset failed.\n", bp->dev->name); 609 printk(KERN_ERR "%s: PHY reset failed.\n", bp->dev->name);
609 610
610 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, BIGMAC_BMCR); 611 bp->sw_bmcr = bigmac_tcvr_read(bp, tregs, MII_BMCR);
611 612
612 /* First we try 100baseT. */ 613 /* First we try 100baseT. */
613 bp->sw_bmcr |= BMCR_SPEED100; 614 bp->sw_bmcr |= BMCR_SPEED100;
614 bigmac_tcvr_write(bp, tregs, BIGMAC_BMCR, bp->sw_bmcr); 615 bigmac_tcvr_write(bp, tregs, MII_BMCR, bp->sw_bmcr);
615 616
616 bp->timer_state = ltrywait; 617 bp->timer_state = ltrywait;
617 bp->timer_ticks = 0; 618 bp->timer_ticks = 0;
@@ -1054,7 +1055,7 @@ static u32 bigmac_get_link(struct net_device *dev)
1054 struct bigmac *bp = netdev_priv(dev); 1055 struct bigmac *bp = netdev_priv(dev);
1055 1056
1056 spin_lock_irq(&bp->lock); 1057 spin_lock_irq(&bp->lock);
1057 bp->sw_bmsr = bigmac_tcvr_read(bp, bp->tregs, BIGMAC_BMSR); 1058 bp->sw_bmsr = bigmac_tcvr_read(bp, bp->tregs, MII_BMSR);
1058 spin_unlock_irq(&bp->lock); 1059 spin_unlock_irq(&bp->lock);
1059 1060
1060 return (bp->sw_bmsr & BMSR_LSTATUS); 1061 return (bp->sw_bmsr & BMSR_LSTATUS);
diff --git a/drivers/net/ethernet/sun/sunbmac.h b/drivers/net/ethernet/sun/sunbmac.h
index 4943e975a731..06dd21707353 100644
--- a/drivers/net/ethernet/sun/sunbmac.h
+++ b/drivers/net/ethernet/sun/sunbmac.h
@@ -223,23 +223,6 @@
223#define BIGMAC_PHY_EXTERNAL 0 /* External transceiver */ 223#define BIGMAC_PHY_EXTERNAL 0 /* External transceiver */
224#define BIGMAC_PHY_INTERNAL 1 /* Internal transceiver */ 224#define BIGMAC_PHY_INTERNAL 1 /* Internal transceiver */
225 225
226/* PHY registers */
227#define BIGMAC_BMCR 0x00 /* Basic mode control register */
228#define BIGMAC_BMSR 0x01 /* Basic mode status register */
229
230/* BMCR bits */
231#define BMCR_ISOLATE 0x0400 /* Disconnect DP83840 from MII */
232#define BMCR_PDOWN 0x0800 /* Powerdown the DP83840 */
233#define BMCR_ANENABLE 0x1000 /* Enable auto negotiation */
234#define BMCR_SPEED100 0x2000 /* Select 100Mbps */
235#define BMCR_LOOPBACK 0x4000 /* TXD loopback bits */
236#define BMCR_RESET 0x8000 /* Reset the DP83840 */
237
238/* BMSR bits */
239#define BMSR_ERCAP 0x0001 /* Ext-reg capability */
240#define BMSR_JCD 0x0002 /* Jabber detected */
241#define BMSR_LSTATUS 0x0004 /* Link status */
242
243/* Ring descriptors and such, same as Quad Ethernet. */ 226/* Ring descriptors and such, same as Quad Ethernet. */
244struct be_rxd { 227struct be_rxd {
245 u32 rx_flags; 228 u32 rx_flags;