mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-04-03 13:01:31 +00:00
ARMV7: Restructure omap3 musb driver to allow code sharing between OMAP3 and OMAP4
Signed-off-by: Steve Sakoman <steve@sakoman.com> Signed-off-by: Sandeep Paulraj <s-paulraj@ti.com>
This commit is contained in:
parent
516799f677
commit
9b16757758
4 changed files with 24 additions and 1 deletions
|
@ -483,4 +483,7 @@ struct pm {
|
||||||
#define I2C_BASE2 (OMAP34XX_CORE_L4_IO_BASE + 0x72000)
|
#define I2C_BASE2 (OMAP34XX_CORE_L4_IO_BASE + 0x72000)
|
||||||
#define I2C_BASE3 (OMAP34XX_CORE_L4_IO_BASE + 0x60000)
|
#define I2C_BASE3 (OMAP34XX_CORE_L4_IO_BASE + 0x60000)
|
||||||
|
|
||||||
|
/* MUSB base */
|
||||||
|
#define MUSB_BASE (OMAP34XX_CORE_L4_IO_BASE + 0xAB000)
|
||||||
|
|
||||||
#endif /* _CPU_H */
|
#endif /* _CPU_H */
|
||||||
|
|
|
@ -139,4 +139,7 @@ struct watchdog {
|
||||||
#define I2C_BASE2 (OMAP44XX_L4_PER_BASE + 0x72000)
|
#define I2C_BASE2 (OMAP44XX_L4_PER_BASE + 0x72000)
|
||||||
#define I2C_BASE3 (OMAP44XX_L4_PER_BASE + 0x60000)
|
#define I2C_BASE3 (OMAP44XX_L4_PER_BASE + 0x60000)
|
||||||
|
|
||||||
|
/* MUSB base */
|
||||||
|
#define MUSB_BASE (OMAP44XX_L4_CORE_BASE + 0xAB000)
|
||||||
|
|
||||||
#endif /* _CPU_H */
|
#endif /* _CPU_H */
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <twl4030.h>
|
#include <twl4030.h>
|
||||||
|
#include <twl6030.h>
|
||||||
#include "omap3.h"
|
#include "omap3.h"
|
||||||
|
|
||||||
static int platform_needs_initialization = 1;
|
static int platform_needs_initialization = 1;
|
||||||
|
@ -65,7 +66,12 @@ static struct omap3_otg_regs *otg;
|
||||||
|
|
||||||
#define OMAP3_OTG_SYSSTATUS_RESETDONE 0x0001
|
#define OMAP3_OTG_SYSSTATUS_RESETDONE 0x0001
|
||||||
|
|
||||||
|
/* OMAP4430 has an internal PHY, use it */
|
||||||
|
#ifdef CONFIG_OMAP4430
|
||||||
|
#define OMAP3_OTG_INTERFSEL_OMAP 0x0000
|
||||||
|
#else
|
||||||
#define OMAP3_OTG_INTERFSEL_OMAP 0x0001
|
#define OMAP3_OTG_INTERFSEL_OMAP 0x0001
|
||||||
|
#endif
|
||||||
|
|
||||||
#define OMAP3_OTG_FORCESTDBY_STANDBY 0x0001
|
#define OMAP3_OTG_FORCESTDBY_STANDBY 0x0001
|
||||||
|
|
||||||
|
@ -105,6 +111,11 @@ int musb_platform_init(void)
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_TWL6030_POWER
|
||||||
|
twl6030_usb_device_settings();
|
||||||
|
#endif
|
||||||
|
|
||||||
otg = (struct omap3_otg_regs *)OMAP3_OTG_BASE;
|
otg = (struct omap3_otg_regs *)OMAP3_OTG_BASE;
|
||||||
|
|
||||||
/* Set OTG to always be on */
|
/* Set OTG to always be on */
|
||||||
|
@ -122,6 +133,11 @@ int musb_platform_init(void)
|
||||||
#ifdef CONFIG_OMAP3_EVM
|
#ifdef CONFIG_OMAP3_EVM
|
||||||
musb_cfg.extvbus = omap3_evm_need_extvbus();
|
musb_cfg.extvbus = omap3_evm_need_extvbus();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_OMAP4430
|
||||||
|
u32 *usbotghs_control = (u32 *)(CTRL_BASE + 0x33C);
|
||||||
|
*usbotghs_control = 0x15;
|
||||||
|
#endif
|
||||||
platform_needs_initialization = 0;
|
platform_needs_initialization = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,10 +31,11 @@
|
||||||
#ifndef _MUSB_OMAP3_H_
|
#ifndef _MUSB_OMAP3_H_
|
||||||
#define _MUSB_OMAP3_H_
|
#define _MUSB_OMAP3_H_
|
||||||
|
|
||||||
|
#include <asm/arch/cpu.h>
|
||||||
#include "musb_core.h"
|
#include "musb_core.h"
|
||||||
|
|
||||||
/* Base address of MUSB registers */
|
/* Base address of MUSB registers */
|
||||||
#define MENTOR_USB0_BASE (OMAP34XX_CORE_L4_IO_BASE + 0xAB000)
|
#define MENTOR_USB0_BASE MUSB_BASE
|
||||||
|
|
||||||
/* Base address of OTG registers */
|
/* Base address of OTG registers */
|
||||||
#define OMAP3_OTG_BASE (MENTOR_USB0_BASE + 0x400)
|
#define OMAP3_OTG_BASE (MENTOR_USB0_BASE + 0x400)
|
||||||
|
|
Loading…
Add table
Reference in a new issue