xref: /netbsd-src/sys/arch/arm/imx/imxusbreg.h (revision dff9645d2aa552c0e54cfdc1881cabac618b6adf)
1*dff9645dSandvar /*	$NetBSD: imxusbreg.h,v 1.6 2024/02/08 11:31:00 andvar Exp $	*/
2c1719a03Sbsh /*
3c1719a03Sbsh  * Copyright (c) 2009, 2010  Genetec Corporation.  All rights reserved.
4c1719a03Sbsh  * Written by Hashimoto Kenichi for Genetec Corporation.
5c1719a03Sbsh  *
6c1719a03Sbsh  * Redistribution and use in source and binary forms, with or without
7c1719a03Sbsh  * modification, are permitted provided that the following conditions
8c1719a03Sbsh  * are met:
9c1719a03Sbsh  * 1. Redistributions of source code must retain the above copyright
10c1719a03Sbsh  *    notice, this list of conditions and the following disclaimer.
11c1719a03Sbsh  * 2. Redistributions in binary form must reproduce the above copyright
12c1719a03Sbsh  *    notice, this list of conditions and the following disclaimer in the
13c1719a03Sbsh  *    documentation and/or other materials provided with the distribution.
14c1719a03Sbsh  *
15c1719a03Sbsh  * THIS SOFTWARE IS PROVIDED BY GENETEC CORPORATION ``AS IS'' AND
16c1719a03Sbsh  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17c1719a03Sbsh  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18c1719a03Sbsh  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL GENETEC CORPORATION
19c1719a03Sbsh  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20c1719a03Sbsh  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21c1719a03Sbsh  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22c1719a03Sbsh  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23c1719a03Sbsh  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24c1719a03Sbsh  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25c1719a03Sbsh  * POSSIBILITY OF SUCH DAMAGE.
26c1719a03Sbsh  */
27c1719a03Sbsh 
28c1719a03Sbsh #ifndef _ARM_IMX_IMXUSBREG_H
29c1719a03Sbsh #define _ARM_IMX_IMXUSBREG_H
30c1719a03Sbsh 
31c1719a03Sbsh #define	IMXUSB_ID		0x0000
322868f5bcShkenken #define	 IMXUSB_ID_ID		__BITS(5,0)
332868f5bcShkenken #define	 IMXUSB_ID_REVISION	__BITS(23,16)
34c1719a03Sbsh #define	IMXUSB_HWGENERAL	0x0004
35c1719a03Sbsh #define	IMXUSB_HWHOST		0x0008
36c1719a03Sbsh #define	 HWHOST_HC		__BIT(0)
372868f5bcShkenken #define	 HWHOST_NPORT		__BITS(3,1)
38c1719a03Sbsh #define	IMXUSB_HWDEVICE		0x000c
39c1719a03Sbsh #define	 HWDEVICE_DC		__BIT(0)
402868f5bcShkenken #define	 HWDEVICE_DEVEP		__BITS(5,1)
41c1719a03Sbsh #define	IMXUSB_HWTXBUF		0x0010
42c1719a03Sbsh #define	IMXUSB_HWRXBUF		0x0014
43c1719a03Sbsh 
44c1719a03Sbsh #define	IMXUSB_EHCIREGS	0x0100
45c1719a03Sbsh 
46c1719a03Sbsh #define	IMXUSB_ULPIVIEW	0x0170
47c1719a03Sbsh #define	 ULPI_WU	__BIT(31)
48c1719a03Sbsh #define	 ULPI_RUN	__BIT(30)
49c1719a03Sbsh #define	 ULPI_RW	__BIT(29)
50c1719a03Sbsh #define	 ULPI_SS	__BIT(27)
512868f5bcShkenken #define	 ULPI_PORT	__BITS(26,24)
522868f5bcShkenken #define	 ULPI_ADDR	__BITS(23,16)
532868f5bcShkenken #define	 ULPI_DATRD	__BITS(15,8)
542868f5bcShkenken #define	 ULPI_DATWR	__BITS(7,0)
55c1719a03Sbsh 
56c1719a03Sbsh #define	IMXUSB_OTGSC	0x01A4
57c1719a03Sbsh #define	 OTGSC_DPIE	__BIT(30)
58c1719a03Sbsh #define	 OTGSC_1MSE	__BIT(29)
59c1719a03Sbsh #define	 OTGSC_BSEIE	__BIT(28)
60c1719a03Sbsh #define	 OTGSC_BSVIE	__BIT(27)
61c1719a03Sbsh #define	 OTGSC_ASVIE	__BIT(26)
62c1719a03Sbsh #define	 OTGSC_AVVIE	__BIT(25)
63c1719a03Sbsh #define	 OTGSC_IDIE	__BIT(24)
64c1719a03Sbsh #define	 OTGSC_DPIS	__BIT(22)
65c1719a03Sbsh #define	 OTGSC_1MSS	__BIT(21)
66c1719a03Sbsh #define	 OTGSC_BSEIS	__BIT(20)
67c1719a03Sbsh #define	 OTGSC_BSVIS	__BIT(19)
68c1719a03Sbsh #define	 OTGSC_ASVIS	__BIT(18)
69c1719a03Sbsh #define	 OTGSC_AVVIS	__BIT(17)
70c1719a03Sbsh #define	 OTGSC_IDIS	__BIT(16)
71c1719a03Sbsh #define	 OTGSC_DPS	__BIT(14)
72c1719a03Sbsh #define	 OTGSC_1MST	__BIT(13)
73c1719a03Sbsh #define	 OTGSC_BSE	__BIT(12)
74c1719a03Sbsh #define	 OTGSC_BSV	__BIT(11)
75c1719a03Sbsh #define	 OTGSC_ASV	__BIT(10)
76c1719a03Sbsh #define	 OTGSC_AVV	__BIT( 9)
77c1719a03Sbsh #define	 OTGSC_ID	__BIT( 8)
78c1719a03Sbsh #define	 OTGSC_IDPU	__BIT( 5)
79c1719a03Sbsh #define	 OTGSC_DP	__BIT( 4)
80c1719a03Sbsh #define	 OTGSC_OT	__BIT( 3)
81c1719a03Sbsh #define	 OTGSC_VC	__BIT( 1)
82c1719a03Sbsh #define	 OTGSC_VD	__BIT( 0)
8350aa6e87Sskrll #define	IMXUSB_USBMODE	0x01A8
8455d6f5fbSskrll #define	 USBMODE_VBPS	__BIT(5)	/* Vbus power selectt */
8555d6f5fbSskrll #define	 USBMODE_SDIS	__BIT(4)	/* Stream disable mode 1=act */
8655d6f5fbSskrll #define	 USBMODE_SLOM	__BIT(3)	/* setup lockouts on */
8755d6f5fbSskrll #define	 USBMODE_ES	__BIT(2)	/* Endian Select ES=1 */
8855d6f5fbSskrll #define	 USBMODE_CM	__BITS(1,0)	/* Controller mode */
892868f5bcShkenken #define	 USBMODE_CM_IDLE	__SHIFTIN(0,USBMODE_CM)
902868f5bcShkenken #define	 USBMODE_CM_DEVICE	__SHIFTIN(2,USBMODE_CM)
912868f5bcShkenken #define	 USBMODE_CM_HOST	__SHIFTIN(3,USBMODE_CM)
92c1719a03Sbsh 
93c1719a03Sbsh #define	IMXUSB_EHCI_SIZE	0x200
94c1719a03Sbsh 
95c1719a03Sbsh 
96c1719a03Sbsh /* extension to PORTSCx register of EHCI. */
972868f5bcShkenken #define	PORTSC_PTS		__BITS(31,30)
982868f5bcShkenken #define	PORTSC_PTS_UTMI		__SHIFTIN(0,PORTSC_PTS)
992868f5bcShkenken #define	PORTSC_PTS_PHILIPS	__SHIFTIN(1,PORTSC_PTS) /* not in i.MX51*/
1002868f5bcShkenken #define	PORTSC_PTS_ULPI		__SHIFTIN(2,PORTSC_PTS)
1012868f5bcShkenken #define	PORTSC_PTS_SERIAL	__SHIFTIN(3,PORTSC_PTS)
102ec482321Sryo #define	PORTSC_PTS2		__BIT(25)	/* iMX6,7 */
103c1719a03Sbsh 
104*dff9645dSandvar #define	PORTSC_STS	__BIT(29)	/* serial transceiver select */
105c1719a03Sbsh #define	PORTSC_PTW	__BIT(28)	/* parallel transceiver width */
106c1719a03Sbsh #define	PORTSC_PTW_8	0
1072868f5bcShkenken #define	PORTSC_PTW_16	PORTSC_PTW
108c1719a03Sbsh #define	PORTSC_PSPD	__BITS(26,27)	/* port speed (RO) */
109c1719a03Sbsh #define	PORTSC_PFSC	__BIT(24)	/* port force full speed */
110c1719a03Sbsh #define	PORTSC_PHCD	__BIT(23)	/* PHY low power suspend */
111c1719a03Sbsh 
112c1719a03Sbsh #endif	/* _ARM_IMX_IMXUSBREG_H */
113