mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-26 16:13:55 +01:00 
			
		
		
		
	usb: dwc3: switch to peripheral mode when exiting
This allow the phy to enter idle and then suspend. the K2 platforms require the PHY to be suspended before the USB domain clock can be turned off. Signed-off-by: Jean-Jacques Hiblot <jjhiblot@ti.com>
This commit is contained in:
		
				
					committed by
					
						 Marek Vasut
						Marek Vasut
					
				
			
			
				
	
			
			
			
						parent
						
							a8973731a4
						
					
				
				
					commit
					bbe3d4a6c1
				
			| @@ -581,6 +581,12 @@ static int dwc3_core_init_mode(struct dwc3 *dwc) | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static void dwc3_gadget_run(struct dwc3 *dwc) | ||||
| { | ||||
| 	dwc3_writel(dwc->regs, DWC3_DCTL, DWC3_DCTL_RUN_STOP); | ||||
| 	mdelay(100); | ||||
| } | ||||
|  | ||||
| static void dwc3_core_exit_mode(struct dwc3 *dwc) | ||||
| { | ||||
| 	switch (dwc->dr_mode) { | ||||
| @@ -598,6 +604,13 @@ static void dwc3_core_exit_mode(struct dwc3 *dwc) | ||||
| 		/* do nothing */ | ||||
| 		break; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * switch back to peripheral mode | ||||
| 	 * This enables the phy to enter idle and then, if enabled, suspend. | ||||
| 	 */ | ||||
| 	dwc3_set_mode(dwc, DWC3_GCTL_PRTCAP_DEVICE); | ||||
| 	dwc3_gadget_run(dwc); | ||||
| } | ||||
|  | ||||
| #define DWC3_ALIGN_MASK		(16 - 1) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user