diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2016-09-29 11:40:30 +0200 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2016-09-29 14:00:33 +0200 |
commit | 081554dca90cdc59d6ca64f83125e741078ea0d9 (patch) | |
tree | 6fb98a17ebce86a84c8b54a5baf8c409ee6f2c81 | |
parent | 850557842f01ecb47b00ecb43b3bc3c8f1bb826f (diff) | |
download | barebox-081554dca90cdc59d6ca64f83125e741078ea0d9.tar.gz barebox-081554dca90cdc59d6ca64f83125e741078ea0d9.tar.xz |
phy: Introduce to_usbphy conversion function
The generic phy support layer has the necessary list handling
and phy retrieval functions, so we should reuse them for usb
phys. This adds a phy_to_usbphy() conversion function which
drivers can implement which attach to the generic phy layer
and are really usb phys.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
-rw-r--r-- | drivers/phy/phy-core.c | 12 | ||||
-rw-r--r-- | include/linux/phy/phy.h | 8 |
2 files changed, 20 insertions, 0 deletions
diff --git a/drivers/phy/phy-core.c b/drivers/phy/phy-core.c index 7c1f3d440b..1b6a9f7b1d 100644 --- a/drivers/phy/phy-core.c +++ b/drivers/phy/phy-core.c @@ -15,6 +15,7 @@ #include <common.h> #include <malloc.h> #include <linux/phy/phy.h> +#include <usb/phy.h> static LIST_HEAD(phy_provider_list); static int phy_ida; @@ -201,6 +202,17 @@ int phy_power_off(struct phy *phy) return 0; } +struct usb_phy *phy_to_usbphy(struct phy *phy) +{ + if (!phy) + return NULL; + + if (!phy->ops->to_usbphy) + return ERR_PTR(-EINVAL); + + return phy->ops->to_usbphy(phy); +} + static struct phy_provider *of_phy_provider_lookup(struct device_node *node) { struct phy_provider *phy_provider; diff --git a/include/linux/phy/phy.h b/include/linux/phy/phy.h index 0d78923358..5d96e02df4 100644 --- a/include/linux/phy/phy.h +++ b/include/linux/phy/phy.h @@ -33,6 +33,7 @@ struct phy_ops { int (*exit)(struct phy *phy); int (*power_on)(struct phy *phy); int (*power_off)(struct phy *phy); + struct usb_phy *(*to_usbphy)(struct phy *phy); }; /** @@ -150,6 +151,7 @@ struct phy_provider *__of_phy_provider_register(struct device_d *dev, struct phy * (*of_xlate)(struct device_d *dev, struct of_phandle_args *args)); void of_phy_provider_unregister(struct phy_provider *phy_provider); +struct usb_phy *phy_to_usbphy(struct phy *phy); #else static inline int phy_init(struct phy *phy) { @@ -243,6 +245,12 @@ static inline struct phy_provider *__of_phy_provider_register( static inline void of_phy_provider_unregister(struct phy_provider *phy_provider) { } + +static inline struct usb_phy *phy_to_usbphy(struct phy *phy) +{ + return NULL; +} + #endif #endif /* __DRIVERS_PHY_H */ |