clock.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * (C) Copyright 2009
  4. * Stefano Babic, DENX Software Engineering, sbabic@denx.de.
  5. */
  6. #ifndef __ASM_ARCH_CLOCK_H
  7. #define __ASM_ARCH_CLOCK_H
  8. #include <common.h>
  9. #ifdef CONFIG_SYS_MX6_HCLK
  10. #define MXC_HCLK CONFIG_SYS_MX6_HCLK
  11. #else
  12. #define MXC_HCLK 24000000
  13. #endif
  14. #ifdef CONFIG_SYS_MX6_CLK32
  15. #define MXC_CLK32 CONFIG_SYS_MX6_CLK32
  16. #else
  17. #define MXC_CLK32 32768
  18. #endif
  19. enum mxc_clock {
  20. MXC_ARM_CLK = 0,
  21. MXC_PER_CLK,
  22. MXC_AHB_CLK,
  23. MXC_IPG_CLK,
  24. MXC_IPG_PERCLK,
  25. MXC_UART_CLK,
  26. MXC_CSPI_CLK,
  27. MXC_AXI_CLK,
  28. MXC_EMI_SLOW_CLK,
  29. MXC_DDR_CLK,
  30. MXC_ESDHC_CLK,
  31. MXC_ESDHC2_CLK,
  32. MXC_ESDHC3_CLK,
  33. MXC_ESDHC4_CLK,
  34. MXC_SATA_CLK,
  35. MXC_NFC_CLK,
  36. MXC_I2C_CLK,
  37. };
  38. enum ldb_di_clock {
  39. MXC_PLL5_CLK = 0,
  40. MXC_PLL2_PFD0_CLK,
  41. MXC_PLL2_PFD2_CLK,
  42. MXC_MMDC_CH1_CLK,
  43. MXC_PLL3_SW_CLK,
  44. };
  45. enum enet_freq {
  46. ENET_25MHZ,
  47. ENET_50MHZ,
  48. ENET_100MHZ,
  49. ENET_125MHZ,
  50. };
  51. u32 imx_get_uartclk(void);
  52. u32 imx_get_fecclk(void);
  53. unsigned int mxc_get_clock(enum mxc_clock clk);
  54. void setup_gpmi_io_clk(u32 cfg);
  55. void hab_caam_clock_enable(unsigned char enable);
  56. void enable_ocotp_clk(unsigned char enable);
  57. void enable_usboh3_clk(unsigned char enable);
  58. void enable_uart_clk(unsigned char enable);
  59. int enable_usdhc_clk(unsigned char enable, unsigned bus_num);
  60. int enable_sata_clock(void);
  61. void disable_sata_clock(void);
  62. int enable_pcie_clock(void);
  63. int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
  64. int enable_spi_clk(unsigned char enable, unsigned spi_num);
  65. void enable_ipu_clock(void);
  66. int enable_fec_anatop_clock(int fec_id, enum enet_freq freq);
  67. void enable_enet_clk(unsigned char enable);
  68. int enable_lcdif_clock(u32 base_addr, bool enable);
  69. void enable_qspi_clk(int qspi_num);
  70. void enable_thermal_clk(void);
  71. void mxs_set_lcdclk(u32 base_addr, u32 freq);
  72. void select_ldb_di_clock_source(enum ldb_di_clock clk);
  73. void enable_eim_clk(unsigned char enable);
  74. int do_mx6_showclocks(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
  75. #endif /* __ASM_ARCH_CLOCK_H */