stmp37xx.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. /*
  2. * Freescale STMP37XX platform support
  3. *
  4. * Embedded Alley Solutions, Inc <source@embeddedalley.com>
  5. *
  6. * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved.
  7. * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved.
  8. */
  9. /*
  10. * The code contained herein is licensed under the GNU General Public
  11. * License. You may obtain a copy of the GNU General Public License
  12. * Version 2 or later at the following locations:
  13. *
  14. * http://www.opensource.org/licenses/gpl-license.html
  15. * http://www.gnu.org/copyleft/gpl.html
  16. */
  17. #include <linux/types.h>
  18. #include <linux/kernel.h>
  19. #include <linux/init.h>
  20. #include <linux/device.h>
  21. #include <linux/platform_device.h>
  22. #include <linux/irq.h>
  23. #include <linux/io.h>
  24. #include <asm/setup.h>
  25. #include <asm/mach-types.h>
  26. #include <asm/mach/arch.h>
  27. #include <asm/mach/irq.h>
  28. #include <asm/mach/map.h>
  29. #include <asm/mach/time.h>
  30. #include <mach/stmp3xxx.h>
  31. #include <mach/dma.h>
  32. #include <mach/platform.h>
  33. #include <mach/regs-icoll.h>
  34. #include <mach/regs-apbh.h>
  35. #include <mach/regs-apbx.h>
  36. #include "stmp37xx.h"
  37. /*
  38. * IRQ handling
  39. */
  40. static void stmp37xx_ack_irq(unsigned int irq)
  41. {
  42. /* Disable IRQ */
  43. stmp3xxx_clearl(0x04 << ((irq % 4) * 8),
  44. REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10);
  45. /* ACK current interrupt */
  46. __raw_writel(1, REGS_ICOLL_BASE + HW_ICOLL_LEVELACK);
  47. /* Barrier */
  48. (void)__raw_readl(REGS_ICOLL_BASE + HW_ICOLL_STAT);
  49. }
  50. static void stmp37xx_mask_irq(unsigned int irq)
  51. {
  52. /* IRQ disable */
  53. stmp3xxx_clearl(0x04 << ((irq % 4) * 8),
  54. REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10);
  55. }
  56. static void stmp37xx_unmask_irq(unsigned int irq)
  57. {
  58. /* IRQ enable */
  59. stmp3xxx_setl(0x04 << ((irq % 4) * 8),
  60. REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10);
  61. }
  62. static struct irq_chip stmp37xx_chip = {
  63. .ack = stmp37xx_ack_irq,
  64. .mask = stmp37xx_mask_irq,
  65. .unmask = stmp37xx_unmask_irq,
  66. };
  67. void __init stmp37xx_init_irq(void)
  68. {
  69. stmp3xxx_init_irq(&stmp37xx_chip);
  70. }
  71. /*
  72. * DMA interrupt handling
  73. */
  74. void stmp3xxx_arch_dma_enable_interrupt(int channel)
  75. {
  76. switch (STMP3XXX_DMA_BUS(channel)) {
  77. case STMP3XXX_BUS_APBH:
  78. stmp3xxx_setl(1 << (8 + STMP3XXX_DMA_CHANNEL(channel)),
  79. REGS_APBH_BASE + HW_APBH_CTRL1);
  80. break;
  81. case STMP3XXX_BUS_APBX:
  82. stmp3xxx_setl(1 << (8 + STMP3XXX_DMA_CHANNEL(channel)),
  83. REGS_APBX_BASE + HW_APBX_CTRL1);
  84. break;
  85. }
  86. }
  87. EXPORT_SYMBOL(stmp3xxx_arch_dma_enable_interrupt);
  88. void stmp3xxx_arch_dma_clear_interrupt(int channel)
  89. {
  90. switch (STMP3XXX_DMA_BUS(channel)) {
  91. case STMP3XXX_BUS_APBH:
  92. stmp3xxx_clearl(1 << STMP3XXX_DMA_CHANNEL(channel),
  93. REGS_APBH_BASE + HW_APBH_CTRL1);
  94. break;
  95. case STMP3XXX_BUS_APBX:
  96. stmp3xxx_clearl(1 << STMP3XXX_DMA_CHANNEL(channel),
  97. REGS_APBX_BASE + HW_APBX_CTRL1);
  98. break;
  99. }
  100. }
  101. EXPORT_SYMBOL(stmp3xxx_arch_dma_clear_interrupt);
  102. int stmp3xxx_arch_dma_is_interrupt(int channel)
  103. {
  104. int r = 0;
  105. switch (STMP3XXX_DMA_BUS(channel)) {
  106. case STMP3XXX_BUS_APBH:
  107. r = __raw_readl(REGS_APBH_BASE + HW_APBH_CTRL1) &
  108. (1 << STMP3XXX_DMA_CHANNEL(channel));
  109. break;
  110. case STMP3XXX_BUS_APBX:
  111. r = __raw_readl(REGS_APBH_BASE + HW_APBH_CTRL1) &
  112. (1 << STMP3XXX_DMA_CHANNEL(channel));
  113. break;
  114. }
  115. return r;
  116. }
  117. EXPORT_SYMBOL(stmp3xxx_arch_dma_is_interrupt);
  118. void stmp3xxx_arch_dma_reset_channel(int channel)
  119. {
  120. unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel);
  121. switch (STMP3XXX_DMA_BUS(channel)) {
  122. case STMP3XXX_BUS_APBH:
  123. /* Reset channel and wait for it to complete */
  124. stmp3xxx_setl(chbit << BP_APBH_CTRL0_RESET_CHANNEL,
  125. REGS_APBH_BASE + HW_APBH_CTRL0);
  126. while (__raw_readl(REGS_APBH_BASE + HW_APBH_CTRL0) &
  127. (chbit << BP_APBH_CTRL0_RESET_CHANNEL))
  128. cpu_relax();
  129. break;
  130. case STMP3XXX_BUS_APBX:
  131. stmp3xxx_setl(chbit << BP_APBX_CTRL0_RESET_CHANNEL,
  132. REGS_APBX_BASE + HW_APBX_CTRL0);
  133. while (__raw_readl(REGS_APBX_BASE + HW_APBX_CTRL0) &
  134. (chbit << BP_APBX_CTRL0_RESET_CHANNEL))
  135. cpu_relax();
  136. break;
  137. }
  138. }
  139. EXPORT_SYMBOL(stmp3xxx_arch_dma_reset_channel);
  140. void stmp3xxx_arch_dma_freeze(int channel)
  141. {
  142. unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel);
  143. switch (STMP3XXX_DMA_BUS(channel)) {
  144. case STMP3XXX_BUS_APBH:
  145. stmp3xxx_setl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0);
  146. break;
  147. case STMP3XXX_BUS_APBX:
  148. stmp3xxx_setl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0);
  149. break;
  150. }
  151. }
  152. EXPORT_SYMBOL(stmp3xxx_arch_dma_freeze);
  153. void stmp3xxx_arch_dma_unfreeze(int channel)
  154. {
  155. unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel);
  156. switch (STMP3XXX_DMA_BUS(channel)) {
  157. case STMP3XXX_BUS_APBH:
  158. stmp3xxx_clearl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0);
  159. break;
  160. case STMP3XXX_BUS_APBX:
  161. stmp3xxx_clearl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0);
  162. break;
  163. }
  164. }
  165. EXPORT_SYMBOL(stmp3xxx_arch_dma_unfreeze);
  166. /*
  167. * The registers are all very closely mapped, so we might as well map them all
  168. * with a single mapping
  169. *
  170. * Logical Physical
  171. * f0000000 80000000 On-chip registers
  172. * f1000000 00000000 32k on-chip SRAM
  173. */
  174. static struct map_desc stmp37xx_io_desc[] __initdata = {
  175. {
  176. .virtual = (u32)STMP3XXX_REGS_BASE,
  177. .pfn = __phys_to_pfn(STMP3XXX_REGS_PHBASE),
  178. .length = SZ_1M,
  179. .type = MT_DEVICE
  180. },
  181. {
  182. .virtual = (u32)STMP3XXX_OCRAM_BASE,
  183. .pfn = __phys_to_pfn(STMP3XXX_OCRAM_PHBASE),
  184. .length = STMP3XXX_OCRAM_SIZE,
  185. .type = MT_DEVICE,
  186. },
  187. };
  188. void __init stmp37xx_map_io(void)
  189. {
  190. iotable_init(stmp37xx_io_desc, ARRAY_SIZE(stmp37xx_io_desc));
  191. }