diff options
author | Sudhakar Rajashekhara <sudhakar.raj@ti.com> | 2010-11-18 09:59:37 -0500 |
---|---|---|
committer | Wolfgang Denk <wd@denx.de> | 2010-12-09 10:24:12 +0100 |
commit | df48676aea313fdaeef0b356dfde386b656e152d (patch) | |
tree | e7443ae1e0ef72c33dc9c63f6efdd6f520be3c4c /board/davinci/da8xxevm/common.c | |
parent | dfddb5e6ba2144610e83c6b516b14e33f82b0604 (diff) | |
download | u-boot-imx-df48676aea313fdaeef0b356dfde386b656e152d.zip u-boot-imx-df48676aea313fdaeef0b356dfde386b656e152d.tar.gz u-boot-imx-df48676aea313fdaeef0b356dfde386b656e152d.tar.bz2 |
da850: Add RMII support for EMAC
This patch is a port of the work by Sudhakar Rajeshekhara in commit
ab3effbcad8851cc65dc5241a01c064d2030a3b2 of
git://arago-project.org/git/people/sandeep/u-boot-davinci.git.
The da850 UI board has on it an RMII PHY which can be used if the MDC line
to the MII PHY on the baseboard is disabled and the RMII PHY is enabled by
configuring the values of some GPIO pins on the IO expander of the UI board.
This patch implements disabling that line via GPIO2[6], configuring the UI
board's IO expander and setting only the pinmux settings that are needed for
RMII operation.
Tested on da850evm by adding a define for CONFIG_DRIVER_TI_EMAC_USE_RMII.
Signed-off-by: Sudhakar Rajashekhara <sudhakar.raj@ti.com>
Signed-off-by: Ben Gardiner <bengardiner@nanometrics.ca>
CC: Sandeep Paulraj <s-paulraj@ti.com>
CC: Ben Warren <biggerbadderben@gmail.com>
CC: Mike Frysinger <vapier@gentoo.org>
CC: Sughosh Ganu <urwithsughosh@gmail.com>
Signed-off-by: Sandeep Paulraj <s-paulraj@ti.com>
Diffstat (limited to 'board/davinci/da8xxevm/common.c')
-rw-r--r-- | board/davinci/da8xxevm/common.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/board/davinci/da8xxevm/common.c b/board/davinci/da8xxevm/common.c index 36bf693..2d9a64b 100644 --- a/board/davinci/da8xxevm/common.c +++ b/board/davinci/da8xxevm/common.c @@ -53,3 +53,17 @@ int da8xx_configure_lpsc_items(const struct lpsc_resource *item, return 0; } + +#if defined(CONFIG_DRIVER_TI_EMAC) && defined(CONFIG_MACH_DAVINCI_DA850_EVM) +void da850_emac_mii_mode_sel(int mode_sel) +{ + int val; + + val = readl(&davinci_syscfg_regs->cfgchip3); + if (mode_sel == 0) + val &= ~(1 << 8); + else + val |= (1 << 8); + writel(val, &davinci_syscfg_regs->cfgchip3); +} +#endif |