2 * USB transceiver driver for AB8500 family chips
4 * Copyright (C) 2010-2013 ST-Ericsson AB
5 * Mian Yousaf Kaukab <mian.yousaf.kaukab@stericsson.com>
6 * Avinash Kumar <avinash.kumar@stericsson.com>
7 * Thirupathi Chippakurthy <thirupathi.chippakurthy@stericsson.com>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 #include <linux/module.h>
26 #include <linux/platform_device.h>
27 #include <linux/usb/otg.h>
28 #include <linux/slab.h>
29 #include <linux/notifier.h>
30 #include <linux/interrupt.h>
31 #include <linux/delay.h>
32 #include <linux/clk.h>
33 #include <linux/err.h>
34 #include <linux/mfd/abx500.h>
35 #include <linux/mfd/abx500/ab8500.h>
36 #include <linux/usb/musb-ux500.h>
37 #include <linux/regulator/consumer.h>
38 #include <linux/pinctrl/consumer.h>
40 /* Bank AB8500_SYS_CTRL2_BLOCK */
41 #define AB8500_MAIN_WD_CTRL_REG 0x01
44 #define AB8500_USB_LINE_STAT_REG 0x80
45 #define AB8505_USB_LINE_STAT_REG 0x94
46 #define AB8540_USB_LINK_STAT_REG 0x94
47 #define AB9540_USB_LINK_STAT_REG 0x94
48 #define AB8540_USB_OTG_CTL_REG 0x87
49 #define AB8500_USB_PHY_CTRL_REG 0x8A
50 #define AB8540_VBUS_CTRL_REG 0x82
52 /* Bank AB8500_DEVELOPMENT */
53 #define AB8500_BANK12_ACCESS 0x00
55 /* Bank AB8500_DEBUG */
56 #define AB8540_DEBUG 0x32
57 #define AB8500_USB_PHY_TUNE1 0x05
58 #define AB8500_USB_PHY_TUNE2 0x06
59 #define AB8500_USB_PHY_TUNE3 0x07
61 /* Bank AB8500_INTERRUPT */
62 #define AB8500_IT_SOURCE2_REG 0x01
64 #define AB8500_BIT_OTG_STAT_ID (1 << 0)
65 #define AB8500_BIT_PHY_CTRL_HOST_EN (1 << 0)
66 #define AB8500_BIT_PHY_CTRL_DEVICE_EN (1 << 1)
67 #define AB8500_BIT_WD_CTRL_ENABLE (1 << 0)
68 #define AB8500_BIT_WD_CTRL_KICK (1 << 1)
69 #define AB8500_BIT_SOURCE2_VBUSDET (1 << 7)
70 #define AB8540_BIT_OTG_CTL_VBUS_VALID_ENA (1 << 0)
71 #define AB8540_BIT_OTG_CTL_ID_HOST_ENA (1 << 1)
72 #define AB8540_BIT_OTG_CTL_ID_DEV_ENA (1 << 5)
73 #define AB8540_BIT_VBUS_CTRL_CHARG_DET_ENA (1 << 0)
75 #define AB8500_WD_KICK_DELAY_US 100 /* usec */
76 #define AB8500_WD_V11_DISABLE_DELAY_US 100 /* usec */
77 #define AB8500_V20_31952_DISABLE_DELAY_US 100 /* usec */
79 /* Usb line status register */
80 enum ab8500_usb_link_status
{
81 USB_LINK_NOT_CONFIGURED_8500
= 0,
82 USB_LINK_STD_HOST_NC_8500
,
83 USB_LINK_STD_HOST_C_NS_8500
,
84 USB_LINK_STD_HOST_C_S_8500
,
85 USB_LINK_HOST_CHG_NM_8500
,
86 USB_LINK_HOST_CHG_HS_8500
,
87 USB_LINK_HOST_CHG_HS_CHIRP_8500
,
88 USB_LINK_DEDICATED_CHG_8500
,
89 USB_LINK_ACA_RID_A_8500
,
90 USB_LINK_ACA_RID_B_8500
,
91 USB_LINK_ACA_RID_C_NM_8500
,
92 USB_LINK_ACA_RID_C_HS_8500
,
93 USB_LINK_ACA_RID_C_HS_CHIRP_8500
,
94 USB_LINK_HM_IDGND_8500
,
95 USB_LINK_RESERVED_8500
,
96 USB_LINK_NOT_VALID_LINK_8500
,
99 enum ab8505_usb_link_status
{
100 USB_LINK_NOT_CONFIGURED_8505
= 0,
101 USB_LINK_STD_HOST_NC_8505
,
102 USB_LINK_STD_HOST_C_NS_8505
,
103 USB_LINK_STD_HOST_C_S_8505
,
105 USB_LINK_RESERVED0_8505
,
106 USB_LINK_RESERVED1_8505
,
107 USB_LINK_DEDICATED_CHG_8505
,
108 USB_LINK_ACA_RID_A_8505
,
109 USB_LINK_ACA_RID_B_8505
,
110 USB_LINK_ACA_RID_C_NM_8505
,
111 USB_LINK_RESERVED2_8505
,
112 USB_LINK_RESERVED3_8505
,
113 USB_LINK_HM_IDGND_8505
,
114 USB_LINK_CHARGERPORT_NOT_OK_8505
,
115 USB_LINK_CHARGER_DM_HIGH_8505
,
116 USB_LINK_PHYEN_NO_VBUS_NO_IDGND_8505
,
117 USB_LINK_STD_UPSTREAM_NO_IDGNG_NO_VBUS_8505
,
118 USB_LINK_STD_UPSTREAM_8505
,
119 USB_LINK_CHARGER_SE1_8505
,
120 USB_LINK_CARKIT_CHGR_1_8505
,
121 USB_LINK_CARKIT_CHGR_2_8505
,
122 USB_LINK_ACA_DOCK_CHGR_8505
,
123 USB_LINK_SAMSUNG_BOOT_CBL_PHY_EN_8505
,
124 USB_LINK_SAMSUNG_BOOT_CBL_PHY_DISB_8505
,
125 USB_LINK_SAMSUNG_UART_CBL_PHY_EN_8505
,
126 USB_LINK_SAMSUNG_UART_CBL_PHY_DISB_8505
,
127 USB_LINK_MOTOROLA_FACTORY_CBL_PHY_EN_8505
,
130 enum ab8540_usb_link_status
{
131 USB_LINK_NOT_CONFIGURED_8540
= 0,
132 USB_LINK_STD_HOST_NC_8540
,
133 USB_LINK_STD_HOST_C_NS_8540
,
134 USB_LINK_STD_HOST_C_S_8540
,
136 USB_LINK_RESERVED0_8540
,
137 USB_LINK_RESERVED1_8540
,
138 USB_LINK_DEDICATED_CHG_8540
,
139 USB_LINK_ACA_RID_A_8540
,
140 USB_LINK_ACA_RID_B_8540
,
141 USB_LINK_ACA_RID_C_NM_8540
,
142 USB_LINK_RESERVED2_8540
,
143 USB_LINK_RESERVED3_8540
,
144 USB_LINK_HM_IDGND_8540
,
145 USB_LINK_CHARGERPORT_NOT_OK_8540
,
146 USB_LINK_CHARGER_DM_HIGH_8540
,
147 USB_LINK_PHYEN_NO_VBUS_NO_IDGND_8540
,
148 USB_LINK_STD_UPSTREAM_NO_IDGNG_VBUS_8540
,
149 USB_LINK_STD_UPSTREAM_8540
,
150 USB_LINK_CHARGER_SE1_8540
,
151 USB_LINK_CARKIT_CHGR_1_8540
,
152 USB_LINK_CARKIT_CHGR_2_8540
,
153 USB_LINK_ACA_DOCK_CHGR_8540
,
154 USB_LINK_SAMSUNG_BOOT_CBL_PHY_EN_8540
,
155 USB_LINK_SAMSUNG_BOOT_CBL_PHY_DISB_8540
,
156 USB_LINK_SAMSUNG_UART_CBL_PHY_EN_8540
,
157 USB_LINK_SAMSUNG_UART_CBL_PHY_DISB_8540
,
158 USB_LINK_MOTOROLA_FACTORY_CBL_PHY_EN_8540
161 enum ab9540_usb_link_status
{
162 USB_LINK_NOT_CONFIGURED_9540
= 0,
163 USB_LINK_STD_HOST_NC_9540
,
164 USB_LINK_STD_HOST_C_NS_9540
,
165 USB_LINK_STD_HOST_C_S_9540
,
167 USB_LINK_RESERVED0_9540
,
168 USB_LINK_RESERVED1_9540
,
169 USB_LINK_DEDICATED_CHG_9540
,
170 USB_LINK_ACA_RID_A_9540
,
171 USB_LINK_ACA_RID_B_9540
,
172 USB_LINK_ACA_RID_C_NM_9540
,
173 USB_LINK_RESERVED2_9540
,
174 USB_LINK_RESERVED3_9540
,
175 USB_LINK_HM_IDGND_9540
,
176 USB_LINK_CHARGERPORT_NOT_OK_9540
,
177 USB_LINK_CHARGER_DM_HIGH_9540
,
178 USB_LINK_PHYEN_NO_VBUS_NO_IDGND_9540
,
179 USB_LINK_STD_UPSTREAM_NO_IDGNG_VBUS_9540
,
180 USB_LINK_STD_UPSTREAM_9540
,
181 USB_LINK_CHARGER_SE1_9540
,
182 USB_LINK_CARKIT_CHGR_1_9540
,
183 USB_LINK_CARKIT_CHGR_2_9540
,
184 USB_LINK_ACA_DOCK_CHGR_9540
,
185 USB_LINK_SAMSUNG_BOOT_CBL_PHY_EN_9540
,
186 USB_LINK_SAMSUNG_BOOT_CBL_PHY_DISB_9540
,
187 USB_LINK_SAMSUNG_UART_CBL_PHY_EN_9540
,
188 USB_LINK_SAMSUNG_UART_CBL_PHY_DISB_9540
,
189 USB_LINK_MOTOROLA_FACTORY_CBL_PHY_EN_9540
192 enum ab8500_usb_mode
{
199 /* Register USB_LINK_STATUS interrupt */
200 #define AB8500_USB_FLAG_USE_LINK_STATUS_IRQ (1 << 0)
201 /* Register ID_WAKEUP_F interrupt */
202 #define AB8500_USB_FLAG_USE_ID_WAKEUP_IRQ (1 << 1)
203 /* Register VBUS_DET_F interrupt */
204 #define AB8500_USB_FLAG_USE_VBUS_DET_IRQ (1 << 2)
205 /* Driver is using the ab-iddet driver*/
206 #define AB8500_USB_FLAG_USE_AB_IDDET (1 << 3)
207 /* Enable setting regulators voltage */
208 #define AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE (1 << 4)
209 /* Enable the check_vbus_status workaround */
210 #define AB8500_USB_FLAG_USE_CHECK_VBUS_STATUS (1 << 5)
211 /* Enable the vbus host workaround */
212 #define AB8500_USB_FLAG_USE_VBUS_HOST_QUIRK (1 << 6)
217 struct ab8500
*ab8500
;
219 struct work_struct phy_dis_work
;
220 struct work_struct vbus_event_work
;
221 enum ab8500_usb_mode mode
;
223 struct regulator
*v_ape
;
224 struct regulator
*v_musb
;
225 struct regulator
*v_ulpi
;
227 int previous_link_status_state
;
228 struct pinctrl
*pinctrl
;
229 struct pinctrl_state
*pins_sleep
;
230 bool enabled_charging_detection
;
234 static inline struct ab8500_usb
*phy_to_ab(struct usb_phy
*x
)
236 return container_of(x
, struct ab8500_usb
, phy
);
239 static void ab8500_usb_wd_workaround(struct ab8500_usb
*ab
)
241 abx500_set_register_interruptible(ab
->dev
,
242 AB8500_SYS_CTRL2_BLOCK
,
243 AB8500_MAIN_WD_CTRL_REG
,
244 AB8500_BIT_WD_CTRL_ENABLE
);
246 udelay(AB8500_WD_KICK_DELAY_US
);
248 abx500_set_register_interruptible(ab
->dev
,
249 AB8500_SYS_CTRL2_BLOCK
,
250 AB8500_MAIN_WD_CTRL_REG
,
251 (AB8500_BIT_WD_CTRL_ENABLE
252 | AB8500_BIT_WD_CTRL_KICK
));
254 udelay(AB8500_WD_V11_DISABLE_DELAY_US
);
256 abx500_set_register_interruptible(ab
->dev
,
257 AB8500_SYS_CTRL2_BLOCK
,
258 AB8500_MAIN_WD_CTRL_REG
,
262 static void ab8500_usb_regulator_enable(struct ab8500_usb
*ab
)
266 ret
= regulator_enable(ab
->v_ape
);
268 dev_err(ab
->dev
, "Failed to enable v-ape\n");
270 if (ab
->flags
& AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
) {
271 ab
->saved_v_ulpi
= regulator_get_voltage(ab
->v_ulpi
);
272 if (ab
->saved_v_ulpi
< 0)
273 dev_err(ab
->dev
, "Failed to get v_ulpi voltage\n");
275 ret
= regulator_set_voltage(ab
->v_ulpi
, 1300000, 1350000);
277 dev_err(ab
->dev
, "Failed to set the Vintcore to 1.3V, ret=%d\n",
280 ret
= regulator_set_load(ab
->v_ulpi
, 28000);
282 dev_err(ab
->dev
, "Failed to set optimum mode (ret=%d)\n",
286 ret
= regulator_enable(ab
->v_ulpi
);
288 dev_err(ab
->dev
, "Failed to enable vddulpivio18\n");
290 if (ab
->flags
& AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
) {
291 volt
= regulator_get_voltage(ab
->v_ulpi
);
292 if ((volt
!= 1300000) && (volt
!= 1350000))
293 dev_err(ab
->dev
, "Vintcore is not set to 1.3V volt=%d\n",
297 ret
= regulator_enable(ab
->v_musb
);
299 dev_err(ab
->dev
, "Failed to enable musb_1v8\n");
302 static void ab8500_usb_regulator_disable(struct ab8500_usb
*ab
)
306 regulator_disable(ab
->v_musb
);
308 regulator_disable(ab
->v_ulpi
);
310 /* USB is not the only consumer of Vintcore, restore old settings */
311 if (ab
->flags
& AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
) {
312 if (ab
->saved_v_ulpi
> 0) {
313 ret
= regulator_set_voltage(ab
->v_ulpi
,
314 ab
->saved_v_ulpi
, ab
->saved_v_ulpi
);
316 dev_err(ab
->dev
, "Failed to set the Vintcore to %duV, ret=%d\n",
317 ab
->saved_v_ulpi
, ret
);
320 ret
= regulator_set_load(ab
->v_ulpi
, 0);
322 dev_err(ab
->dev
, "Failed to set optimum mode (ret=%d)\n",
326 regulator_disable(ab
->v_ape
);
329 static void ab8500_usb_wd_linkstatus(struct ab8500_usb
*ab
, u8 bit
)
331 /* Workaround for v2.0 bug # 31952 */
332 if (is_ab8500_2p0(ab
->ab8500
)) {
333 abx500_mask_and_set_register_interruptible(ab
->dev
,
334 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
336 udelay(AB8500_V20_31952_DISABLE_DELAY_US
);
340 static void ab8500_usb_phy_enable(struct ab8500_usb
*ab
, bool sel_host
)
343 bit
= sel_host
? AB8500_BIT_PHY_CTRL_HOST_EN
:
344 AB8500_BIT_PHY_CTRL_DEVICE_EN
;
346 /* mux and configure USB pins to DEFAULT state */
347 ab
->pinctrl
= pinctrl_get_select(ab
->dev
, PINCTRL_STATE_DEFAULT
);
348 if (IS_ERR(ab
->pinctrl
))
349 dev_err(ab
->dev
, "could not get/set default pinstate\n");
351 if (clk_prepare_enable(ab
->sysclk
))
352 dev_err(ab
->dev
, "can't prepare/enable clock\n");
354 ab8500_usb_regulator_enable(ab
);
356 abx500_mask_and_set_register_interruptible(ab
->dev
,
357 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
360 if (ab
->flags
& AB8500_USB_FLAG_USE_VBUS_HOST_QUIRK
) {
362 abx500_set_register_interruptible(ab
->dev
,
363 AB8500_USB
, AB8540_USB_OTG_CTL_REG
,
364 AB8540_BIT_OTG_CTL_VBUS_VALID_ENA
|
365 AB8540_BIT_OTG_CTL_ID_HOST_ENA
|
366 AB8540_BIT_OTG_CTL_ID_DEV_ENA
);
370 static void ab8500_usb_phy_disable(struct ab8500_usb
*ab
, bool sel_host
)
373 bit
= sel_host
? AB8500_BIT_PHY_CTRL_HOST_EN
:
374 AB8500_BIT_PHY_CTRL_DEVICE_EN
;
376 ab8500_usb_wd_linkstatus(ab
, bit
);
378 abx500_mask_and_set_register_interruptible(ab
->dev
,
379 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
382 /* Needed to disable the phy.*/
383 ab8500_usb_wd_workaround(ab
);
385 clk_disable_unprepare(ab
->sysclk
);
387 ab8500_usb_regulator_disable(ab
);
389 if (!IS_ERR(ab
->pinctrl
)) {
390 /* configure USB pins to SLEEP state */
391 ab
->pins_sleep
= pinctrl_lookup_state(ab
->pinctrl
,
392 PINCTRL_STATE_SLEEP
);
394 if (IS_ERR(ab
->pins_sleep
))
395 dev_dbg(ab
->dev
, "could not get sleep pinstate\n");
396 else if (pinctrl_select_state(ab
->pinctrl
, ab
->pins_sleep
))
397 dev_err(ab
->dev
, "could not set pins to sleep state\n");
400 * as USB pins are shared with iddet, release them to allow
401 * iddet to request them
403 pinctrl_put(ab
->pinctrl
);
407 #define ab8500_usb_host_phy_en(ab) ab8500_usb_phy_enable(ab, true)
408 #define ab8500_usb_host_phy_dis(ab) ab8500_usb_phy_disable(ab, true)
409 #define ab8500_usb_peri_phy_en(ab) ab8500_usb_phy_enable(ab, false)
410 #define ab8500_usb_peri_phy_dis(ab) ab8500_usb_phy_disable(ab, false)
412 static int ab9540_usb_link_status_update(struct ab8500_usb
*ab
,
413 enum ab9540_usb_link_status lsts
)
415 enum ux500_musb_vbus_id_status event
= 0;
417 dev_dbg(ab
->dev
, "ab9540_usb_link_status_update %d\n", lsts
);
419 if (ab
->previous_link_status_state
== USB_LINK_HM_IDGND_9540
&&
420 (lsts
== USB_LINK_STD_HOST_C_NS_9540
||
421 lsts
== USB_LINK_STD_HOST_NC_9540
))
424 if (ab
->previous_link_status_state
== USB_LINK_ACA_RID_A_9540
&&
425 (lsts
== USB_LINK_STD_HOST_NC_9540
))
428 ab
->previous_link_status_state
= lsts
;
431 case USB_LINK_ACA_RID_B_9540
:
432 event
= UX500_MUSB_RIDB
;
433 case USB_LINK_NOT_CONFIGURED_9540
:
434 case USB_LINK_RESERVED0_9540
:
435 case USB_LINK_RESERVED1_9540
:
436 case USB_LINK_RESERVED2_9540
:
437 case USB_LINK_RESERVED3_9540
:
438 if (ab
->mode
== USB_PERIPHERAL
)
439 atomic_notifier_call_chain(&ab
->phy
.notifier
,
440 UX500_MUSB_CLEAN
, &ab
->vbus_draw
);
442 ab
->phy
.otg
->default_a
= false;
444 if (event
!= UX500_MUSB_RIDB
)
445 event
= UX500_MUSB_NONE
;
446 /* Fallback to default B_IDLE as nothing is connected. */
447 ab
->phy
.otg
->state
= OTG_STATE_B_IDLE
;
448 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
451 case USB_LINK_ACA_RID_C_NM_9540
:
452 event
= UX500_MUSB_RIDC
;
453 case USB_LINK_STD_HOST_NC_9540
:
454 case USB_LINK_STD_HOST_C_NS_9540
:
455 case USB_LINK_STD_HOST_C_S_9540
:
456 case USB_LINK_CDP_9540
:
457 if (ab
->mode
== USB_HOST
) {
458 ab
->mode
= USB_PERIPHERAL
;
459 ab8500_usb_host_phy_dis(ab
);
460 ab8500_usb_peri_phy_en(ab
);
461 atomic_notifier_call_chain(&ab
->phy
.notifier
,
462 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
463 usb_phy_set_event(&ab
->phy
, USB_EVENT_ENUMERATED
);
465 if (ab
->mode
== USB_IDLE
) {
466 ab
->mode
= USB_PERIPHERAL
;
467 ab8500_usb_peri_phy_en(ab
);
468 atomic_notifier_call_chain(&ab
->phy
.notifier
,
469 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
470 usb_phy_set_event(&ab
->phy
, USB_EVENT_ENUMERATED
);
472 if (event
!= UX500_MUSB_RIDC
)
473 event
= UX500_MUSB_VBUS
;
476 case USB_LINK_ACA_RID_A_9540
:
477 event
= UX500_MUSB_RIDA
;
478 case USB_LINK_HM_IDGND_9540
:
479 case USB_LINK_STD_UPSTREAM_9540
:
480 if (ab
->mode
== USB_PERIPHERAL
) {
482 ab8500_usb_peri_phy_dis(ab
);
483 ab8500_usb_host_phy_en(ab
);
484 atomic_notifier_call_chain(&ab
->phy
.notifier
,
485 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
487 if (ab
->mode
== USB_IDLE
) {
489 ab8500_usb_host_phy_en(ab
);
490 atomic_notifier_call_chain(&ab
->phy
.notifier
,
491 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
493 ab
->phy
.otg
->default_a
= true;
494 if (event
!= UX500_MUSB_RIDA
)
495 event
= UX500_MUSB_ID
;
497 atomic_notifier_call_chain(&ab
->phy
.notifier
,
498 event
, &ab
->vbus_draw
);
501 case USB_LINK_DEDICATED_CHG_9540
:
502 ab
->mode
= USB_DEDICATED_CHG
;
503 event
= UX500_MUSB_CHARGER
;
504 atomic_notifier_call_chain(&ab
->phy
.notifier
,
505 event
, &ab
->vbus_draw
);
506 usb_phy_set_event(&ab
->phy
, USB_EVENT_CHARGER
);
509 case USB_LINK_PHYEN_NO_VBUS_NO_IDGND_9540
:
510 case USB_LINK_STD_UPSTREAM_NO_IDGNG_VBUS_9540
:
511 if (!(is_ab9540_2p0_or_earlier(ab
->ab8500
))) {
512 event
= UX500_MUSB_NONE
;
513 if (ab
->mode
== USB_HOST
) {
514 ab
->phy
.otg
->default_a
= false;
516 atomic_notifier_call_chain(&ab
->phy
.notifier
,
517 event
, &ab
->vbus_draw
);
518 ab8500_usb_host_phy_dis(ab
);
521 if (ab
->mode
== USB_PERIPHERAL
) {
522 atomic_notifier_call_chain(&ab
->phy
.notifier
,
523 event
, &ab
->vbus_draw
);
524 ab8500_usb_peri_phy_dis(ab
);
525 atomic_notifier_call_chain(&ab
->phy
.notifier
,
529 ab
->phy
.otg
->default_a
= false;
531 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
543 static int ab8540_usb_link_status_update(struct ab8500_usb
*ab
,
544 enum ab8540_usb_link_status lsts
)
546 enum ux500_musb_vbus_id_status event
= 0;
548 dev_dbg(ab
->dev
, "ab8540_usb_link_status_update %d\n", lsts
);
550 if (ab
->enabled_charging_detection
) {
551 /* Disable USB Charger detection */
552 abx500_mask_and_set_register_interruptible(ab
->dev
,
553 AB8500_USB
, AB8540_VBUS_CTRL_REG
,
554 AB8540_BIT_VBUS_CTRL_CHARG_DET_ENA
, 0x00);
555 ab
->enabled_charging_detection
= false;
559 * Spurious link_status interrupts are seen in case of a
560 * disconnection of a device in IDGND and RIDA stage
562 if (ab
->previous_link_status_state
== USB_LINK_HM_IDGND_8540
&&
563 (lsts
== USB_LINK_STD_HOST_C_NS_8540
||
564 lsts
== USB_LINK_STD_HOST_NC_8540
))
567 if (ab
->previous_link_status_state
== USB_LINK_ACA_RID_A_8540
&&
568 (lsts
== USB_LINK_STD_HOST_NC_8540
))
571 ab
->previous_link_status_state
= lsts
;
574 case USB_LINK_ACA_RID_B_8540
:
575 event
= UX500_MUSB_RIDB
;
576 case USB_LINK_NOT_CONFIGURED_8540
:
577 case USB_LINK_RESERVED0_8540
:
578 case USB_LINK_RESERVED1_8540
:
579 case USB_LINK_RESERVED2_8540
:
580 case USB_LINK_RESERVED3_8540
:
582 ab
->phy
.otg
->default_a
= false;
584 if (event
!= UX500_MUSB_RIDB
)
585 event
= UX500_MUSB_NONE
;
587 * Fallback to default B_IDLE as nothing
590 ab
->phy
.otg
->state
= OTG_STATE_B_IDLE
;
591 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
594 case USB_LINK_ACA_RID_C_NM_8540
:
595 event
= UX500_MUSB_RIDC
;
596 case USB_LINK_STD_HOST_NC_8540
:
597 case USB_LINK_STD_HOST_C_NS_8540
:
598 case USB_LINK_STD_HOST_C_S_8540
:
599 case USB_LINK_CDP_8540
:
600 if (ab
->mode
== USB_IDLE
) {
601 ab
->mode
= USB_PERIPHERAL
;
602 ab8500_usb_peri_phy_en(ab
);
603 atomic_notifier_call_chain(&ab
->phy
.notifier
,
604 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
605 usb_phy_set_event(&ab
->phy
, USB_EVENT_ENUMERATED
);
607 if (event
!= UX500_MUSB_RIDC
)
608 event
= UX500_MUSB_VBUS
;
611 case USB_LINK_ACA_RID_A_8540
:
612 case USB_LINK_ACA_DOCK_CHGR_8540
:
613 event
= UX500_MUSB_RIDA
;
614 case USB_LINK_HM_IDGND_8540
:
615 case USB_LINK_STD_UPSTREAM_8540
:
616 if (ab
->mode
== USB_IDLE
) {
618 ab8500_usb_host_phy_en(ab
);
619 atomic_notifier_call_chain(&ab
->phy
.notifier
,
620 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
622 ab
->phy
.otg
->default_a
= true;
623 if (event
!= UX500_MUSB_RIDA
)
624 event
= UX500_MUSB_ID
;
625 atomic_notifier_call_chain(&ab
->phy
.notifier
,
626 event
, &ab
->vbus_draw
);
629 case USB_LINK_DEDICATED_CHG_8540
:
630 ab
->mode
= USB_DEDICATED_CHG
;
631 event
= UX500_MUSB_CHARGER
;
632 atomic_notifier_call_chain(&ab
->phy
.notifier
,
633 event
, &ab
->vbus_draw
);
634 usb_phy_set_event(&ab
->phy
, USB_EVENT_CHARGER
);
637 case USB_LINK_PHYEN_NO_VBUS_NO_IDGND_8540
:
638 case USB_LINK_STD_UPSTREAM_NO_IDGNG_VBUS_8540
:
639 event
= UX500_MUSB_NONE
;
640 if (ab
->mode
== USB_HOST
) {
641 ab
->phy
.otg
->default_a
= false;
643 atomic_notifier_call_chain(&ab
->phy
.notifier
,
644 event
, &ab
->vbus_draw
);
645 ab8500_usb_host_phy_dis(ab
);
648 if (ab
->mode
== USB_PERIPHERAL
) {
649 atomic_notifier_call_chain(&ab
->phy
.notifier
,
650 event
, &ab
->vbus_draw
);
651 ab8500_usb_peri_phy_dis(ab
);
652 atomic_notifier_call_chain(&ab
->phy
.notifier
,
653 UX500_MUSB_CLEAN
, &ab
->vbus_draw
);
655 ab
->phy
.otg
->default_a
= false;
657 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
662 event
= UX500_MUSB_NONE
;
669 static int ab8505_usb_link_status_update(struct ab8500_usb
*ab
,
670 enum ab8505_usb_link_status lsts
)
672 enum ux500_musb_vbus_id_status event
= 0;
674 dev_dbg(ab
->dev
, "ab8505_usb_link_status_update %d\n", lsts
);
677 * Spurious link_status interrupts are seen at the time of
678 * disconnection of a device in RIDA state
680 if (ab
->previous_link_status_state
== USB_LINK_ACA_RID_A_8505
&&
681 (lsts
== USB_LINK_STD_HOST_NC_8505
))
684 ab
->previous_link_status_state
= lsts
;
687 case USB_LINK_ACA_RID_B_8505
:
688 event
= UX500_MUSB_RIDB
;
689 case USB_LINK_NOT_CONFIGURED_8505
:
690 case USB_LINK_RESERVED0_8505
:
691 case USB_LINK_RESERVED1_8505
:
692 case USB_LINK_RESERVED2_8505
:
693 case USB_LINK_RESERVED3_8505
:
695 ab
->phy
.otg
->default_a
= false;
697 if (event
!= UX500_MUSB_RIDB
)
698 event
= UX500_MUSB_NONE
;
700 * Fallback to default B_IDLE as nothing
703 ab
->phy
.otg
->state
= OTG_STATE_B_IDLE
;
704 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
707 case USB_LINK_ACA_RID_C_NM_8505
:
708 event
= UX500_MUSB_RIDC
;
709 case USB_LINK_STD_HOST_NC_8505
:
710 case USB_LINK_STD_HOST_C_NS_8505
:
711 case USB_LINK_STD_HOST_C_S_8505
:
712 case USB_LINK_CDP_8505
:
713 if (ab
->mode
== USB_IDLE
) {
714 ab
->mode
= USB_PERIPHERAL
;
715 ab8500_usb_peri_phy_en(ab
);
716 atomic_notifier_call_chain(&ab
->phy
.notifier
,
717 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
718 usb_phy_set_event(&ab
->phy
, USB_EVENT_ENUMERATED
);
720 if (event
!= UX500_MUSB_RIDC
)
721 event
= UX500_MUSB_VBUS
;
724 case USB_LINK_ACA_RID_A_8505
:
725 case USB_LINK_ACA_DOCK_CHGR_8505
:
726 event
= UX500_MUSB_RIDA
;
727 case USB_LINK_HM_IDGND_8505
:
728 if (ab
->mode
== USB_IDLE
) {
730 ab8500_usb_host_phy_en(ab
);
731 atomic_notifier_call_chain(&ab
->phy
.notifier
,
732 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
734 ab
->phy
.otg
->default_a
= true;
735 if (event
!= UX500_MUSB_RIDA
)
736 event
= UX500_MUSB_ID
;
737 atomic_notifier_call_chain(&ab
->phy
.notifier
,
738 event
, &ab
->vbus_draw
);
741 case USB_LINK_DEDICATED_CHG_8505
:
742 ab
->mode
= USB_DEDICATED_CHG
;
743 event
= UX500_MUSB_CHARGER
;
744 atomic_notifier_call_chain(&ab
->phy
.notifier
,
745 event
, &ab
->vbus_draw
);
746 usb_phy_set_event(&ab
->phy
, USB_EVENT_CHARGER
);
756 static int ab8500_usb_link_status_update(struct ab8500_usb
*ab
,
757 enum ab8500_usb_link_status lsts
)
759 enum ux500_musb_vbus_id_status event
= 0;
761 dev_dbg(ab
->dev
, "ab8500_usb_link_status_update %d\n", lsts
);
764 * Spurious link_status interrupts are seen in case of a
765 * disconnection of a device in IDGND and RIDA stage
767 if (ab
->previous_link_status_state
== USB_LINK_HM_IDGND_8500
&&
768 (lsts
== USB_LINK_STD_HOST_C_NS_8500
||
769 lsts
== USB_LINK_STD_HOST_NC_8500
))
772 if (ab
->previous_link_status_state
== USB_LINK_ACA_RID_A_8500
&&
773 lsts
== USB_LINK_STD_HOST_NC_8500
)
776 ab
->previous_link_status_state
= lsts
;
779 case USB_LINK_ACA_RID_B_8500
:
780 event
= UX500_MUSB_RIDB
;
781 case USB_LINK_NOT_CONFIGURED_8500
:
782 case USB_LINK_NOT_VALID_LINK_8500
:
784 ab
->phy
.otg
->default_a
= false;
786 if (event
!= UX500_MUSB_RIDB
)
787 event
= UX500_MUSB_NONE
;
788 /* Fallback to default B_IDLE as nothing is connected */
789 ab
->phy
.otg
->state
= OTG_STATE_B_IDLE
;
790 usb_phy_set_event(&ab
->phy
, USB_EVENT_NONE
);
793 case USB_LINK_ACA_RID_C_NM_8500
:
794 case USB_LINK_ACA_RID_C_HS_8500
:
795 case USB_LINK_ACA_RID_C_HS_CHIRP_8500
:
796 event
= UX500_MUSB_RIDC
;
797 case USB_LINK_STD_HOST_NC_8500
:
798 case USB_LINK_STD_HOST_C_NS_8500
:
799 case USB_LINK_STD_HOST_C_S_8500
:
800 case USB_LINK_HOST_CHG_NM_8500
:
801 case USB_LINK_HOST_CHG_HS_8500
:
802 case USB_LINK_HOST_CHG_HS_CHIRP_8500
:
803 if (ab
->mode
== USB_IDLE
) {
804 ab
->mode
= USB_PERIPHERAL
;
805 ab8500_usb_peri_phy_en(ab
);
806 atomic_notifier_call_chain(&ab
->phy
.notifier
,
807 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
808 usb_phy_set_event(&ab
->phy
, USB_EVENT_ENUMERATED
);
810 if (event
!= UX500_MUSB_RIDC
)
811 event
= UX500_MUSB_VBUS
;
814 case USB_LINK_ACA_RID_A_8500
:
815 event
= UX500_MUSB_RIDA
;
816 case USB_LINK_HM_IDGND_8500
:
817 if (ab
->mode
== USB_IDLE
) {
819 ab8500_usb_host_phy_en(ab
);
820 atomic_notifier_call_chain(&ab
->phy
.notifier
,
821 UX500_MUSB_PREPARE
, &ab
->vbus_draw
);
823 ab
->phy
.otg
->default_a
= true;
824 if (event
!= UX500_MUSB_RIDA
)
825 event
= UX500_MUSB_ID
;
826 atomic_notifier_call_chain(&ab
->phy
.notifier
,
827 event
, &ab
->vbus_draw
);
830 case USB_LINK_DEDICATED_CHG_8500
:
831 ab
->mode
= USB_DEDICATED_CHG
;
832 event
= UX500_MUSB_CHARGER
;
833 atomic_notifier_call_chain(&ab
->phy
.notifier
,
834 event
, &ab
->vbus_draw
);
835 usb_phy_set_event(&ab
->phy
, USB_EVENT_CHARGER
);
838 case USB_LINK_RESERVED_8500
:
846 * Connection Sequence:
847 * 1. Link Status Interrupt
849 * 3. Enable AB regulators
851 * 5. Reset the musb controller
852 * 6. Switch the ULPI GPIO pins to fucntion mode
853 * 7. Enable the musb Peripheral5 clock
854 * 8. Restore MUSB context
856 static int abx500_usb_link_status_update(struct ab8500_usb
*ab
)
861 if (is_ab8500(ab
->ab8500
)) {
862 enum ab8500_usb_link_status lsts
;
864 abx500_get_register_interruptible(ab
->dev
,
865 AB8500_USB
, AB8500_USB_LINE_STAT_REG
, ®
);
866 lsts
= (reg
>> 3) & 0x0F;
867 ret
= ab8500_usb_link_status_update(ab
, lsts
);
868 } else if (is_ab8505(ab
->ab8500
)) {
869 enum ab8505_usb_link_status lsts
;
871 abx500_get_register_interruptible(ab
->dev
,
872 AB8500_USB
, AB8505_USB_LINE_STAT_REG
, ®
);
873 lsts
= (reg
>> 3) & 0x1F;
874 ret
= ab8505_usb_link_status_update(ab
, lsts
);
875 } else if (is_ab8540(ab
->ab8500
)) {
876 enum ab8540_usb_link_status lsts
;
878 abx500_get_register_interruptible(ab
->dev
,
879 AB8500_USB
, AB8540_USB_LINK_STAT_REG
, ®
);
880 lsts
= (reg
>> 3) & 0xFF;
881 ret
= ab8540_usb_link_status_update(ab
, lsts
);
882 } else if (is_ab9540(ab
->ab8500
)) {
883 enum ab9540_usb_link_status lsts
;
885 abx500_get_register_interruptible(ab
->dev
,
886 AB8500_USB
, AB9540_USB_LINK_STAT_REG
, ®
);
887 lsts
= (reg
>> 3) & 0xFF;
888 ret
= ab9540_usb_link_status_update(ab
, lsts
);
895 * Disconnection Sequence:
896 * 1. Disconnect Interrupt
897 * 2. Disable regulators
898 * 3. Disable AB clock
900 * 5. Link Status Interrupt
901 * 6. Disable Musb Clock
903 static irqreturn_t
ab8500_usb_disconnect_irq(int irq
, void *data
)
905 struct ab8500_usb
*ab
= (struct ab8500_usb
*) data
;
906 enum usb_phy_events event
= UX500_MUSB_NONE
;
908 /* Link status will not be updated till phy is disabled. */
909 if (ab
->mode
== USB_HOST
) {
910 ab
->phy
.otg
->default_a
= false;
912 atomic_notifier_call_chain(&ab
->phy
.notifier
,
913 event
, &ab
->vbus_draw
);
914 ab8500_usb_host_phy_dis(ab
);
918 if (ab
->mode
== USB_PERIPHERAL
) {
919 atomic_notifier_call_chain(&ab
->phy
.notifier
,
920 event
, &ab
->vbus_draw
);
921 ab8500_usb_peri_phy_dis(ab
);
922 atomic_notifier_call_chain(&ab
->phy
.notifier
,
923 UX500_MUSB_CLEAN
, &ab
->vbus_draw
);
925 ab
->phy
.otg
->default_a
= false;
929 if (is_ab8500_2p0(ab
->ab8500
)) {
930 if (ab
->mode
== USB_DEDICATED_CHG
) {
931 ab8500_usb_wd_linkstatus(ab
,
932 AB8500_BIT_PHY_CTRL_DEVICE_EN
);
933 abx500_mask_and_set_register_interruptible(ab
->dev
,
934 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
935 AB8500_BIT_PHY_CTRL_DEVICE_EN
, 0);
942 static irqreturn_t
ab8500_usb_link_status_irq(int irq
, void *data
)
944 struct ab8500_usb
*ab
= (struct ab8500_usb
*)data
;
946 abx500_usb_link_status_update(ab
);
951 static void ab8500_usb_phy_disable_work(struct work_struct
*work
)
953 struct ab8500_usb
*ab
= container_of(work
, struct ab8500_usb
,
956 if (!ab
->phy
.otg
->host
)
957 ab8500_usb_host_phy_dis(ab
);
959 if (!ab
->phy
.otg
->gadget
)
960 ab8500_usb_peri_phy_dis(ab
);
963 /* Check if VBUS is set and linkstatus has not detected a cable. */
964 static bool ab8500_usb_check_vbus_status(struct ab8500_usb
*ab
)
968 enum ab8540_usb_link_status lsts
;
970 abx500_get_register_interruptible(ab
->dev
,
971 AB8500_INTERRUPT
, AB8500_IT_SOURCE2_REG
,
974 /* If Vbus is below 3.6V abort */
975 if (!(isource2
& AB8500_BIT_SOURCE2_VBUSDET
))
978 abx500_get_register_interruptible(ab
->dev
,
979 AB8500_USB
, AB8540_USB_LINK_STAT_REG
,
982 lsts
= (reg
>> 3) & 0xFF;
984 /* Check if linkstatus has detected a cable */
991 /* re-trigger charger detection again with watchdog re-kick. */
992 static void ab8500_usb_vbus_turn_on_event_work(struct work_struct
*work
)
994 struct ab8500_usb
*ab
= container_of(work
, struct ab8500_usb
,
997 if (ab
->mode
!= USB_IDLE
)
1000 abx500_set_register_interruptible(ab
->dev
,
1001 AB8500_SYS_CTRL2_BLOCK
, AB8500_MAIN_WD_CTRL_REG
,
1002 AB8500_BIT_WD_CTRL_ENABLE
);
1006 abx500_set_register_interruptible(ab
->dev
,
1007 AB8500_SYS_CTRL2_BLOCK
, AB8500_MAIN_WD_CTRL_REG
,
1008 AB8500_BIT_WD_CTRL_ENABLE
| AB8500_BIT_WD_CTRL_KICK
);
1012 /* Disable Main watchdog */
1013 abx500_set_register_interruptible(ab
->dev
,
1014 AB8500_SYS_CTRL2_BLOCK
, AB8500_MAIN_WD_CTRL_REG
,
1017 /* Enable USB Charger detection */
1018 abx500_mask_and_set_register_interruptible(ab
->dev
,
1019 AB8500_USB
, AB8540_VBUS_CTRL_REG
,
1020 AB8540_BIT_VBUS_CTRL_CHARG_DET_ENA
,
1021 AB8540_BIT_VBUS_CTRL_CHARG_DET_ENA
);
1023 ab
->enabled_charging_detection
= true;
1026 static unsigned ab8500_eyediagram_workaroud(struct ab8500_usb
*ab
, unsigned mA
)
1029 * AB8500 V2 has eye diagram issues when drawing more than 100mA from
1030 * VBUS. Set charging current to 100mA in case of standard host
1032 if (is_ab8500_2p0_or_earlier(ab
->ab8500
))
1039 static int ab8500_usb_set_power(struct usb_phy
*phy
, unsigned mA
)
1041 struct ab8500_usb
*ab
;
1046 ab
= phy_to_ab(phy
);
1048 mA
= ab8500_eyediagram_workaroud(ab
, mA
);
1052 atomic_notifier_call_chain(&ab
->phy
.notifier
,
1053 UX500_MUSB_VBUS
, &ab
->vbus_draw
);
1058 static int ab8500_usb_set_suspend(struct usb_phy
*x
, int suspend
)
1064 static int ab8500_usb_set_peripheral(struct usb_otg
*otg
,
1065 struct usb_gadget
*gadget
)
1067 struct ab8500_usb
*ab
;
1072 ab
= phy_to_ab(otg
->usb_phy
);
1074 ab
->phy
.otg
->gadget
= gadget
;
1076 /* Some drivers call this function in atomic context.
1077 * Do not update ab8500 registers directly till this
1081 if ((ab
->mode
!= USB_IDLE
) && !gadget
) {
1082 ab
->mode
= USB_IDLE
;
1083 schedule_work(&ab
->phy_dis_work
);
1089 static int ab8500_usb_set_host(struct usb_otg
*otg
, struct usb_bus
*host
)
1091 struct ab8500_usb
*ab
;
1096 ab
= phy_to_ab(otg
->usb_phy
);
1098 ab
->phy
.otg
->host
= host
;
1100 /* Some drivers call this function in atomic context.
1101 * Do not update ab8500 registers directly till this
1105 if ((ab
->mode
!= USB_IDLE
) && !host
) {
1106 ab
->mode
= USB_IDLE
;
1107 schedule_work(&ab
->phy_dis_work
);
1113 static void ab8500_usb_restart_phy(struct ab8500_usb
*ab
)
1115 abx500_mask_and_set_register_interruptible(ab
->dev
,
1116 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
1117 AB8500_BIT_PHY_CTRL_DEVICE_EN
,
1118 AB8500_BIT_PHY_CTRL_DEVICE_EN
);
1122 abx500_mask_and_set_register_interruptible(ab
->dev
,
1123 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
1124 AB8500_BIT_PHY_CTRL_DEVICE_EN
,
1127 abx500_mask_and_set_register_interruptible(ab
->dev
,
1128 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
1129 AB8500_BIT_PHY_CTRL_HOST_EN
,
1130 AB8500_BIT_PHY_CTRL_HOST_EN
);
1134 abx500_mask_and_set_register_interruptible(ab
->dev
,
1135 AB8500_USB
, AB8500_USB_PHY_CTRL_REG
,
1136 AB8500_BIT_PHY_CTRL_HOST_EN
,
1140 static int ab8500_usb_regulator_get(struct ab8500_usb
*ab
)
1144 ab
->v_ape
= devm_regulator_get(ab
->dev
, "v-ape");
1145 if (IS_ERR(ab
->v_ape
)) {
1146 dev_err(ab
->dev
, "Could not get v-ape supply\n");
1147 err
= PTR_ERR(ab
->v_ape
);
1151 ab
->v_ulpi
= devm_regulator_get(ab
->dev
, "vddulpivio18");
1152 if (IS_ERR(ab
->v_ulpi
)) {
1153 dev_err(ab
->dev
, "Could not get vddulpivio18 supply\n");
1154 err
= PTR_ERR(ab
->v_ulpi
);
1158 ab
->v_musb
= devm_regulator_get(ab
->dev
, "musb_1v8");
1159 if (IS_ERR(ab
->v_musb
)) {
1160 dev_err(ab
->dev
, "Could not get musb_1v8 supply\n");
1161 err
= PTR_ERR(ab
->v_musb
);
1168 static int ab8500_usb_irq_setup(struct platform_device
*pdev
,
1169 struct ab8500_usb
*ab
)
1174 if (ab
->flags
& AB8500_USB_FLAG_USE_LINK_STATUS_IRQ
) {
1175 irq
= platform_get_irq_byname(pdev
, "USB_LINK_STATUS");
1177 dev_err(&pdev
->dev
, "Link status irq not found\n");
1180 err
= devm_request_threaded_irq(&pdev
->dev
, irq
, NULL
,
1181 ab8500_usb_link_status_irq
,
1182 IRQF_NO_SUSPEND
| IRQF_SHARED
| IRQF_ONESHOT
,
1183 "usb-link-status", ab
);
1185 dev_err(ab
->dev
, "request_irq failed for link status irq\n");
1190 if (ab
->flags
& AB8500_USB_FLAG_USE_ID_WAKEUP_IRQ
) {
1191 irq
= platform_get_irq_byname(pdev
, "ID_WAKEUP_F");
1193 dev_err(&pdev
->dev
, "ID fall irq not found\n");
1196 err
= devm_request_threaded_irq(&pdev
->dev
, irq
, NULL
,
1197 ab8500_usb_disconnect_irq
,
1198 IRQF_NO_SUSPEND
| IRQF_SHARED
| IRQF_ONESHOT
,
1201 dev_err(ab
->dev
, "request_irq failed for ID fall irq\n");
1206 if (ab
->flags
& AB8500_USB_FLAG_USE_VBUS_DET_IRQ
) {
1207 irq
= platform_get_irq_byname(pdev
, "VBUS_DET_F");
1209 dev_err(&pdev
->dev
, "VBUS fall irq not found\n");
1212 err
= devm_request_threaded_irq(&pdev
->dev
, irq
, NULL
,
1213 ab8500_usb_disconnect_irq
,
1214 IRQF_NO_SUSPEND
| IRQF_SHARED
| IRQF_ONESHOT
,
1215 "usb-vbus-fall", ab
);
1217 dev_err(ab
->dev
, "request_irq failed for Vbus fall irq\n");
1225 static void ab8500_usb_set_ab8500_tuning_values(struct ab8500_usb
*ab
)
1229 /* Enable the PBT/Bank 0x12 access */
1230 err
= abx500_set_register_interruptible(ab
->dev
,
1231 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
, 0x01);
1233 dev_err(ab
->dev
, "Failed to enable bank12 access err=%d\n",
1236 err
= abx500_set_register_interruptible(ab
->dev
,
1237 AB8500_DEBUG
, AB8500_USB_PHY_TUNE1
, 0xC8);
1239 dev_err(ab
->dev
, "Failed to set PHY_TUNE1 register err=%d\n",
1242 err
= abx500_set_register_interruptible(ab
->dev
,
1243 AB8500_DEBUG
, AB8500_USB_PHY_TUNE2
, 0x00);
1245 dev_err(ab
->dev
, "Failed to set PHY_TUNE2 register err=%d\n",
1248 err
= abx500_set_register_interruptible(ab
->dev
,
1249 AB8500_DEBUG
, AB8500_USB_PHY_TUNE3
, 0x78);
1251 dev_err(ab
->dev
, "Failed to set PHY_TUNE3 regester err=%d\n",
1254 /* Switch to normal mode/disable Bank 0x12 access */
1255 err
= abx500_set_register_interruptible(ab
->dev
,
1256 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
, 0x00);
1258 dev_err(ab
->dev
, "Failed to switch bank12 access err=%d\n",
1262 static void ab8500_usb_set_ab8505_tuning_values(struct ab8500_usb
*ab
)
1266 /* Enable the PBT/Bank 0x12 access */
1267 err
= abx500_mask_and_set_register_interruptible(ab
->dev
,
1268 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
,
1271 dev_err(ab
->dev
, "Failed to enable bank12 access err=%d\n",
1274 err
= abx500_mask_and_set_register_interruptible(ab
->dev
,
1275 AB8500_DEBUG
, AB8500_USB_PHY_TUNE1
,
1278 dev_err(ab
->dev
, "Failed to set PHY_TUNE1 register err=%d\n",
1281 err
= abx500_mask_and_set_register_interruptible(ab
->dev
,
1282 AB8500_DEBUG
, AB8500_USB_PHY_TUNE2
,
1285 dev_err(ab
->dev
, "Failed to set PHY_TUNE2 register err=%d\n",
1288 err
= abx500_mask_and_set_register_interruptible(ab
->dev
,
1289 AB8500_DEBUG
, AB8500_USB_PHY_TUNE3
,
1293 dev_err(ab
->dev
, "Failed to set PHY_TUNE3 regester err=%d\n",
1296 /* Switch to normal mode/disable Bank 0x12 access */
1297 err
= abx500_mask_and_set_register_interruptible(ab
->dev
,
1298 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
,
1301 dev_err(ab
->dev
, "Failed to switch bank12 access err=%d\n",
1305 static void ab8500_usb_set_ab8540_tuning_values(struct ab8500_usb
*ab
)
1309 err
= abx500_set_register_interruptible(ab
->dev
,
1310 AB8540_DEBUG
, AB8500_USB_PHY_TUNE1
, 0xCC);
1312 dev_err(ab
->dev
, "Failed to set PHY_TUNE1 register ret=%d\n",
1315 err
= abx500_set_register_interruptible(ab
->dev
,
1316 AB8540_DEBUG
, AB8500_USB_PHY_TUNE2
, 0x60);
1318 dev_err(ab
->dev
, "Failed to set PHY_TUNE2 register ret=%d\n",
1321 err
= abx500_set_register_interruptible(ab
->dev
,
1322 AB8540_DEBUG
, AB8500_USB_PHY_TUNE3
, 0x90);
1324 dev_err(ab
->dev
, "Failed to set PHY_TUNE3 regester ret=%d\n",
1328 static void ab8500_usb_set_ab9540_tuning_values(struct ab8500_usb
*ab
)
1332 /* Enable the PBT/Bank 0x12 access */
1333 err
= abx500_set_register_interruptible(ab
->dev
,
1334 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
, 0x01);
1336 dev_err(ab
->dev
, "Failed to enable bank12 access err=%d\n",
1339 err
= abx500_set_register_interruptible(ab
->dev
,
1340 AB8500_DEBUG
, AB8500_USB_PHY_TUNE1
, 0xC8);
1342 dev_err(ab
->dev
, "Failed to set PHY_TUNE1 register err=%d\n",
1345 err
= abx500_set_register_interruptible(ab
->dev
,
1346 AB8500_DEBUG
, AB8500_USB_PHY_TUNE2
, 0x60);
1348 dev_err(ab
->dev
, "Failed to set PHY_TUNE2 register err=%d\n",
1351 err
= abx500_set_register_interruptible(ab
->dev
,
1352 AB8500_DEBUG
, AB8500_USB_PHY_TUNE3
, 0x80);
1354 dev_err(ab
->dev
, "Failed to set PHY_TUNE3 regester err=%d\n",
1357 /* Switch to normal mode/disable Bank 0x12 access */
1358 err
= abx500_set_register_interruptible(ab
->dev
,
1359 AB8500_DEVELOPMENT
, AB8500_BANK12_ACCESS
, 0x00);
1361 dev_err(ab
->dev
, "Failed to switch bank12 access err=%d\n",
1365 static int ab8500_usb_probe(struct platform_device
*pdev
)
1367 struct ab8500_usb
*ab
;
1368 struct ab8500
*ab8500
;
1369 struct usb_otg
*otg
;
1373 ab8500
= dev_get_drvdata(pdev
->dev
.parent
);
1374 rev
= abx500_get_chip_id(&pdev
->dev
);
1376 if (is_ab8500_1p1_or_earlier(ab8500
)) {
1377 dev_err(&pdev
->dev
, "Unsupported AB8500 chip rev=%d\n", rev
);
1381 ab
= devm_kzalloc(&pdev
->dev
, sizeof(*ab
), GFP_KERNEL
);
1385 otg
= devm_kzalloc(&pdev
->dev
, sizeof(*otg
), GFP_KERNEL
);
1389 ab
->dev
= &pdev
->dev
;
1390 ab
->ab8500
= ab8500
;
1391 ab
->phy
.dev
= ab
->dev
;
1393 ab
->phy
.label
= "ab8500";
1394 ab
->phy
.set_suspend
= ab8500_usb_set_suspend
;
1395 ab
->phy
.set_power
= ab8500_usb_set_power
;
1396 ab
->phy
.otg
->state
= OTG_STATE_UNDEFINED
;
1398 otg
->usb_phy
= &ab
->phy
;
1399 otg
->set_host
= ab8500_usb_set_host
;
1400 otg
->set_peripheral
= ab8500_usb_set_peripheral
;
1402 if (is_ab8500(ab
->ab8500
)) {
1403 ab
->flags
|= AB8500_USB_FLAG_USE_LINK_STATUS_IRQ
|
1404 AB8500_USB_FLAG_USE_ID_WAKEUP_IRQ
|
1405 AB8500_USB_FLAG_USE_VBUS_DET_IRQ
|
1406 AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
;
1407 } else if (is_ab8505(ab
->ab8500
)) {
1408 ab
->flags
|= AB8500_USB_FLAG_USE_LINK_STATUS_IRQ
|
1409 AB8500_USB_FLAG_USE_ID_WAKEUP_IRQ
|
1410 AB8500_USB_FLAG_USE_VBUS_DET_IRQ
|
1411 AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
;
1412 } else if (is_ab8540(ab
->ab8500
)) {
1413 ab
->flags
|= AB8500_USB_FLAG_USE_LINK_STATUS_IRQ
|
1414 AB8500_USB_FLAG_USE_CHECK_VBUS_STATUS
|
1415 AB8500_USB_FLAG_USE_VBUS_HOST_QUIRK
|
1416 AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
;
1417 } else if (is_ab9540(ab
->ab8500
)) {
1418 ab
->flags
|= AB8500_USB_FLAG_USE_LINK_STATUS_IRQ
|
1419 AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
;
1420 if (is_ab9540_2p0_or_earlier(ab
->ab8500
))
1421 ab
->flags
|= AB8500_USB_FLAG_USE_ID_WAKEUP_IRQ
|
1422 AB8500_USB_FLAG_USE_VBUS_DET_IRQ
;
1425 /* Disable regulator voltage setting for AB8500 <= v2.0 */
1426 if (is_ab8500_2p0_or_earlier(ab
->ab8500
))
1427 ab
->flags
&= ~AB8500_USB_FLAG_REGULATOR_SET_VOLTAGE
;
1429 platform_set_drvdata(pdev
, ab
);
1431 /* all: Disable phy when called from set_host and set_peripheral */
1432 INIT_WORK(&ab
->phy_dis_work
, ab8500_usb_phy_disable_work
);
1434 INIT_WORK(&ab
->vbus_event_work
, ab8500_usb_vbus_turn_on_event_work
);
1436 err
= ab8500_usb_regulator_get(ab
);
1440 ab
->sysclk
= devm_clk_get(ab
->dev
, "sysclk");
1441 if (IS_ERR(ab
->sysclk
)) {
1442 dev_err(ab
->dev
, "Could not get sysclk.\n");
1443 return PTR_ERR(ab
->sysclk
);
1446 err
= ab8500_usb_irq_setup(pdev
, ab
);
1450 err
= usb_add_phy(&ab
->phy
, USB_PHY_TYPE_USB2
);
1452 dev_err(&pdev
->dev
, "Can't register transceiver\n");
1456 if (is_ab8500(ab
->ab8500
) && !is_ab8500_2p0_or_earlier(ab
->ab8500
))
1457 /* Phy tuning values for AB8500 > v2.0 */
1458 ab8500_usb_set_ab8500_tuning_values(ab
);
1459 else if (is_ab8505(ab
->ab8500
))
1460 /* Phy tuning values for AB8505 */
1461 ab8500_usb_set_ab8505_tuning_values(ab
);
1462 else if (is_ab8540(ab
->ab8500
))
1463 /* Phy tuning values for AB8540 */
1464 ab8500_usb_set_ab8540_tuning_values(ab
);
1465 else if (is_ab9540(ab
->ab8500
))
1466 /* Phy tuning values for AB9540 */
1467 ab8500_usb_set_ab9540_tuning_values(ab
);
1469 /* Needed to enable ID detection. */
1470 ab8500_usb_wd_workaround(ab
);
1473 * This is required for usb-link-status to work properly when a
1474 * cable is connected at boot time.
1476 ab8500_usb_restart_phy(ab
);
1478 if (ab
->flags
& AB8500_USB_FLAG_USE_CHECK_VBUS_STATUS
) {
1479 if (ab8500_usb_check_vbus_status(ab
))
1480 schedule_work(&ab
->vbus_event_work
);
1483 abx500_usb_link_status_update(ab
);
1485 dev_info(&pdev
->dev
, "revision 0x%2x driver initialized\n", rev
);
1490 static int ab8500_usb_remove(struct platform_device
*pdev
)
1492 struct ab8500_usb
*ab
= platform_get_drvdata(pdev
);
1494 cancel_work_sync(&ab
->phy_dis_work
);
1495 cancel_work_sync(&ab
->vbus_event_work
);
1497 usb_remove_phy(&ab
->phy
);
1499 if (ab
->mode
== USB_HOST
)
1500 ab8500_usb_host_phy_dis(ab
);
1501 else if (ab
->mode
== USB_PERIPHERAL
)
1502 ab8500_usb_peri_phy_dis(ab
);
1507 static struct platform_device_id ab8500_usb_devtype
[] = {
1508 { .name
= "ab8500-usb", },
1509 { .name
= "ab8540-usb", },
1510 { .name
= "ab9540-usb", },
1513 MODULE_DEVICE_TABLE(platform
, ab8500_usb_devtype
);
1515 static struct platform_driver ab8500_usb_driver
= {
1516 .probe
= ab8500_usb_probe
,
1517 .remove
= ab8500_usb_remove
,
1518 .id_table
= ab8500_usb_devtype
,
1520 .name
= "abx5x0-usb",
1524 static int __init
ab8500_usb_init(void)
1526 return platform_driver_register(&ab8500_usb_driver
);
1528 subsys_initcall(ab8500_usb_init
);
1530 static void __exit
ab8500_usb_exit(void)
1532 platform_driver_unregister(&ab8500_usb_driver
);
1534 module_exit(ab8500_usb_exit
);
1536 MODULE_AUTHOR("ST-Ericsson AB");
1537 MODULE_DESCRIPTION("AB8500 family usb transceiver driver");
1538 MODULE_LICENSE("GPL");