diff mbox

[RESEND/RFC/RFT] arm: omap1: get rid of OMAP_TAG_USB

Message ID 1234661409-653-1-git-send-email-felipe.balbi@nokia.com (mailing list archive)
State Accepted
Commit ab3c80298f3cc8caaeebd4c943c6b314b67581e4
Delegated to: Tony Lindgren
Headers show

Commit Message

Felipe Balbi Feb. 15, 2009, 1:30 a.m. UTC
OMAP_TAGS should vanish soon since they're not generic arm tags.
Most of them can be converted to a platform_data or parsed
from a command line like e.g. serial tag.

For OMAP_TAG_USB we just let boards call omap_usb_init()
passing a pointer to omap_usb_config.

This patch is compile tested only.

Signed-off-by: Felipe Balbi <felipe.balbi@nokia.com>
---
 arch/arm/mach-omap1/board-ams-delta.c   |    2 +-
 arch/arm/mach-omap1/board-generic.c     |    5 ++---
 arch/arm/mach-omap1/board-h2.c          |    2 +-
 arch/arm/mach-omap1/board-h3.c          |    2 +-
 arch/arm/mach-omap1/board-innovator.c   |    5 ++---
 arch/arm/mach-omap1/board-nokia770.c    |    3 +--
 arch/arm/mach-omap1/board-osk.c         |    2 +-
 arch/arm/mach-omap1/board-palmte.c      |    2 +-
 arch/arm/mach-omap1/board-palmtt.c      |    2 +-
 arch/arm/mach-omap1/board-palmz71.c     |    2 +-
 arch/arm/mach-omap1/board-sx1.c         |    2 +-
 arch/arm/mach-omap1/board-voiceblue.c   |    2 +-
 arch/arm/mach-omap2/board-apollon.c     |    2 +-
 arch/arm/mach-omap2/board-h4.c          |    2 +-
 arch/arm/plat-omap/include/mach/board.h |    1 -
 arch/arm/plat-omap/include/mach/usb.h   |    2 ++
 arch/arm/plat-omap/usb.c                |   25 ++++---------------------
 17 files changed, 22 insertions(+), 41 deletions(-)

Comments

Felipe Balbi Feb. 19, 2009, 9:19 p.m. UTC | #1
On Sun, Feb 15, 2009 at 03:30:09AM +0200, Felipe Balbi wrote:
> OMAP_TAGS should vanish soon since they're not generic arm tags.
> Most of them can be converted to a platform_data or parsed
> from a command line like e.g. serial tag.
> 
> For OMAP_TAG_USB we just let boards call omap_usb_init()
> passing a pointer to omap_usb_config.
> 
> This patch is compile tested only.
> 
> Signed-off-by: Felipe Balbi <felipe.balbi@nokia.com>

Hello, anyone with omap1 board, could you please TEST this ?? Damn, they
took our 770s, maybe someone at the office still have one, gotta check.

