Lines Matching +full:big +full:- +full:endian +full:- +full:desc
1 // SPDX-License-Identifier: GPL-2.0
6 * Copyright 2011-2012 Hauke Mehrtens <hauke@hauke-m.de>
9 * Derived from the OCHI-SSB driver
10 * Derived from the OHCI-PCI driver
12 * Copyright 2000-2002 David Brownell
18 #include <linux/dma-mapping.h>
37 #define hcd_to_ohci_priv(h) ((struct ohci_platform_priv *)hcd_to_ohci(h)->priv)
50 for (clk = 0; clk < OHCI_MAX_CLKS && priv->clks[clk]; clk++) { in ohci_platform_power_on()
51 ret = clk_prepare_enable(priv->clks[clk]); in ohci_platform_power_on()
59 while (--clk >= 0) in ohci_platform_power_on()
60 clk_disable_unprepare(priv->clks[clk]); in ohci_platform_power_on()
71 for (clk = OHCI_MAX_CLKS - 1; clk >= 0; clk--) in ohci_platform_power_off()
72 if (priv->clks[clk]) in ohci_platform_power_off()
73 clk_disable_unprepare(priv->clks[clk]); in ohci_platform_power_off()
93 struct usb_ohci_pdata *pdata = dev_get_platdata(&dev->dev); in ohci_platform_probe()
99 return -ENODEV; in ohci_platform_probe()
108 err = dma_coerce_mask_and_coherent(&dev->dev, DMA_BIT_MASK(32)); in ohci_platform_probe()
116 hcd = usb_create_hcd(&ohci_platform_hc_driver, &dev->dev, in ohci_platform_probe()
117 dev_name(&dev->dev)); in ohci_platform_probe()
119 return -ENOMEM; in ohci_platform_probe()
122 dev->dev.platform_data = pdata; in ohci_platform_probe()
126 if (pdata == &ohci_platform_defaults && dev->dev.of_node) { in ohci_platform_probe()
127 if (of_property_read_bool(dev->dev.of_node, "big-endian-regs")) in ohci_platform_probe()
128 ohci->flags |= OHCI_QUIRK_BE_MMIO; in ohci_platform_probe()
130 if (of_property_read_bool(dev->dev.of_node, "big-endian-desc")) in ohci_platform_probe()
131 ohci->flags |= OHCI_QUIRK_BE_DESC; in ohci_platform_probe()
133 if (of_property_read_bool(dev->dev.of_node, "big-endian")) in ohci_platform_probe()
134 ohci->flags |= OHCI_QUIRK_BE_MMIO | OHCI_QUIRK_BE_DESC; in ohci_platform_probe()
136 if (of_property_read_bool(dev->dev.of_node, "no-big-frame-no")) in ohci_platform_probe()
137 ohci->flags |= OHCI_QUIRK_FRAME_NO; in ohci_platform_probe()
139 if (of_property_read_bool(dev->dev.of_node, in ohci_platform_probe()
140 "remote-wakeup-connected")) in ohci_platform_probe()
141 ohci->hc_control = OHCI_CTRL_RWC; in ohci_platform_probe()
143 of_property_read_u32(dev->dev.of_node, "num-ports", in ohci_platform_probe()
144 &ohci->num_ports); in ohci_platform_probe()
147 priv->clks[clk] = of_clk_get(dev->dev.of_node, clk); in ohci_platform_probe()
148 if (IS_ERR(priv->clks[clk])) { in ohci_platform_probe()
149 err = PTR_ERR(priv->clks[clk]); in ohci_platform_probe()
150 if (err == -EPROBE_DEFER) in ohci_platform_probe()
152 priv->clks[clk] = NULL; in ohci_platform_probe()
157 priv->resets = devm_reset_control_array_get_optional_shared( in ohci_platform_probe()
158 &dev->dev); in ohci_platform_probe()
159 if (IS_ERR(priv->resets)) { in ohci_platform_probe()
160 err = PTR_ERR(priv->resets); in ohci_platform_probe()
164 err = reset_control_deassert(priv->resets); in ohci_platform_probe()
169 if (pdata->big_endian_desc) in ohci_platform_probe()
170 ohci->flags |= OHCI_QUIRK_BE_DESC; in ohci_platform_probe()
171 if (pdata->big_endian_mmio) in ohci_platform_probe()
172 ohci->flags |= OHCI_QUIRK_BE_MMIO; in ohci_platform_probe()
173 if (pdata->no_big_frame_no) in ohci_platform_probe()
174 ohci->flags |= OHCI_QUIRK_FRAME_NO; in ohci_platform_probe()
175 if (pdata->num_ports) in ohci_platform_probe()
176 ohci->num_ports = pdata->num_ports; in ohci_platform_probe()
179 if (ohci->flags & OHCI_QUIRK_BE_MMIO) { in ohci_platform_probe()
180 dev_err(&dev->dev, in ohci_platform_probe()
182 err = -EINVAL; in ohci_platform_probe()
187 if (ohci->flags & OHCI_QUIRK_BE_DESC) { in ohci_platform_probe()
188 dev_err(&dev->dev, in ohci_platform_probe()
190 err = -EINVAL; in ohci_platform_probe()
195 pm_runtime_set_active(&dev->dev); in ohci_platform_probe()
196 pm_runtime_enable(&dev->dev); in ohci_platform_probe()
197 if (pdata->power_on) { in ohci_platform_probe()
198 err = pdata->power_on(dev); in ohci_platform_probe()
204 hcd->regs = devm_ioremap_resource(&dev->dev, res_mem); in ohci_platform_probe()
205 if (IS_ERR(hcd->regs)) { in ohci_platform_probe()
206 err = PTR_ERR(hcd->regs); in ohci_platform_probe()
209 hcd->rsrc_start = res_mem->start; in ohci_platform_probe()
210 hcd->rsrc_len = resource_size(res_mem); in ohci_platform_probe()
212 hcd->tpl_support = of_usb_host_tpl_support(dev->dev.of_node); in ohci_platform_probe()
218 device_wakeup_enable(hcd->self.controller); in ohci_platform_probe()
225 if (pdata->power_off) in ohci_platform_probe()
226 pdata->power_off(dev); in ohci_platform_probe()
228 pm_runtime_disable(&dev->dev); in ohci_platform_probe()
229 reset_control_assert(priv->resets); in ohci_platform_probe()
231 while (--clk >= 0) in ohci_platform_probe()
232 clk_put(priv->clks[clk]); in ohci_platform_probe()
235 dev->dev.platform_data = NULL; in ohci_platform_probe()
245 struct usb_ohci_pdata *pdata = dev_get_platdata(&dev->dev); in ohci_platform_remove()
249 pm_runtime_get_sync(&dev->dev); in ohci_platform_remove()
252 if (pdata->power_off) in ohci_platform_remove()
253 pdata->power_off(dev); in ohci_platform_remove()
255 reset_control_assert(priv->resets); in ohci_platform_remove()
257 for (clk = 0; clk < OHCI_MAX_CLKS && priv->clks[clk]; clk++) in ohci_platform_remove()
258 clk_put(priv->clks[clk]); in ohci_platform_remove()
262 pm_runtime_put_sync(&dev->dev); in ohci_platform_remove()
263 pm_runtime_disable(&dev->dev); in ohci_platform_remove()
266 dev->dev.platform_data = NULL; in ohci_platform_remove()
275 struct usb_ohci_pdata *pdata = dev->platform_data; in ohci_platform_suspend()
284 if (pdata->power_suspend) in ohci_platform_suspend()
285 pdata->power_suspend(pdev); in ohci_platform_suspend()
296 if (pdata->power_on) { in ohci_platform_resume_common()
297 int err = pdata->power_on(pdev); in ohci_platform_resume_common()
323 { .compatible = "generic-ohci", },
324 { .compatible = "cavium,octeon-6335-ohci", },
325 { .compatible = "ti,ohci-omap3", },
331 { "ohci-platform", 0 },
353 .name = "ohci-platform",
365 return -ENODEV; in ohci_platform_init()