clk.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /*
  2. * (C) Copyright 2010 Samsung Electronics
  3. * Minkyu Kang <mk7.kang@samsung.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __ASM_ARM_ARCH_CLK_H_
  8. #define __ASM_ARM_ARCH_CLK_H_
  9. #define APLL 0
  10. #define MPLL 1
  11. #define EPLL 2
  12. #define HPLL 3
  13. #define VPLL 4
  14. #define BPLL 5
  15. #define RPLL 6
  16. enum pll_src_bit {
  17. EXYNOS_SRC_MPLL = 6,
  18. EXYNOS_SRC_EPLL,
  19. EXYNOS_SRC_VPLL,
  20. };
  21. unsigned long get_pll_clk(int pllreg);
  22. unsigned long get_arm_clk(void);
  23. unsigned long get_i2c_clk(void);
  24. unsigned long get_pwm_clk(void);
  25. unsigned long get_uart_clk(int dev_index);
  26. unsigned long get_mmc_clk(int dev_index);
  27. void set_mmc_clk(int dev_index, unsigned int div);
  28. unsigned long get_lcd_clk(void);
  29. void set_lcd_clk(void);
  30. void set_mipi_clk(void);
  31. int set_i2s_clk_source(unsigned int i2s_id);
  32. int set_i2s_clk_prescaler(unsigned int src_frq, unsigned int dst_frq,
  33. unsigned int i2s_id);
  34. int set_epll_clk(unsigned long rate);
  35. int set_spi_clk(int periph_id, unsigned int rate);
  36. /**
  37. * get the clk frequency of the required peripheral
  38. *
  39. * @param peripheral Peripheral id
  40. *
  41. * @return frequency of the peripheral clk
  42. */
  43. unsigned long clock_get_periph_rate(int peripheral);
  44. #endif