pm.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * Register definitions for the Power Manager (PM)
  3. */
  4. #ifndef __ARCH_AVR32_MACH_AT32AP_PM_H__
  5. #define __ARCH_AVR32_MACH_AT32AP_PM_H__
  6. /*
  7. * We can reduce the code size a bit by using a constant here. Since
  8. * this file is only used on AVR32 AP CPUs with segmentation enabled,
  9. * it's safe to not use ioremap. Generic drivers should of course
  10. * never do this.
  11. */
  12. #define AT32_PM_BASE 0xfff00000
  13. /* PM register offsets */
  14. #define PM_MCCTRL 0x0000
  15. #define PM_CKSEL 0x0004
  16. #define PM_CPU_MASK 0x0008
  17. #define PM_HSB_MASK 0x000c
  18. #define PM_PBA_MASK 0x0010
  19. #define PM_PBB_MASK 0x0014
  20. #define PM_PLL0 0x0020
  21. #define PM_PLL1 0x0024
  22. #define PM_IER 0x0040
  23. #define PM_IDR 0x0044
  24. #define PM_IMR 0x0048
  25. #define PM_ISR 0x004c
  26. #define PM_ICR 0x0050
  27. #define PM_GCCTRL(x) (0x0060 + 4 * (x))
  28. #define PM_RCAUSE 0x00c0
  29. /* Bitfields in CKSEL */
  30. #define PM_CPUSEL_OFFSET 0
  31. #define PM_CPUSEL_SIZE 3
  32. #define PM_CPUDIV_OFFSET 7
  33. #define PM_CPUDIV_SIZE 1
  34. #define PM_HSBSEL_OFFSET 8
  35. #define PM_HSBSEL_SIZE 3
  36. #define PM_HSBDIV_OFFSET 15
  37. #define PM_HSBDIV_SIZE 1
  38. #define PM_PBASEL_OFFSET 16
  39. #define PM_PBASEL_SIZE 3
  40. #define PM_PBADIV_OFFSET 23
  41. #define PM_PBADIV_SIZE 1
  42. #define PM_PBBSEL_OFFSET 24
  43. #define PM_PBBSEL_SIZE 3
  44. #define PM_PBBDIV_OFFSET 31
  45. #define PM_PBBDIV_SIZE 1
  46. /* Bitfields in PLL0 */
  47. #define PM_PLLEN_OFFSET 0
  48. #define PM_PLLEN_SIZE 1
  49. #define PM_PLLOSC_OFFSET 1
  50. #define PM_PLLOSC_SIZE 1
  51. #define PM_PLLOPT_OFFSET 2
  52. #define PM_PLLOPT_SIZE 3
  53. #define PM_PLLDIV_OFFSET 8
  54. #define PM_PLLDIV_SIZE 8
  55. #define PM_PLLMUL_OFFSET 16
  56. #define PM_PLLMUL_SIZE 8
  57. #define PM_PLLCOUNT_OFFSET 24
  58. #define PM_PLLCOUNT_SIZE 6
  59. #define PM_PLLTEST_OFFSET 31
  60. #define PM_PLLTEST_SIZE 1
  61. /* Bitfields in ICR */
  62. #define PM_LOCK0_OFFSET 0
  63. #define PM_LOCK0_SIZE 1
  64. #define PM_LOCK1_OFFSET 1
  65. #define PM_LOCK1_SIZE 1
  66. #define PM_WAKE_OFFSET 2
  67. #define PM_WAKE_SIZE 1
  68. #define PM_CKRDY_OFFSET 5
  69. #define PM_CKRDY_SIZE 1
  70. #define PM_MSKRDY_OFFSET 6
  71. #define PM_MSKRDY_SIZE 1
  72. /* Bitfields in GCCTRL0 */
  73. #define PM_OSCSEL_OFFSET 0
  74. #define PM_OSCSEL_SIZE 1
  75. #define PM_PLLSEL_OFFSET 1
  76. #define PM_PLLSEL_SIZE 1
  77. #define PM_CEN_OFFSET 2
  78. #define PM_CEN_SIZE 1
  79. #define PM_DIVEN_OFFSET 4
  80. #define PM_DIVEN_SIZE 1
  81. #define PM_DIV_OFFSET 8
  82. #define PM_DIV_SIZE 8
  83. /* Bitfields in RCAUSE */
  84. #define PM_POR_OFFSET 0
  85. #define PM_POR_SIZE 1
  86. #define PM_EXT_OFFSET 2
  87. #define PM_EXT_SIZE 1
  88. #define PM_WDT_OFFSET 3
  89. #define PM_WDT_SIZE 1
  90. #define PM_NTAE_OFFSET 4
  91. #define PM_NTAE_SIZE 1
  92. /* Bit manipulation macros */
  93. #define PM_BIT(name) \
  94. (1 << PM_##name##_OFFSET)
  95. #define PM_BF(name,value) \
  96. (((value) & ((1 << PM_##name##_SIZE) - 1)) \
  97. << PM_##name##_OFFSET)
  98. #define PM_BFEXT(name,value) \
  99. (((value) >> PM_##name##_OFFSET) \
  100. & ((1 << PM_##name##_SIZE) - 1))
  101. #define PM_BFINS(name,value,old)\
  102. (((old) & ~(((1 << PM_##name##_SIZE) - 1) \
  103. << PM_##name##_OFFSET)) \
  104. | PM_BF(name,value))
  105. /* Register access macros */
  106. #define pm_readl(reg) \
  107. __raw_readl((void __iomem *)AT32_PM_BASE + PM_##reg)
  108. #define pm_writel(reg,value) \
  109. __raw_writel((value), (void __iomem *)AT32_PM_BASE + PM_##reg)
  110. #endif /* __ARCH_AVR32_MACH_AT32AP_PM_H__ */