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