clock.h 912 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (C) 2016 Freescale Semiconductor, Inc.
  4. */
  5. #ifndef _ASM_ARCH_CLOCK_H
  6. #define _ASM_ARCH_CLOCK_H
  7. #include <common.h>
  8. #include <asm/arch/pcc.h>
  9. #include <asm/arch/scg.h>
  10. /* Mainly for compatible to imx common code. */
  11. enum mxc_clock {
  12. MXC_ARM_CLK = 0,
  13. MXC_AHB_CLK,
  14. MXC_IPG_CLK,
  15. MXC_UART_CLK,
  16. MXC_CSPI_CLK,
  17. MXC_AXI_CLK,
  18. MXC_DDR_CLK,
  19. MXC_ESDHC_CLK,
  20. MXC_ESDHC2_CLK,
  21. MXC_I2C_CLK,
  22. };
  23. u32 mxc_get_clock(enum mxc_clock clk);
  24. u32 get_lpuart_clk(void);
  25. #ifdef CONFIG_SYS_LPI2C_IMX
  26. int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
  27. u32 imx_get_i2cclk(unsigned i2c_num);
  28. #endif
  29. #ifdef CONFIG_MXC_OCOTP
  30. void enable_ocotp_clk(unsigned char enable);
  31. #endif
  32. #ifdef CONFIG_USB_EHCI_HCD
  33. void enable_usboh3_clk(unsigned char enable);
  34. #endif
  35. void init_clk_usdhc(u32 index);
  36. void clock_init(void);
  37. void hab_caam_clock_enable(unsigned char enable);
  38. #endif