提交 2b97789f 编写于 作者: G Grygorii Strashko 提交者: Greg Kroah-Hartman

phy: core: make NULL a valid phy reference if !CONFIG_GENERIC_PHY

This fixes a regression on Keystone 2 platforms caused by patch
57303488
"usb: dwc3: adapt dwc3 core to use Generic PHY Framework" which adds
optional support of generic phy in DWC3 core.

On Keystone 2 platforms the USB is not working now because
CONFIG_GENERIC_PHY isn't set and, as result, Generic PHY APIs stubs
return -ENOSYS always. The log shows:
 dwc3 2690000.dwc3: failed to initialize core
 dwc3: probe of 2690000.dwc3 failed with error -38

Hence, fix it by making NULL a valid phy reference in Generic PHY
APIs stubs in the same way as it was done by the patch
04c2faca "drivers: phy: Make NULL
a valid phy reference".
Acked-by: NFelipe Balbi <balbi@ti.com>
Acked-by: NSantosh Shilimkar <santosh.shilimkar@ti.com>
Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: NKishon Vijay Abraham I <kishon@ti.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 743bb387
...@@ -174,21 +174,29 @@ void devm_of_phy_provider_unregister(struct device *dev, ...@@ -174,21 +174,29 @@ void devm_of_phy_provider_unregister(struct device *dev,
#else #else
static inline int phy_pm_runtime_get(struct phy *phy) static inline int phy_pm_runtime_get(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_pm_runtime_get_sync(struct phy *phy) static inline int phy_pm_runtime_get_sync(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_pm_runtime_put(struct phy *phy) static inline int phy_pm_runtime_put(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_pm_runtime_put_sync(struct phy *phy) static inline int phy_pm_runtime_put_sync(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
...@@ -204,21 +212,29 @@ static inline void phy_pm_runtime_forbid(struct phy *phy) ...@@ -204,21 +212,29 @@ static inline void phy_pm_runtime_forbid(struct phy *phy)
static inline int phy_init(struct phy *phy) static inline int phy_init(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_exit(struct phy *phy) static inline int phy_exit(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_power_on(struct phy *phy) static inline int phy_power_on(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
static inline int phy_power_off(struct phy *phy) static inline int phy_power_off(struct phy *phy)
{ {
if (!phy)
return 0;
return -ENOSYS; return -ENOSYS;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册