clock.h 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. * (C) Copyright 2009
  3. * Stefano Babic, DENX Software Engineering, sbabic@denx.de.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __ASM_ARCH_CLOCK_H
  8. #define __ASM_ARCH_CLOCK_H
  9. #include <common.h>
  10. #ifdef CONFIG_SYS_MX6_HCLK
  11. #define MXC_HCLK CONFIG_SYS_MX6_HCLK
  12. #else
  13. #define MXC_HCLK 24000000
  14. #endif
  15. #ifdef CONFIG_SYS_MX6_CLK32
  16. #define MXC_CLK32 CONFIG_SYS_MX6_CLK32
  17. #else
  18. #define MXC_CLK32 32768
  19. #endif
  20. enum mxc_clock {
  21. MXC_ARM_CLK = 0,
  22. MXC_PER_CLK,
  23. MXC_AHB_CLK,
  24. MXC_IPG_CLK,
  25. MXC_IPG_PERCLK,
  26. MXC_UART_CLK,
  27. MXC_CSPI_CLK,
  28. MXC_AXI_CLK,
  29. MXC_EMI_SLOW_CLK,
  30. MXC_DDR_CLK,
  31. MXC_ESDHC_CLK,
  32. MXC_ESDHC2_CLK,
  33. MXC_ESDHC3_CLK,
  34. MXC_ESDHC4_CLK,
  35. MXC_SATA_CLK,
  36. MXC_NFC_CLK,
  37. MXC_I2C_CLK,
  38. };
  39. u32 imx_get_uartclk(void);
  40. u32 imx_get_fecclk(void);
  41. unsigned int mxc_get_clock(enum mxc_clock clk);
  42. void enable_ocotp_clk(unsigned char enable);
  43. void enable_usboh3_clk(unsigned char enable);
  44. int enable_sata_clock(void);
  45. int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
  46. void enable_ipu_clock(void);
  47. int enable_fec_anatop_clock(void);
  48. #endif /* __ASM_ARCH_CLOCK_H */