Lines Matching +full:usb2 +full:- +full:only
1 // SPDX-License-Identifier: GPL-2.0+
3 * Setup platform devices needed by the Freescale multi-port host
4 * and/or dual-role USB controller modules based on the description
16 #include <linux/dma-mapping.h>
27 .drivers = { "fsl-ehci", NULL, NULL, },
32 .drivers = { "fsl-usb2-otg", "fsl-ehci", "fsl-usb2-udc", },
37 .drivers = { "fsl-usb2-udc", NULL, NULL, },
83 const struct resource *res = ofdev->resource; in fsl_usb2_device_register()
84 unsigned int num = ofdev->num_resources; in fsl_usb2_device_register()
89 retval = -ENOMEM; in fsl_usb2_device_register()
93 pdev->dev.parent = &ofdev->dev; in fsl_usb2_device_register()
95 pdev->dev.coherent_dma_mask = ofdev->dev.coherent_dma_mask; in fsl_usb2_device_register()
97 if (!pdev->dev.dma_mask) { in fsl_usb2_device_register()
98 pdev->dev.dma_mask = &ofdev->dev.coherent_dma_mask; in fsl_usb2_device_register()
100 retval = dma_set_mask(&pdev->dev, DMA_BIT_MASK(32)); in fsl_usb2_device_register()
139 if (of_device_is_compatible(np, "fsl-usb2-dr")) { in usb_get_ver_info()
140 if (of_device_is_compatible(np, "fsl-usb2-dr-v1.6")) in usb_get_ver_info()
142 else if (of_device_is_compatible(np, "fsl-usb2-dr-v2.2")) in usb_get_ver_info()
144 else if (of_device_is_compatible(np, "fsl-usb2-dr-v2.4")) in usb_get_ver_info()
146 else if (of_device_is_compatible(np, "fsl-usb2-dr-v2.5")) in usb_get_ver_info()
155 if (of_device_is_compatible(np, "fsl,mpc5121-usb2-dr")) in usb_get_ver_info()
158 if (of_device_is_compatible(np, "fsl-usb2-mph")) { in usb_get_ver_info()
159 if (of_device_is_compatible(np, "fsl-usb2-mph-v1.6")) in usb_get_ver_info()
161 else if (of_device_is_compatible(np, "fsl-usb2-mph-v2.2")) in usb_get_ver_info()
163 else if (of_device_is_compatible(np, "fsl-usb2-mph-v2.4")) in usb_get_ver_info()
165 else if (of_device_is_compatible(np, "fsl-usb2-mph-v2.5")) in usb_get_ver_info()
176 struct device_node *np = ofdev->dev.of_node; in fsl_usb2_mph_dr_of_probe()
186 return -ENODEV; in fsl_usb2_mph_dr_of_probe()
188 match = of_match_device(fsl_usb2_mph_dr_of_match, &ofdev->dev); in fsl_usb2_mph_dr_of_probe()
190 return -ENODEV; in fsl_usb2_mph_dr_of_probe()
193 if (match->data) in fsl_usb2_mph_dr_of_probe()
194 memcpy(pdata, match->data, sizeof(data)); in fsl_usb2_mph_dr_of_probe()
200 if (of_device_is_compatible(np, "fsl-usb2-mph")) { in fsl_usb2_mph_dr_of_probe()
202 pdata->port_enables |= FSL_USB2_PORT0_ENABLED; in fsl_usb2_mph_dr_of_probe()
205 pdata->port_enables |= FSL_USB2_PORT1_ENABLED; in fsl_usb2_mph_dr_of_probe()
207 pdata->operating_mode = FSL_USB2_MPH_HOST; in fsl_usb2_mph_dr_of_probe()
209 if (of_get_property(np, "fsl,invert-drvvbus", NULL)) in fsl_usb2_mph_dr_of_probe()
210 pdata->invert_drvvbus = 1; in fsl_usb2_mph_dr_of_probe()
212 if (of_get_property(np, "fsl,invert-pwr-fault", NULL)) in fsl_usb2_mph_dr_of_probe()
213 pdata->invert_pwr_fault = 1; in fsl_usb2_mph_dr_of_probe()
216 pdata->operating_mode = dev_data->op_mode; in fsl_usb2_mph_dr_of_probe()
220 pdata->phy_mode = determine_usb_phy(prop); in fsl_usb2_mph_dr_of_probe()
221 pdata->controller_ver = usb_get_ver_info(np); in fsl_usb2_mph_dr_of_probe()
224 pdata->has_fsl_erratum_a007792 = in fsl_usb2_mph_dr_of_probe()
225 of_property_read_bool(np, "fsl,usb-erratum-a007792"); in fsl_usb2_mph_dr_of_probe()
226 pdata->has_fsl_erratum_a005275 = in fsl_usb2_mph_dr_of_probe()
227 of_property_read_bool(np, "fsl,usb-erratum-a005275"); in fsl_usb2_mph_dr_of_probe()
228 pdata->has_fsl_erratum_a005697 = in fsl_usb2_mph_dr_of_probe()
229 of_property_read_bool(np, "fsl,usb_erratum-a005697"); in fsl_usb2_mph_dr_of_probe()
230 pdata->has_fsl_erratum_a006918 = in fsl_usb2_mph_dr_of_probe()
231 of_property_read_bool(np, "fsl,usb_erratum-a006918"); in fsl_usb2_mph_dr_of_probe()
232 pdata->has_fsl_erratum_14 = in fsl_usb2_mph_dr_of_probe()
233 of_property_read_bool(np, "fsl,usb_erratum-14"); in fsl_usb2_mph_dr_of_probe()
239 pdata->check_phy_clk_valid = in fsl_usb2_mph_dr_of_probe()
240 of_property_read_bool(np, "phy-clk-valid"); in fsl_usb2_mph_dr_of_probe()
242 if (pdata->have_sysif_regs) { in fsl_usb2_mph_dr_of_probe()
243 if (pdata->controller_ver == FSL_USB_VER_NONE) { in fsl_usb2_mph_dr_of_probe()
244 dev_warn(&ofdev->dev, "Could not get controller version\n"); in fsl_usb2_mph_dr_of_probe()
245 return -ENODEV; in fsl_usb2_mph_dr_of_probe()
249 for (i = 0; i < ARRAY_SIZE(dev_data->drivers); i++) { in fsl_usb2_mph_dr_of_probe()
250 if (!dev_data->drivers[i]) in fsl_usb2_mph_dr_of_probe()
253 dev_data->drivers[i], idx); in fsl_usb2_mph_dr_of_probe()
255 dev_err(&ofdev->dev, "Can't register usb device\n"); in fsl_usb2_mph_dr_of_probe()
271 device_for_each_child(&ofdev->dev, NULL, __unregister_subdev); in fsl_usb2_mph_dr_of_remove()
279 #define GC_ULPI_SEL (1 << 4) /* ULPI i/f select (usb0 only)*/
286 #define PHYCTRL_PHYE (1 << 4) /* On-chip UTMI PHY enable */
294 struct fsl_usb2_platform_data *pdata = dev_get_platdata(&pdev->dev); in fsl_usb2_mpc5121_init()
298 clk = devm_clk_get(pdev->dev.parent, "ipg"); in fsl_usb2_mpc5121_init()
300 dev_err(&pdev->dev, "failed to get clk\n"); in fsl_usb2_mpc5121_init()
305 dev_err(&pdev->dev, "failed to enable clk\n"); in fsl_usb2_mpc5121_init()
308 pdata->clk = clk; in fsl_usb2_mpc5121_init()
310 if (pdata->phy_mode == FSL_USB2_PHY_UTMI_WIDE) { in fsl_usb2_mpc5121_init()
313 if (pdata->invert_drvvbus) in fsl_usb2_mpc5121_init()
316 if (pdata->invert_pwr_fault) in fsl_usb2_mpc5121_init()
319 out_be32(pdata->regs + ISIPHYCTRL, PHYCTRL_PHYE | PHYCTRL_PXE); in fsl_usb2_mpc5121_init()
320 out_be32(pdata->regs + USBGENCTRL, reg); in fsl_usb2_mpc5121_init()
327 struct fsl_usb2_platform_data *pdata = dev_get_platdata(&pdev->dev); in fsl_usb2_mpc5121_exit()
329 pdata->regs = NULL; in fsl_usb2_mpc5121_exit()
331 if (pdata->clk) in fsl_usb2_mpc5121_exit()
332 clk_disable_unprepare(pdata->clk); in fsl_usb2_mpc5121_exit()
351 { .compatible = "fsl-usb2-mph", .data = &fsl_usb2_mpc8xxx_pd, },
352 { .compatible = "fsl-usb2-dr", .data = &fsl_usb2_mpc8xxx_pd, },
354 { .compatible = "fsl,mpc5121-usb2-dr", .data = &fsl_usb2_mpc5121_pd, },
362 .name = "fsl-usb2-mph-dr",