of.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /*
  2. * of.c The helpers for hcd device tree support
  3. *
  4. * Copyright (C) 2016 Freescale Semiconductor, Inc.
  5. * Author: Peter Chen <peter.chen@freescale.com>
  6. *
  7. * This program is free software: you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License version 2 of
  9. * the License as published by the Free Software Foundation.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. #include <linux/of.h>
  20. #include <linux/of_platform.h>
  21. #include <linux/usb/of.h>
  22. /**
  23. * usb_of_get_child_node - Find the device node match port number
  24. * @parent: the parent device node
  25. * @portnum: the port number which device is connecting
  26. *
  27. * Find the node from device tree according to its port number.
  28. *
  29. * Return: On success, a pointer to the device node, %NULL on failure.
  30. */
  31. struct device_node *usb_of_get_child_node(struct device_node *parent,
  32. int portnum)
  33. {
  34. struct device_node *node;
  35. u32 port;
  36. for_each_child_of_node(parent, node) {
  37. if (!of_property_read_u32(node, "reg", &port)) {
  38. if (port == portnum)
  39. return node;
  40. }
  41. }
  42. return NULL;
  43. }
  44. EXPORT_SYMBOL_GPL(usb_of_get_child_node);
  45. /**
  46. * usb_of_get_companion_dev - Find the companion device
  47. * @dev: the device pointer to find a companion
  48. *
  49. * Find the companion device from platform bus.
  50. *
  51. * Takes a reference to the returned struct device which needs to be dropped
  52. * after use.
  53. *
  54. * Return: On success, a pointer to the companion device, %NULL on failure.
  55. */
  56. struct device *usb_of_get_companion_dev(struct device *dev)
  57. {
  58. struct device_node *node;
  59. struct platform_device *pdev = NULL;
  60. node = of_parse_phandle(dev->of_node, "companion", 0);
  61. if (node)
  62. pdev = of_find_device_by_node(node);
  63. of_node_put(node);
  64. return pdev ? &pdev->dev : NULL;
  65. }
  66. EXPORT_SYMBOL_GPL(usb_of_get_companion_dev);