mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	ARM: OMAP4+: hwmod data: Don't prevent RESET of USB Host module
Without this, the USB devices are sometimes not detected on OMAP4 Panda
with u-boot v2013.10.
Unlike what the comment states, errata i660 does not state that we
can't RESET the USB host module. Instead it states that RESET is the
only way to recover from a deadlock situation.
RESET ensures that the module is in a known good state irrespective
of what bootloader does with the module, so it must be done at boot.
Reported-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Signed-off-by: Roger Quadros <rogerq@ti.com>
Tested-by: Tomi Valkeinen <tomi.valkeinen@ti.com> # Panda, BeagleXM
Acked-by: Benoît Cousson <bcousson@baylibre.com>
Fixes: af88fa9aa7 ("ARM: OMAP: USB: EHCI and OHCI hwmod structures for OMAP4")
Signed-off-by: Paul Walmsley <paul@pwsan.com>
			
			
This commit is contained in:
		
							parent
							
								
									6ce4eac1f6
								
							
						
					
					
						commit
						b483a4a5a7
					
				| @ -2937,7 +2937,7 @@ static struct omap_hwmod_class_sysconfig omap44xx_usb_host_hs_sysc = { | ||||
| 	.sysc_offs	= 0x0010, | ||||
| 	.syss_offs	= 0x0014, | ||||
| 	.sysc_flags	= (SYSC_HAS_MIDLEMODE | SYSC_HAS_SIDLEMODE | | ||||
| 			   SYSC_HAS_SOFTRESET), | ||||
| 			   SYSC_HAS_SOFTRESET | SYSC_HAS_RESET_STATUS), | ||||
| 	.idlemodes	= (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART | | ||||
| 			   SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO | | ||||
| 			   MSTANDBY_SMART | MSTANDBY_SMART_WKUP), | ||||
| @ -3001,15 +3001,7 @@ static struct omap_hwmod omap44xx_usb_host_hs_hwmod = { | ||||
| 	 * hence HWMOD_SWSUP_MSTANDBY | ||||
| 	 */ | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * During system boot; If the hwmod framework resets the module | ||||
| 	 * the module will have smart idle settings; which can lead to deadlock | ||||
| 	 * (above Errata Id:i660); so, dont reset the module during boot; | ||||
| 	 * Use HWMOD_INIT_NO_RESET. | ||||
| 	 */ | ||||
| 
 | ||||
| 	.flags		= HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY | | ||||
| 			  HWMOD_INIT_NO_RESET, | ||||
| 	.flags		= HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY, | ||||
| }; | ||||
| 
 | ||||
| /*
 | ||||
|  | ||||
| @ -1544,7 +1544,8 @@ static struct omap_hwmod_class_sysconfig omap54xx_usb_host_hs_sysc = { | ||||
| 	.rev_offs	= 0x0000, | ||||
| 	.sysc_offs	= 0x0010, | ||||
| 	.sysc_flags	= (SYSC_HAS_MIDLEMODE | SYSC_HAS_RESET_STATUS | | ||||
| 			   SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET), | ||||
| 			   SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET | | ||||
| 			   SYSC_HAS_RESET_STATUS), | ||||
| 	.idlemodes	= (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART | | ||||
| 			   SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO | | ||||
| 			   MSTANDBY_SMART | MSTANDBY_SMART_WKUP), | ||||
| @ -1598,15 +1599,7 @@ static struct omap_hwmod omap54xx_usb_host_hs_hwmod = { | ||||
| 	 * hence HWMOD_SWSUP_MSTANDBY | ||||
| 	 */ | ||||
| 
 | ||||
| 	/*
 | ||||
| 	 * During system boot; If the hwmod framework resets the module | ||||
| 	 * the module will have smart idle settings; which can lead to deadlock | ||||
| 	 * (above Errata Id:i660); so, dont reset the module during boot; | ||||
| 	 * Use HWMOD_INIT_NO_RESET. | ||||
| 	 */ | ||||
| 
 | ||||
| 	.flags		= HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY | | ||||
| 			  HWMOD_INIT_NO_RESET, | ||||
| 	.flags		= HWMOD_SWSUP_SIDLE | HWMOD_SWSUP_MSTANDBY, | ||||
| 	.main_clk	= "l3init_60m_fclk", | ||||
| 	.prcm = { | ||||
| 		.omap4 = { | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Roger Quadros
						Roger Quadros