diff options
author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-09 18:26:43 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-09 18:26:43 -0400 |
commit | 71ba22fa739029bb158144813b9e82c00326497c (patch) | |
tree | cca33deab3b79b38e15e6b3f7d7f9dfbf7ab32a2 /drivers/net/gianfar.c | |
parent | 27a278aa4309df244a2619f47031acce00ca1b7c (diff) | |
parent | f2ec8030085a27c4ba8e95a10a96f248efb34177 (diff) |
Merge branch 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6
* 'upstream-linus' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6: (75 commits)
Ethernet driver for EISA only SNI RM200/RM400 machines
Extract chip specific code out of lasi_82596.c
ehea: Whitespace cleanup
pasemi_mac: Fix TX interrupt threshold
spidernet: Replace literal with const
r8169: perform RX config change after mac filtering
r8169: mac address change support
r8169: display some extra debug information during startup
r8169: add endianess annotations to [RT]xDesc
r8169: align the IP header when there is no DMA constraint
r8169: add bit description for the TxPoll register
r8169: cleanup
r8169: remove the media option
r8169: small 8101 comment
r8169: confusion between hardware and IP header alignment
r8169: merge with version 8.001.00 of Realtek's r8168 driver
r8169: merge with version 6.001.00 of Realtek's r8169 driver
r8169: prettify mac_version
r8169: populate the hw_start handler for the 8110
r8169: populate the hw_start handler for the 8168
...
Diffstat (limited to 'drivers/net/gianfar.c')
-rw-r--r-- | drivers/net/gianfar.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 1b854bf07b09..d7a1a58de766 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
@@ -130,6 +130,9 @@ static int gfar_remove(struct platform_device *pdev); | |||
130 | static void free_skb_resources(struct gfar_private *priv); | 130 | static void free_skb_resources(struct gfar_private *priv); |
131 | static void gfar_set_multi(struct net_device *dev); | 131 | static void gfar_set_multi(struct net_device *dev); |
132 | static void gfar_set_hash_for_addr(struct net_device *dev, u8 *addr); | 132 | static void gfar_set_hash_for_addr(struct net_device *dev, u8 *addr); |
133 | static void gfar_configure_serdes(struct net_device *dev); | ||
134 | extern int gfar_local_mdio_write(struct gfar_mii *regs, int mii_id, int regnum, u16 value); | ||
135 | extern int gfar_local_mdio_read(struct gfar_mii *regs, int mii_id, int regnum); | ||
133 | #ifdef CONFIG_GFAR_NAPI | 136 | #ifdef CONFIG_GFAR_NAPI |
134 | static int gfar_poll(struct net_device *dev, int *budget); | 137 | static int gfar_poll(struct net_device *dev, int *budget); |
135 | #endif | 138 | #endif |
@@ -451,6 +454,9 @@ static int init_phy(struct net_device *dev) | |||
451 | 454 | ||
452 | phydev = phy_connect(dev, phy_id, &adjust_link, 0, interface); | 455 | phydev = phy_connect(dev, phy_id, &adjust_link, 0, interface); |
453 | 456 | ||
457 | if (interface == PHY_INTERFACE_MODE_SGMII) | ||
458 | gfar_configure_serdes(dev); | ||
459 | |||
454 | if (IS_ERR(phydev)) { | 460 | if (IS_ERR(phydev)) { |
455 | printk(KERN_ERR "%s: Could not attach to PHY\n", dev->name); | 461 | printk(KERN_ERR "%s: Could not attach to PHY\n", dev->name); |
456 | return PTR_ERR(phydev); | 462 | return PTR_ERR(phydev); |
@@ -465,6 +471,27 @@ static int init_phy(struct net_device *dev) | |||
465 | return 0; | 471 | return 0; |
466 | } | 472 | } |
467 | 473 | ||
474 | static void gfar_configure_serdes(struct net_device *dev) | ||
475 | { | ||
476 | struct gfar_private *priv = netdev_priv(dev); | ||
477 | struct gfar_mii __iomem *regs = | ||
478 | (void __iomem *)&priv->regs->gfar_mii_regs; | ||
479 | |||
480 | /* Initialise TBI i/f to communicate with serdes (lynx phy) */ | ||
481 | |||
482 | /* Single clk mode, mii mode off(for aerdes communication) */ | ||
483 | gfar_local_mdio_write(regs, TBIPA_VALUE, MII_TBICON, TBICON_CLK_SELECT); | ||
484 | |||
485 | /* Supported pause and full-duplex, no half-duplex */ | ||
486 | gfar_local_mdio_write(regs, TBIPA_VALUE, MII_ADVERTISE, | ||
487 | ADVERTISE_1000XFULL | ADVERTISE_1000XPAUSE | | ||
488 | ADVERTISE_1000XPSE_ASYM); | ||
489 | |||
490 | /* ANEG enable, restart ANEG, full duplex mode, speed[1] set */ | ||
491 | gfar_local_mdio_write(regs, TBIPA_VALUE, MII_BMCR, BMCR_ANENABLE | | ||
492 | BMCR_ANRESTART | BMCR_FULLDPLX | BMCR_SPEED1000); | ||
493 | } | ||
494 | |||
468 | static void init_registers(struct net_device *dev) | 495 | static void init_registers(struct net_device *dev) |
469 | { | 496 | { |
470 | struct gfar_private *priv = netdev_priv(dev); | 497 | struct gfar_private *priv = netdev_priv(dev); |