aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHeikki Krogerus <heikki.krogerus@linux.intel.com>2015-05-13 08:26:52 -0400
committerFelipe Balbi <balbi@ti.com>2015-05-13 13:06:56 -0400
commit723487a6ff50bb88c628a859aeac3fe721f0d1fa (patch)
tree53280a33f392ad1aed2297957d6871d8d6d11c1c
parent88bc9d194ff69875a4d3c958d969ed2a053c8308 (diff)
phy: helpers for USB ULPI PHY registering
ULPI PHYs need to be bound to their controllers with a lookup. This adds helpers that the ULPI drivers can use to do both, the registration of the PHY and the lookup, at the same time. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Acked-by: David Cohen <david.a.cohen@linux.intel.com> Acked-by: Kishon Vijay Abraham I <kishon@ti.com> Signed-off-by: Felipe Balbi <balbi@ti.com>
-rw-r--r--drivers/phy/ulpi_phy.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/drivers/phy/ulpi_phy.h b/drivers/phy/ulpi_phy.h
new file mode 100644
index 000000000000..ac49fb6285ee
--- /dev/null
+++ b/drivers/phy/ulpi_phy.h
@@ -0,0 +1,31 @@
1#include <linux/phy/phy.h>
2
3/**
4 * Helper that registers PHY for a ULPI device and adds a lookup for binding it
5 * and it's controller, which is always the parent.
6 */
7static inline struct phy
8*ulpi_phy_create(struct ulpi *ulpi, struct phy_ops *ops)
9{
10 struct phy *phy;
11 int ret;
12
13 phy = phy_create(&ulpi->dev, NULL, ops);
14 if (IS_ERR(phy))
15 return phy;
16
17 ret = phy_create_lookup(phy, "usb2-phy", dev_name(ulpi->dev.parent));
18 if (ret) {
19 phy_destroy(phy);
20 return ERR_PTR(ret);
21 }
22
23 return phy;
24}
25
26/* Remove a PHY that was created with ulpi_phy_create() and it's lookup. */
27static inline void ulpi_phy_destroy(struct ulpi *ulpi, struct phy *phy)
28{
29 phy_remove_lookup(phy, "usb2-phy", dev_name(ulpi->dev.parent));
30 phy_destroy(phy);
31}