Lines Matching refs:ci
37 struct platform_device *ci; member
79 static int ci_hdrc_msm_notify_event(struct ci_hdrc *ci, unsigned event) in ci_hdrc_msm_notify_event() argument
81 struct device *dev = ci->dev->parent; in ci_hdrc_msm_notify_event()
89 hw_phymode_configure(ci); in ci_hdrc_msm_notify_event()
96 ret = phy_init(ci->phy); in ci_hdrc_msm_notify_event()
100 ret = phy_power_on(ci->phy); in ci_hdrc_msm_notify_event()
102 phy_exit(ci->phy); in ci_hdrc_msm_notify_event()
107 hw_write_id_reg(ci, HS_PHY_AHB_MODE, 0xffffffff, 0x8); in ci_hdrc_msm_notify_event()
110 hw_write_id_reg(ci, HS_PHY_GENCONFIG, in ci_hdrc_msm_notify_event()
114 hw_write_id_reg(ci, HS_PHY_GENCONFIG_2, in ci_hdrc_msm_notify_event()
117 if (!IS_ERR(ci->platdata->vbus_extcon.edev)) { in ci_hdrc_msm_notify_event()
118 hw_write_id_reg(ci, HS_PHY_GENCONFIG_2, in ci_hdrc_msm_notify_event()
121 hw_write(ci, OP_USBCMD, HSPHY_SESS_VLD_CTRL, in ci_hdrc_msm_notify_event()
128 phy_power_off(ci->phy); in ci_hdrc_msm_notify_event()
129 phy_exit(ci->phy); in ci_hdrc_msm_notify_event()
139 static int ci_hdrc_msm_mux_phy(struct ci_hdrc_msm *ci, in ci_hdrc_msm_mux_phy() argument
162 ci->secondary_phy = !!args.args[1]; in ci_hdrc_msm_mux_phy()
163 if (ci->secondary_phy) { in ci_hdrc_msm_mux_phy()
164 val = readl_relaxed(ci->base + HS_PHY_SEC_CTRL); in ci_hdrc_msm_mux_phy()
166 writel_relaxed(val, ci->base + HS_PHY_SEC_CTRL); in ci_hdrc_msm_mux_phy()
174 struct ci_hdrc_msm *ci; in ci_hdrc_msm_probe() local
184 ci = devm_kzalloc(&pdev->dev, sizeof(*ci), GFP_KERNEL); in ci_hdrc_msm_probe()
185 if (!ci) in ci_hdrc_msm_probe()
187 platform_set_drvdata(pdev, ci); in ci_hdrc_msm_probe()
189 ci->pdata.name = "ci_hdrc_msm"; in ci_hdrc_msm_probe()
190 ci->pdata.capoffset = DEF_CAPOFFSET; in ci_hdrc_msm_probe()
191 ci->pdata.flags = CI_HDRC_REGS_SHARED | CI_HDRC_DISABLE_STREAMING | in ci_hdrc_msm_probe()
194 ci->pdata.notify_event = ci_hdrc_msm_notify_event; in ci_hdrc_msm_probe()
200 ci->core_clk = clk = devm_clk_get(&pdev->dev, "core"); in ci_hdrc_msm_probe()
204 ci->iface_clk = clk = devm_clk_get(&pdev->dev, "iface"); in ci_hdrc_msm_probe()
208 ci->fs_clk = clk = devm_clk_get(&pdev->dev, "fs"); in ci_hdrc_msm_probe()
212 ci->fs_clk = NULL; in ci_hdrc_msm_probe()
216 ci->base = devm_ioremap_resource(&pdev->dev, res); in ci_hdrc_msm_probe()
217 if (IS_ERR(ci->base)) in ci_hdrc_msm_probe()
218 return PTR_ERR(ci->base); in ci_hdrc_msm_probe()
220 ci->rcdev.owner = THIS_MODULE; in ci_hdrc_msm_probe()
221 ci->rcdev.ops = &ci_hdrc_msm_reset_ops; in ci_hdrc_msm_probe()
222 ci->rcdev.of_node = pdev->dev.of_node; in ci_hdrc_msm_probe()
223 ci->rcdev.nr_resets = 2; in ci_hdrc_msm_probe()
224 ret = reset_controller_register(&ci->rcdev); in ci_hdrc_msm_probe()
228 ret = clk_prepare_enable(ci->fs_clk); in ci_hdrc_msm_probe()
236 clk_disable_unprepare(ci->fs_clk); in ci_hdrc_msm_probe()
238 ret = clk_prepare_enable(ci->core_clk); in ci_hdrc_msm_probe()
242 ret = clk_prepare_enable(ci->iface_clk); in ci_hdrc_msm_probe()
246 ret = ci_hdrc_msm_mux_phy(ci, pdev); in ci_hdrc_msm_probe()
253 ci->hsic = of_device_is_compatible(phy_node, "qcom,usb-hsic-phy"); in ci_hdrc_msm_probe()
259 pdev->num_resources, &ci->pdata); in ci_hdrc_msm_probe()
267 ci->ci = plat_ci; in ci_hdrc_msm_probe()
276 clk_disable_unprepare(ci->iface_clk); in ci_hdrc_msm_probe()
278 clk_disable_unprepare(ci->core_clk); in ci_hdrc_msm_probe()
280 reset_controller_unregister(&ci->rcdev); in ci_hdrc_msm_probe()
286 struct ci_hdrc_msm *ci = platform_get_drvdata(pdev); in ci_hdrc_msm_remove() local
289 ci_hdrc_remove_device(ci->ci); in ci_hdrc_msm_remove()
290 clk_disable_unprepare(ci->iface_clk); in ci_hdrc_msm_remove()
291 clk_disable_unprepare(ci->core_clk); in ci_hdrc_msm_remove()
292 reset_controller_unregister(&ci->rcdev); in ci_hdrc_msm_remove()