xref: /openbmc/u-boot/arch/arm/cpu/pxa/usb.c (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
284ad6884SPeter Tyser /*
384ad6884SPeter Tyser  * (C) Copyright 2006
484ad6884SPeter Tyser  * Markus Klotzbuecher, DENX Software Engineering <mk@denx.de>
584ad6884SPeter Tyser  */
684ad6884SPeter Tyser 
784ad6884SPeter Tyser #include <common.h>
884ad6884SPeter Tyser 
984ad6884SPeter Tyser #if defined(CONFIG_USB_OHCI_NEW) && defined(CONFIG_SYS_USB_OHCI_CPU_INIT)
10abc20abaSMarek Vasut # if defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_CPU_PXA27X)
1184ad6884SPeter Tyser 
1284ad6884SPeter Tyser #include <asm/arch/pxa-regs.h>
133ba8bf7cSMarek Vasut #include <asm/io.h>
1484ad6884SPeter Tyser #include <usb.h>
1584ad6884SPeter Tyser 
usb_cpu_init(void)1684ad6884SPeter Tyser int usb_cpu_init(void)
1784ad6884SPeter Tyser {
1884ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
1984ad6884SPeter Tyser 	/* Enable USB host clock. */
203ba8bf7cSMarek Vasut 	writel(readl(CKENA) | CKENA_2_USBHOST | CKENA_20_UDC, CKENA);
2184ad6884SPeter Tyser 	udelay(100);
2284ad6884SPeter Tyser #endif
23abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
2484ad6884SPeter Tyser 	/* Enable USB host clock. */
253ba8bf7cSMarek Vasut 	writel(readl(CKEN) | CKEN10_USBHOST, CKEN);
2684ad6884SPeter Tyser #endif
2784ad6884SPeter Tyser 
2884ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
2984ad6884SPeter Tyser 	/* Configure Port 2 for Host (USB Client Registers) */
303ba8bf7cSMarek Vasut 	writel(0x3000c, UP2OCR);
3184ad6884SPeter Tyser #endif
3284ad6884SPeter Tyser 
333ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FHR, UHCHR);
345b84dd67SMike Frysinger 	mdelay(11);
353ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_FHR, UHCHR);
3684ad6884SPeter Tyser 
373ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FSBIR, UHCHR);
383ba8bf7cSMarek Vasut 	while (readl(UHCHR) & UHCHR_FSBIR)
3984ad6884SPeter Tyser 		udelay(1);
4084ad6884SPeter Tyser 
4166a18186SStefan Herbrechtsmeier #if defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_PXA27X)
423ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_SSEP0, UHCHR);
4384ad6884SPeter Tyser #endif
44abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
453ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_SSEP2, UHCHR);
4684ad6884SPeter Tyser #endif
473ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~(UHCHR_SSEP1 | UHCHR_SSE), UHCHR);
4884ad6884SPeter Tyser 
4984ad6884SPeter Tyser 	return 0;
5084ad6884SPeter Tyser }
5184ad6884SPeter Tyser 
usb_cpu_stop(void)5284ad6884SPeter Tyser int usb_cpu_stop(void)
5384ad6884SPeter Tyser {
543ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FHR, UHCHR);
5584ad6884SPeter Tyser 	udelay(11);
563ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_FHR, UHCHR);
5784ad6884SPeter Tyser 
581c0a14ebSStefan Herbrechtsmeier 	writel(readl(UHCCOMS) | UHCCOMS_HCR, UHCCOMS);
5984ad6884SPeter Tyser 	udelay(10);
6084ad6884SPeter Tyser 
6166a18186SStefan Herbrechtsmeier #if defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_PXA27X)
623ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP0, UHCHR);
6384ad6884SPeter Tyser #endif
64abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
653ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP2, UHCHR);
6684ad6884SPeter Tyser #endif
673ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP1 | UHCHR_SSE, UHCHR);
683ba8bf7cSMarek Vasut 
693ba8bf7cSMarek Vasut #if defined(CONFIG_CPU_MONAHANS)
703ba8bf7cSMarek Vasut 	/* Disable USB host clock. */
713ba8bf7cSMarek Vasut 	writel(readl(CKENA) & ~(CKENA_2_USBHOST | CKENA_20_UDC), CKENA);
723ba8bf7cSMarek Vasut 	udelay(100);
733ba8bf7cSMarek Vasut #endif
74abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
753ba8bf7cSMarek Vasut 	/* Disable USB host clock. */
763ba8bf7cSMarek Vasut 	writel(readl(CKEN) & ~CKEN10_USBHOST, CKEN);
773ba8bf7cSMarek Vasut #endif
7884ad6884SPeter Tyser 
7984ad6884SPeter Tyser 	return 0;
8084ad6884SPeter Tyser }
8184ad6884SPeter Tyser 
usb_cpu_init_fail(void)8284ad6884SPeter Tyser int usb_cpu_init_fail(void)
8384ad6884SPeter Tyser {
843ba8bf7cSMarek Vasut 	return usb_cpu_stop();
8584ad6884SPeter Tyser }
8684ad6884SPeter Tyser 
87abc20abaSMarek Vasut # endif /* defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_CPU_PXA27X) */
8884ad6884SPeter Tyser #endif /* defined(CONFIG_USB_OHCI) && defined(CONFIG_SYS_USB_OHCI_CPU_INIT) */
89