| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | * omap_udc.h -- for omap 3.2 udc, with OTG support | 
|  | 3 | * | 
|  | 4 | * 2004 (C) Texas Instruments, Inc. | 
|  | 5 | * 2004 (C) David Brownell | 
|  | 6 | */ | 
|  | 7 |  | 
|  | 8 | /* | 
|  | 9 | * USB device/endpoint management registers | 
|  | 10 | */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 |  | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 12 | #define	UDC_REV				(UDC_BASE + 0x0)	/* Revision */ | 
|  | 13 | #define	UDC_EP_NUM			(UDC_BASE + 0x4)	/* Which endpoint */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | #	define	UDC_SETUP_SEL		(1 << 6) | 
|  | 15 | #	define	UDC_EP_SEL		(1 << 5) | 
|  | 16 | #	define	UDC_EP_DIR		(1 << 4) | 
|  | 17 | /* low 4 bits for endpoint number */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 18 | #define	UDC_DATA			(UDC_BASE + 0x08)	/* Endpoint FIFO */ | 
|  | 19 | #define	UDC_CTRL			(UDC_BASE + 0x0C)	/* Endpoint control */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | #	define	UDC_CLR_HALT		(1 << 7) | 
|  | 21 | #	define	UDC_SET_HALT		(1 << 6) | 
| David Brownell | 6511108 | 2005-04-28 13:52:31 -0700 | [diff] [blame] | 22 | #	define	UDC_CLRDATA_TOGGLE	(1 << 3) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 23 | #	define	UDC_SET_FIFO_EN		(1 << 2) | 
|  | 24 | #	define	UDC_CLR_EP		(1 << 1) | 
|  | 25 | #	define	UDC_RESET_EP		(1 << 0) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 26 | #define	UDC_STAT_FLG			(UDC_BASE + 0x10)	/* Endpoint status */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | #	define	UDC_NO_RXPACKET		(1 << 15) | 
|  | 28 | #	define	UDC_MISS_IN		(1 << 14) | 
|  | 29 | #	define	UDC_DATA_FLUSH		(1 << 13) | 
|  | 30 | #	define	UDC_ISO_ERR		(1 << 12) | 
|  | 31 | #	define	UDC_ISO_FIFO_EMPTY	(1 << 9) | 
|  | 32 | #	define	UDC_ISO_FIFO_FULL	(1 << 8) | 
|  | 33 | #	define	UDC_EP_HALTED		(1 << 6) | 
|  | 34 | #	define	UDC_STALL		(1 << 5) | 
|  | 35 | #	define	UDC_NAK			(1 << 4) | 
|  | 36 | #	define	UDC_ACK			(1 << 3) | 
|  | 37 | #	define	UDC_FIFO_EN		(1 << 2) | 
|  | 38 | #	define	UDC_NON_ISO_FIFO_EMPTY	(1 << 1) | 
|  | 39 | #	define	UDC_NON_ISO_FIFO_FULL	(1 << 0) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 40 | #define	UDC_RXFSTAT			(UDC_BASE + 0x14)	/* OUT bytecount */ | 
|  | 41 | #define	UDC_SYSCON1			(UDC_BASE + 0x18)	/* System config 1 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 42 | #	define	UDC_CFG_LOCK		(1 << 8) | 
|  | 43 | #	define	UDC_DATA_ENDIAN		(1 << 7) | 
|  | 44 | #	define	UDC_DMA_ENDIAN		(1 << 6) | 
|  | 45 | #	define	UDC_NAK_EN		(1 << 4) | 
|  | 46 | #	define	UDC_AUTODECODE_DIS	(1 << 3) | 
|  | 47 | #	define	UDC_SELF_PWR		(1 << 2) | 
|  | 48 | #	define	UDC_SOFF_DIS		(1 << 1) | 
|  | 49 | #	define	UDC_PULLUP_EN		(1 << 0) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 50 | #define	UDC_SYSCON2			(UDC_BASE + 0x1C)	/* System config 2 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 | #	define	UDC_RMT_WKP		(1 << 6) | 
|  | 52 | #	define	UDC_STALL_CMD		(1 << 5) | 
|  | 53 | #	define	UDC_DEV_CFG		(1 << 3) | 
|  | 54 | #	define	UDC_CLR_CFG		(1 << 2) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 55 | #define	UDC_DEVSTAT			(UDC_BASE + 0x20)	/* Device status */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | #	define	UDC_B_HNP_ENABLE	(1 << 9) | 
|  | 57 | #	define	UDC_A_HNP_SUPPORT	(1 << 8) | 
|  | 58 | #	define	UDC_A_ALT_HNP_SUPPORT	(1 << 7) | 
|  | 59 | #	define	UDC_R_WK_OK		(1 << 6) | 
|  | 60 | #	define	UDC_USB_RESET		(1 << 5) | 
|  | 61 | #	define	UDC_SUS			(1 << 4) | 
|  | 62 | #	define	UDC_CFG			(1 << 3) | 
|  | 63 | #	define	UDC_ADD			(1 << 2) | 
|  | 64 | #	define	UDC_DEF			(1 << 1) | 
|  | 65 | #	define	UDC_ATT			(1 << 0) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 66 | #define	UDC_SOF				(UDC_BASE + 0x24)	/* Start of frame */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 67 | #	define	UDC_FT_LOCK		(1 << 12) | 
|  | 68 | #	define	UDC_TS_OK		(1 << 11) | 
|  | 69 | #	define	UDC_TS			0x03ff | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 70 | #define	UDC_IRQ_EN			(UDC_BASE + 0x28)	/* Interrupt enable */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | #	define	UDC_SOF_IE		(1 << 7) | 
|  | 72 | #	define	UDC_EPN_RX_IE		(1 << 5) | 
|  | 73 | #	define	UDC_EPN_TX_IE		(1 << 4) | 
|  | 74 | #	define	UDC_DS_CHG_IE		(1 << 3) | 
|  | 75 | #	define	UDC_EP0_IE		(1 << 0) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 76 | #define	UDC_DMA_IRQ_EN			(UDC_BASE + 0x2C)	/* DMA irq enable */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 77 | /* rx/tx dma channels numbered 1-3 not 0-2 */ | 
|  | 78 | #	define	UDC_TX_DONE_IE(n)	(1 << (4 * (n) - 2)) | 
|  | 79 | #	define	UDC_RX_CNT_IE(n)	(1 << (4 * (n) - 3)) | 
|  | 80 | #	define	UDC_RX_EOT_IE(n)	(1 << (4 * (n) - 4)) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 81 | #define	UDC_IRQ_SRC			(UDC_BASE + 0x30)	/* Interrupt source */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 82 | #	define	UDC_TXN_DONE		(1 << 10) | 
|  | 83 | #	define	UDC_RXN_CNT		(1 << 9) | 
|  | 84 | #	define	UDC_RXN_EOT		(1 << 8) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 85 | #	define	UDC_IRQ_SOF		(1 << 7) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 86 | #	define	UDC_EPN_RX		(1 << 5) | 
|  | 87 | #	define	UDC_EPN_TX		(1 << 4) | 
|  | 88 | #	define	UDC_DS_CHG		(1 << 3) | 
|  | 89 | #	define	UDC_SETUP		(1 << 2) | 
|  | 90 | #	define	UDC_EP0_RX		(1 << 1) | 
|  | 91 | #	define	UDC_EP0_TX		(1 << 0) | 
|  | 92 | #	define	UDC_IRQ_SRC_MASK	0x7bf | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 93 | #define	UDC_EPN_STAT			(UDC_BASE + 0x34)	/* EP irq status */ | 
|  | 94 | #define	UDC_DMAN_STAT			(UDC_BASE + 0x38)	/* DMA irq status */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 95 | #	define	UDC_DMA_RX_SB		(1 << 12) | 
|  | 96 | #	define	UDC_DMA_RX_SRC(x)	(((x)>>8) & 0xf) | 
|  | 97 | #	define	UDC_DMA_TX_SRC(x)	(((x)>>0) & 0xf) | 
|  | 98 |  | 
|  | 99 |  | 
|  | 100 | /* DMA configuration registers:  up to three channels in each direction.  */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 101 | #define	UDC_RXDMA_CFG			(UDC_BASE + 0x40)	/* 3 eps for RX DMA */ | 
| David Brownell | 6511108 | 2005-04-28 13:52:31 -0700 | [diff] [blame] | 102 | #	define	UDC_DMA_REQ		(1 << 12) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 103 | #define	UDC_TXDMA_CFG			(UDC_BASE + 0x44)	/* 3 eps for TX DMA */ | 
|  | 104 | #define	UDC_DATA_DMA			(UDC_BASE + 0x48)	/* rx/tx fifo addr */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 105 |  | 
|  | 106 | /* rx/tx dma control, numbering channels 1-3 not 0-2 */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 107 | #define	UDC_TXDMA(chan)			(UDC_BASE + 0x50 - 4 + 4 * (chan)) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 108 | #	define UDC_TXN_EOT		(1 << 15)	/* bytes vs packets */ | 
|  | 109 | #	define UDC_TXN_START		(1 << 14)	/* start transfer */ | 
|  | 110 | #	define UDC_TXN_TSC		0x03ff		/* units in xfer */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 111 | #define	UDC_RXDMA(chan)			(UDC_BASE + 0x60 - 4 + 4 * (chan)) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 112 | #	define UDC_RXN_STOP		(1 << 15)	/* enable EOT irq */ | 
|  | 113 | #	define UDC_RXN_TC		0x00ff		/* packets in xfer */ | 
|  | 114 |  | 
|  | 115 |  | 
|  | 116 | /* | 
|  | 117 | * Endpoint configuration registers (used before CFG_LOCK is set) | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 118 | * UDC_EP_TX(0) is unused | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 119 | */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 120 | #define	UDC_EP_RX(endpoint)		(UDC_BASE + 0x80 + (endpoint)*4) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 121 | #	define	UDC_EPN_RX_VALID	(1 << 15) | 
|  | 122 | #	define	UDC_EPN_RX_DB		(1 << 14) | 
|  | 123 | /* buffer size in bits 13, 12 */ | 
|  | 124 | #	define	UDC_EPN_RX_ISO		(1 << 11) | 
|  | 125 | /* buffer pointer in low 11 bits */ | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 126 | #define	UDC_EP_TX(endpoint)		(UDC_BASE + 0xc0 + (endpoint)*4) | 
|  | 127 | /* same bitfields as in RX */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 128 |  | 
|  | 129 | /*-------------------------------------------------------------------------*/ | 
|  | 130 |  | 
|  | 131 | struct omap_req { | 
|  | 132 | struct usb_request		req; | 
|  | 133 | struct list_head		queue; | 
|  | 134 | unsigned			dma_bytes; | 
|  | 135 | unsigned			mapped:1; | 
|  | 136 | }; | 
|  | 137 |  | 
|  | 138 | struct omap_ep { | 
|  | 139 | struct usb_ep			ep; | 
|  | 140 | struct list_head		queue; | 
|  | 141 | unsigned long			irqs; | 
|  | 142 | struct list_head		iso; | 
|  | 143 | const struct usb_endpoint_descriptor	*desc; | 
|  | 144 | char				name[14]; | 
|  | 145 | u16				maxpacket; | 
|  | 146 | u8				bEndpointAddress; | 
|  | 147 | u8				bmAttributes; | 
|  | 148 | unsigned			double_buf:1; | 
|  | 149 | unsigned			stopped:1; | 
|  | 150 | unsigned			fnf:1; | 
|  | 151 | unsigned			has_dma:1; | 
|  | 152 | u8				ackwait; | 
|  | 153 | u8				dma_channel; | 
|  | 154 | u16				dma_counter; | 
|  | 155 | int				lch; | 
|  | 156 | struct omap_udc			*udc; | 
|  | 157 | struct timer_list		timer; | 
|  | 158 | }; | 
|  | 159 |  | 
|  | 160 | struct omap_udc { | 
|  | 161 | struct usb_gadget		gadget; | 
|  | 162 | struct usb_gadget_driver	*driver; | 
|  | 163 | spinlock_t			lock; | 
|  | 164 | struct omap_ep			ep[32]; | 
|  | 165 | u16				devstat; | 
| David Brownell | 6511108 | 2005-04-28 13:52:31 -0700 | [diff] [blame] | 166 | u16				clr_halt; | 
| Heikki Krogerus | 8675381 | 2012-02-13 13:24:02 +0200 | [diff] [blame] | 167 | struct usb_phy			*transceiver; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 168 | struct list_head		iso; | 
|  | 169 | unsigned			softconnect:1; | 
|  | 170 | unsigned			vbus_active:1; | 
|  | 171 | unsigned			ep0_pending:1; | 
|  | 172 | unsigned			ep0_in:1; | 
|  | 173 | unsigned			ep0_set_config:1; | 
|  | 174 | unsigned			ep0_reset_config:1; | 
|  | 175 | unsigned			ep0_setup:1; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 176 | struct completion		*done; | 
| David Brownell | e6a6e47 | 2006-12-10 11:47:04 -0800 | [diff] [blame] | 177 | struct clk			*dc_clk; | 
|  | 178 | struct clk			*hhc_clk; | 
|  | 179 | unsigned			clk_requested:1; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 180 | }; | 
|  | 181 |  | 
|  | 182 | /*-------------------------------------------------------------------------*/ | 
|  | 183 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 184 | #ifdef VERBOSE | 
|  | 185 | #    define VDBG		DBG | 
|  | 186 | #else | 
|  | 187 | #    define VDBG(stuff...)	do{}while(0) | 
|  | 188 | #endif | 
|  | 189 |  | 
| David Brownell | 0027492 | 2007-11-19 12:58:36 -0800 | [diff] [blame] | 190 | #define ERR(stuff...)		pr_err("udc: " stuff) | 
| Arjan van de Ven | b6c6393 | 2008-07-25 01:45:52 -0700 | [diff] [blame] | 191 | #define WARNING(stuff...)	pr_warning("udc: " stuff) | 
| David Brownell | 0027492 | 2007-11-19 12:58:36 -0800 | [diff] [blame] | 192 | #define INFO(stuff...)		pr_info("udc: " stuff) | 
|  | 193 | #define DBG(stuff...)		pr_debug("udc: " stuff) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 194 |  | 
|  | 195 | /*-------------------------------------------------------------------------*/ | 
|  | 196 |  | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 197 | /* MOD_CONF_CTRL_0 */ | 
|  | 198 | #define VBUS_W2FC_1510		(1 << 17)	/* 0 gpio0, 1 dvdd2 pin */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 199 |  | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 200 | /* FUNC_MUX_CTRL_0 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 201 | #define	VBUS_CTRL_1510		(1 << 19)	/* 1 connected (software) */ | 
|  | 202 | #define	VBUS_MODE_1510		(1 << 18)	/* 0 hardware, 1 software */ | 
|  | 203 |  | 
| Tony Lindgren | f35ae63 | 2008-07-03 12:24:43 +0300 | [diff] [blame] | 204 | #define	HMC_1510	((omap_readl(MOD_CONF_CTRL_0) >> 1) & 0x3f) | 
|  | 205 | #define	HMC_1610	(omap_readl(OTG_SYSCON_2) & 0x3f) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 206 | #define	HMC		(cpu_is_omap15xx() ? HMC_1510 : HMC_1610) | 
|  | 207 |  |