blob: 1ef5bf604070deab903ec474da3053fb64218b1a [file] [log] [blame]
Kuninori Morimotof1407d52011-04-04 13:44:59 +09001/*
2 * Renesas USB driver
3 *
4 * Copyright (C) 2011 Renesas Solutions Corp.
5 * Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 *
12 * You should have received a copy of the GNU General Public License
13 * along with this program; if not, write to the Free Software
14 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
15 *
16 */
17#ifndef RENESAS_USB_MOD_H
18#define RENESAS_USB_MOD_H
19
20#include <linux/spinlock.h>
21#include <linux/usb/renesas_usbhs.h>
Paul Bollecc502bb2012-06-03 18:39:13 +020022#include "common.h"
Kuninori Morimotof1407d52011-04-04 13:44:59 +090023
24/*
25 * struct
26 */
27struct usbhs_irq_state {
28 u16 intsts0;
29 u16 intsts1;
30 u16 brdysts;
31 u16 nrdysts;
32 u16 bempsts;
Kuninori Morimotof1407d52011-04-04 13:44:59 +090033};
34
35struct usbhs_mod {
36 char *name;
37
38 /*
39 * entry point from common.c
40 */
41 int (*start)(struct usbhs_priv *priv);
42 int (*stop)(struct usbhs_priv *priv);
43
Kuninori Morimoto89c1d2e2011-10-10 22:06:57 -070044 /*
45 * INTSTS0
46 */
47
48 /* DVST (DVSQ) */
Kuninori Morimotof1407d52011-04-04 13:44:59 +090049 int (*irq_dev_state)(struct usbhs_priv *priv,
50 struct usbhs_irq_state *irq_state);
51
Kuninori Morimoto89c1d2e2011-10-10 22:06:57 -070052 /* CTRT (CTSQ) */
Kuninori Morimotof1407d52011-04-04 13:44:59 +090053 int (*irq_ctrl_stage)(struct usbhs_priv *priv,
54 struct usbhs_irq_state *irq_state);
55
Kuninori Morimoto89c1d2e2011-10-10 22:06:57 -070056 /* BEMP / BEMPSTS */
Kuninori Morimotof1407d52011-04-04 13:44:59 +090057 int (*irq_empty)(struct usbhs_priv *priv,
58 struct usbhs_irq_state *irq_state);
59 u16 irq_bempsts;
60
Kuninori Morimoto89c1d2e2011-10-10 22:06:57 -070061 /* BRDY / BRDYSTS */
Kuninori Morimotof1407d52011-04-04 13:44:59 +090062 int (*irq_ready)(struct usbhs_priv *priv,
63 struct usbhs_irq_state *irq_state);
64 u16 irq_brdysts;
65
Kuninori Morimoto89c1d2e2011-10-10 22:06:57 -070066 /*
67 * INTSTS1
68 */
69
70 /* ATTCHE */
71 int (*irq_attch)(struct usbhs_priv *priv,
72 struct usbhs_irq_state *irq_state);
73
74 /* DTCHE */
75 int (*irq_dtch)(struct usbhs_priv *priv,
76 struct usbhs_irq_state *irq_state);
77
78 /* SIGN */
79 int (*irq_sign)(struct usbhs_priv *priv,
80 struct usbhs_irq_state *irq_state);
81
82 /* SACK */
83 int (*irq_sack)(struct usbhs_priv *priv,
84 struct usbhs_irq_state *irq_state);
85
Kuninori Morimotof1407d52011-04-04 13:44:59 +090086 struct usbhs_priv *priv;
87};
88
89struct usbhs_mod_info {
90 struct usbhs_mod *mod[USBHS_MAX];
91 struct usbhs_mod *curt; /* current mod */
Kuninori Morimotob002ff62011-04-28 16:41:20 +090092
93 /*
94 * INTSTS0 :: VBINT
95 *
96 * This function will be used as autonomy mode
97 * when platform cannot call notify_hotplug.
98 *
99 * This callback cannot be member of "struct usbhs_mod"
100 * because it will be used even though
101 * host/gadget has not been selected.
102 */
103 int (*irq_vbus)(struct usbhs_priv *priv,
104 struct usbhs_irq_state *irq_state);
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900105};
106
107/*
108 * for host/gadget module
109 */
110struct usbhs_mod *usbhs_mod_get(struct usbhs_priv *priv, int id);
111struct usbhs_mod *usbhs_mod_get_current(struct usbhs_priv *priv);
112void usbhs_mod_register(struct usbhs_priv *priv, struct usbhs_mod *usb, int id);
Kuninori Morimoto0deb3e72011-10-10 22:02:45 -0700113int usbhs_mod_is_host(struct usbhs_priv *priv);
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900114int usbhs_mod_change(struct usbhs_priv *priv, int id);
115int usbhs_mod_probe(struct usbhs_priv *priv);
116void usbhs_mod_remove(struct usbhs_priv *priv);
117
Kuninori Morimotob002ff62011-04-28 16:41:20 +0900118void usbhs_mod_autonomy_mode(struct usbhs_priv *priv);
119
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900120/*
121 * status functions
122 */
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900123int usbhs_status_get_device_state(struct usbhs_irq_state *irq_state);
124int usbhs_status_get_ctrl_stage(struct usbhs_irq_state *irq_state);
125
126/*
127 * callback functions
128 */
129void usbhs_irq_callback_update(struct usbhs_priv *priv, struct usbhs_mod *mod);
130
131
132#define usbhs_mod_call(priv, func, param...) \
133 ({ \
134 struct usbhs_mod *mod; \
135 mod = usbhs_mod_get_current(priv); \
136 !mod ? -ENODEV : \
137 !mod->func ? 0 : \
138 mod->func(param); \
139 })
140
Kuninori Morimoto2f983822011-04-05 11:40:54 +0900141/*
Kuninori Morimoto034d7c12011-10-10 22:07:40 -0700142 * host / gadget control
Kuninori Morimoto2f983822011-04-05 11:40:54 +0900143 */
Kuninori Morimoto951fe822011-10-12 21:02:44 -0700144#if defined(CONFIG_USB_RENESAS_USBHS_HCD) || \
145 defined(CONFIG_USB_RENESAS_USBHS_HCD_MODULE)
Kuninori Morimotob7a8d172011-10-26 19:33:49 -0700146extern int usbhs_mod_host_probe(struct usbhs_priv *priv);
147extern int usbhs_mod_host_remove(struct usbhs_priv *priv);
Kuninori Morimoto034d7c12011-10-10 22:07:40 -0700148#else
149static inline int usbhs_mod_host_probe(struct usbhs_priv *priv)
150{
151 return 0;
152}
153static inline void usbhs_mod_host_remove(struct usbhs_priv *priv)
154{
155}
156#endif
157
Kuninori Morimoto951fe822011-10-12 21:02:44 -0700158#if defined(CONFIG_USB_RENESAS_USBHS_UDC) || \
159 defined(CONFIG_USB_RENESAS_USBHS_UDC_MODULE)
Kuninori Morimotob7a8d172011-10-26 19:33:49 -0700160extern int usbhs_mod_gadget_probe(struct usbhs_priv *priv);
161extern void usbhs_mod_gadget_remove(struct usbhs_priv *priv);
Kuninori Morimoto2f983822011-04-05 11:40:54 +0900162#else
163static inline int usbhs_mod_gadget_probe(struct usbhs_priv *priv)
164{
165 return 0;
166}
167static inline void usbhs_mod_gadget_remove(struct usbhs_priv *priv)
168{
169}
170#endif
171
Kuninori Morimotof1407d52011-04-04 13:44:59 +0900172#endif /* RENESAS_USB_MOD_H */