diff options
author | Fabio Estevam <fabio.estevam@nxp.com> | 2016-11-01 14:58:16 -0200 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2016-11-06 07:40:40 -0500 |
commit | dac09fc10b71045ac261a9b8a05d34029ebec2ae (patch) | |
tree | 00c5f8b5630d8c5baed413c314f1ae2bd3e1639a /board/wandboard | |
parent | 0f7c6cdc8143d6cf0577a84bf27bdaadd6229ff4 (diff) | |
download | u-boot-dac09fc10b71045ac261a9b8a05d34029ebec2ae.tar.gz u-boot-dac09fc10b71045ac261a9b8a05d34029ebec2ae.tar.bz2 u-boot-dac09fc10b71045ac261a9b8a05d34029ebec2ae.zip |
wandboard: Make Ethernet functional again
Since commit ce412b79e7255770 ("drivers: net: phy: atheros: add separate
config for AR8031") ethernet does not work on mx6sabresd.
This commit correctly assigns ar8031_config() as the configuration
function for AR8031 in the same way as done in the Linux kernel.
However, on wandboard design we need some additional configuration,
such as enabling the 125 MHz AR8031 output that needs to be done
in the board file.
This also aligns with the same method that the kernel performs
the AR8031 fixup in arch/arm/mach-imx/mach-imx6q.c.
Signed-off-by: Fabio Estevam <fabio.estevam@nxp.com>
Acked-by: Joe Hershberger <joe.hershberger@ni.com>
Diffstat (limited to 'board/wandboard')
-rw-r--r-- | board/wandboard/wandboard.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/board/wandboard/wandboard.c b/board/wandboard/wandboard.c index 1de1e0b257..b3f3b34f44 100644 --- a/board/wandboard/wandboard.c +++ b/board/wandboard/wandboard.c @@ -189,6 +189,39 @@ int board_mmc_init(bd_t *bis) return 0; } +static int ar8031_phy_fixup(struct phy_device *phydev) +{ + unsigned short val; + + /* To enable AR8031 ouput a 125MHz clk from CLK_25M */ + phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x7); + phy_write(phydev, MDIO_DEVAD_NONE, 0xe, 0x8016); + phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x4007); + + val = phy_read(phydev, MDIO_DEVAD_NONE, 0xe); + val &= 0xffe3; + val |= 0x18; + phy_write(phydev, MDIO_DEVAD_NONE, 0xe, val); + + /* introduce tx clock delay */ + phy_write(phydev, MDIO_DEVAD_NONE, 0x1d, 0x5); + val = phy_read(phydev, MDIO_DEVAD_NONE, 0x1e); + val |= 0x0100; + phy_write(phydev, MDIO_DEVAD_NONE, 0x1e, val); + + return 0; +} + +int board_phy_config(struct phy_device *phydev) +{ + ar8031_phy_fixup(phydev); + + if (phydev->drv->config) + phydev->drv->config(phydev); + + return 0; +} + #if defined(CONFIG_VIDEO_IPUV3) struct i2c_pads_info mx6q_i2c2_pad_info = { .scl = { |