clk-fixed-rate.c 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2022-11-26 GuEe-GUI first version
  9. * 2024-05-01 GuEe-GUI update for new clk
  10. */
  11. #include <rtthread.h>
  12. #include <rtdevice.h>
  13. struct clk_fixed
  14. {
  15. struct rt_clk_node parent;
  16. struct rt_clk_fixed_rate fcell;
  17. struct rt_clk_cell *cells[1];
  18. };
  19. static rt_ubase_t fixed_clk_recalc_rate(struct rt_clk_cell *cell, rt_ubase_t parent_rate)
  20. {
  21. struct rt_clk_fixed_rate *fr = rt_container_of(cell, struct rt_clk_fixed_rate, cell);
  22. return fr->fixed_rate;
  23. }
  24. static struct rt_clk_ops fixed_clk_ops =
  25. {
  26. .recalc_rate = fixed_clk_recalc_rate,
  27. };
  28. static rt_err_t fixed_clk_probe(struct rt_platform_device *pdev)
  29. {
  30. rt_err_t err;
  31. rt_uint32_t val;
  32. struct rt_device *dev = &pdev->parent;
  33. struct clk_fixed *cf = rt_calloc(1, sizeof(*cf));
  34. if (!cf)
  35. {
  36. return -RT_ENOMEM;
  37. }
  38. if ((err = rt_dm_dev_prop_read_u32(dev, "clock-frequency", &val)))
  39. {
  40. goto _fail;
  41. }
  42. cf->fcell.fixed_rate = val;
  43. val = 0;
  44. rt_dm_dev_prop_read_u32(dev, "clock-accuracy", &val);
  45. cf->fcell.fixed_accuracy = val;
  46. rt_dm_dev_prop_read_string(dev, "clock-output-names", &cf->fcell.cell.name);
  47. cf->parent.dev = dev;
  48. cf->parent.cells_nr = 1;
  49. cf->parent.cells = cf->cells;
  50. cf->cells[0] = &cf->fcell.cell;
  51. cf->fcell.cell.ops = &fixed_clk_ops;
  52. if ((err = rt_clk_register(&cf->parent)))
  53. {
  54. goto _fail;
  55. }
  56. return RT_EOK;
  57. _fail:
  58. rt_free(cf);
  59. return err;
  60. }
  61. static const struct rt_ofw_node_id fixed_clk_ofw_ids[] =
  62. {
  63. { .compatible = "fixed-clock" },
  64. { /* sentinel */ }
  65. };
  66. static struct rt_platform_driver fixed_clk_driver =
  67. {
  68. .name = "clk-fixed-rate",
  69. .ids = fixed_clk_ofw_ids,
  70. .probe = fixed_clk_probe,
  71. };
  72. static int fixed_clk_drv_register(void)
  73. {
  74. rt_platform_driver_register(&fixed_clk_driver);
  75. return 0;
  76. }
  77. INIT_SUBSYS_EXPORT(fixed_clk_drv_register);