clk.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*
  2. * (C) Copyright 2010 Samsung Electronics
  3. * Minkyu Kang <mk7.kang@samsung.com>
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation; either version 2 of
  8. * the License, or (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  18. * MA 02111-1307 USA
  19. *
  20. */
  21. #ifndef __ASM_ARM_ARCH_CLK_H_
  22. #define __ASM_ARM_ARCH_CLK_H_
  23. #define APLL 0
  24. #define MPLL 1
  25. #define EPLL 2
  26. #define HPLL 3
  27. #define VPLL 4
  28. #define BPLL 5
  29. enum pll_src_bit {
  30. EXYNOS_SRC_MPLL = 6,
  31. EXYNOS_SRC_EPLL,
  32. EXYNOS_SRC_VPLL,
  33. };
  34. unsigned long get_pll_clk(int pllreg);
  35. unsigned long get_arm_clk(void);
  36. unsigned long get_i2c_clk(void);
  37. unsigned long get_pwm_clk(void);
  38. unsigned long get_uart_clk(int dev_index);
  39. unsigned long get_mmc_clk(int dev_index);
  40. void set_mmc_clk(int dev_index, unsigned int div);
  41. unsigned long get_lcd_clk(void);
  42. void set_lcd_clk(void);
  43. void set_mipi_clk(void);
  44. void set_i2s_clk_source(void);
  45. int set_i2s_clk_prescaler(unsigned int src_frq, unsigned int dst_frq);
  46. int set_epll_clk(unsigned long rate);
  47. int set_spi_clk(int periph_id, unsigned int rate);
  48. /**
  49. * get the clk frequency of the required peripheral
  50. *
  51. * @param peripheral Peripheral id
  52. *
  53. * @return frequency of the peripheral clk
  54. */
  55. unsigned long clock_get_periph_rate(int peripheral);
  56. #endif