> ---
>  arch/arm/mach-omap1/board-ams-delta.c   |    2 +-
>  arch/arm/mach-omap1/board-generic.c     |    5 ++---
>  arch/arm/mach-omap1/board-h2.c          |    2 +-
>  arch/arm/mach-omap1/board-h3.c          |    2 +-
>  arch/arm/mach-omap1/board-innovator.c   |    5 ++---
>  arch/arm/mach-omap1/board-nokia770.c    |    3 +--
>  arch/arm/mach-omap1/board-osk.c         |    2 +-
>  arch/arm/mach-omap1/board-palmte.c      |    2 +-
>  arch/arm/mach-omap1/board-palmtt.c      |    2 +-
>  arch/arm/mach-omap1/board-palmz71.c     |    2 +-
>  arch/arm/mach-omap1/board-sx1.c         |    2 +-
>  arch/arm/mach-omap1/board-voiceblue.c   |    2 +-
>  arch/arm/mach-omap2/board-apollon.c     |    2 +-
>  arch/arm/mach-omap2/board-h4.c          |    2 +-
>  arch/arm/plat-omap/include/mach/board.h |    1 -
>  arch/arm/plat-omap/include/mach/usb.h   |    2 ++
>  arch/arm/plat-omap/usb.c                |   25 ++++---------------------
>  17 files changed, 22 insertions(+), 41 deletions(-)
> 
> diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c
> index 2e61839..8b40aac 100644
> --- a/arch/arm/mach-omap1/board-ams-delta.c
> +++ b/arch/arm/mach-omap1/board-ams-delta.c
> @@ -175,7 +175,6 @@ static struct omap_usb_config ams_delta_usb_config __initdata = {
>  static struct omap_board_config_kernel ams_delta_config[] = {
>  	{ OMAP_TAG_LCD,		&ams_delta_lcd_config },
>  	{ OMAP_TAG_UART,	&ams_delta_uart_config },
> -	{ OMAP_TAG_USB,		&ams_delta_usb_config },
>  };
>  
>  static struct resource ams_delta_kp_resources[] = {
> @@ -232,6 +231,7 @@ static void __init ams_delta_init(void)
>  	/* Clear latch2 (NAND, LCD, modem enable) */
>  	ams_delta_latch2_write(~0, 0);
>  
> +	omap_usb_init(&ams_delta_usb_config);
>  	platform_add_devices(ams_delta_devices, ARRAY_SIZE(ams_delta_devices));
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-generic.c b/arch/arm/mach-omap1/board-generic.c
> index 7d26702..e724940 100644
> --- a/arch/arm/mach-omap1/board-generic.c
> +++ b/arch/arm/mach-omap1/board-generic.c
> @@ -62,7 +62,6 @@ static struct omap_uart_config generic_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel generic_config[] __initdata = {
> -	{ OMAP_TAG_USB,		NULL },
>  	{ OMAP_TAG_UART,	&generic_uart_config },
>  };
>  
> @@ -70,12 +69,12 @@ static void __init omap_generic_init(void)
>  {
>  #ifdef CONFIG_ARCH_OMAP15XX
>  	if (cpu_is_omap15xx()) {
> -		generic_config[0].data = &generic1510_usb_config;
> +		omap_usb_init(&generic1510_usb_config);
>  	}
>  #endif
>  #if defined(CONFIG_ARCH_OMAP16XX)
>  	if (!cpu_is_omap1510()) {
> -		generic_config[0].data = &generic1610_usb_config;
> +		omap_usb_init(&generic1610_usb_config);
>  	}
>  #endif
>  
> diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c
> index 0d784a7..9f3b392 100644
> --- a/arch/arm/mach-omap1/board-h2.c
> +++ b/arch/arm/mach-omap1/board-h2.c
> @@ -364,7 +364,6 @@ static struct omap_lcd_config h2_lcd_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel h2_config[] __initdata = {
> -	{ OMAP_TAG_USB,		&h2_usb_config },
>  	{ OMAP_TAG_UART,	&h2_uart_config },
>  	{ OMAP_TAG_LCD,		&h2_lcd_config },
>  };
> @@ -413,6 +412,7 @@ static void __init h2_init(void)
>  	omap_serial_init();
>  	omap_register_i2c_bus(1, 100, h2_i2c_board_info,
>  			      ARRAY_SIZE(h2_i2c_board_info));
> +	omap_usb_init(&h2_usb_config);
>  	h2_mmc_init();
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-h3.c b/arch/arm/mach-omap1/board-h3.c
> index bf08b6a..a3c513d 100644
> --- a/arch/arm/mach-omap1/board-h3.c
> +++ b/arch/arm/mach-omap1/board-h3.c
> @@ -418,7 +418,6 @@ static struct omap_lcd_config h3_lcd_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel h3_config[] __initdata = {
> -	{ OMAP_TAG_USB,		&h3_usb_config },
>  	{ OMAP_TAG_UART,	&h3_uart_config },
>  	{ OMAP_TAG_LCD,		&h3_lcd_config },
>  };
> @@ -472,6 +471,7 @@ static void __init h3_init(void)
>  	omap_serial_init();
>  	omap_register_i2c_bus(1, 100, h3_i2c_board_info,
>  			      ARRAY_SIZE(h3_i2c_board_info));
> +	omap_usb_init(&h3_usb_config);
>  	h3_mmc_init();
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c
> index 071cd02..ed7ee07 100644
> --- a/arch/arm/mach-omap1/board-innovator.c
> +++ b/arch/arm/mach-omap1/board-innovator.c
> @@ -370,7 +370,6 @@ static struct omap_uart_config innovator_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel innovator_config[] = {
> -	{ OMAP_TAG_USB,         NULL },
>  	{ OMAP_TAG_LCD,		NULL },
>  	{ OMAP_TAG_UART,	&innovator_uart_config },
>  };
> @@ -392,13 +391,13 @@ static void __init innovator_init(void)
>  
>  #ifdef CONFIG_ARCH_OMAP15XX
>  	if (cpu_is_omap1510()) {
> -		innovator_config[0].data = &innovator1510_usb_config;
> +		omap_usb_init(&innovator1510_usb_config);
>  		innovator_config[1].data = &innovator1510_lcd_config;
>  	}
>  #endif
>  #ifdef CONFIG_ARCH_OMAP16XX
>  	if (cpu_is_omap1610()) {
> -		innovator_config[0].data = &h2_usb_config;
> +		omap_usb_init(&h2_usb_config);
>  		innovator_config[1].data = &innovator1610_lcd_config;
>  	}
>  #endif
> diff --git a/arch/arm/mach-omap1/board-nokia770.c b/arch/arm/mach-omap1/board-nokia770.c
> index af51e0b..a495455 100644
> --- a/arch/arm/mach-omap1/board-nokia770.c
> +++ b/arch/arm/mach-omap1/board-nokia770.c
> @@ -371,8 +371,6 @@ static __init int omap_dsp_init(void)
>  
>  static void __init omap_nokia770_init(void)
>  {
> -	nokia770_config[0].data = &nokia770_usb_config;
> -
>  	platform_add_devices(nokia770_devices, ARRAY_SIZE(nokia770_devices));
>  	spi_register_board_info(nokia770_spi_board_info,
>  				ARRAY_SIZE(nokia770_spi_board_info));
> @@ -384,6 +382,7 @@ static void __init omap_nokia770_init(void)
>  	omap_dsp_init();
>  	ads7846_dev_init();
>  	mipid_dev_init();
> +	omap_usb_init(&nokia770_usb_config);
>  	nokia770_mmc_init();
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-osk.c b/arch/arm/mach-omap1/board-osk.c
> index 1a16ecb..99913ac 100644
> --- a/arch/arm/mach-omap1/board-osk.c
> +++ b/arch/arm/mach-omap1/board-osk.c
> @@ -290,7 +290,6 @@ static struct omap_lcd_config osk_lcd_config __initdata = {
>  #endif
>  
>  static struct omap_board_config_kernel osk_config[] __initdata = {
> -	{ OMAP_TAG_USB,           &osk_usb_config },
>  	{ OMAP_TAG_UART,		&osk_uart_config },
>  #ifdef	CONFIG_OMAP_OSK_MISTRAL
>  	{ OMAP_TAG_LCD,			&osk_lcd_config },
> @@ -510,6 +509,7 @@ static void __init osk_mistral_init(void)
>  	i2c_register_board_info(1, mistral_i2c_board_info,
>  			ARRAY_SIZE(mistral_i2c_board_info));
>  
> +	omap_usb_init(&osk_usb_config);
>  	platform_add_devices(mistral_devices, ARRAY_SIZE(mistral_devices));
>  }
>  #else
> diff --git a/arch/arm/mach-omap1/board-palmte.c b/arch/arm/mach-omap1/board-palmte.c
> index 99f2b43..b2d3a36 100644
> --- a/arch/arm/mach-omap1/board-palmte.c
> +++ b/arch/arm/mach-omap1/board-palmte.c
> @@ -286,7 +286,6 @@ static void palmte_get_power_status(struct apm_power_info *info, int *battery)
>  #endif
>  
>  static struct omap_board_config_kernel palmte_config[] __initdata = {
> -	{ OMAP_TAG_USB,		&palmte_usb_config },
>  	{ OMAP_TAG_LCD,		&palmte_lcd_config },
>  	{ OMAP_TAG_UART,	&palmte_uart_config },
>  };
> @@ -341,6 +340,7 @@ static void __init omap_palmte_init(void)
>  	spi_register_board_info(palmte_spi_info, ARRAY_SIZE(palmte_spi_info));
>  	palmte_misc_gpio_setup();
>  	omap_serial_init();
> +	omap_usb_init(&palmte_usb_config);
>  	omap_register_i2c_bus(1, 100, NULL, 0);
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-palmtt.c b/arch/arm/mach-omap1/board-palmtt.c
> index 1cbc127..90795bf 100644
> --- a/arch/arm/mach-omap1/board-palmtt.c
> +++ b/arch/arm/mach-omap1/board-palmtt.c
> @@ -272,7 +272,6 @@ static struct omap_uart_config palmtt_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel palmtt_config[] __initdata = {
> -	{ OMAP_TAG_USB,		&palmtt_usb_config	},
>  	{ OMAP_TAG_LCD,		&palmtt_lcd_config	},
>  	{ OMAP_TAG_UART,	&palmtt_uart_config	},
>  };
> @@ -297,6 +296,7 @@ static void __init omap_palmtt_init(void)
>  
>  	spi_register_board_info(palmtt_boardinfo,ARRAY_SIZE(palmtt_boardinfo));
>  	omap_serial_init();
> +	omap_usb_init(&palmtt_usb_config);
>  	omap_register_i2c_bus(1, 100, NULL, 0);
>  }
>  
> diff --git a/arch/arm/mach-omap1/board-palmz71.c b/arch/arm/mach-omap1/board-palmz71.c
> index baf5efb..89b50e8 100644
> --- a/arch/arm/mach-omap1/board-palmz71.c
> +++ b/arch/arm/mach-omap1/board-palmz71.c
> @@ -239,7 +239,6 @@ static struct omap_uart_config palmz71_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel palmz71_config[] __initdata = {
> -	{OMAP_TAG_USB,	&palmz71_usb_config},
>  	{OMAP_TAG_LCD,	&palmz71_lcd_config},
>  	{OMAP_TAG_UART,	&palmz71_uart_config},
>  };
> @@ -313,6 +312,7 @@ omap_palmz71_init(void)
>  
>  	spi_register_board_info(palmz71_boardinfo,
>  				ARRAY_SIZE(palmz71_boardinfo));
> +	omap_usb_init(&palmz71_usb_config);
>  	omap_serial_init();
>  	omap_register_i2c_bus(1, 100, NULL, 0);
>  	palmz71_gpio_setup(0);
> diff --git a/arch/arm/mach-omap1/board-sx1.c b/arch/arm/mach-omap1/board-sx1.c
> index 28c76a1..7d6f0b7 100644
> --- a/arch/arm/mach-omap1/board-sx1.c
> +++ b/arch/arm/mach-omap1/board-sx1.c
> @@ -373,7 +373,6 @@ static struct omap_uart_config sx1_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel sx1_config[] __initdata = {
> -	{ OMAP_TAG_USB,	&sx1_usb_config },
>  	{ OMAP_TAG_LCD,	&sx1_lcd_config },
>  	{ OMAP_TAG_UART,	&sx1_uart_config },
>  };
> @@ -388,6 +387,7 @@ static void __init omap_sx1_init(void)
>  	omap_board_config_size = ARRAY_SIZE(sx1_config);
>  	omap_serial_init();
>  	omap_register_i2c_bus(1, 100, NULL, 0);
> +	omap_usb_init(&sx1_usb_config);
>  	sx1_mmc_init();
>  
>  	/* turn on USB power */
> diff --git a/arch/arm/mach-omap1/board-voiceblue.c b/arch/arm/mach-omap1/board-voiceblue.c
> index a765354..98275e0 100644
> --- a/arch/arm/mach-omap1/board-voiceblue.c
> +++ b/arch/arm/mach-omap1/board-voiceblue.c
> @@ -145,7 +145,6 @@ static struct omap_uart_config voiceblue_uart_config __initdata = {
>  };
>  
>  static struct omap_board_config_kernel voiceblue_config[] = {
> -	{ OMAP_TAG_USB,  &voiceblue_usb_config },
>  	{ OMAP_TAG_UART, &voiceblue_uart_config },
>  };
>  
> @@ -185,6 +184,7 @@ static void __init voiceblue_init(void)
>  	omap_board_config = voiceblue_config;
>  	omap_board_config_size = ARRAY_SIZE(voiceblue_config);
>  	omap_serial_init();
> +	omap_usb_init(&voiceblue_usb_config);
>  	omap_register_i2c_bus(1, 100, NULL, 0);
>  
>  	/* There is a good chance board is going up, so enable power LED
> diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c
> index 994c947..727d282 100644
> --- a/arch/arm/mach-omap2/board-apollon.c
> +++ b/arch/arm/mach-omap2/board-apollon.c
> @@ -364,7 +364,6 @@ static struct omap_lcd_config apollon_lcd_config __initdata = {
>  
>  static struct omap_board_config_kernel apollon_config[] __initdata = {
>  	{ OMAP_TAG_UART,	&apollon_uart_config },
> -	{ OMAP_TAG_USB,		&apollon_usb_config },
>  	{ OMAP_TAG_LCD,		&apollon_lcd_config },
>  };
>  
> @@ -393,6 +392,7 @@ static void __init apollon_usb_init(void)
>  	omap_cfg_reg(P21_242X_GPIO12);
>  	gpio_request(12, "USB suspend");
>  	gpio_direction_output(12, 0);
> +	omap_usb_init(&apollon_usb_config);
>  }
>  
>  static void __init apollon_tsc_init(void)
> diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c
> index b0252c8..cb5c09b 100644
> --- a/arch/arm/mach-omap2/board-h4.c
> +++ b/arch/arm/mach-omap2/board-h4.c
> @@ -429,7 +429,6 @@ static struct spi_board_info h4_spi_board_info[] __initdata = {
>  static struct omap_board_config_kernel h4_config[] __initdata = {
>  	{ OMAP_TAG_UART,	&h4_uart_config },
>  	{ OMAP_TAG_LCD,		&h4_lcd_config },
> -	{ OMAP_TAG_USB,		&h4_usb_config },
>  };
>  
>  #ifdef	CONFIG_MACH_OMAP_H4_TUSB
> @@ -748,6 +747,7 @@ static void __init omap_h4_init(void)
>  	omap_board_config = h4_config;
>  	omap_board_config_size = ARRAY_SIZE(h4_config);
>  	omap_serial_init();
> +	omap_usb_init(&h4_usb_config);
>  	h4_mmc_init();
>  	omap_register_i2c_bus(1, 100, h4_i2c_board_info,
>  			      ARRAY_SIZE(h4_i2c_board_info));
> diff --git a/arch/arm/plat-omap/include/mach/board.h b/arch/arm/plat-omap/include/mach/board.h
> index 3a329f5..ae8c2db 100644
> --- a/arch/arm/plat-omap/include/mach/board.h
> +++ b/arch/arm/plat-omap/include/mach/board.h
> @@ -17,7 +17,6 @@
>  /* Different peripheral ids */
>  #define OMAP_TAG_CLOCK		0x4f01
>  #define OMAP_TAG_SERIAL_CONSOLE 0x4f03
> -#define OMAP_TAG_USB		0x4f04
>  #define OMAP_TAG_LCD		0x4f05
>  #define OMAP_TAG_GPIO_SWITCH	0x4f06
>  #define OMAP_TAG_UART		0x4f07
> diff --git a/arch/arm/plat-omap/include/mach/usb.h b/arch/arm/plat-omap/include/mach/usb.h
> index 47aba6b..64e44c7 100644
> --- a/arch/arm/plat-omap/include/mach/usb.h
> +++ b/arch/arm/plat-omap/include/mach/usb.h
> @@ -21,6 +21,8 @@
>  #define UDC_BASE			OMAP1_UDC_BASE
>  #define OMAP_OHCI_BASE			OMAP1_OHCI_BASE
>  
> +void omap_usb_init(struct omap_usb_config *pdata);
> +
>  #else
>  
>  #define OTG_BASE			OMAP2_OTG_BASE
> diff --git a/arch/arm/plat-omap/usb.c b/arch/arm/plat-omap/usb.c
> index e278de6..509f2ed 100644
> --- a/arch/arm/plat-omap/usb.c
> +++ b/arch/arm/plat-omap/usb.c
> @@ -729,30 +729,13 @@ static inline void omap_1510_usb_init(struct omap_usb_config *config) {}
>  
>  /*-------------------------------------------------------------------------*/
>  
> -static struct omap_usb_config platform_data;
> -
> -static int __init
> -omap_usb_init(void)
> +void __init omap_usb_init(struct omap_usb_config *pdata)
>  {
> -	const struct omap_usb_config *config;
> -
> -	config = omap_get_config(OMAP_TAG_USB, struct omap_usb_config);
> -	if (config == NULL) {
> -		printk(KERN_ERR "USB: No board-specific "
> -				"platform config found\n");
> -		return -ENODEV;
> -	}
> -	platform_data = *config;
> -
>  	if (cpu_is_omap730() || cpu_is_omap16xx() || cpu_is_omap24xx())
> -		omap_otg_init(&platform_data);
> +		omap_otg_init(pdata);
>  	else if (cpu_is_omap15xx())
> -		omap_1510_usb_init(&platform_data);
> -	else {
> +		omap_1510_usb_init(pdata);
> +	else
>  		printk(KERN_ERR "USB: No init for your chip yet\n");
> -		return -ENODEV;
> -	}
> -	return 0;
>  }
>  
> -subsys_initcall(omap_usb_init);
> -- 
> 1.6.1.265.g9a013
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
Tony Lindgren Feb. 27, 2009, 11:03 p.m. UTC | #2
* Felipe Balbi <me@felipebalbi.com> [090219 13:23]:
> On Sun, Feb 15, 2009 at 03:30:09AM +0200, Felipe Balbi wrote:
> > OMAP_TAGS should vanish soon since they're not generic arm tags.
> > Most of them can be converted to a platform_data or parsed
> > from a command line like e.g. serial tag.
> > 
> > For OMAP_TAG_USB we just let boards call omap_usb_init()
> > passing a pointer to omap_usb_config.
> > 
> > This patch is compile tested only.
> > 
> > Signed-off-by: Felipe Balbi <felipe.balbi@nokia.com>
> 
> Hello, anyone with omap1 board, could you please TEST this ?? Damn, they
> took our 770s, maybe someone at the office still have one, gotta check.

Well I got around trying this applied on mainline kernel on H2.
Still getting "hub 1-0:1.0: unable to enumerate USB device on port 2"
but the result is same as without the patch. So let's apply this.

Tony
 
> > ---
> >  arch/arm/mach-omap1/board-ams-delta.c   |    2 +-
> >  arch/arm/mach-omap1/board-generic.c     |    5 ++---
> >  arch/arm/mach-omap1/board-h2.c          |    2 +-
> >  arch/arm/mach-omap1/board-h3.c          |    2 +-
> >  arch/arm/mach-omap1/board-innovator.c   |    5 ++---
> >  arch/arm/mach-omap1/board-nokia770.c    |    3 +--
> >  arch/arm/mach-omap1/board-osk.c         |    2 +-
> >  arch/arm/mach-omap1/board-palmte.c      |    2 +-
> >  arch/arm/mach-omap1/board-palmtt.c      |    2 +-
> >  arch/arm/mach-omap1/board-palmz71.c     |    2 +-
> >  arch/arm/mach-omap1/board-sx1.c         |    2 +-
> >  arch/arm/mach-omap1/board-voiceblue.c   |    2 +-
> >  arch/arm/mach-omap2/board-apollon.c     |    2 +-
> >  arch/arm/mach-omap2/board-h4.c          |    2 +-
> >  arch/arm/plat-omap/include/mach/board.h |    1 -
> >  arch/arm/plat-omap/include/mach/usb.h   |    2 ++
> >  arch/arm/plat-omap/usb.c                |   25 ++++---------------------
> >  17 files changed, 22 insertions(+), 41 deletions(-)
> > 
> > diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c
> > index 2e61839..8b40aac 100644
> > --- a/arch/arm/mach-omap1/board-ams-delta.c
> > +++ b/arch/arm/mach-omap1/board-ams-delta.c
> > @@ -175,7 +175,6 @@ static struct omap_usb_config ams_delta_usb_config __initdata = {
> >  static struct omap_board_config_kernel ams_delta_config[] = {
> >  	{ OMAP_TAG_LCD,		&ams_delta_lcd_config },
> >  	{ OMAP_TAG_UART,	&ams_delta_uart_config },
> > -	{ OMAP_TAG_USB,		&ams_delta_usb_config },
> >  };
> >  
> >  static struct resource ams_delta_kp_resources[] = {
> > @@ -232,6 +231,7 @@ static void __init ams_delta_init(void)
> >  	/* Clear latch2 (NAND, LCD, modem enable) */
> >  	ams_delta_latch2_write(~0, 0);
> >  
> > +	omap_usb_init(&ams_delta_usb_config);
> >  	platform_add_devices(ams_delta_devices, ARRAY_SIZE(ams_delta_devices));
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-generic.c b/arch/arm/mach-omap1/board-generic.c
> > index 7d26702..e724940 100644
> > --- a/arch/arm/mach-omap1/board-generic.c
> > +++ b/arch/arm/mach-omap1/board-generic.c
> > @@ -62,7 +62,6 @@ static struct omap_uart_config generic_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel generic_config[] __initdata = {
> > -	{ OMAP_TAG_USB,		NULL },
> >  	{ OMAP_TAG_UART,	&generic_uart_config },
> >  };
> >  
> > @@ -70,12 +69,12 @@ static void __init omap_generic_init(void)
> >  {
> >  #ifdef CONFIG_ARCH_OMAP15XX
> >  	if (cpu_is_omap15xx()) {
> > -		generic_config[0].data = &generic1510_usb_config;
> > +		omap_usb_init(&generic1510_usb_config);
> >  	}
> >  #endif
> >  #if defined(CONFIG_ARCH_OMAP16XX)
> >  	if (!cpu_is_omap1510()) {
> > -		generic_config[0].data = &generic1610_usb_config;
> > +		omap_usb_init(&generic1610_usb_config);
> >  	}
> >  #endif
> >  
> > diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c
> > index 0d784a7..9f3b392 100644
> > --- a/arch/arm/mach-omap1/board-h2.c
> > +++ b/arch/arm/mach-omap1/board-h2.c
> > @@ -364,7 +364,6 @@ static struct omap_lcd_config h2_lcd_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel h2_config[] __initdata = {
> > -	{ OMAP_TAG_USB,		&h2_usb_config },
> >  	{ OMAP_TAG_UART,	&h2_uart_config },
> >  	{ OMAP_TAG_LCD,		&h2_lcd_config },
> >  };
> > @@ -413,6 +412,7 @@ static void __init h2_init(void)
> >  	omap_serial_init();
> >  	omap_register_i2c_bus(1, 100, h2_i2c_board_info,
> >  			      ARRAY_SIZE(h2_i2c_board_info));
> > +	omap_usb_init(&h2_usb_config);
> >  	h2_mmc_init();
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-h3.c b/arch/arm/mach-omap1/board-h3.c
> > index bf08b6a..a3c513d 100644
> > --- a/arch/arm/mach-omap1/board-h3.c
> > +++ b/arch/arm/mach-omap1/board-h3.c
> > @@ -418,7 +418,6 @@ static struct omap_lcd_config h3_lcd_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel h3_config[] __initdata = {
> > -	{ OMAP_TAG_USB,		&h3_usb_config },
> >  	{ OMAP_TAG_UART,	&h3_uart_config },
> >  	{ OMAP_TAG_LCD,		&h3_lcd_config },
> >  };
> > @@ -472,6 +471,7 @@ static void __init h3_init(void)
> >  	omap_serial_init();
> >  	omap_register_i2c_bus(1, 100, h3_i2c_board_info,
> >  			      ARRAY_SIZE(h3_i2c_board_info));
> > +	omap_usb_init(&h3_usb_config);
> >  	h3_mmc_init();
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c
> > index 071cd02..ed7ee07 100644
> > --- a/arch/arm/mach-omap1/board-innovator.c
> > +++ b/arch/arm/mach-omap1/board-innovator.c
> > @@ -370,7 +370,6 @@ static struct omap_uart_config innovator_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel innovator_config[] = {
> > -	{ OMAP_TAG_USB,         NULL },
> >  	{ OMAP_TAG_LCD,		NULL },
> >  	{ OMAP_TAG_UART,	&innovator_uart_config },
> >  };
> > @@ -392,13 +391,13 @@ static void __init innovator_init(void)
> >  
> >  #ifdef CONFIG_ARCH_OMAP15XX
> >  	if (cpu_is_omap1510()) {
> > -		innovator_config[0].data = &innovator1510_usb_config;
> > +		omap_usb_init(&innovator1510_usb_config);
> >  		innovator_config[1].data = &innovator1510_lcd_config;
> >  	}
> >  #endif
> >  #ifdef CONFIG_ARCH_OMAP16XX
> >  	if (cpu_is_omap1610()) {
> > -		innovator_config[0].data = &h2_usb_config;
> > +		omap_usb_init(&h2_usb_config);
> >  		innovator_config[1].data = &innovator1610_lcd_config;
> >  	}
> >  #endif
> > diff --git a/arch/arm/mach-omap1/board-nokia770.c b/arch/arm/mach-omap1/board-nokia770.c
> > index af51e0b..a495455 100644
> > --- a/arch/arm/mach-omap1/board-nokia770.c
> > +++ b/arch/arm/mach-omap1/board-nokia770.c
> > @@ -371,8 +371,6 @@ static __init int omap_dsp_init(void)
> >  
> >  static void __init omap_nokia770_init(void)
> >  {
> > -	nokia770_config[0].data = &nokia770_usb_config;
> > -
> >  	platform_add_devices(nokia770_devices, ARRAY_SIZE(nokia770_devices));
> >  	spi_register_board_info(nokia770_spi_board_info,
> >  				ARRAY_SIZE(nokia770_spi_board_info));
> > @@ -384,6 +382,7 @@ static void __init omap_nokia770_init(void)
> >  	omap_dsp_init();
> >  	ads7846_dev_init();
> >  	mipid_dev_init();
> > +	omap_usb_init(&nokia770_usb_config);
> >  	nokia770_mmc_init();
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-osk.c b/arch/arm/mach-omap1/board-osk.c
> > index 1a16ecb..99913ac 100644
> > --- a/arch/arm/mach-omap1/board-osk.c
> > +++ b/arch/arm/mach-omap1/board-osk.c
> > @@ -290,7 +290,6 @@ static struct omap_lcd_config osk_lcd_config __initdata = {
> >  #endif
> >  
> >  static struct omap_board_config_kernel osk_config[] __initdata = {
> > -	{ OMAP_TAG_USB,           &osk_usb_config },
> >  	{ OMAP_TAG_UART,		&osk_uart_config },
> >  #ifdef	CONFIG_OMAP_OSK_MISTRAL
> >  	{ OMAP_TAG_LCD,			&osk_lcd_config },
> > @@ -510,6 +509,7 @@ static void __init osk_mistral_init(void)
> >  	i2c_register_board_info(1, mistral_i2c_board_info,
> >  			ARRAY_SIZE(mistral_i2c_board_info));
> >  
> > +	omap_usb_init(&osk_usb_config);
> >  	platform_add_devices(mistral_devices, ARRAY_SIZE(mistral_devices));
> >  }
> >  #else
> > diff --git a/arch/arm/mach-omap1/board-palmte.c b/arch/arm/mach-omap1/board-palmte.c
> > index 99f2b43..b2d3a36 100644
> > --- a/arch/arm/mach-omap1/board-palmte.c
> > +++ b/arch/arm/mach-omap1/board-palmte.c
> > @@ -286,7 +286,6 @@ static void palmte_get_power_status(struct apm_power_info *info, int *battery)
> >  #endif
> >  
> >  static struct omap_board_config_kernel palmte_config[] __initdata = {
> > -	{ OMAP_TAG_USB,		&palmte_usb_config },
> >  	{ OMAP_TAG_LCD,		&palmte_lcd_config },
> >  	{ OMAP_TAG_UART,	&palmte_uart_config },
> >  };
> > @@ -341,6 +340,7 @@ static void __init omap_palmte_init(void)
> >  	spi_register_board_info(palmte_spi_info, ARRAY_SIZE(palmte_spi_info));
> >  	palmte_misc_gpio_setup();
> >  	omap_serial_init();
> > +	omap_usb_init(&palmte_usb_config);
> >  	omap_register_i2c_bus(1, 100, NULL, 0);
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-palmtt.c b/arch/arm/mach-omap1/board-palmtt.c
> > index 1cbc127..90795bf 100644
> > --- a/arch/arm/mach-omap1/board-palmtt.c
> > +++ b/arch/arm/mach-omap1/board-palmtt.c
> > @@ -272,7 +272,6 @@ static struct omap_uart_config palmtt_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel palmtt_config[] __initdata = {
> > -	{ OMAP_TAG_USB,		&palmtt_usb_config	},
> >  	{ OMAP_TAG_LCD,		&palmtt_lcd_config	},
> >  	{ OMAP_TAG_UART,	&palmtt_uart_config	},
> >  };
> > @@ -297,6 +296,7 @@ static void __init omap_palmtt_init(void)
> >  
> >  	spi_register_board_info(palmtt_boardinfo,ARRAY_SIZE(palmtt_boardinfo));
> >  	omap_serial_init();
> > +	omap_usb_init(&palmtt_usb_config);
> >  	omap_register_i2c_bus(1, 100, NULL, 0);
> >  }
> >  
> > diff --git a/arch/arm/mach-omap1/board-palmz71.c b/arch/arm/mach-omap1/board-palmz71.c
> > index baf5efb..89b50e8 100644
> > --- a/arch/arm/mach-omap1/board-palmz71.c
> > +++ b/arch/arm/mach-omap1/board-palmz71.c
> > @@ -239,7 +239,6 @@ static struct omap_uart_config palmz71_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel palmz71_config[] __initdata = {
> > -	{OMAP_TAG_USB,	&palmz71_usb_config},
> >  	{OMAP_TAG_LCD,	&palmz71_lcd_config},
> >  	{OMAP_TAG_UART,	&palmz71_uart_config},
> >  };
> > @@ -313,6 +312,7 @@ omap_palmz71_init(void)
> >  
> >  	spi_register_board_info(palmz71_boardinfo,
> >  				ARRAY_SIZE(palmz71_boardinfo));
> > +	omap_usb_init(&palmz71_usb_config);
> >  	omap_serial_init();
> >  	omap_register_i2c_bus(1, 100, NULL, 0);
> >  	palmz71_gpio_setup(0);
> > diff --git a/arch/arm/mach-omap1/board-sx1.c b/arch/arm/mach-omap1/board-sx1.c
> > index 28c76a1..7d6f0b7 100644
> > --- a/arch/arm/mach-omap1/board-sx1.c
> > +++ b/arch/arm/mach-omap1/board-sx1.c
> > @@ -373,7 +373,6 @@ static struct omap_uart_config sx1_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel sx1_config[] __initdata = {
> > -	{ OMAP_TAG_USB,	&sx1_usb_config },
> >  	{ OMAP_TAG_LCD,	&sx1_lcd_config },
> >  	{ OMAP_TAG_UART,	&sx1_uart_config },
> >  };
> > @@ -388,6 +387,7 @@ static void __init omap_sx1_init(void)
> >  	omap_board_config_size = ARRAY_SIZE(sx1_config);
> >  	omap_serial_init();
> >  	omap_register_i2c_bus(1, 100, NULL, 0);
> > +	omap_usb_init(&sx1_usb_config);
> >  	sx1_mmc_init();
> >  
> >  	/* turn on USB power */
> > diff --git a/arch/arm/mach-omap1/board-voiceblue.c b/arch/arm/mach-omap1/board-voiceblue.c
> > index a765354..98275e0 100644
> > --- a/arch/arm/mach-omap1/board-voiceblue.c
> > +++ b/arch/arm/mach-omap1/board-voiceblue.c
> > @@ -145,7 +145,6 @@ static struct omap_uart_config voiceblue_uart_config __initdata = {
> >  };
> >  
> >  static struct omap_board_config_kernel voiceblue_config[] = {
> > -	{ OMAP_TAG_USB,  &voiceblue_usb_config },
> >  	{ OMAP_TAG_UART, &voiceblue_uart_config },
> >  };
> >  
> > @@ -185,6 +184,7 @@ static void __init voiceblue_init(void)
> >  	omap_board_config = voiceblue_config;
> >  	omap_board_config_size = ARRAY_SIZE(voiceblue_config);
> >  	omap_serial_init();
> > +	omap_usb_init(&voiceblue_usb_config);
> >  	omap_register_i2c_bus(1, 100, NULL, 0);
> >  
> >  	/* There is a good chance board is going up, so enable power LED
> > diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c
> > index 994c947..727d282 100644
> > --- a/arch/arm/mach-omap2/board-apollon.c
> > +++ b/arch/arm/mach-omap2/board-apollon.c
> > @@ -364,7 +364,6 @@ static struct omap_lcd_config apollon_lcd_config __initdata = {
> >  
> >  static struct omap_board_config_kernel apollon_config[] __initdata = {
> >  	{ OMAP_TAG_UART,	&apollon_uart_config },
> > -	{ OMAP_TAG_USB,		&apollon_usb_config },
> >  	{ OMAP_TAG_LCD,		&apollon_lcd_config },
> >  };
> >  
> > @@ -393,6 +392,7 @@ static void __init apollon_usb_init(void)
> >  	omap_cfg_reg(P21_242X_GPIO12);
> >  	gpio_request(12, "USB suspend");
> >  	gpio_direction_output(12, 0);
> > +	omap_usb_init(&apollon_usb_config);
> >  }
> >  
> >  static void __init apollon_tsc_init(void)
> > diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c
> > index b0252c8..cb5c09b 100644
> > --- a/arch/arm/mach-omap2/board-h4.c
> > +++ b/arch/arm/mach-omap2/board-h4.c
> > @@ -429,7 +429,6 @@ static struct spi_board_info h4_spi_board_info[] __initdata = {
> >  static struct omap_board_config_kernel h4_config[] __initdata = {
> >  	{ OMAP_TAG_UART,	&h4_uart_config },
> >  	{ OMAP_TAG_LCD,		&h4_lcd_config },
> > -	{ OMAP_TAG_USB,		&h4_usb_config },
> >  };
> >  
> >  #ifdef	CONFIG_MACH_OMAP_H4_TUSB
> > @@ -748,6 +747,7 @@ static void __init omap_h4_init(void)
> >  	omap_board_config = h4_config;
> >  	omap_board_config_size = ARRAY_SIZE(h4_config);
> >  	omap_serial_init();
> > +	omap_usb_init(&h4_usb_config);
> >  	h4_mmc_init();
> >  	omap_register_i2c_bus(1, 100, h4_i2c_board_info,
> >  			      ARRAY_SIZE(h4_i2c_board_info));
> > diff --git a/arch/arm/plat-omap/include/mach/board.h b/arch/arm/plat-omap/include/mach/board.h
> > index 3a329f5..ae8c2db 100644
> > --- a/arch/arm/plat-omap/include/mach/board.h
> > +++ b/arch/arm/plat-omap/include/mach/board.h
> > @@ -17,7 +17,6 @@
> >  /* Different peripheral ids */
> >  #define OMAP_TAG_CLOCK		0x4f01
> >  #define OMAP_TAG_SERIAL_CONSOLE 0x4f03
> > -#define OMAP_TAG_USB		0x4f04
> >  #define OMAP_TAG_LCD		0x4f05
> >  #define OMAP_TAG_GPIO_SWITCH	0x4f06
> >  #define OMAP_TAG_UART		0x4f07
> > diff --git a/arch/arm/plat-omap/include/mach/usb.h b/arch/arm/plat-omap/include/mach/usb.h
> > index 47aba6b..64e44c7 100644
> > --- a/arch/arm/plat-omap/include/mach/usb.h
> > +++ b/arch/arm/plat-omap/include/mach/usb.h
> > @@ -21,6 +21,8 @@
> >  #define UDC_BASE			OMAP1_UDC_BASE
> >  #define OMAP_OHCI_BASE			OMAP1_OHCI_BASE
> >  
> > +void omap_usb_init(struct omap_usb_config *pdata);
> > +
> >  #else
> >  
> >  #define OTG_BASE			OMAP2_OTG_BASE
> > diff --git a/arch/arm/plat-omap/usb.c b/arch/arm/plat-omap/usb.c
> > index e278de6..509f2ed 100644
> > --- a/arch/arm/plat-omap/usb.c
> > +++ b/arch/arm/plat-omap/usb.c
> > @@ -729,30 +729,13 @@ static inline void omap_1510_usb_init(struct omap_usb_config *config) {}
> >  
> >  /*-------------------------------------------------------------------------*/
> >  
> > -static struct omap_usb_config platform_data;
> > -
> > -static int __init
> > -omap_usb_init(void)
> > +void __init omap_usb_init(struct omap_usb_config *pdata)
> >  {
> > -	const struct omap_usb_config *config;
> > -
> > -	config = omap_get_config(OMAP_TAG_USB, struct omap_usb_config);
> > -	if (config == NULL) {
> > -		printk(KERN_ERR "USB: No board-specific "
> > -				"platform config found\n");
> > -		return -ENODEV;
> > -	}
> > -	platform_data = *config;
> > -
> >  	if (cpu_is_omap730() || cpu_is_omap16xx() || cpu_is_omap24xx())
> > -		omap_otg_init(&platform_data);
> > +		omap_otg_init(pdata);
> >  	else if (cpu_is_omap15xx())
> > -		omap_1510_usb_init(&platform_data);
> > -	else {
> > +		omap_1510_usb_init(pdata);
> > +	else
> >  		printk(KERN_ERR "USB: No init for your chip yet\n");
> > -		return -ENODEV;
> > -	}
> > -	return 0;
> >  }
> >  
> > -subsys_initcall(omap_usb_init);
> > -- 
> > 1.6.1.265.g9a013
> > 
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> > the body of a message to majordomo@vger.kernel.org
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> -- 
> balbi
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Tony Lindgren Feb. 27, 2009, 11:04 p.m. UTC | #3
This patch has been applied to the linux-omap
by youw fwiendly patch wobot.

Commit: ab3c80298f3cc8caaeebd4c943c6b314b67581e4

PatchWorks
http://patchwork.kernel.org/patch/7304/

Git
http://git.kernel.org/?p=linux/kernel/git/tmlind/linux-omap-2.6.git;a=commit;h=ab3c80298f3cc8caaeebd4c943c6b314b67581e4


--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Felipe Balbi Feb. 27, 2009, 11:22 p.m. UTC | #4
On Fri, Feb 27, 2009 at 03:03:55PM -0800, Tony Lindgren wrote:
> Well I got around trying this applied on mainline kernel on H2.
> Still getting "hub 1-0:1.0: unable to enumerate USB device on port 2"
> but the result is same as without the patch. So let's apply this.

could be a bug in either ohci-omap.c or tps65010.c
diff mbox

Patch

diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c
index 2e61839..8b40aac 100644
--- a/arch/arm/mach-omap1/board-ams-delta.c
+++ b/arch/arm/mach-omap1/board-ams-delta.c
@@ -175,7 +175,6 @@  static struct omap_usb_config ams_delta_usb_config __initdata = {
 static struct omap_board_config_kernel ams_delta_config[] = {
 	{ OMAP_TAG_LCD,		&ams_delta_lcd_config },
 	{ OMAP_TAG_UART,	&ams_delta_uart_config },
-	{ OMAP_TAG_USB,		&ams_delta_usb_config },
 };
 
 static struct resource ams_delta_kp_resources[] = {
@@ -232,6 +231,7 @@  static void __init ams_delta_init(void)
 	/* Clear latch2 (NAND, LCD, modem enable) */
 	ams_delta_latch2_write(~0, 0);
 
+	omap_usb_init(&ams_delta_usb_config);
 	platform_add_devices(ams_delta_devices, ARRAY_SIZE(ams_delta_devices));
 }
 
diff --git a/arch/arm/mach-omap1/board-generic.c b/arch/arm/mach-omap1/board-generic.c
index 7d26702..e724940 100644
--- a/arch/arm/mach-omap1/board-generic.c
+++ b/arch/arm/mach-omap1/board-generic.c
@@ -62,7 +62,6 @@  static struct omap_uart_config generic_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel generic_config[] __initdata = {
-	{ OMAP_TAG_USB,		NULL },
 	{ OMAP_TAG_UART,	&generic_uart_config },
 };
 
@@ -70,12 +69,12 @@  static void __init omap_generic_init(void)
 {
 #ifdef CONFIG_ARCH_OMAP15XX
 	if (cpu_is_omap15xx()) {
-		generic_config[0].data = &generic1510_usb_config;
+		omap_usb_init(&generic1510_usb_config);
 	}
 #endif
 #if defined(CONFIG_ARCH_OMAP16XX)
 	if (!cpu_is_omap1510()) {
-		generic_config[0].data = &generic1610_usb_config;
+		omap_usb_init(&generic1610_usb_config);
 	}
 #endif
 
diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c
index 0d784a7..9f3b392 100644
--- a/arch/arm/mach-omap1/board-h2.c
+++ b/arch/arm/mach-omap1/board-h2.c
@@ -364,7 +364,6 @@  static struct omap_lcd_config h2_lcd_config __initdata = {
 };
 
 static struct omap_board_config_kernel h2_config[] __initdata = {
-	{ OMAP_TAG_USB,		&h2_usb_config },
 	{ OMAP_TAG_UART,	&h2_uart_config },
 	{ OMAP_TAG_LCD,		&h2_lcd_config },
 };
@@ -413,6 +412,7 @@  static void __init h2_init(void)
 	omap_serial_init();
 	omap_register_i2c_bus(1, 100, h2_i2c_board_info,
 			      ARRAY_SIZE(h2_i2c_board_info));
+	omap_usb_init(&h2_usb_config);
 	h2_mmc_init();
 }
 
diff --git a/arch/arm/mach-omap1/board-h3.c b/arch/arm/mach-omap1/board-h3.c
index bf08b6a..a3c513d 100644
--- a/arch/arm/mach-omap1/board-h3.c
+++ b/arch/arm/mach-omap1/board-h3.c
@@ -418,7 +418,6 @@  static struct omap_lcd_config h3_lcd_config __initdata = {
 };
 
 static struct omap_board_config_kernel h3_config[] __initdata = {
-	{ OMAP_TAG_USB,		&h3_usb_config },
 	{ OMAP_TAG_UART,	&h3_uart_config },
 	{ OMAP_TAG_LCD,		&h3_lcd_config },
 };
@@ -472,6 +471,7 @@  static void __init h3_init(void)
 	omap_serial_init();
 	omap_register_i2c_bus(1, 100, h3_i2c_board_info,
 			      ARRAY_SIZE(h3_i2c_board_info));
+	omap_usb_init(&h3_usb_config);
 	h3_mmc_init();
 }
 
diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c
index 071cd02..ed7ee07 100644
--- a/arch/arm/mach-omap1/board-innovator.c
+++ b/arch/arm/mach-omap1/board-innovator.c
@@ -370,7 +370,6 @@  static struct omap_uart_config innovator_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel innovator_config[] = {
-	{ OMAP_TAG_USB,         NULL },
 	{ OMAP_TAG_LCD,		NULL },
 	{ OMAP_TAG_UART,	&innovator_uart_config },
 };
@@ -392,13 +391,13 @@  static void __init innovator_init(void)
 
 #ifdef CONFIG_ARCH_OMAP15XX
 	if (cpu_is_omap1510()) {
-		innovator_config[0].data = &innovator1510_usb_config;
+		omap_usb_init(&innovator1510_usb_config);
 		innovator_config[1].data = &innovator1510_lcd_config;
 	}
 #endif
 #ifdef CONFIG_ARCH_OMAP16XX
 	if (cpu_is_omap1610()) {
-		innovator_config[0].data = &h2_usb_config;
+		omap_usb_init(&h2_usb_config);
 		innovator_config[1].data = &innovator1610_lcd_config;
 	}
 #endif
diff --git a/arch/arm/mach-omap1/board-nokia770.c b/arch/arm/mach-omap1/board-nokia770.c
index af51e0b..a495455 100644
--- a/arch/arm/mach-omap1/board-nokia770.c
+++ b/arch/arm/mach-omap1/board-nokia770.c
@@ -371,8 +371,6 @@  static __init int omap_dsp_init(void)
 
 static void __init omap_nokia770_init(void)
 {
-	nokia770_config[0].data = &nokia770_usb_config;
-
 	platform_add_devices(nokia770_devices, ARRAY_SIZE(nokia770_devices));
 	spi_register_board_info(nokia770_spi_board_info,
 				ARRAY_SIZE(nokia770_spi_board_info));
@@ -384,6 +382,7 @@  static void __init omap_nokia770_init(void)
 	omap_dsp_init();
 	ads7846_dev_init();
 	mipid_dev_init();
+	omap_usb_init(&nokia770_usb_config);
 	nokia770_mmc_init();
 }
 
diff --git a/arch/arm/mach-omap1/board-osk.c b/arch/arm/mach-omap1/board-osk.c
index 1a16ecb..99913ac 100644
--- a/arch/arm/mach-omap1/board-osk.c
+++ b/arch/arm/mach-omap1/board-osk.c
@@ -290,7 +290,6 @@  static struct omap_lcd_config osk_lcd_config __initdata = {
 #endif
 
 static struct omap_board_config_kernel osk_config[] __initdata = {
-	{ OMAP_TAG_USB,           &osk_usb_config },
 	{ OMAP_TAG_UART,		&osk_uart_config },
 #ifdef	CONFIG_OMAP_OSK_MISTRAL
 	{ OMAP_TAG_LCD,			&osk_lcd_config },
@@ -510,6 +509,7 @@  static void __init osk_mistral_init(void)
 	i2c_register_board_info(1, mistral_i2c_board_info,
 			ARRAY_SIZE(mistral_i2c_board_info));
 
+	omap_usb_init(&osk_usb_config);
 	platform_add_devices(mistral_devices, ARRAY_SIZE(mistral_devices));
 }
 #else
diff --git a/arch/arm/mach-omap1/board-palmte.c b/arch/arm/mach-omap1/board-palmte.c
index 99f2b43..b2d3a36 100644
--- a/arch/arm/mach-omap1/board-palmte.c
+++ b/arch/arm/mach-omap1/board-palmte.c
@@ -286,7 +286,6 @@  static void palmte_get_power_status(struct apm_power_info *info, int *battery)
 #endif
 
 static struct omap_board_config_kernel palmte_config[] __initdata = {
-	{ OMAP_TAG_USB,		&palmte_usb_config },
 	{ OMAP_TAG_LCD,		&palmte_lcd_config },
 	{ OMAP_TAG_UART,	&palmte_uart_config },
 };
@@ -341,6 +340,7 @@  static void __init omap_palmte_init(void)
 	spi_register_board_info(palmte_spi_info, ARRAY_SIZE(palmte_spi_info));
 	palmte_misc_gpio_setup();
 	omap_serial_init();
+	omap_usb_init(&palmte_usb_config);
 	omap_register_i2c_bus(1, 100, NULL, 0);
 }
 
diff --git a/arch/arm/mach-omap1/board-palmtt.c b/arch/arm/mach-omap1/board-palmtt.c
index 1cbc127..90795bf 100644
--- a/arch/arm/mach-omap1/board-palmtt.c
+++ b/arch/arm/mach-omap1/board-palmtt.c
@@ -272,7 +272,6 @@  static struct omap_uart_config palmtt_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel palmtt_config[] __initdata = {
-	{ OMAP_TAG_USB,		&palmtt_usb_config	},
 	{ OMAP_TAG_LCD,		&palmtt_lcd_config	},
 	{ OMAP_TAG_UART,	&palmtt_uart_config	},
 };
@@ -297,6 +296,7 @@  static void __init omap_palmtt_init(void)
 
 	spi_register_board_info(palmtt_boardinfo,ARRAY_SIZE(palmtt_boardinfo));
 	omap_serial_init();
+	omap_usb_init(&palmtt_usb_config);
 	omap_register_i2c_bus(1, 100, NULL, 0);
 }
 
diff --git a/arch/arm/mach-omap1/board-palmz71.c b/arch/arm/mach-omap1/board-palmz71.c
index baf5efb..89b50e8 100644
--- a/arch/arm/mach-omap1/board-palmz71.c
+++ b/arch/arm/mach-omap1/board-palmz71.c
@@ -239,7 +239,6 @@  static struct omap_uart_config palmz71_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel palmz71_config[] __initdata = {
-	{OMAP_TAG_USB,	&palmz71_usb_config},
 	{OMAP_TAG_LCD,	&palmz71_lcd_config},
 	{OMAP_TAG_UART,	&palmz71_uart_config},
 };
@@ -313,6 +312,7 @@  omap_palmz71_init(void)
 
 	spi_register_board_info(palmz71_boardinfo,
 				ARRAY_SIZE(palmz71_boardinfo));
+	omap_usb_init(&palmz71_usb_config);
 	omap_serial_init();
 	omap_register_i2c_bus(1, 100, NULL, 0);
 	palmz71_gpio_setup(0);
diff --git a/arch/arm/mach-omap1/board-sx1.c b/arch/arm/mach-omap1/board-sx1.c
index 28c76a1..7d6f0b7 100644
--- a/arch/arm/mach-omap1/board-sx1.c
+++ b/arch/arm/mach-omap1/board-sx1.c
@@ -373,7 +373,6 @@  static struct omap_uart_config sx1_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel sx1_config[] __initdata = {
-	{ OMAP_TAG_USB,	&sx1_usb_config },
 	{ OMAP_TAG_LCD,	&sx1_lcd_config },
 	{ OMAP_TAG_UART,	&sx1_uart_config },
 };
@@ -388,6 +387,7 @@  static void __init omap_sx1_init(void)
 	omap_board_config_size = ARRAY_SIZE(sx1_config);
 	omap_serial_init();
 	omap_register_i2c_bus(1, 100, NULL, 0);
+	omap_usb_init(&sx1_usb_config);
 	sx1_mmc_init();
 
 	/* turn on USB power */
diff --git a/arch/arm/mach-omap1/board-voiceblue.c b/arch/arm/mach-omap1/board-voiceblue.c
index a765354..98275e0 100644
--- a/arch/arm/mach-omap1/board-voiceblue.c
+++ b/arch/arm/mach-omap1/board-voiceblue.c
@@ -145,7 +145,6 @@  static struct omap_uart_config voiceblue_uart_config __initdata = {
 };
 
 static struct omap_board_config_kernel voiceblue_config[] = {
-	{ OMAP_TAG_USB,  &voiceblue_usb_config },
 	{ OMAP_TAG_UART, &voiceblue_uart_config },
 };
 
@@ -185,6 +184,7 @@  static void __init voiceblue_init(void)
 	omap_board_config = voiceblue_config;
 	omap_board_config_size = ARRAY_SIZE(voiceblue_config);
 	omap_serial_init();
+	omap_usb_init(&voiceblue_usb_config);
 	omap_register_i2c_bus(1, 100, NULL, 0);
 
 	/* There is a good chance board is going up, so enable power LED
diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c
index 994c947..727d282 100644
--- a/arch/arm/mach-omap2/board-apollon.c
+++ b/arch/arm/mach-omap2/board-apollon.c
@@ -364,7 +364,6 @@  static struct omap_lcd_config apollon_lcd_config __initdata = {
 
 static struct omap_board_config_kernel apollon_config[] __initdata = {
 	{ OMAP_TAG_UART,	&apollon_uart_config },
-	{ OMAP_TAG_USB,		&apollon_usb_config },
 	{ OMAP_TAG_LCD,		&apollon_lcd_config },
 };
 
@@ -393,6 +392,7 @@  static void __init apollon_usb_init(void)
 	omap_cfg_reg(P21_242X_GPIO12);
 	gpio_request(12, "USB suspend");
 	gpio_direction_output(12, 0);
+	omap_usb_init(&apollon_usb_config);
 }
 
 static void __init apollon_tsc_init(void)
diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c
index b0252c8..cb5c09b 100644
--- a/arch/arm/mach-omap2/board-h4.c
+++ b/arch/arm/mach-omap2/board-h4.c
@@ -429,7 +429,6 @@  static struct spi_board_info h4_spi_board_info[] __initdata = {
 static struct omap_board_config_kernel h4_config[] __initdata = {
 	{ OMAP_TAG_UART,	&h4_uart_config },
 	{ OMAP_TAG_LCD,		&h4_lcd_config },
-	{ OMAP_TAG_USB,		&h4_usb_config },
 };
 
 #ifdef	CONFIG_MACH_OMAP_H4_TUSB
@@ -748,6 +747,7 @@  static void __init omap_h4_init(void)
 	omap_board_config = h4_config;
 	omap_board_config_size = ARRAY_SIZE(h4_config);
 	omap_serial_init();
+	omap_usb_init(&h4_usb_config);
 	h4_mmc_init();
 	omap_register_i2c_bus(1, 100, h4_i2c_board_info,
 			      ARRAY_SIZE(h4_i2c_board_info));
diff --git a/arch/arm/plat-omap/include/mach/board.h b/arch/arm/plat-omap/include/mach/board.h
index 3a329f5..ae8c2db 100644
--- a/arch/arm/plat-omap/include/mach/board.h
+++ b/arch/arm/plat-omap/include/mach/board.h
@@ -17,7 +17,6 @@ 
 /* Different peripheral ids */
 #define OMAP_TAG_CLOCK		0x4f01
 #define OMAP_TAG_SERIAL_CONSOLE 0x4f03
-#define OMAP_TAG_USB		0x4f04
 #define OMAP_TAG_LCD		0x4f05
 #define OMAP_TAG_GPIO_SWITCH	0x4f06
 #define OMAP_TAG_UART		0x4f07
diff --git a/arch/arm/plat-omap/include/mach/usb.h b/arch/arm/plat-omap/include/mach/usb.h
index 47aba6b..64e44c7 100644
--- a/arch/arm/plat-omap/include/mach/usb.h
+++ b/arch/arm/plat-omap/include/mach/usb.h
@@ -21,6 +21,8 @@ 
 #define UDC_BASE			OMAP1_UDC_BASE
 #define OMAP_OHCI_BASE			OMAP1_OHCI_BASE
 
+void omap_usb_init(struct omap_usb_config *pdata);
+
 #else
 
 #define OTG_BASE			OMAP2_OTG_BASE
diff --git a/arch/arm/plat-omap/usb.c b/arch/arm/plat-omap/usb.c
index e278de6..509f2ed 100644
--- a/arch/arm/plat-omap/usb.c
+++ b/arch/arm/plat-omap/usb.c
@@ -729,30 +729,13 @@  static inline void omap_1510_usb_init(struct omap_usb_config *config) {}
 
 /*-------------------------------------------------------------------------*/
 
-static struct omap_usb_config platform_data;
-
-static int __init
-omap_usb_init(void)
+void __init omap_usb_init(struct omap_usb_config *pdata)
 {
-	const struct omap_usb_config *config;
-
-	config = omap_get_config(OMAP_TAG_USB, struct omap_usb_config);
-	if (config == NULL) {
-		printk(KERN_ERR "USB: No board-specific "
-				"platform config found\n");
-		return -ENODEV;
-	}
-	platform_data = *config;
-
 	if (cpu_is_omap730() || cpu_is_omap16xx() || cpu_is_omap24xx())
-		omap_otg_init(&platform_data);
+		omap_otg_init(pdata);
 	else if (cpu_is_omap15xx())
-		omap_1510_usb_init(&platform_data);
-	else {
+		omap_1510_usb_init(pdata);
+	else
 		printk(KERN_ERR "USB: No init for your chip yet\n");
-		return -ENODEV;
-	}
-	return 0;
 }
 
-subsys_initcall(omap_usb_init);