clock.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. MXC_CSI_CLK,
  40. MXC_EPIT_CLK,
  41. MXC_ESAI_CLK,
  42. MXC_ESDHC1_CLK,
  43. MXC_ESDHC2_CLK,
  44. MXC_GPT_CLK,
  45. MXC_I2C_CLK,
  46. MXC_LCDC_CLK,
  47. MXC_NFC_CLK,
  48. MXC_OWIRE_CLK,
  49. MXC_PWM_CLK,
  50. MXC_SIM1_CLK,
  51. MXC_SIM2_CLK,
  52. MXC_SSI1_CLK,
  53. MXC_SSI2_CLK,
  54. MXC_UART_CLK,
  55. MXC_ARM_CLK,
  56. MXC_FEC_CLK,
  57. MXC_CLK_NUM
  58. };
  59. ulong imx_get_perclk(int clk);
  60. ulong imx_get_ahbclk(void);
  61. #define imx_get_uartclk() imx_get_perclk(15)
  62. #define imx_get_fecclk() (imx_get_ahbclk()/2)
  63. unsigned int mxc_get_clock(enum mxc_clock clk);
  64. #endif /* __ASM_ARCH_CLOCK_H */