Lines Matching full:usb
13 #include <linux/usb.h>
14 #include <linux/usb/chipidea.h>
15 #include <linux/usb/hcd.h>
16 #include <linux/usb/of.h>
17 #include <linux/usb/phy.h>
105 rst = devm_reset_control_get_shared(dev, "usb"); in tegra_usb_reset_controller()
116 * The 1st USB controller contains some UTMI pad registers that are in tegra_usb_reset_controller()
154 struct tegra_usb *usb = dev_get_drvdata(ci->dev->parent); in tegra_usb_notify_event() local
162 ehci_writel(ehci, usb->soc->txfifothresh << 16, in tegra_usb_notify_event()
180 /* disable USB interrupt */ in tegra_usb_internal_port_reset()
238 struct tegra_usb *usb = dev_get_drvdata(ci->dev->parent); in tegra_ehci_hub_control() local
247 if (wValue != USB_PORT_FEAT_RESET || !usb->needs_double_reset) in tegra_ehci_hub_control()
263 * hang CPU if USB controller is put into low power mode because in tegra_usb_enter_lpm()
264 * AHB USB clock is gated on Tegra in the LPM. in tegra_usb_enter_lpm()
277 struct tegra_usb *usb; in tegra_usb_probe() local
280 usb = devm_kzalloc(&pdev->dev, sizeof(*usb), GFP_KERNEL); in tegra_usb_probe()
281 if (!usb) in tegra_usb_probe()
284 platform_set_drvdata(pdev, usb); in tegra_usb_probe()
292 usb->phy = devm_usb_get_phy_by_phandle(&pdev->dev, "nvidia,phy", 0); in tegra_usb_probe()
293 if (IS_ERR(usb->phy)) in tegra_usb_probe()
294 return dev_err_probe(&pdev->dev, PTR_ERR(usb->phy), in tegra_usb_probe()
297 usb->clk = devm_clk_get(&pdev->dev, NULL); in tegra_usb_probe()
298 if (IS_ERR(usb->clk)) { in tegra_usb_probe()
299 err = PTR_ERR(usb->clk); in tegra_usb_probe()
314 usb->needs_double_reset = true; in tegra_usb_probe()
323 * USB controller registers shouldn't be touched before PHY is in tegra_usb_probe()
325 * PHY driver controls gating of internal USB clocks on Tegra. in tegra_usb_probe()
327 err = usb_phy_init(usb->phy); in tegra_usb_probe()
332 usb->soc = soc; in tegra_usb_probe()
333 usb->data.name = "tegra-usb"; in tegra_usb_probe()
334 usb->data.flags = soc->flags; in tegra_usb_probe()
335 usb->data.usb_phy = usb->phy; in tegra_usb_probe()
336 usb->data.dr_mode = soc->dr_mode; in tegra_usb_probe()
337 usb->data.capoffset = DEF_CAPOFFSET; in tegra_usb_probe()
338 usb->data.enter_lpm = tegra_usb_enter_lpm; in tegra_usb_probe()
339 usb->data.hub_control = tegra_ehci_hub_control; in tegra_usb_probe()
340 usb->data.notify_event = tegra_usb_notify_event; in tegra_usb_probe()
344 usb->data.flags &= ~CI_HDRC_SUPPORTS_RUNTIME_PM; in tegra_usb_probe()
346 usb->dev = ci_hdrc_add_device(&pdev->dev, pdev->resource, in tegra_usb_probe()
347 pdev->num_resources, &usb->data); in tegra_usb_probe()
348 if (IS_ERR(usb->dev)) { in tegra_usb_probe()
349 err = PTR_ERR(usb->dev); in tegra_usb_probe()
357 usb_phy_shutdown(usb->phy); in tegra_usb_probe()
367 struct tegra_usb *usb = platform_get_drvdata(pdev); in tegra_usb_remove() local
369 ci_hdrc_remove_device(usb->dev); in tegra_usb_remove()
370 usb_phy_shutdown(usb->phy); in tegra_usb_remove()
380 struct tegra_usb *usb = dev_get_drvdata(dev); in tegra_usb_runtime_resume() local
383 err = clk_prepare_enable(usb->clk); in tegra_usb_runtime_resume()
394 struct tegra_usb *usb = dev_get_drvdata(dev); in tegra_usb_runtime_suspend() local
396 clk_disable_unprepare(usb->clk); in tegra_usb_runtime_suspend()
408 .name = "tegra-usb",
417 MODULE_DESCRIPTION("NVIDIA Tegra USB driver");