stm32_rcc.c 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2017, STMicroelectronics - All Rights Reserved
  4. * Author(s): Patrice Chotard, <patrice.chotard@foss.st.com> for STMicroelectronics.
  5. */
  6. #define LOG_CATEGORY UCLASS_NOP
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <log.h>
  10. #include <misc.h>
  11. #include <stm32_rcc.h>
  12. #include <dm/device-internal.h>
  13. #include <dm/device_compat.h>
  14. #include <dm/lists.h>
  15. struct stm32_rcc_clk stm32_rcc_clk_f42x = {
  16. .drv_name = "stm32fx_rcc_clock",
  17. .soc = STM32F42X,
  18. };
  19. struct stm32_rcc_clk stm32_rcc_clk_f469 = {
  20. .drv_name = "stm32fx_rcc_clock",
  21. .soc = STM32F469,
  22. };
  23. struct stm32_rcc_clk stm32_rcc_clk_f7 = {
  24. .drv_name = "stm32fx_rcc_clock",
  25. .soc = STM32F7,
  26. };
  27. struct stm32_rcc_clk stm32_rcc_clk_h7 = {
  28. .drv_name = "stm32h7_rcc_clock",
  29. };
  30. struct stm32_rcc_clk stm32_rcc_clk_mp1 = {
  31. .drv_name = "stm32mp1_clk",
  32. .soc = STM32MP1,
  33. };
  34. struct stm32_rcc_clk stm32_rcc_clk_mp13 = {
  35. .drv_name = "stm32mp13_clk",
  36. .soc = STM32MP1,
  37. };
  38. static int stm32_rcc_bind(struct udevice *dev)
  39. {
  40. struct udevice *child;
  41. struct driver *drv;
  42. struct stm32_rcc_clk *rcc_clk =
  43. (struct stm32_rcc_clk *)dev_get_driver_data(dev);
  44. int ret;
  45. dev_dbg(dev, "RCC bind\n");
  46. drv = lists_driver_lookup_name(rcc_clk->drv_name);
  47. if (!drv) {
  48. dev_err(dev, "Cannot find driver '%s'\n", rcc_clk->drv_name);
  49. return -ENOENT;
  50. }
  51. ret = device_bind_with_driver_data(dev, drv, dev->name,
  52. rcc_clk->soc,
  53. dev_ofnode(dev), &child);
  54. if (ret)
  55. return ret;
  56. drv = lists_driver_lookup_name("stm32_rcc_reset");
  57. if (!drv) {
  58. dev_err(dev, "Cannot find driver stm32_rcc_reset'\n");
  59. return -ENOENT;
  60. }
  61. return device_bind_with_driver_data(dev, drv, dev->name,
  62. rcc_clk->soc,
  63. dev_ofnode(dev), &child);
  64. }
  65. static const struct udevice_id stm32_rcc_ids[] = {
  66. {.compatible = "st,stm32f42xx-rcc", .data = (ulong)&stm32_rcc_clk_f42x },
  67. {.compatible = "st,stm32f469-rcc", .data = (ulong)&stm32_rcc_clk_f469 },
  68. {.compatible = "st,stm32f746-rcc", .data = (ulong)&stm32_rcc_clk_f7 },
  69. {.compatible = "st,stm32h743-rcc", .data = (ulong)&stm32_rcc_clk_h7 },
  70. {.compatible = "st,stm32mp1-rcc", .data = (ulong)&stm32_rcc_clk_mp1 },
  71. {.compatible = "st,stm32mp1-rcc-secure", .data = (ulong)&stm32_rcc_clk_mp1 },
  72. {.compatible = "st,stm32mp13-rcc", .data = (ulong)&stm32_rcc_clk_mp13 },
  73. { }
  74. };
  75. U_BOOT_DRIVER(stm32_rcc) = {
  76. .name = "stm32-rcc",
  77. .id = UCLASS_NOP,
  78. .of_match = stm32_rcc_ids,
  79. .bind = stm32_rcc_bind,
  80. };