clk-rk-cpu.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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-3-08 GuEe-GUI the first version
  9. */
  10. #ifndef __CLK_RK_CPU_H__
  11. #define __CLK_RK_CPU_H__
  12. #include "clk-rk.h"
  13. #define ROCKCHIP_CPUCLK_NUM_DIVIDERS 6
  14. #define ROCKCHIP_CPUCLK_MAX_CORES 4
  15. struct rockchip_cpu_clk_clksel
  16. {
  17. int reg;
  18. rt_uint32_t val;
  19. };
  20. struct rockchip_cpu_clk_rate_table
  21. {
  22. rt_ubase_t prate;
  23. struct rockchip_cpu_clk_clksel divs[ROCKCHIP_CPUCLK_NUM_DIVIDERS];
  24. struct rockchip_cpu_clk_clksel pre_muxs[ROCKCHIP_CPUCLK_NUM_DIVIDERS];
  25. struct rockchip_cpu_clk_clksel post_muxs[ROCKCHIP_CPUCLK_NUM_DIVIDERS];
  26. };
  27. struct rockchip_cpu_clk_reg_data
  28. {
  29. int core_reg[ROCKCHIP_CPUCLK_MAX_CORES];
  30. rt_uint8_t div_core_shift[ROCKCHIP_CPUCLK_MAX_CORES];
  31. rt_uint32_t div_core_mask[ROCKCHIP_CPUCLK_MAX_CORES];
  32. int num_cores;
  33. int mux_core_reg;
  34. rt_uint8_t mux_core_alt;
  35. rt_uint8_t mux_core_main;
  36. rt_uint8_t mux_core_shift;
  37. rt_uint32_t mux_core_mask;
  38. const char *pll_name;
  39. };
  40. struct rockchip_cpu_clk_cell
  41. {
  42. struct rockchip_clk_cell rk_cell;
  43. struct rockchip_clk_cell *rk_cell_parent, *rk_cell_alt_parent;
  44. int rate_count;
  45. const struct rockchip_cpu_clk_rate_table *rate_table;
  46. const struct rockchip_cpu_clk_reg_data *reg_data;
  47. struct rt_clk_notifier notifier;
  48. };
  49. #define CPU(_id, cname, parent, alt_parent, _rates, _nrates, _reg_data) \
  50. (void *)&(struct rockchip_cpu_clk_cell) \
  51. { \
  52. .rk_cell.cell.name = cname, \
  53. .rk_cell.cell.ops = &rockchip_cpu_clk_ops, \
  54. .rk_cell.cell.flags = RT_CLK_F_GET_RATE_NOCACHE, \
  55. .rk_cell.id = _id, \
  56. .rk_cell.init = rockchip_cpu_clk_cell_init, \
  57. .rk_cell.setup = rockchip_cpu_clk_cell_setup, \
  58. .rk_cell_parent = parent, \
  59. .rk_cell_alt_parent = alt_parent, \
  60. .rate_count = _nrates, \
  61. .rate_table = _rates, \
  62. .reg_data = _reg_data, \
  63. }
  64. extern const struct rt_clk_ops rockchip_cpu_clk_ops;
  65. rt_inline struct rockchip_cpu_clk_cell *cell_to_rockchip_cpu_cell(struct rt_clk_cell *cell)
  66. {
  67. struct rockchip_clk_cell *rk_cell = cell_to_rockchip_clk_cell(cell);
  68. return rt_container_of(rk_cell, struct rockchip_cpu_clk_cell, rk_cell);
  69. }
  70. void rockchip_cpu_clk_cell_init(struct rockchip_clk_cell *rk_cell);
  71. void rockchip_cpu_clk_cell_setup(struct rockchip_clk_cell *rk_cell);
  72. #endif /* __CLK_RK_cpu_H__ */