clock.h 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. *
  3. * (c) 2009 Ilya Yanok, Emcraft Systems <yanok@emcraft.com>
  4. *
  5. * Modified for mx25 by John Rigby <jrigby@gmail.com>
  6. *
  7. * See file CREDITS for list of people who contributed to this
  8. * project.
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public License as
  12. * published by the Free Software Foundation; either version 2 of
  13. * the License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with this program; if not, write to the Free Software
  22. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  23. * MA 02111-1307 USA
  24. */
  25. #ifndef __ASM_ARCH_CLOCK_H
  26. #define __ASM_ARCH_CLOCK_H
  27. #include <common.h>
  28. #ifdef CONFIG_MX25_HCLK_FREQ
  29. #define MXC_HCLK CONFIG_MX25_HCLK_FREQ
  30. #else
  31. #define MXC_HCLK 24000000
  32. #endif
  33. #ifdef CONFIG_MX25_CLK32
  34. #define MXC_CLK32 CONFIG_MX25_CLK32
  35. #else
  36. #define MXC_CLK32 32768
  37. #endif
  38. enum mxc_clock {
  39. /* PER clocks (do not change order) */
  40. MXC_CSI_CLK,
  41. MXC_EPIT_CLK,
  42. MXC_ESAI_CLK,
  43. MXC_ESDHC1_CLK,
  44. MXC_ESDHC2_CLK,
  45. MXC_GPT_CLK,
  46. MXC_I2C_CLK,
  47. MXC_LCDC_CLK,
  48. MXC_NFC_CLK,
  49. MXC_OWIRE_CLK,
  50. MXC_PWM_CLK,
  51. MXC_SIM1_CLK,
  52. MXC_SIM2_CLK,
  53. MXC_SSI1_CLK,
  54. MXC_SSI2_CLK,
  55. MXC_UART_CLK,
  56. /* Other clocks */
  57. MXC_ARM_CLK,
  58. MXC_AHB_CLK,
  59. MXC_IPG_CLK,
  60. MXC_CSPI_CLK,
  61. MXC_FEC_CLK,
  62. MXC_CLK_NUM
  63. };
  64. unsigned int mxc_get_clock(enum mxc_clock clk);
  65. #define imx_get_uartclk() mxc_get_clock(MXC_UART_CLK)
  66. #define imx_get_fecclk() mxc_get_clock(MXC_FEC_CLK)
  67. #endif /* __ASM_ARCH_CLOCK_H */