regs-clock.h
上传用户:szlgq88
上传日期:2009-04-28
资源大小:48287k
文件大小:5k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /* linux/include/asm/arch-s3c2410/regs-clock.h
  2.  *
  3.  * Copyright (c) 2003,2004,2005 Simtec Electronics <linux@simtec.co.uk>
  4.  *       http://armlinux.simtec.co.uk/
  5.  *
  6.  * This program is free software; you can redistribute it and/or modify
  7.  * it under the terms of the GNU General Public License version 2 as
  8.  * published by the Free Software Foundation.
  9.  *
  10.  * S3C2410 clock register definitions
  11.  *
  12.  *  Changelog:
  13.  *    18-Aug-2004 Ben Dooks         Added 2440 definitions
  14.  *    08-Aug-2004 Herbert P鰐zl     Added CLKCON definitions
  15.  *    19-06-2003  Ben Dooks         Created file
  16.  *    12-03-2004  Ben Dooks         Updated include protection
  17.  *    29-Sep-2004 Ben Dooks     Fixed usage for assembly inclusion
  18.  *    10-Feb-2005 Ben Dooks     Fixed CAMDIVN address (Guillaume Gourat)
  19.  *    10-Mar-2005 Lucas Villa Real  Changed S3C2410_VA to S3C24XX_VA
  20.  *    27-Aug-2005 Ben Dooks     Add clock-slow info
  21.  *    20-Oct-2005 Ben Dooks     Fixed overflow in PLL (Guillaume Gourat)
  22.  *    20-Oct-2005 Ben Dooks     Add masks for DCLK (Guillaume Gourat)
  23. */
  24. #ifndef __ASM_ARM_REGS_CLOCK
  25. #define __ASM_ARM_REGS_CLOCK "$Id: clock.h,v 1.4 2003/04/30 14:50:51 ben Exp $"
  26. #define S3C2410_CLKREG(x) ((x) + S3C24XX_VA_CLKPWR)
  27. #define S3C2410_PLLVAL(_m,_p,_s) ((_m) << 12 | ((_p) << 4) | ((_s)))
  28. #define S3C2410_LOCKTIME    S3C2410_CLKREG(0x00)
  29. #define S3C2410_MPLLCON     S3C2410_CLKREG(0x04)
  30. #define S3C2410_UPLLCON     S3C2410_CLKREG(0x08)
  31. #define S3C2410_CLKCON     S3C2410_CLKREG(0x0C)
  32. #define S3C2410_CLKSLOW     S3C2410_CLKREG(0x10)
  33. #define S3C2410_CLKDIVN     S3C2410_CLKREG(0x14)
  34. #define S3C2410_CLKCON_IDLE      (1<<2)
  35. #define S3C2410_CLKCON_POWER      (1<<3)
  36. #define S3C2410_CLKCON_NAND      (1<<4)
  37. #define S3C2410_CLKCON_LCDC      (1<<5)
  38. #define S3C2410_CLKCON_USBH      (1<<6)
  39. #define S3C2410_CLKCON_USBD      (1<<7)
  40. #define S3C2410_CLKCON_PWMT      (1<<8)
  41. #define S3C2410_CLKCON_SDI      (1<<9)
  42. #define S3C2410_CLKCON_UART0      (1<<10)
  43. #define S3C2410_CLKCON_UART1      (1<<11)
  44. #define S3C2410_CLKCON_UART2      (1<<12)
  45. #define S3C2410_CLKCON_GPIO      (1<<13)
  46. #define S3C2410_CLKCON_RTC      (1<<14)
  47. #define S3C2410_CLKCON_ADC      (1<<15)
  48. #define S3C2410_CLKCON_IIC      (1<<16)
  49. #define S3C2410_CLKCON_IIS      (1<<17)
  50. #define S3C2410_CLKCON_SPI      (1<<18)
  51. #define S3C2410_PLLCON_MDIVSHIFT     12
  52. #define S3C2410_PLLCON_PDIVSHIFT     4
  53. #define S3C2410_PLLCON_SDIVSHIFT     0
  54. #define S3C2410_PLLCON_MDIVMASK      ((1<<(1+(19-12)))-1)
  55. #define S3C2410_PLLCON_PDIVMASK      ((1<<5)-1)
  56. #define S3C2410_PLLCON_SDIVMASK      3
  57. /* DCLKCON register addresses in gpio.h */
  58. #define S3C2410_DCLKCON_DCLK0EN      (1<<0)
  59. #define S3C2410_DCLKCON_DCLK0_PCLK   (0<<1)
  60. #define S3C2410_DCLKCON_DCLK0_UCLK   (1<<1)
  61. #define S3C2410_DCLKCON_DCLK0_DIV(x) (((x) - 1 )<<4)
  62. #define S3C2410_DCLKCON_DCLK0_CMP(x) (((x) - 1 )<<8)
  63. #define S3C2410_DCLKCON_DCLK0_DIV_MASK ((0xf)<<4)
  64. #define S3C2410_DCLKCON_DCLK0_CMP_MASK ((0xf)<<8)
  65. #define S3C2410_DCLKCON_DCLK1EN      (1<<16)
  66. #define S3C2410_DCLKCON_DCLK1_PCLK   (0<<17)
  67. #define S3C2410_DCLKCON_DCLK1_UCLK   (1<<17)
  68. #define S3C2410_DCLKCON_DCLK1_DIV(x) (((x) - 1) <<20)
  69. #define S3C2410_DCLKCON_DCLK1_CMP(x) (((x) - 1) <<24)
  70. #define S3C2410_DCLKCON_DCLK1_DIV_MASK ((0xf) <<20)
  71. #define S3C2410_DCLKCON_DCLK1_CMP_MASK ((0xf) <<24)
  72. #define S3C2410_CLKDIVN_PDIVN      (1<<0)
  73. #define S3C2410_CLKDIVN_HDIVN      (1<<1)
  74. #define S3C2410_CLKSLOW_UCLK_OFF (1<<7)
  75. #define S3C2410_CLKSLOW_MPLL_OFF (1<<5)
  76. #define S3C2410_CLKSLOW_SLOW (1<<4)
  77. #define S3C2410_CLKSLOW_SLOWVAL(x) (x)
  78. #define S3C2410_CLKSLOW_GET_SLOWVAL(x) ((x) & 7)
  79. #ifndef __ASSEMBLY__
  80. #include <asm/div64.h>
  81. static inline unsigned int
  82. s3c2410_get_pll(unsigned int pllval, unsigned int baseclk)
  83. {
  84. unsigned int mdiv, pdiv, sdiv;
  85. uint64_t fvco;
  86. mdiv = pllval >> S3C2410_PLLCON_MDIVSHIFT;
  87. pdiv = pllval >> S3C2410_PLLCON_PDIVSHIFT;
  88. sdiv = pllval >> S3C2410_PLLCON_SDIVSHIFT;
  89. mdiv &= S3C2410_PLLCON_MDIVMASK;
  90. pdiv &= S3C2410_PLLCON_PDIVMASK;
  91. sdiv &= S3C2410_PLLCON_SDIVMASK;
  92. fvco = (uint64_t)baseclk * (mdiv + 8);
  93. do_div(fvco, (pdiv + 2) << sdiv);
  94. return (unsigned int)fvco;
  95. }
  96. #endif /* __ASSEMBLY__ */
  97. #ifdef CONFIG_CPU_S3C2440
  98. /* extra registers */
  99. #define S3C2440_CAMDIVN     S3C2410_CLKREG(0x18)
  100. #define S3C2440_CLKCON_CAMERA        (1<<19)
  101. #define S3C2440_CLKCON_AC97          (1<<20)
  102. #define S3C2440_CLKDIVN_PDIVN      (1<<0)
  103. #define S3C2440_CLKDIVN_HDIVN_MASK   (3<<1)
  104. #define S3C2440_CLKDIVN_HDIVN_1      (0<<1)
  105. #define S3C2440_CLKDIVN_HDIVN_2      (1<<1)
  106. #define S3C2440_CLKDIVN_HDIVN_4_8    (2<<1)
  107. #define S3C2440_CLKDIVN_HDIVN_3_6    (3<<1)
  108. #define S3C2440_CLKDIVN_UCLK         (1<<3)
  109. #define S3C2440_CAMDIVN_CAMCLK_MASK  (0xf<<0)
  110. #define S3C2440_CAMDIVN_CAMCLK_SEL   (1<<4)
  111. #define S3C2440_CAMDIVN_HCLK3_HALF   (1<<8)
  112. #define S3C2440_CAMDIVN_HCLK4_HALF   (1<<9)
  113. #define S3C2440_CAMDIVN_DVSEN        (1<<12)
  114. #endif /* CONFIG_CPU_S3C2440 */
  115. #endif /* __ASM_ARM_REGS_CLOCK */