diff options
author | Koen Kooi <koen@openembedded.org> | 2009-11-25 10:27:57 +0100 |
---|---|---|
committer | Koen Kooi <koen@openembedded.org> | 2009-11-25 10:27:57 +0100 |
commit | 24c8c7b88f2271a95289fdf3e9b0c61a3e254ca9 (patch) | |
tree | c6d5dcf6b2dcea0f397a826d811ecd0d9ca7e4bf /recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch | |
parent | 46a3e348d56cb51ba75c291613e535510203225e (diff) | |
download | openembedded-24c8c7b88f2271a95289fdf3e9b0c61a3e254ca9.tar.gz |
linux-omap 2.6.29: add smsc patches and update overo defconfig
Diffstat (limited to 'recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch')
-rw-r--r-- | recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch | 152 |
1 files changed, 152 insertions, 0 deletions
diff --git a/recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch b/recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch new file mode 100644 index 0000000000..0fb7f4f0cc --- /dev/null +++ b/recipes/linux/linux-omap-2.6.29/smsc/smsc911x-3.patch @@ -0,0 +1,152 @@ +From: Steve Glendinning <steve.glendinning@smsc.com> + +On LAN9115/LAN9117/LAN9215/LAN9217, external phys are supported. These +are usually indicated by a hardware strap which sets an "external PHY +detected" bit in the HW_CFG register. + +In some cases it is desirable to override this hardware strap and force +use of either the internal phy or an external PHY. This patch adds +SMSC911X_FORCE_INTERNAL_PHY and SMSC911X_FORCE_EXTERNAL_PHY flags so a +platform can indicate this preference via its platform_data. + +Signed-off-by: Steve Glendinning <steve.glendinning@smsc.com> +Acked-by: Sascha Hauer <s.hauer@pengutronix.de> +Tested-by: Sascha Hauer <s.hauer@pengutronix.de> +--- + drivers/net/smsc911x.c | 75 +++++++++++++++++++++++---------------------- + include/linux/smsc911x.h | 2 + + 2 files changed, 40 insertions(+), 37 deletions(-) + +diff --git a/drivers/net/smsc911x.c b/drivers/net/smsc911x.c +index f882fd5..c7379f5 100644 +--- a/drivers/net/smsc911x.c ++++ b/drivers/net/smsc911x.c +@@ -368,48 +368,53 @@ out: + return reg; + } + +-/* Autodetects and initialises external phy for SMSC9115 and SMSC9117 flavors. +- * If something goes wrong, returns -ENODEV to revert back to internal phy. +- * Performed at initialisation only, so interrupts are enabled */ +-static int smsc911x_phy_initialise_external(struct smsc911x_data *pdata) ++/* Switch to external phy. Assumes tx and rx are stopped. */ ++static void smsc911x_phy_enable_external(struct smsc911x_data *pdata) + { + unsigned int hwcfg = smsc911x_reg_read(pdata, HW_CFG); + +- /* External phy is requested, supported, and detected */ +- if (hwcfg & HW_CFG_EXT_PHY_DET_) { ++ /* Disable phy clocks to the MAC */ ++ hwcfg &= (~HW_CFG_PHY_CLK_SEL_); ++ hwcfg |= HW_CFG_PHY_CLK_SEL_CLK_DIS_; ++ smsc911x_reg_write(pdata, HW_CFG, hwcfg); ++ udelay(10); /* Enough time for clocks to stop */ + +- /* Switch to external phy. Assuming tx and rx are stopped +- * because smsc911x_phy_initialise is called before +- * smsc911x_rx_initialise and tx_initialise. */ ++ /* Switch to external phy */ ++ hwcfg |= HW_CFG_EXT_PHY_EN_; ++ smsc911x_reg_write(pdata, HW_CFG, hwcfg); + +- /* Disable phy clocks to the MAC */ +- hwcfg &= (~HW_CFG_PHY_CLK_SEL_); +- hwcfg |= HW_CFG_PHY_CLK_SEL_CLK_DIS_; +- smsc911x_reg_write(pdata, HW_CFG, hwcfg); +- udelay(10); /* Enough time for clocks to stop */ ++ /* Enable phy clocks to the MAC */ ++ hwcfg &= (~HW_CFG_PHY_CLK_SEL_); ++ hwcfg |= HW_CFG_PHY_CLK_SEL_EXT_PHY_; ++ smsc911x_reg_write(pdata, HW_CFG, hwcfg); ++ udelay(10); /* Enough time for clocks to restart */ + +- /* Switch to external phy */ +- hwcfg |= HW_CFG_EXT_PHY_EN_; +- smsc911x_reg_write(pdata, HW_CFG, hwcfg); +- +- /* Enable phy clocks to the MAC */ +- hwcfg &= (~HW_CFG_PHY_CLK_SEL_); +- hwcfg |= HW_CFG_PHY_CLK_SEL_EXT_PHY_; +- smsc911x_reg_write(pdata, HW_CFG, hwcfg); +- udelay(10); /* Enough time for clocks to restart */ ++ hwcfg |= HW_CFG_SMI_SEL_; ++ smsc911x_reg_write(pdata, HW_CFG, hwcfg); ++} + +- hwcfg |= HW_CFG_SMI_SEL_; +- smsc911x_reg_write(pdata, HW_CFG, hwcfg); ++/* Autodetects and enables external phy if present on supported chips. ++ * autodetection can be overridden by specifying SMSC911X_FORCE_INTERNAL_PHY ++ * or SMSC911X_FORCE_EXTERNAL_PHY in the platform_data flags. */ ++static void smsc911x_phy_initialise_external(struct smsc911x_data *pdata) ++{ ++ unsigned int hwcfg = smsc911x_reg_read(pdata, HW_CFG); + +- SMSC_TRACE(HW, "Successfully switched to external PHY"); ++ if (pdata->config.flags & SMSC911X_FORCE_INTERNAL_PHY) { ++ SMSC_TRACE(HW, "Forcing internal PHY"); ++ pdata->using_extphy = 0; ++ } else if (pdata->config.flags & SMSC911X_FORCE_EXTERNAL_PHY) { ++ SMSC_TRACE(HW, "Forcing external PHY"); ++ smsc911x_phy_enable_external(pdata); ++ pdata->using_extphy = 1; ++ } else if (hwcfg & HW_CFG_EXT_PHY_DET_) { ++ SMSC_TRACE(HW, "HW_CFG EXT_PHY_DET set, using external PHY"); ++ smsc911x_phy_enable_external(pdata); + pdata->using_extphy = 1; + } else { +- SMSC_WARNING(HW, "No external PHY detected, " +- "Using internal PHY instead."); +- /* Use internal phy */ +- return -ENODEV; ++ SMSC_TRACE(HW, "HW_CFG EXT_PHY_DET clear, using internal PHY"); ++ pdata->using_extphy = 0; + } +- return 0; + } + + /* Fetches a tx status out of the status fifo */ +@@ -824,22 +829,18 @@ static int __devinit smsc911x_mii_init(struct platform_device *pdev, + + pdata->mii_bus->parent = &pdev->dev; + +- pdata->using_extphy = 0; +- + switch (pdata->idrev & 0xFFFF0000) { + case 0x01170000: + case 0x01150000: + case 0x117A0000: + case 0x115A0000: + /* External PHY supported, try to autodetect */ +- if (smsc911x_phy_initialise_external(pdata) < 0) { +- SMSC_TRACE(HW, "No external PHY detected, " +- "using internal PHY"); +- } ++ smsc911x_phy_initialise_external(pdata); + break; + default: + SMSC_TRACE(HW, "External PHY is not supported, " + "using internal PHY"); ++ pdata->using_extphy = 0; + break; + } + +diff --git a/include/linux/smsc911x.h b/include/linux/smsc911x.h +index 1cbf031..170c76b 100644 +--- a/include/linux/smsc911x.h ++++ b/include/linux/smsc911x.h +@@ -43,5 +43,7 @@ struct smsc911x_platform_config { + /* Constants for flags */ + #define SMSC911X_USE_16BIT (BIT(0)) + #define SMSC911X_USE_32BIT (BIT(1)) ++#define SMSC911X_FORCE_INTERNAL_PHY (BIT(2)) ++#define SMSC911X_FORCE_EXTERNAL_PHY (BIT(3)) + + #endif /* __LINUX_SMSC911X_H__ */ +-- +1.6.0.6 + +-- +To unsubscribe from this list: send the line "unsubscribe netdev" in +the body of a message to majordomo@vger.kernel.org +More majordomo info at http://vger.kernel.org/majordomo-info.html |