Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2b97789f authored by Grygorii Strashko's avatar Grygorii Strashko Committed by Greg Kroah-Hartman
Browse files

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: default avatarFelipe Balbi <balbi@ti.com>
Acked-by: default avatarSantosh Shilimkar <santosh.shilimkar@ti.com>
Signed-off-by: default avatarGrygorii Strashko <grygorii.strashko@ti.com>
Signed-off-by: default avatarKishon Vijay Abraham I <kishon@ti.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 743bb387
Loading
Loading
Loading
Loading
+16 −0
Original line number Original line Diff line number Diff line
@@ -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)


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;
}
}