aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHuang Rui <ray.huang@amd.com>2014-10-28 07:54:28 -0400
committerFelipe Balbi <balbi@ti.com>2014-11-03 11:03:36 -0500
commitb5a65c406367e3e79ece6f687c83d4ffce4c174c (patch)
treef8e0b8062965db9a6d1d5761ae9890c68c307e35
parent9a5b2f3167c1f98b879d6a800ab138f04e34f9d5 (diff)
usb: dwc3: add P3 in U2 SS inactive quirk
This patch adds P3 in U2 SS inactive quirk, and some special platforms can configure that if it is needed. [ balbi@ti.com : added DeviceTree binding documentation ] Signed-off-by: Huang Rui <ray.huang@amd.com> Signed-off-by: Felipe Balbi <balbi@ti.com>
-rw-r--r--Documentation/devicetree/bindings/usb/dwc3.txt1
-rw-r--r--drivers/usb/dwc3/core.c23
-rw-r--r--drivers/usb/dwc3/core.h3
-rw-r--r--drivers/usb/dwc3/platform_data.h1
4 files changed, 28 insertions, 0 deletions
diff --git a/Documentation/devicetree/bindings/usb/dwc3.txt b/Documentation/devicetree/bindings/usb/dwc3.txt
index 5fcd68008945..36e4287c40f5 100644
--- a/Documentation/devicetree/bindings/usb/dwc3.txt
+++ b/Documentation/devicetree/bindings/usb/dwc3.txt
@@ -19,6 +19,7 @@ Optional properties:
19 - snps,has-lpm-erratum: true when DWC3 was configured with LPM Erratum enabled 19 - snps,has-lpm-erratum: true when DWC3 was configured with LPM Erratum enabled
20 - snps,lpm-nyet-threshold: LPM NYET threshold 20 - snps,lpm-nyet-threshold: LPM NYET threshold
21 - snps,u2exit_lfps_quirk: set if we want to enable u2exit lfps quirk 21 - snps,u2exit_lfps_quirk: set if we want to enable u2exit lfps quirk
22 - snps,u2ss_inp3_quirk: set if we enable P3 OK for U2/SS Inactive quirk
22 23
23This is usually a subnode to DWC3 glue to which it is connected. 24This is usually a subnode to DWC3 glue to which it is connected.
24 25
diff --git a/drivers/usb/dwc3/core.c b/drivers/usb/dwc3/core.c
index 33cbea5c6dda..7c54da187062 100644
--- a/drivers/usb/dwc3/core.c
+++ b/drivers/usb/dwc3/core.c
@@ -365,6 +365,24 @@ static void dwc3_cache_hwparams(struct dwc3 *dwc)
365} 365}
366 366
367/** 367/**
368 * dwc3_phy_setup - Configure USB PHY Interface of DWC3 Core
369 * @dwc: Pointer to our controller context structure
370 */
371static void dwc3_phy_setup(struct dwc3 *dwc)
372{
373 u32 reg;
374
375 reg = dwc3_readl(dwc->regs, DWC3_GUSB3PIPECTL(0));
376
377 if (dwc->u2ss_inp3_quirk)
378 reg |= DWC3_GUSB3PIPECTL_U2SSINP3OK;
379
380 dwc3_writel(dwc->regs, DWC3_GUSB3PIPECTL(0), reg);
381
382 mdelay(100);
383}
384
385/**
368 * dwc3_core_init - Low-level initialization of DWC3 Core 386 * dwc3_core_init - Low-level initialization of DWC3 Core
369 * @dwc: Pointer to our controller context structure 387 * @dwc: Pointer to our controller context structure
370 * 388 *
@@ -489,6 +507,8 @@ static int dwc3_core_init(struct dwc3 *dwc)
489 507
490 dwc3_writel(dwc->regs, DWC3_GCTL, reg); 508 dwc3_writel(dwc->regs, DWC3_GCTL, reg);
491 509
510 dwc3_phy_setup(dwc);
511
492 ret = dwc3_alloc_scratch_buffers(dwc); 512 ret = dwc3_alloc_scratch_buffers(dwc);
493 if (ret) 513 if (ret)
494 goto err1; 514 goto err1;
@@ -734,6 +754,8 @@ static int dwc3_probe(struct platform_device *pdev)
734 "snps,disable_scramble_quirk"); 754 "snps,disable_scramble_quirk");
735 dwc->u2exit_lfps_quirk = of_property_read_bool(node, 755 dwc->u2exit_lfps_quirk = of_property_read_bool(node,
736 "snps,u2exit_lfps_quirk"); 756 "snps,u2exit_lfps_quirk");
757 dwc->u2ss_inp3_quirk = of_property_read_bool(node,
758 "snps,u2ss_inp3_quirk");
737 } else if (pdata) { 759 } else if (pdata) {
738 dwc->maximum_speed = pdata->maximum_speed; 760 dwc->maximum_speed = pdata->maximum_speed;
739 dwc->has_lpm_erratum = pdata->has_lpm_erratum; 761 dwc->has_lpm_erratum = pdata->has_lpm_erratum;
@@ -745,6 +767,7 @@ static int dwc3_probe(struct platform_device *pdev)
745 767
746 dwc->disable_scramble_quirk = pdata->disable_scramble_quirk; 768 dwc->disable_scramble_quirk = pdata->disable_scramble_quirk;
747 dwc->u2exit_lfps_quirk = pdata->u2exit_lfps_quirk; 769 dwc->u2exit_lfps_quirk = pdata->u2exit_lfps_quirk;
770 dwc->u2ss_inp3_quirk = pdata->u2ss_inp3_quirk;
748 } 771 }
749 772
750 /* default to superspeed if no maximum_speed passed */ 773 /* default to superspeed if no maximum_speed passed */
diff --git a/drivers/usb/dwc3/core.h b/drivers/usb/dwc3/core.h
index f93145cb52f5..66fd26bfdbfa 100644
--- a/drivers/usb/dwc3/core.h
+++ b/drivers/usb/dwc3/core.h
@@ -176,6 +176,7 @@
176 176
177/* Global USB3 PIPE Control Register */ 177/* Global USB3 PIPE Control Register */
178#define DWC3_GUSB3PIPECTL_PHYSOFTRST (1 << 31) 178#define DWC3_GUSB3PIPECTL_PHYSOFTRST (1 << 31)
179#define DWC3_GUSB3PIPECTL_U2SSINP3OK (1 << 29)
179#define DWC3_GUSB3PIPECTL_SUSPHY (1 << 17) 180#define DWC3_GUSB3PIPECTL_SUSPHY (1 << 17)
180 181
181/* Global TX Fifo Size Register */ 182/* Global TX Fifo Size Register */
@@ -681,6 +682,7 @@ struct dwc3_scratchpad_array {
681 * @three_stage_setup: set if we perform a three phase setup 682 * @three_stage_setup: set if we perform a three phase setup
682 * @disable_scramble_quirk: set if we enable the disable scramble quirk 683 * @disable_scramble_quirk: set if we enable the disable scramble quirk
683 * @u2exit_lfps_quirk: set if we enable u2exit lfps quirk 684 * @u2exit_lfps_quirk: set if we enable u2exit lfps quirk
685 * @u2ss_inp3_quirk: set if we enable P3 OK for U2/SS Inactive quirk
684 */ 686 */
685struct dwc3 { 687struct dwc3 {
686 struct usb_ctrlrequest *ctrl_req; 688 struct usb_ctrlrequest *ctrl_req;
@@ -790,6 +792,7 @@ struct dwc3 {
790 792
791 unsigned disable_scramble_quirk:1; 793 unsigned disable_scramble_quirk:1;
792 unsigned u2exit_lfps_quirk:1; 794 unsigned u2exit_lfps_quirk:1;
795 unsigned u2ss_inp3_quirk:1;
793}; 796};
794 797
795/* -------------------------------------------------------------------------- */ 798/* -------------------------------------------------------------------------- */
diff --git a/drivers/usb/dwc3/platform_data.h b/drivers/usb/dwc3/platform_data.h
index 3f2159108f7d..cf92c81e2e22 100644
--- a/drivers/usb/dwc3/platform_data.h
+++ b/drivers/usb/dwc3/platform_data.h
@@ -30,4 +30,5 @@ struct dwc3_platform_data {
30 unsigned disable_scramble_quirk:1; 30 unsigned disable_scramble_quirk:1;
31 unsigned has_lpm_erratum:1; 31 unsigned has_lpm_erratum:1;
32 unsigned u2exit_lfps_quirk:1; 32 unsigned u2exit_lfps_quirk:1;
33 unsigned u2ss_inp3_quirk:1;
33}; 34};