xref: /openbmc/linux/drivers/phy/tegra/xusb.c (revision 023e41632e065d49bcbe31b3c4b336217f96a271)
1 /*
2  * Copyright (c) 2014-2015, NVIDIA CORPORATION.  All rights reserved.
3  *
4  * This program is free software; you can redistribute it and/or modify it
5  * under the terms and conditions of the GNU General Public License,
6  * version 2, as published by the Free Software Foundation.
7  *
8  * This program is distributed in the hope it will be useful, but WITHOUT
9  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
11  * more details.
12  */
13 
14 #include <linux/delay.h>
15 #include <linux/io.h>
16 #include <linux/mailbox_client.h>
17 #include <linux/module.h>
18 #include <linux/of.h>
19 #include <linux/of_device.h>
20 #include <linux/phy/phy.h>
21 #include <linux/phy/tegra/xusb.h>
22 #include <linux/platform_device.h>
23 #include <linux/regulator/consumer.h>
24 #include <linux/reset.h>
25 #include <linux/slab.h>
26 #include <linux/workqueue.h>
27 
28 #include <soc/tegra/fuse.h>
29 
30 #include "xusb.h"
31 
32 static struct phy *tegra_xusb_pad_of_xlate(struct device *dev,
33 					   struct of_phandle_args *args)
34 {
35 	struct tegra_xusb_pad *pad = dev_get_drvdata(dev);
36 	struct phy *phy = NULL;
37 	unsigned int i;
38 
39 	if (args->args_count != 0)
40 		return ERR_PTR(-EINVAL);
41 
42 	for (i = 0; i < pad->soc->num_lanes; i++) {
43 		if (!pad->lanes[i])
44 			continue;
45 
46 		if (pad->lanes[i]->dev.of_node == args->np) {
47 			phy = pad->lanes[i];
48 			break;
49 		}
50 	}
51 
52 	if (phy == NULL)
53 		phy = ERR_PTR(-ENODEV);
54 
55 	return phy;
56 }
57 
58 static const struct of_device_id tegra_xusb_padctl_of_match[] = {
59 #if defined(CONFIG_ARCH_TEGRA_124_SOC) || defined(CONFIG_ARCH_TEGRA_132_SOC)
60 	{
61 		.compatible = "nvidia,tegra124-xusb-padctl",
62 		.data = &tegra124_xusb_padctl_soc,
63 	},
64 #endif
65 #if defined(CONFIG_ARCH_TEGRA_210_SOC)
66 	{
67 		.compatible = "nvidia,tegra210-xusb-padctl",
68 		.data = &tegra210_xusb_padctl_soc,
69 	},
70 #endif
71 	{ }
72 };
73 MODULE_DEVICE_TABLE(of, tegra_xusb_padctl_of_match);
74 
75 static struct device_node *
76 tegra_xusb_find_pad_node(struct tegra_xusb_padctl *padctl, const char *name)
77 {
78 	struct device_node *pads, *np;
79 
80 	pads = of_get_child_by_name(padctl->dev->of_node, "pads");
81 	if (!pads)
82 		return NULL;
83 
84 	np = of_get_child_by_name(pads, name);
85 	of_node_put(pads);
86 
87 	return np;
88 }
89 
90 static struct device_node *
91 tegra_xusb_pad_find_phy_node(struct tegra_xusb_pad *pad, unsigned int index)
92 {
93 	struct device_node *np, *lanes;
94 
95 	lanes = of_get_child_by_name(pad->dev.of_node, "lanes");
96 	if (!lanes)
97 		return NULL;
98 
99 	np = of_get_child_by_name(lanes, pad->soc->lanes[index].name);
100 	of_node_put(lanes);
101 
102 	return np;
103 }
104 
105 int tegra_xusb_lane_parse_dt(struct tegra_xusb_lane *lane,
106 			     struct device_node *np)
107 {
108 	struct device *dev = &lane->pad->dev;
109 	const char *function;
110 	int err;
111 
112 	err = of_property_read_string(np, "nvidia,function", &function);
113 	if (err < 0)
114 		return err;
115 
116 	err = match_string(lane->soc->funcs, lane->soc->num_funcs, function);
117 	if (err < 0) {
118 		dev_err(dev, "invalid function \"%s\" for lane \"%pOFn\"\n",
119 			function, np);
120 		return err;
121 	}
122 
123 	lane->function = err;
124 
125 	return 0;
126 }
127 
128 static void tegra_xusb_lane_destroy(struct phy *phy)
129 {
130 	if (phy) {
131 		struct tegra_xusb_lane *lane = phy_get_drvdata(phy);
132 
133 		lane->pad->ops->remove(lane);
134 		phy_destroy(phy);
135 	}
136 }
137 
138 static void tegra_xusb_pad_release(struct device *dev)
139 {
140 	struct tegra_xusb_pad *pad = to_tegra_xusb_pad(dev);
141 
142 	pad->soc->ops->remove(pad);
143 }
144 
145 static struct device_type tegra_xusb_pad_type = {
146 	.release = tegra_xusb_pad_release,
147 };
148 
149 int tegra_xusb_pad_init(struct tegra_xusb_pad *pad,
150 			struct tegra_xusb_padctl *padctl,
151 			struct device_node *np)
152 {
153 	int err;
154 
155 	device_initialize(&pad->dev);
156 	INIT_LIST_HEAD(&pad->list);
157 	pad->dev.parent = padctl->dev;
158 	pad->dev.type = &tegra_xusb_pad_type;
159 	pad->dev.of_node = np;
160 	pad->padctl = padctl;
161 
162 	err = dev_set_name(&pad->dev, "%s", pad->soc->name);
163 	if (err < 0)
164 		goto unregister;
165 
166 	err = device_add(&pad->dev);
167 	if (err < 0)
168 		goto unregister;
169 
170 	return 0;
171 
172 unregister:
173 	device_unregister(&pad->dev);
174 	return err;
175 }
176 
177 int tegra_xusb_pad_register(struct tegra_xusb_pad *pad,
178 			    const struct phy_ops *ops)
179 {
180 	struct device_node *children;
181 	struct phy *lane;
182 	unsigned int i;
183 	int err;
184 
185 	children = of_get_child_by_name(pad->dev.of_node, "lanes");
186 	if (!children)
187 		return -ENODEV;
188 
189 	pad->lanes = devm_kcalloc(&pad->dev, pad->soc->num_lanes, sizeof(lane),
190 				  GFP_KERNEL);
191 	if (!pad->lanes) {
192 		of_node_put(children);
193 		return -ENOMEM;
194 	}
195 
196 	for (i = 0; i < pad->soc->num_lanes; i++) {
197 		struct device_node *np = tegra_xusb_pad_find_phy_node(pad, i);
198 		struct tegra_xusb_lane *lane;
199 
200 		/* skip disabled lanes */
201 		if (!np || !of_device_is_available(np)) {
202 			of_node_put(np);
203 			continue;
204 		}
205 
206 		pad->lanes[i] = phy_create(&pad->dev, np, ops);
207 		if (IS_ERR(pad->lanes[i])) {
208 			err = PTR_ERR(pad->lanes[i]);
209 			of_node_put(np);
210 			goto remove;
211 		}
212 
213 		lane = pad->ops->probe(pad, np, i);
214 		if (IS_ERR(lane)) {
215 			phy_destroy(pad->lanes[i]);
216 			err = PTR_ERR(lane);
217 			goto remove;
218 		}
219 
220 		list_add_tail(&lane->list, &pad->padctl->lanes);
221 		phy_set_drvdata(pad->lanes[i], lane);
222 	}
223 
224 	pad->provider = of_phy_provider_register_full(&pad->dev, children,
225 						      tegra_xusb_pad_of_xlate);
226 	if (IS_ERR(pad->provider)) {
227 		err = PTR_ERR(pad->provider);
228 		goto remove;
229 	}
230 
231 	return 0;
232 
233 remove:
234 	while (i--)
235 		tegra_xusb_lane_destroy(pad->lanes[i]);
236 
237 	of_node_put(children);
238 
239 	return err;
240 }
241 
242 void tegra_xusb_pad_unregister(struct tegra_xusb_pad *pad)
243 {
244 	unsigned int i = pad->soc->num_lanes;
245 
246 	of_phy_provider_unregister(pad->provider);
247 
248 	while (i--)
249 		tegra_xusb_lane_destroy(pad->lanes[i]);
250 
251 	device_unregister(&pad->dev);
252 }
253 
254 static struct tegra_xusb_pad *
255 tegra_xusb_pad_create(struct tegra_xusb_padctl *padctl,
256 		      const struct tegra_xusb_pad_soc *soc)
257 {
258 	struct tegra_xusb_pad *pad;
259 	struct device_node *np;
260 	int err;
261 
262 	np = tegra_xusb_find_pad_node(padctl, soc->name);
263 	if (!np || !of_device_is_available(np))
264 		return NULL;
265 
266 	pad = soc->ops->probe(padctl, soc, np);
267 	if (IS_ERR(pad)) {
268 		err = PTR_ERR(pad);
269 		dev_err(padctl->dev, "failed to create pad %s: %d\n",
270 			soc->name, err);
271 		return ERR_PTR(err);
272 	}
273 
274 	/* XXX move this into ->probe() to avoid string comparison */
275 	if (strcmp(soc->name, "pcie") == 0)
276 		padctl->pcie = pad;
277 
278 	if (strcmp(soc->name, "sata") == 0)
279 		padctl->sata = pad;
280 
281 	if (strcmp(soc->name, "usb2") == 0)
282 		padctl->usb2 = pad;
283 
284 	if (strcmp(soc->name, "ulpi") == 0)
285 		padctl->ulpi = pad;
286 
287 	if (strcmp(soc->name, "hsic") == 0)
288 		padctl->hsic = pad;
289 
290 	return pad;
291 }
292 
293 static void __tegra_xusb_remove_pads(struct tegra_xusb_padctl *padctl)
294 {
295 	struct tegra_xusb_pad *pad, *tmp;
296 
297 	list_for_each_entry_safe_reverse(pad, tmp, &padctl->pads, list) {
298 		list_del(&pad->list);
299 		tegra_xusb_pad_unregister(pad);
300 	}
301 }
302 
303 static void tegra_xusb_remove_pads(struct tegra_xusb_padctl *padctl)
304 {
305 	mutex_lock(&padctl->lock);
306 	__tegra_xusb_remove_pads(padctl);
307 	mutex_unlock(&padctl->lock);
308 }
309 
310 static void tegra_xusb_lane_program(struct tegra_xusb_lane *lane)
311 {
312 	struct tegra_xusb_padctl *padctl = lane->pad->padctl;
313 	const struct tegra_xusb_lane_soc *soc = lane->soc;
314 	u32 value;
315 
316 	/* choose function */
317 	value = padctl_readl(padctl, soc->offset);
318 	value &= ~(soc->mask << soc->shift);
319 	value |= lane->function << soc->shift;
320 	padctl_writel(padctl, value, soc->offset);
321 }
322 
323 static void tegra_xusb_pad_program(struct tegra_xusb_pad *pad)
324 {
325 	unsigned int i;
326 
327 	for (i = 0; i < pad->soc->num_lanes; i++) {
328 		struct tegra_xusb_lane *lane;
329 
330 		if (pad->lanes[i]) {
331 			lane = phy_get_drvdata(pad->lanes[i]);
332 			tegra_xusb_lane_program(lane);
333 		}
334 	}
335 }
336 
337 static int tegra_xusb_setup_pads(struct tegra_xusb_padctl *padctl)
338 {
339 	struct tegra_xusb_pad *pad;
340 	unsigned int i;
341 
342 	mutex_lock(&padctl->lock);
343 
344 	for (i = 0; i < padctl->soc->num_pads; i++) {
345 		const struct tegra_xusb_pad_soc *soc = padctl->soc->pads[i];
346 		int err;
347 
348 		pad = tegra_xusb_pad_create(padctl, soc);
349 		if (IS_ERR(pad)) {
350 			err = PTR_ERR(pad);
351 			dev_err(padctl->dev, "failed to create pad %s: %d\n",
352 				soc->name, err);
353 			__tegra_xusb_remove_pads(padctl);
354 			mutex_unlock(&padctl->lock);
355 			return err;
356 		}
357 
358 		if (!pad)
359 			continue;
360 
361 		list_add_tail(&pad->list, &padctl->pads);
362 	}
363 
364 	list_for_each_entry(pad, &padctl->pads, list)
365 		tegra_xusb_pad_program(pad);
366 
367 	mutex_unlock(&padctl->lock);
368 	return 0;
369 }
370 
371 static bool tegra_xusb_lane_check(struct tegra_xusb_lane *lane,
372 				  const char *function)
373 {
374 	const char *func = lane->soc->funcs[lane->function];
375 
376 	return strcmp(function, func) == 0;
377 }
378 
379 struct tegra_xusb_lane *tegra_xusb_find_lane(struct tegra_xusb_padctl *padctl,
380 					     const char *type,
381 					     unsigned int index)
382 {
383 	struct tegra_xusb_lane *lane, *hit = ERR_PTR(-ENODEV);
384 	char *name;
385 
386 	name = kasprintf(GFP_KERNEL, "%s-%u", type, index);
387 	if (!name)
388 		return ERR_PTR(-ENOMEM);
389 
390 	list_for_each_entry(lane, &padctl->lanes, list) {
391 		if (strcmp(lane->soc->name, name) == 0) {
392 			hit = lane;
393 			break;
394 		}
395 	}
396 
397 	kfree(name);
398 	return hit;
399 }
400 
401 struct tegra_xusb_lane *
402 tegra_xusb_port_find_lane(struct tegra_xusb_port *port,
403 			  const struct tegra_xusb_lane_map *map,
404 			  const char *function)
405 {
406 	struct tegra_xusb_lane *lane, *match = ERR_PTR(-ENODEV);
407 
408 	for (; map->type; map++) {
409 		if (port->index != map->port)
410 			continue;
411 
412 		lane = tegra_xusb_find_lane(port->padctl, map->type,
413 					    map->index);
414 		if (IS_ERR(lane))
415 			continue;
416 
417 		if (!tegra_xusb_lane_check(lane, function))
418 			continue;
419 
420 		if (!IS_ERR(match))
421 			dev_err(&port->dev, "conflicting match: %s-%u / %s\n",
422 				map->type, map->index, match->soc->name);
423 		else
424 			match = lane;
425 	}
426 
427 	return match;
428 }
429 
430 static struct device_node *
431 tegra_xusb_find_port_node(struct tegra_xusb_padctl *padctl, const char *type,
432 			  unsigned int index)
433 {
434 	struct device_node *ports, *np;
435 	char *name;
436 
437 	ports = of_get_child_by_name(padctl->dev->of_node, "ports");
438 	if (!ports)
439 		return NULL;
440 
441 	name = kasprintf(GFP_KERNEL, "%s-%u", type, index);
442 	if (!name) {
443 		of_node_put(ports);
444 		return ERR_PTR(-ENOMEM);
445 	}
446 	np = of_get_child_by_name(ports, name);
447 	kfree(name);
448 	of_node_put(ports);
449 
450 	return np;
451 }
452 
453 struct tegra_xusb_port *
454 tegra_xusb_find_port(struct tegra_xusb_padctl *padctl, const char *type,
455 		     unsigned int index)
456 {
457 	struct tegra_xusb_port *port;
458 	struct device_node *np;
459 
460 	np = tegra_xusb_find_port_node(padctl, type, index);
461 	if (!np)
462 		return NULL;
463 
464 	list_for_each_entry(port, &padctl->ports, list) {
465 		if (np == port->dev.of_node) {
466 			of_node_put(np);
467 			return port;
468 		}
469 	}
470 
471 	of_node_put(np);
472 
473 	return NULL;
474 }
475 
476 struct tegra_xusb_usb2_port *
477 tegra_xusb_find_usb2_port(struct tegra_xusb_padctl *padctl, unsigned int index)
478 {
479 	struct tegra_xusb_port *port;
480 
481 	port = tegra_xusb_find_port(padctl, "usb2", index);
482 	if (port)
483 		return to_usb2_port(port);
484 
485 	return NULL;
486 }
487 
488 struct tegra_xusb_usb3_port *
489 tegra_xusb_find_usb3_port(struct tegra_xusb_padctl *padctl, unsigned int index)
490 {
491 	struct tegra_xusb_port *port;
492 
493 	port = tegra_xusb_find_port(padctl, "usb3", index);
494 	if (port)
495 		return to_usb3_port(port);
496 
497 	return NULL;
498 }
499 
500 static void tegra_xusb_port_release(struct device *dev)
501 {
502 }
503 
504 static struct device_type tegra_xusb_port_type = {
505 	.release = tegra_xusb_port_release,
506 };
507 
508 static int tegra_xusb_port_init(struct tegra_xusb_port *port,
509 				struct tegra_xusb_padctl *padctl,
510 				struct device_node *np,
511 				const char *name,
512 				unsigned int index)
513 {
514 	int err;
515 
516 	INIT_LIST_HEAD(&port->list);
517 	port->padctl = padctl;
518 	port->index = index;
519 
520 	device_initialize(&port->dev);
521 	port->dev.type = &tegra_xusb_port_type;
522 	port->dev.of_node = of_node_get(np);
523 	port->dev.parent = padctl->dev;
524 
525 	err = dev_set_name(&port->dev, "%s-%u", name, index);
526 	if (err < 0)
527 		goto unregister;
528 
529 	err = device_add(&port->dev);
530 	if (err < 0)
531 		goto unregister;
532 
533 	return 0;
534 
535 unregister:
536 	device_unregister(&port->dev);
537 	return err;
538 }
539 
540 static void tegra_xusb_port_unregister(struct tegra_xusb_port *port)
541 {
542 	device_unregister(&port->dev);
543 }
544 
545 static int tegra_xusb_usb2_port_parse_dt(struct tegra_xusb_usb2_port *usb2)
546 {
547 	struct tegra_xusb_port *port = &usb2->base;
548 	struct device_node *np = port->dev.of_node;
549 
550 	usb2->internal = of_property_read_bool(np, "nvidia,internal");
551 
552 	usb2->supply = devm_regulator_get(&port->dev, "vbus");
553 	return PTR_ERR_OR_ZERO(usb2->supply);
554 }
555 
556 static int tegra_xusb_add_usb2_port(struct tegra_xusb_padctl *padctl,
557 				    unsigned int index)
558 {
559 	struct tegra_xusb_usb2_port *usb2;
560 	struct device_node *np;
561 	int err = 0;
562 
563 	/*
564 	 * USB2 ports don't require additional properties, but if the port is
565 	 * marked as disabled there is no reason to register it.
566 	 */
567 	np = tegra_xusb_find_port_node(padctl, "usb2", index);
568 	if (!np || !of_device_is_available(np))
569 		goto out;
570 
571 	usb2 = devm_kzalloc(padctl->dev, sizeof(*usb2), GFP_KERNEL);
572 	if (!usb2) {
573 		err = -ENOMEM;
574 		goto out;
575 	}
576 
577 	err = tegra_xusb_port_init(&usb2->base, padctl, np, "usb2", index);
578 	if (err < 0)
579 		goto out;
580 
581 	usb2->base.ops = padctl->soc->ports.usb2.ops;
582 
583 	usb2->base.lane = usb2->base.ops->map(&usb2->base);
584 	if (IS_ERR(usb2->base.lane)) {
585 		err = PTR_ERR(usb2->base.lane);
586 		goto out;
587 	}
588 
589 	err = tegra_xusb_usb2_port_parse_dt(usb2);
590 	if (err < 0) {
591 		tegra_xusb_port_unregister(&usb2->base);
592 		goto out;
593 	}
594 
595 	list_add_tail(&usb2->base.list, &padctl->ports);
596 
597 out:
598 	of_node_put(np);
599 	return err;
600 }
601 
602 static int tegra_xusb_ulpi_port_parse_dt(struct tegra_xusb_ulpi_port *ulpi)
603 {
604 	struct tegra_xusb_port *port = &ulpi->base;
605 	struct device_node *np = port->dev.of_node;
606 
607 	ulpi->internal = of_property_read_bool(np, "nvidia,internal");
608 
609 	return 0;
610 }
611 
612 static int tegra_xusb_add_ulpi_port(struct tegra_xusb_padctl *padctl,
613 				    unsigned int index)
614 {
615 	struct tegra_xusb_ulpi_port *ulpi;
616 	struct device_node *np;
617 	int err = 0;
618 
619 	np = tegra_xusb_find_port_node(padctl, "ulpi", index);
620 	if (!np || !of_device_is_available(np))
621 		goto out;
622 
623 	ulpi = devm_kzalloc(padctl->dev, sizeof(*ulpi), GFP_KERNEL);
624 	if (!ulpi) {
625 		err = -ENOMEM;
626 		goto out;
627 	}
628 
629 	err = tegra_xusb_port_init(&ulpi->base, padctl, np, "ulpi", index);
630 	if (err < 0)
631 		goto out;
632 
633 	ulpi->base.ops = padctl->soc->ports.ulpi.ops;
634 
635 	ulpi->base.lane = ulpi->base.ops->map(&ulpi->base);
636 	if (IS_ERR(ulpi->base.lane)) {
637 		err = PTR_ERR(ulpi->base.lane);
638 		goto out;
639 	}
640 
641 	err = tegra_xusb_ulpi_port_parse_dt(ulpi);
642 	if (err < 0) {
643 		tegra_xusb_port_unregister(&ulpi->base);
644 		goto out;
645 	}
646 
647 	list_add_tail(&ulpi->base.list, &padctl->ports);
648 
649 out:
650 	of_node_put(np);
651 	return err;
652 }
653 
654 static int tegra_xusb_hsic_port_parse_dt(struct tegra_xusb_hsic_port *hsic)
655 {
656 	/* XXX */
657 	return 0;
658 }
659 
660 static int tegra_xusb_add_hsic_port(struct tegra_xusb_padctl *padctl,
661 				    unsigned int index)
662 {
663 	struct tegra_xusb_hsic_port *hsic;
664 	struct device_node *np;
665 	int err = 0;
666 
667 	np = tegra_xusb_find_port_node(padctl, "hsic", index);
668 	if (!np || !of_device_is_available(np))
669 		goto out;
670 
671 	hsic = devm_kzalloc(padctl->dev, sizeof(*hsic), GFP_KERNEL);
672 	if (!hsic) {
673 		err = -ENOMEM;
674 		goto out;
675 	}
676 
677 	err = tegra_xusb_port_init(&hsic->base, padctl, np, "hsic", index);
678 	if (err < 0)
679 		goto out;
680 
681 	hsic->base.ops = padctl->soc->ports.hsic.ops;
682 
683 	hsic->base.lane = hsic->base.ops->map(&hsic->base);
684 	if (IS_ERR(hsic->base.lane)) {
685 		err = PTR_ERR(hsic->base.lane);
686 		goto out;
687 	}
688 
689 	err = tegra_xusb_hsic_port_parse_dt(hsic);
690 	if (err < 0) {
691 		tegra_xusb_port_unregister(&hsic->base);
692 		goto out;
693 	}
694 
695 	list_add_tail(&hsic->base.list, &padctl->ports);
696 
697 out:
698 	of_node_put(np);
699 	return err;
700 }
701 
702 static int tegra_xusb_usb3_port_parse_dt(struct tegra_xusb_usb3_port *usb3)
703 {
704 	struct tegra_xusb_port *port = &usb3->base;
705 	struct device_node *np = port->dev.of_node;
706 	u32 value;
707 	int err;
708 
709 	err = of_property_read_u32(np, "nvidia,usb2-companion", &value);
710 	if (err < 0) {
711 		dev_err(&port->dev, "failed to read port: %d\n", err);
712 		return err;
713 	}
714 
715 	usb3->port = value;
716 
717 	usb3->internal = of_property_read_bool(np, "nvidia,internal");
718 
719 	usb3->supply = devm_regulator_get(&port->dev, "vbus");
720 	return PTR_ERR_OR_ZERO(usb3->supply);
721 }
722 
723 static int tegra_xusb_add_usb3_port(struct tegra_xusb_padctl *padctl,
724 				    unsigned int index)
725 {
726 	struct tegra_xusb_usb3_port *usb3;
727 	struct device_node *np;
728 	int err = 0;
729 
730 	/*
731 	 * If there is no supplemental configuration in the device tree the
732 	 * port is unusable. But it is valid to configure only a single port,
733 	 * hence return 0 instead of an error to allow ports to be optional.
734 	 */
735 	np = tegra_xusb_find_port_node(padctl, "usb3", index);
736 	if (!np || !of_device_is_available(np))
737 		goto out;
738 
739 	usb3 = devm_kzalloc(padctl->dev, sizeof(*usb3), GFP_KERNEL);
740 	if (!usb3) {
741 		err = -ENOMEM;
742 		goto out;
743 	}
744 
745 	err = tegra_xusb_port_init(&usb3->base, padctl, np, "usb3", index);
746 	if (err < 0)
747 		goto out;
748 
749 	usb3->base.ops = padctl->soc->ports.usb3.ops;
750 
751 	usb3->base.lane = usb3->base.ops->map(&usb3->base);
752 	if (IS_ERR(usb3->base.lane)) {
753 		err = PTR_ERR(usb3->base.lane);
754 		goto out;
755 	}
756 
757 	err = tegra_xusb_usb3_port_parse_dt(usb3);
758 	if (err < 0) {
759 		tegra_xusb_port_unregister(&usb3->base);
760 		goto out;
761 	}
762 
763 	list_add_tail(&usb3->base.list, &padctl->ports);
764 
765 out:
766 	of_node_put(np);
767 	return err;
768 }
769 
770 static void __tegra_xusb_remove_ports(struct tegra_xusb_padctl *padctl)
771 {
772 	struct tegra_xusb_port *port, *tmp;
773 
774 	list_for_each_entry_safe_reverse(port, tmp, &padctl->ports, list) {
775 		list_del(&port->list);
776 		tegra_xusb_port_unregister(port);
777 	}
778 }
779 
780 static int tegra_xusb_setup_ports(struct tegra_xusb_padctl *padctl)
781 {
782 	struct tegra_xusb_port *port;
783 	unsigned int i;
784 	int err = 0;
785 
786 	mutex_lock(&padctl->lock);
787 
788 	for (i = 0; i < padctl->soc->ports.usb2.count; i++) {
789 		err = tegra_xusb_add_usb2_port(padctl, i);
790 		if (err < 0)
791 			goto remove_ports;
792 	}
793 
794 	for (i = 0; i < padctl->soc->ports.ulpi.count; i++) {
795 		err = tegra_xusb_add_ulpi_port(padctl, i);
796 		if (err < 0)
797 			goto remove_ports;
798 	}
799 
800 	for (i = 0; i < padctl->soc->ports.hsic.count; i++) {
801 		err = tegra_xusb_add_hsic_port(padctl, i);
802 		if (err < 0)
803 			goto remove_ports;
804 	}
805 
806 	for (i = 0; i < padctl->soc->ports.usb3.count; i++) {
807 		err = tegra_xusb_add_usb3_port(padctl, i);
808 		if (err < 0)
809 			goto remove_ports;
810 	}
811 
812 	list_for_each_entry(port, &padctl->ports, list) {
813 		err = port->ops->enable(port);
814 		if (err < 0)
815 			dev_err(padctl->dev, "failed to enable port %s: %d\n",
816 				dev_name(&port->dev), err);
817 	}
818 
819 	goto unlock;
820 
821 remove_ports:
822 	__tegra_xusb_remove_ports(padctl);
823 unlock:
824 	mutex_unlock(&padctl->lock);
825 	return err;
826 }
827 
828 static void tegra_xusb_remove_ports(struct tegra_xusb_padctl *padctl)
829 {
830 	mutex_lock(&padctl->lock);
831 	__tegra_xusb_remove_ports(padctl);
832 	mutex_unlock(&padctl->lock);
833 }
834 
835 static int tegra_xusb_padctl_probe(struct platform_device *pdev)
836 {
837 	struct device_node *np = pdev->dev.of_node;
838 	const struct tegra_xusb_padctl_soc *soc;
839 	struct tegra_xusb_padctl *padctl;
840 	const struct of_device_id *match;
841 	struct resource *res;
842 	int err;
843 
844 	/* for backwards compatibility with old device trees */
845 	np = of_get_child_by_name(np, "pads");
846 	if (!np) {
847 		dev_warn(&pdev->dev, "deprecated DT, using legacy driver\n");
848 		return tegra_xusb_padctl_legacy_probe(pdev);
849 	}
850 
851 	of_node_put(np);
852 
853 	match = of_match_node(tegra_xusb_padctl_of_match, pdev->dev.of_node);
854 	soc = match->data;
855 
856 	padctl = soc->ops->probe(&pdev->dev, soc);
857 	if (IS_ERR(padctl))
858 		return PTR_ERR(padctl);
859 
860 	platform_set_drvdata(pdev, padctl);
861 	INIT_LIST_HEAD(&padctl->ports);
862 	INIT_LIST_HEAD(&padctl->lanes);
863 	INIT_LIST_HEAD(&padctl->pads);
864 	mutex_init(&padctl->lock);
865 
866 	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
867 	padctl->regs = devm_ioremap_resource(&pdev->dev, res);
868 	if (IS_ERR(padctl->regs)) {
869 		err = PTR_ERR(padctl->regs);
870 		goto remove;
871 	}
872 
873 	padctl->rst = devm_reset_control_get(&pdev->dev, NULL);
874 	if (IS_ERR(padctl->rst)) {
875 		err = PTR_ERR(padctl->rst);
876 		goto remove;
877 	}
878 
879 	err = reset_control_deassert(padctl->rst);
880 	if (err < 0)
881 		goto remove;
882 
883 	err = tegra_xusb_setup_pads(padctl);
884 	if (err < 0) {
885 		dev_err(&pdev->dev, "failed to setup pads: %d\n", err);
886 		goto reset;
887 	}
888 
889 	err = tegra_xusb_setup_ports(padctl);
890 	if (err) {
891 		dev_err(&pdev->dev, "failed to setup XUSB ports: %d\n", err);
892 		goto remove_pads;
893 	}
894 
895 	return 0;
896 
897 remove_pads:
898 	tegra_xusb_remove_pads(padctl);
899 reset:
900 	reset_control_assert(padctl->rst);
901 remove:
902 	soc->ops->remove(padctl);
903 	return err;
904 }
905 
906 static int tegra_xusb_padctl_remove(struct platform_device *pdev)
907 {
908 	struct tegra_xusb_padctl *padctl = platform_get_drvdata(pdev);
909 	int err;
910 
911 	tegra_xusb_remove_ports(padctl);
912 	tegra_xusb_remove_pads(padctl);
913 
914 	err = reset_control_assert(padctl->rst);
915 	if (err < 0)
916 		dev_err(&pdev->dev, "failed to assert reset: %d\n", err);
917 
918 	padctl->soc->ops->remove(padctl);
919 
920 	return err;
921 }
922 
923 static struct platform_driver tegra_xusb_padctl_driver = {
924 	.driver = {
925 		.name = "tegra-xusb-padctl",
926 		.of_match_table = tegra_xusb_padctl_of_match,
927 	},
928 	.probe = tegra_xusb_padctl_probe,
929 	.remove = tegra_xusb_padctl_remove,
930 };
931 module_platform_driver(tegra_xusb_padctl_driver);
932 
933 struct tegra_xusb_padctl *tegra_xusb_padctl_get(struct device *dev)
934 {
935 	struct tegra_xusb_padctl *padctl;
936 	struct platform_device *pdev;
937 	struct device_node *np;
938 
939 	np = of_parse_phandle(dev->of_node, "nvidia,xusb-padctl", 0);
940 	if (!np)
941 		return ERR_PTR(-EINVAL);
942 
943 	/*
944 	 * This is slightly ugly. A better implementation would be to keep a
945 	 * registry of pad controllers, but since there will almost certainly
946 	 * only ever be one per SoC that would be a little overkill.
947 	 */
948 	pdev = of_find_device_by_node(np);
949 	if (!pdev) {
950 		of_node_put(np);
951 		return ERR_PTR(-ENODEV);
952 	}
953 
954 	of_node_put(np);
955 
956 	padctl = platform_get_drvdata(pdev);
957 	if (!padctl) {
958 		put_device(&pdev->dev);
959 		return ERR_PTR(-EPROBE_DEFER);
960 	}
961 
962 	return padctl;
963 }
964 EXPORT_SYMBOL_GPL(tegra_xusb_padctl_get);
965 
966 void tegra_xusb_padctl_put(struct tegra_xusb_padctl *padctl)
967 {
968 	if (padctl)
969 		put_device(padctl->dev);
970 }
971 EXPORT_SYMBOL_GPL(tegra_xusb_padctl_put);
972 
973 int tegra_xusb_padctl_usb3_save_context(struct tegra_xusb_padctl *padctl,
974 					unsigned int port)
975 {
976 	if (padctl->soc->ops->usb3_save_context)
977 		return padctl->soc->ops->usb3_save_context(padctl, port);
978 
979 	return -ENOSYS;
980 }
981 EXPORT_SYMBOL_GPL(tegra_xusb_padctl_usb3_save_context);
982 
983 int tegra_xusb_padctl_hsic_set_idle(struct tegra_xusb_padctl *padctl,
984 				    unsigned int port, bool idle)
985 {
986 	if (padctl->soc->ops->hsic_set_idle)
987 		return padctl->soc->ops->hsic_set_idle(padctl, port, idle);
988 
989 	return -ENOSYS;
990 }
991 EXPORT_SYMBOL_GPL(tegra_xusb_padctl_hsic_set_idle);
992 
993 int tegra_xusb_padctl_usb3_set_lfps_detect(struct tegra_xusb_padctl *padctl,
994 					   unsigned int port, bool enable)
995 {
996 	if (padctl->soc->ops->usb3_set_lfps_detect)
997 		return padctl->soc->ops->usb3_set_lfps_detect(padctl, port,
998 							      enable);
999 
1000 	return -ENOSYS;
1001 }
1002 EXPORT_SYMBOL_GPL(tegra_xusb_padctl_usb3_set_lfps_detect);
1003 
1004 MODULE_AUTHOR("Thierry Reding <treding@nvidia.com>");
1005 MODULE_DESCRIPTION("Tegra XUSB Pad Controller driver");
1006 MODULE_LICENSE("GPL v2");
1007