forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
usb: renesas_usbhs: add R-Car Gen3 power control
Since the usb2 phy driver for gen3 (phy-rcar-gen3-usb2) cannot access LPSTS and UGCTRL2 registers in the HSUSB module, this driver have to initialize the registers. So, this patch adds such handling code into rcar3.c. Signed-off-by: Yoshihiro Shimoda <[email protected]> Signed-off-by: Felipe Balbi <[email protected]>
- Loading branch information
1 parent
7580862
commit de18757
Showing
5 changed files
with
69 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
/* | ||
* Renesas USB driver R-Car Gen. 3 initialization and power control | ||
* | ||
* Copyright (C) 2016 Renesas Electronics Corporation | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
* | ||
*/ | ||
|
||
#include <linux/io.h> | ||
#include "common.h" | ||
#include "rcar3.h" | ||
|
||
#define LPSTS 0x102 | ||
#define UGCTRL2 0x184 /* 32-bit register */ | ||
|
||
/* Low Power Status register (LPSTS) */ | ||
#define LPSTS_SUSPM 0x4000 | ||
|
||
/* USB General control register 2 (UGCTRL2), bit[31:6] should be 0 */ | ||
#define UGCTRL2_RESERVED_3 0x00000001 /* bit[3:0] should be B'0001 */ | ||
#define UGCTRL2_USB0SEL_OTG 0x00000030 | ||
|
||
void usbhs_write32(struct usbhs_priv *priv, u32 reg, u32 data) | ||
{ | ||
iowrite32(data, priv->base + reg); | ||
} | ||
|
||
static int usbhs_rcar3_power_ctrl(struct platform_device *pdev, | ||
void __iomem *base, int enable) | ||
{ | ||
struct usbhs_priv *priv = usbhs_pdev_to_priv(pdev); | ||
|
||
usbhs_write32(priv, UGCTRL2, UGCTRL2_RESERVED_3 | UGCTRL2_USB0SEL_OTG); | ||
|
||
if (enable) | ||
usbhs_bset(priv, LPSTS, LPSTS_SUSPM, LPSTS_SUSPM); | ||
else | ||
usbhs_bset(priv, LPSTS, LPSTS_SUSPM, 0); | ||
|
||
return 0; | ||
} | ||
|
||
static int usbhs_rcar3_get_id(struct platform_device *pdev) | ||
{ | ||
return USBHS_GADGET; | ||
} | ||
|
||
const struct renesas_usbhs_platform_callback usbhs_rcar3_ops = { | ||
.power_ctrl = usbhs_rcar3_power_ctrl, | ||
.get_id = usbhs_rcar3_get_id, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
#include "common.h" | ||
|
||
extern const struct renesas_usbhs_platform_callback usbhs_rcar3_ops; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters