xref: /rk3399_rockchip-uboot/arch/arm/cpu/pxa/usb.c (revision abc20aba1834c321a638b367c18dcce1bb4e232d)
184ad6884SPeter Tyser /*
284ad6884SPeter Tyser  * (C) Copyright 2006
384ad6884SPeter Tyser  * Markus Klotzbuecher, DENX Software Engineering <mk@denx.de>
484ad6884SPeter Tyser  *
584ad6884SPeter Tyser  * See file CREDITS for list of people who contributed to this
684ad6884SPeter Tyser  * project.
784ad6884SPeter Tyser  *
884ad6884SPeter Tyser  * This program is free software; you can redistribute it and/or
984ad6884SPeter Tyser  * modify it under the terms of the GNU General Public License as
1084ad6884SPeter Tyser  * published by the Free Software Foundation; either version 2 of
1184ad6884SPeter Tyser  * the License, or (at your option) any later version.
1284ad6884SPeter Tyser  *
1384ad6884SPeter Tyser  * This program is distributed in the hope that it will be useful,
1484ad6884SPeter Tyser  * but WITHOUT ANY WARRANTY; without even the implied warranty of
1584ad6884SPeter Tyser  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1684ad6884SPeter Tyser  * GNU General Public License for more details.
1784ad6884SPeter Tyser  *
1884ad6884SPeter Tyser  * You should have received a copy of the GNU General Public License
1984ad6884SPeter Tyser  * along with this program; if not, write to the Free Software
2084ad6884SPeter Tyser  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
2184ad6884SPeter Tyser  * MA 02111-1307 USA
2284ad6884SPeter Tyser  */
2384ad6884SPeter Tyser 
2484ad6884SPeter Tyser #include <common.h>
2584ad6884SPeter Tyser 
2684ad6884SPeter Tyser #if defined(CONFIG_USB_OHCI_NEW) && defined(CONFIG_SYS_USB_OHCI_CPU_INIT)
27*abc20abaSMarek Vasut # if defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_CPU_PXA27X)
2884ad6884SPeter Tyser 
2984ad6884SPeter Tyser #include <asm/arch/pxa-regs.h>
303ba8bf7cSMarek Vasut #include <asm/io.h>
3184ad6884SPeter Tyser #include <usb.h>
3284ad6884SPeter Tyser 
3384ad6884SPeter Tyser int usb_cpu_init(void)
3484ad6884SPeter Tyser {
3584ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
3684ad6884SPeter Tyser 	/* Enable USB host clock. */
373ba8bf7cSMarek Vasut 	writel(readl(CKENA) | CKENA_2_USBHOST | CKENA_20_UDC, CKENA);
3884ad6884SPeter Tyser 	udelay(100);
3984ad6884SPeter Tyser #endif
40*abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
4184ad6884SPeter Tyser 	/* Enable USB host clock. */
423ba8bf7cSMarek Vasut 	writel(readl(CKEN) | CKEN10_USBHOST, CKEN);
4384ad6884SPeter Tyser #endif
4484ad6884SPeter Tyser 
4584ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
4684ad6884SPeter Tyser 	/* Configure Port 2 for Host (USB Client Registers) */
473ba8bf7cSMarek Vasut 	writel(0x3000c, UP2OCR);
4884ad6884SPeter Tyser #endif
4984ad6884SPeter Tyser 
503ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FHR, UHCHR);
5184ad6884SPeter Tyser 	wait_ms(11);
523ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_FHR, UHCHR);
5384ad6884SPeter Tyser 
543ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FSBIR, UHCHR);
553ba8bf7cSMarek Vasut 	while (readl(UHCHR) & UHCHR_FSBIR)
5684ad6884SPeter Tyser 		udelay(1);
5784ad6884SPeter Tyser 
5884ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
593ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_SSEP0, UHCHR);
6084ad6884SPeter Tyser #endif
61*abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
623ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_SSEP2, UHCHR);
6384ad6884SPeter Tyser #endif
643ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~(UHCHR_SSEP1 | UHCHR_SSE), UHCHR);
6584ad6884SPeter Tyser 
6684ad6884SPeter Tyser 	return 0;
6784ad6884SPeter Tyser }
6884ad6884SPeter Tyser 
6984ad6884SPeter Tyser int usb_cpu_stop(void)
7084ad6884SPeter Tyser {
713ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_FHR, UHCHR);
7284ad6884SPeter Tyser 	udelay(11);
733ba8bf7cSMarek Vasut 	writel(readl(UHCHR) & ~UHCHR_FHR, UHCHR);
7484ad6884SPeter Tyser 
753ba8bf7cSMarek Vasut 	writel(readl(UHCCOMS) | UHCHR_FHR, UHCCOMS);
7684ad6884SPeter Tyser 	udelay(10);
7784ad6884SPeter Tyser 
7884ad6884SPeter Tyser #if defined(CONFIG_CPU_MONAHANS)
793ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP0, UHCHR);
8084ad6884SPeter Tyser #endif
81*abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
823ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP2, UHCHR);
8384ad6884SPeter Tyser #endif
843ba8bf7cSMarek Vasut 	writel(readl(UHCHR) | UHCHR_SSEP1 | UHCHR_SSE, UHCHR);
853ba8bf7cSMarek Vasut 
863ba8bf7cSMarek Vasut #if defined(CONFIG_CPU_MONAHANS)
873ba8bf7cSMarek Vasut 	/* Disable USB host clock. */
883ba8bf7cSMarek Vasut 	writel(readl(CKENA) & ~(CKENA_2_USBHOST | CKENA_20_UDC), CKENA);
893ba8bf7cSMarek Vasut 	udelay(100);
903ba8bf7cSMarek Vasut #endif
91*abc20abaSMarek Vasut #if defined(CONFIG_CPU_PXA27X)
923ba8bf7cSMarek Vasut 	/* Disable USB host clock. */
933ba8bf7cSMarek Vasut 	writel(readl(CKEN) & ~CKEN10_USBHOST, CKEN);
943ba8bf7cSMarek Vasut #endif
9584ad6884SPeter Tyser 
9684ad6884SPeter Tyser 	return 0;
9784ad6884SPeter Tyser }
9884ad6884SPeter Tyser 
9984ad6884SPeter Tyser int usb_cpu_init_fail(void)
10084ad6884SPeter Tyser {
1013ba8bf7cSMarek Vasut 	return usb_cpu_stop();
10284ad6884SPeter Tyser }
10384ad6884SPeter Tyser 
104*abc20abaSMarek Vasut # endif /* defined(CONFIG_CPU_MONAHANS) || defined(CONFIG_CPU_PXA27X) */
10584ad6884SPeter Tyser #endif /* defined(CONFIG_USB_OHCI) && defined(CONFIG_SYS_USB_OHCI_CPU_INIT) */
106