1/*
2 * Copyright (C) 2011 Marvell International Ltd. All rights reserved.
3 *
4 * This program is free software; you can redistribute  it and/or modify it
5 * under  the terms of  the GNU General  Public License as published by the
6 * Free Software Foundation;  either version 2 of the  License, or (at your
7 * option) any later version.
8 */
9
10#ifndef __MV_UDC_H
11#define __MV_UDC_H
12
13#define VUSBHS_MAX_PORTS	8
14
15#define DQH_ALIGNMENT		2048
16#define DTD_ALIGNMENT		64
17#define DMA_BOUNDARY		4096
18
19#define EP_DIR_IN	1
20#define EP_DIR_OUT	0
21
22#define DMA_ADDR_INVALID	(~(dma_addr_t)0)
23
24#define EP0_MAX_PKT_SIZE	64
25/* ep0 transfer state */
26#define WAIT_FOR_SETUP		0
27#define DATA_STATE_XMIT		1
28#define DATA_STATE_NEED_ZLP	2
29#define WAIT_FOR_OUT_STATUS	3
30#define DATA_STATE_RECV		4
31
32#define CAPLENGTH_MASK		(0xff)
33#define DCCPARAMS_DEN_MASK	(0x1f)
34
35#define HCSPARAMS_PPC		(0x10)
36
37/* Frame Index Register Bit Masks */
38#define USB_FRINDEX_MASKS	0x3fff
39
40/* Command Register Bit Masks */
41#define USBCMD_RUN_STOP				(0x00000001)
42#define USBCMD_CTRL_RESET			(0x00000002)
43#define USBCMD_SETUP_TRIPWIRE_SET		(0x00002000)
44#define USBCMD_SETUP_TRIPWIRE_CLEAR		(~USBCMD_SETUP_TRIPWIRE_SET)
45
46#define USBCMD_ATDTW_TRIPWIRE_SET		(0x00004000)
47#define USBCMD_ATDTW_TRIPWIRE_CLEAR		(~USBCMD_ATDTW_TRIPWIRE_SET)
48
49/* bit 15,3,2 are for frame list size */
50#define USBCMD_FRAME_SIZE_1024			(0x00000000) /* 000 */
51#define USBCMD_FRAME_SIZE_512			(0x00000004) /* 001 */
52#define USBCMD_FRAME_SIZE_256			(0x00000008) /* 010 */
53#define USBCMD_FRAME_SIZE_128			(0x0000000C) /* 011 */
54#define USBCMD_FRAME_SIZE_64			(0x00008000) /* 100 */
55#define USBCMD_FRAME_SIZE_32			(0x00008004) /* 101 */
56#define USBCMD_FRAME_SIZE_16			(0x00008008) /* 110 */
57#define USBCMD_FRAME_SIZE_8			(0x0000800C) /* 111 */
58
59#define EPCTRL_TX_ALL_MASK			(0xFFFF0000)
60#define EPCTRL_RX_ALL_MASK			(0x0000FFFF)
61
62#define EPCTRL_TX_DATA_TOGGLE_RST		(0x00400000)
63#define EPCTRL_TX_EP_STALL			(0x00010000)
64#define EPCTRL_RX_EP_STALL			(0x00000001)
65#define EPCTRL_RX_DATA_TOGGLE_RST		(0x00000040)
66#define EPCTRL_RX_ENABLE			(0x00000080)
67#define EPCTRL_TX_ENABLE			(0x00800000)
68#define EPCTRL_CONTROL				(0x00000000)
69#define EPCTRL_ISOCHRONOUS			(0x00040000)
70#define EPCTRL_BULK				(0x00080000)
71#define EPCTRL_INT				(0x000C0000)
72#define EPCTRL_TX_TYPE				(0x000C0000)
73#define EPCTRL_RX_TYPE				(0x0000000C)
74#define EPCTRL_DATA_TOGGLE_INHIBIT		(0x00000020)
75#define EPCTRL_TX_EP_TYPE_SHIFT			(18)
76#define EPCTRL_RX_EP_TYPE_SHIFT			(2)
77
78#define EPCOMPLETE_MAX_ENDPOINTS		(16)
79
80/* endpoint list address bit masks */
81#define USB_EP_LIST_ADDRESS_MASK              0xfffff800
82
83#define PORTSCX_W1C_BITS			0x2a
84#define PORTSCX_PORT_RESET			0x00000100
85#define PORTSCX_PORT_POWER			0x00001000
86#define PORTSCX_FORCE_FULL_SPEED_CONNECT	0x01000000
87#define PORTSCX_PAR_XCVR_SELECT			0xC0000000
88#define PORTSCX_PORT_FORCE_RESUME		0x00000040
89#define PORTSCX_PORT_SUSPEND			0x00000080
90#define PORTSCX_PORT_SPEED_FULL			0x00000000
91#define PORTSCX_PORT_SPEED_LOW			0x04000000
92#define PORTSCX_PORT_SPEED_HIGH			0x08000000
93#define PORTSCX_PORT_SPEED_MASK			0x0C000000
94
95/* USB MODE Register Bit Masks */
96#define USBMODE_CTRL_MODE_IDLE			0x00000000
97#define USBMODE_CTRL_MODE_DEVICE		0x00000002
98#define USBMODE_CTRL_MODE_HOST			0x00000003
99#define USBMODE_CTRL_MODE_RSV			0x00000001
100#define USBMODE_SETUP_LOCK_OFF			0x00000008
101#define USBMODE_STREAM_DISABLE			0x00000010
102
103/* USB STS Register Bit Masks */
104#define USBSTS_INT			0x00000001
105#define USBSTS_ERR			0x00000002
106#define USBSTS_PORT_CHANGE		0x00000004
107#define USBSTS_FRM_LST_ROLL		0x00000008
108#define USBSTS_SYS_ERR			0x00000010
109#define USBSTS_IAA			0x00000020
110#define USBSTS_RESET			0x00000040
111#define USBSTS_SOF			0x00000080
112#define USBSTS_SUSPEND			0x00000100
113#define USBSTS_HC_HALTED		0x00001000
114#define USBSTS_RCL			0x00002000
115#define USBSTS_PERIODIC_SCHEDULE	0x00004000
116#define USBSTS_ASYNC_SCHEDULE		0x00008000
117
118
119/* Interrupt Enable Register Bit Masks */
120#define USBINTR_INT_EN                          (0x00000001)
121#define USBINTR_ERR_INT_EN                      (0x00000002)
122#define USBINTR_PORT_CHANGE_DETECT_EN           (0x00000004)
123
124#define USBINTR_ASYNC_ADV_AAE                   (0x00000020)
125#define USBINTR_ASYNC_ADV_AAE_ENABLE            (0x00000020)
126#define USBINTR_ASYNC_ADV_AAE_DISABLE           (0xFFFFFFDF)
127
128#define USBINTR_RESET_EN                        (0x00000040)
129#define USBINTR_SOF_UFRAME_EN                   (0x00000080)
130#define USBINTR_DEVICE_SUSPEND                  (0x00000100)
131
132#define USB_DEVICE_ADDRESS_MASK			(0xfe000000)
133#define USB_DEVICE_ADDRESS_BIT_SHIFT		(25)
134
135struct mv_cap_regs {
136	u32	caplength_hciversion;
137	u32	hcsparams;	/* HC structural parameters */
138	u32	hccparams;	/* HC Capability Parameters*/
139	u32	reserved[5];
140	u32	dciversion;	/* DC version number and reserved 16 bits */
141	u32	dccparams;	/* DC Capability Parameters */
142};
143
144struct mv_op_regs {
145	u32	usbcmd;		/* Command register */
146	u32	usbsts;		/* Status register */
147	u32	usbintr;	/* Interrupt enable */
148	u32	frindex;	/* Frame index */
149	u32	reserved1[1];
150	u32	deviceaddr;	/* Device Address */
151	u32	eplistaddr;	/* Endpoint List Address */
152	u32	ttctrl;		/* HOST TT status and control */
153	u32	burstsize;	/* Programmable Burst Size */
154	u32	txfilltuning;	/* Host Transmit Pre-Buffer Packet Tuning */
155	u32	reserved[4];
156	u32	epnak;		/* Endpoint NAK */
157	u32	epnaken;	/* Endpoint NAK Enable */
158	u32	configflag;	/* Configured Flag register */
159	u32	portsc[VUSBHS_MAX_PORTS]; /* Port Status/Control x, x = 1..8 */
160	u32	otgsc;
161	u32	usbmode;	/* USB Host/Device mode */
162	u32	epsetupstat;	/* Endpoint Setup Status */
163	u32	epprime;	/* Endpoint Initialize */
164	u32	epflush;	/* Endpoint De-initialize */
165	u32	epstatus;	/* Endpoint Status */
166	u32	epcomplete;	/* Endpoint Interrupt On Complete */
167	u32	epctrlx[16];	/* Endpoint Control, where x = 0.. 15 */
168	u32	mcr;		/* Mux Control */
169	u32	isr;		/* Interrupt Status */
170	u32	ier;		/* Interrupt Enable */
171};
172
173struct mv_udc {
174	struct usb_gadget		gadget;
175	struct usb_gadget_driver	*driver;
176	spinlock_t			lock;
177	struct completion		*done;
178	struct platform_device		*dev;
179	int				irq;
180
181	struct mv_cap_regs __iomem	*cap_regs;
182	struct mv_op_regs __iomem	*op_regs;
183	void __iomem                    *phy_regs;
184	unsigned int			max_eps;
185	struct mv_dqh			*ep_dqh;
186	size_t				ep_dqh_size;
187	dma_addr_t			ep_dqh_dma;
188
189	struct dma_pool			*dtd_pool;
190	struct mv_ep			*eps;
191
192	struct mv_dtd			*dtd_head;
193	struct mv_dtd			*dtd_tail;
194	unsigned int			dtd_entries;
195
196	struct mv_req			*status_req;
197	struct usb_ctrlrequest		local_setup_buff;
198
199	unsigned int		resume_state;	/* USB state to resume */
200	unsigned int		usb_state;	/* USB current state */
201	unsigned int		ep0_state;	/* Endpoint zero state */
202	unsigned int		ep0_dir;
203
204	unsigned int		dev_addr;
205	unsigned int		test_mode;
206
207	int			errors;
208	unsigned		softconnect:1,
209				vbus_active:1,
210				remote_wakeup:1,
211				softconnected:1,
212				force_fs:1,
213				clock_gating:1,
214				active:1,
215				stopped:1;      /* stop bit is setted */
216
217	struct work_struct	vbus_work;
218	struct workqueue_struct *qwork;
219
220	struct usb_phy		*transceiver;
221
222	struct mv_usb_platform_data     *pdata;
223
224	/* some SOC has mutiple clock sources for USB*/
225	struct clk      *clk;
226};
227
228/* endpoint data structure */
229struct mv_ep {
230	struct usb_ep		ep;
231	struct mv_udc		*udc;
232	struct list_head	queue;
233	struct mv_dqh		*dqh;
234	u32			direction;
235	char			name[14];
236	unsigned		stopped:1,
237				wedge:1,
238				ep_type:2,
239				ep_num:8;
240};
241
242/* request data structure */
243struct mv_req {
244	struct usb_request	req;
245	struct mv_dtd		*dtd, *head, *tail;
246	struct mv_ep		*ep;
247	struct list_head	queue;
248	unsigned int            test_mode;
249	unsigned		dtd_count;
250	unsigned		mapped:1;
251};
252
253#define EP_QUEUE_HEAD_MULT_POS			30
254#define EP_QUEUE_HEAD_ZLT_SEL			0x20000000
255#define EP_QUEUE_HEAD_MAX_PKT_LEN_POS		16
256#define EP_QUEUE_HEAD_MAX_PKT_LEN(ep_info)	(((ep_info)>>16)&0x07ff)
257#define EP_QUEUE_HEAD_IOS			0x00008000
258#define EP_QUEUE_HEAD_NEXT_TERMINATE		0x00000001
259#define EP_QUEUE_HEAD_IOC			0x00008000
260#define EP_QUEUE_HEAD_MULTO			0x00000C00
261#define EP_QUEUE_HEAD_STATUS_HALT		0x00000040
262#define EP_QUEUE_HEAD_STATUS_ACTIVE		0x00000080
263#define EP_QUEUE_CURRENT_OFFSET_MASK		0x00000FFF
264#define EP_QUEUE_HEAD_NEXT_POINTER_MASK		0xFFFFFFE0
265#define EP_QUEUE_FRINDEX_MASK			0x000007FF
266#define EP_MAX_LENGTH_TRANSFER			0x4000
267
268struct mv_dqh {
269	/* Bits 16..26 Bit 15 is Interrupt On Setup */
270	u32	max_packet_length;
271	u32	curr_dtd_ptr;		/* Current dTD Pointer */
272	u32	next_dtd_ptr;		/* Next dTD Pointer */
273	/* Total bytes (16..30), IOC (15), INT (8), STS (0-7) */
274	u32	size_ioc_int_sts;
275	u32	buff_ptr0;		/* Buffer pointer Page 0 (12-31) */
276	u32	buff_ptr1;		/* Buffer pointer Page 1 (12-31) */
277	u32	buff_ptr2;		/* Buffer pointer Page 2 (12-31) */
278	u32	buff_ptr3;		/* Buffer pointer Page 3 (12-31) */
279	u32	buff_ptr4;		/* Buffer pointer Page 4 (12-31) */
280	u32	reserved1;
281	/* 8 bytes of setup data that follows the Setup PID */
282	u8	setup_buffer[8];
283	u32	reserved2[4];
284};
285
286
287#define DTD_NEXT_TERMINATE		(0x00000001)
288#define DTD_IOC				(0x00008000)
289#define DTD_STATUS_ACTIVE		(0x00000080)
290#define DTD_STATUS_HALTED		(0x00000040)
291#define DTD_STATUS_DATA_BUFF_ERR	(0x00000020)
292#define DTD_STATUS_TRANSACTION_ERR	(0x00000008)
293#define DTD_RESERVED_FIELDS		(0x00007F00)
294#define DTD_ERROR_MASK			(0x68)
295#define DTD_ADDR_MASK			(0xFFFFFFE0)
296#define DTD_PACKET_SIZE			0x7FFF0000
297#define DTD_LENGTH_BIT_POS		(16)
298
299struct mv_dtd {
300	u32	dtd_next;
301	u32	size_ioc_sts;
302	u32	buff_ptr0;		/* Buffer pointer Page 0 */
303	u32	buff_ptr1;		/* Buffer pointer Page 1 */
304	u32	buff_ptr2;		/* Buffer pointer Page 2 */
305	u32	buff_ptr3;		/* Buffer pointer Page 3 */
306	u32	buff_ptr4;		/* Buffer pointer Page 4 */
307	u32	scratch_ptr;
308	/* 32 bytes */
309	dma_addr_t td_dma;		/* dma address for this td */
310	struct mv_dtd *next_dtd_virt;
311};
312
313#endif
314