clk.h 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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. #define MASK_PRE_RATIO(x) (0xff << ((x << 4) + 8))
  17. #define MASK_RATIO(x) (0xf << (x << 4))
  18. #define SET_PRE_RATIO(x, y) ((y & 0xff) << ((x << 4) + 8))
  19. #define SET_RATIO(x, y) ((y & 0xf) << (x << 4))
  20. enum pll_src_bit {
  21. EXYNOS_SRC_MPLL = 6,
  22. EXYNOS_SRC_EPLL,
  23. EXYNOS_SRC_VPLL,
  24. };
  25. unsigned long get_pll_clk(int pllreg);
  26. unsigned long get_arm_clk(void);
  27. unsigned long get_i2c_clk(void);
  28. unsigned long get_pwm_clk(void);
  29. unsigned long get_uart_clk(int dev_index);
  30. unsigned long get_mmc_clk(int dev_index);
  31. void set_mmc_clk(int dev_index, unsigned int div);
  32. unsigned long get_lcd_clk(void);
  33. void set_lcd_clk(void);
  34. void set_mipi_clk(void);
  35. int set_i2s_clk_source(unsigned int i2s_id);
  36. int set_i2s_clk_prescaler(unsigned int src_frq, unsigned int dst_frq,
  37. unsigned int i2s_id);
  38. int set_epll_clk(unsigned long rate);
  39. int set_spi_clk(int periph_id, unsigned int rate);
  40. /**
  41. * get the clk frequency of the required peripheral
  42. *
  43. * @param peripheral Peripheral id
  44. *
  45. * @return frequency of the peripheral clk
  46. */
  47. unsigned long clock_get_periph_rate(int peripheral);
  48. #endif