Lines Matching +full:dp +full:- +full:phy
2 * Rockchip DP PHY driver
5 * Author: Yakir Yang <ykk@@rock-chips.com>
16 #include <linux/phy/phy.h>
35 static int rockchip_set_phy_state(struct phy *phy, bool enable) in rockchip_set_phy_state() argument
37 struct rockchip_dp_phy *dp = phy_get_drvdata(phy); in rockchip_set_phy_state() local
41 ret = regmap_write(dp->grf, GRF_SOC_CON12, in rockchip_set_phy_state()
45 dev_err(dp->dev, "Can't enable PHY power %d\n", ret); in rockchip_set_phy_state()
49 ret = clk_prepare_enable(dp->phy_24m); in rockchip_set_phy_state()
51 clk_disable_unprepare(dp->phy_24m); in rockchip_set_phy_state()
53 ret = regmap_write(dp->grf, GRF_SOC_CON12, in rockchip_set_phy_state()
61 static int rockchip_dp_phy_power_on(struct phy *phy) in rockchip_dp_phy_power_on() argument
63 return rockchip_set_phy_state(phy, true); in rockchip_dp_phy_power_on()
66 static int rockchip_dp_phy_power_off(struct phy *phy) in rockchip_dp_phy_power_off() argument
68 return rockchip_set_phy_state(phy, false); in rockchip_dp_phy_power_off()
79 struct device *dev = &pdev->dev; in rockchip_dp_phy_probe()
80 struct device_node *np = dev->of_node; in rockchip_dp_phy_probe()
82 struct rockchip_dp_phy *dp; in rockchip_dp_phy_probe() local
83 struct phy *phy; in rockchip_dp_phy_probe() local
87 return -ENODEV; in rockchip_dp_phy_probe()
89 if (!dev->parent || !dev->parent->of_node) in rockchip_dp_phy_probe()
90 return -ENODEV; in rockchip_dp_phy_probe()
92 dp = devm_kzalloc(dev, sizeof(*dp), GFP_KERNEL); in rockchip_dp_phy_probe()
93 if (!dp) in rockchip_dp_phy_probe()
94 return -ENOMEM; in rockchip_dp_phy_probe()
96 dp->dev = dev; in rockchip_dp_phy_probe()
98 dp->phy_24m = devm_clk_get(dev, "24m"); in rockchip_dp_phy_probe()
99 if (IS_ERR(dp->phy_24m)) { in rockchip_dp_phy_probe()
101 return PTR_ERR(dp->phy_24m); in rockchip_dp_phy_probe()
104 ret = clk_set_rate(dp->phy_24m, 24000000); in rockchip_dp_phy_probe()
106 dev_err(dp->dev, "cannot set clock phy_24m %d\n", ret); in rockchip_dp_phy_probe()
110 dp->grf = syscon_node_to_regmap(dev->parent->of_node); in rockchip_dp_phy_probe()
111 if (IS_ERR(dp->grf)) { in rockchip_dp_phy_probe()
112 dev_err(dev, "rk3288-dp needs the General Register Files syscon\n"); in rockchip_dp_phy_probe()
113 return PTR_ERR(dp->grf); in rockchip_dp_phy_probe()
116 ret = regmap_write(dp->grf, GRF_SOC_CON12, GRF_EDP_REF_CLK_SEL_INTER | in rockchip_dp_phy_probe()
119 dev_err(dp->dev, "Could not config GRF edp ref clk: %d\n", ret); in rockchip_dp_phy_probe()
123 phy = devm_phy_create(dev, np, &rockchip_dp_phy_ops); in rockchip_dp_phy_probe()
124 if (IS_ERR(phy)) { in rockchip_dp_phy_probe()
125 dev_err(dev, "failed to create phy\n"); in rockchip_dp_phy_probe()
126 return PTR_ERR(phy); in rockchip_dp_phy_probe()
128 phy_set_drvdata(phy, dp); in rockchip_dp_phy_probe()
136 { .compatible = "rockchip,rk3288-dp-phy" },
145 .name = "rockchip-dp-phy",
152 MODULE_AUTHOR("Yakir Yang <ykk@rock-chips.com>");
153 MODULE_DESCRIPTION("Rockchip DP PHY driver");