7559e7572c
The DT of_device.h and of_platform.h date back to the separate of_platform_bus_type before it as merged into the regular platform bus. As part of that merge prepping Arm DT support 13 years ago, they "temporarily" include each other. They also include platform_device.h and of.h. As a result, there's a pretty much random mix of those include files used throughout the tree. In order to detangle these headers and replace the implicit includes with struct declarations, users need to explicitly include the correct includes. Signed-off-by: Rob Herring <robh@kernel.org> Acked-by: Marc Kleine-Budde <mkl@pengutronix.de> # for drivers/phy/phy-can-transceiver.c Acked-by: Heiko Stuebner <heiko@sntech.de> Acked-by: Sergio Paracuellos <sergio.paracuellos@gmail.com> Link: https://lore.kernel.org/r/20230714174841.4061919-1-robh@kernel.org Signed-off-by: Vinod Koul <vkoul@kernel.org>
80 lines
1.9 KiB
C
80 lines
1.9 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* Copyright (C) 2020 Lubomir Rintel <lkundrak@v3.sk>
|
|
*/
|
|
|
|
#include <linux/delay.h>
|
|
#include <linux/io.h>
|
|
#include <linux/mod_devicetable.h>
|
|
#include <linux/module.h>
|
|
#include <linux/phy/phy.h>
|
|
#include <linux/platform_device.h>
|
|
|
|
#define HSIC_CTRL 0x08
|
|
#define HSIC_ENABLE BIT(7)
|
|
#define PLL_BYPASS BIT(4)
|
|
|
|
static int mmp3_hsic_phy_init(struct phy *phy)
|
|
{
|
|
void __iomem *base = (void __iomem *)phy_get_drvdata(phy);
|
|
u32 hsic_ctrl;
|
|
|
|
hsic_ctrl = readl_relaxed(base + HSIC_CTRL);
|
|
hsic_ctrl |= HSIC_ENABLE;
|
|
hsic_ctrl |= PLL_BYPASS;
|
|
writel_relaxed(hsic_ctrl, base + HSIC_CTRL);
|
|
|
|
return 0;
|
|
}
|
|
|
|
static const struct phy_ops mmp3_hsic_phy_ops = {
|
|
.init = mmp3_hsic_phy_init,
|
|
.owner = THIS_MODULE,
|
|
};
|
|
|
|
static const struct of_device_id mmp3_hsic_phy_of_match[] = {
|
|
{ .compatible = "marvell,mmp3-hsic-phy", },
|
|
{ },
|
|
};
|
|
MODULE_DEVICE_TABLE(of, mmp3_hsic_phy_of_match);
|
|
|
|
static int mmp3_hsic_phy_probe(struct platform_device *pdev)
|
|
{
|
|
struct device *dev = &pdev->dev;
|
|
struct phy_provider *provider;
|
|
void __iomem *base;
|
|
struct phy *phy;
|
|
|
|
base = devm_platform_get_and_ioremap_resource(pdev, 0, NULL);
|
|
if (IS_ERR(base))
|
|
return PTR_ERR(base);
|
|
|
|
phy = devm_phy_create(dev, NULL, &mmp3_hsic_phy_ops);
|
|
if (IS_ERR(phy)) {
|
|
dev_err(dev, "failed to create PHY\n");
|
|
return PTR_ERR(phy);
|
|
}
|
|
|
|
phy_set_drvdata(phy, (void *)base);
|
|
provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate);
|
|
if (IS_ERR(provider)) {
|
|
dev_err(dev, "failed to register PHY provider\n");
|
|
return PTR_ERR(provider);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static struct platform_driver mmp3_hsic_phy_driver = {
|
|
.probe = mmp3_hsic_phy_probe,
|
|
.driver = {
|
|
.name = "mmp3-hsic-phy",
|
|
.of_match_table = mmp3_hsic_phy_of_match,
|
|
},
|
|
};
|
|
module_platform_driver(mmp3_hsic_phy_driver);
|
|
|
|
MODULE_AUTHOR("Lubomir Rintel <lkundrak@v3.sk>");
|
|
MODULE_DESCRIPTION("Marvell MMP3 USB HSIC PHY Driver");
|
|
MODULE_LICENSE("GPL");
|