/kern_oII/arch/arm/mach-pxa/generic.c

http://omnia2droid.googlecode.com/ · C · 160 lines · 107 code · 16 blank · 37 comment · 16 complexity · e45c4a92624d0cba12fd827bb6f3798f MD5 · raw file

  1. /*
  2. * linux/arch/arm/mach-pxa/generic.c
  3. *
  4. * Author: Nicolas Pitre
  5. * Created: Jun 15, 2001
  6. * Copyright: MontaVista Software Inc.
  7. *
  8. * Code common to all PXA machines.
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License version 2 as
  12. * published by the Free Software Foundation.
  13. *
  14. * Since this file should be linked before any other machine specific file,
  15. * the __initcall() here will be executed first. This serves as default
  16. * initialization stuff for PXA machines which can be overridden later if
  17. * need be.
  18. */
  19. #include <linux/module.h>
  20. #include <linux/kernel.h>
  21. #include <linux/init.h>
  22. #include <mach/hardware.h>
  23. #include <asm/system.h>
  24. #include <asm/pgtable.h>
  25. #include <asm/mach/map.h>
  26. #include <asm/mach-types.h>
  27. #include <mach/reset.h>
  28. #include <mach/gpio.h>
  29. #include <mach/pxa2xx-gpio.h>
  30. #include "generic.h"
  31. void clear_reset_status(unsigned int mask)
  32. {
  33. if (cpu_is_pxa2xx())
  34. pxa2xx_clear_reset_status(mask);
  35. if (cpu_is_pxa3xx())
  36. pxa3xx_clear_reset_status(mask);
  37. }
  38. unsigned long get_clock_tick_rate(void)
  39. {
  40. unsigned long clock_tick_rate;
  41. if (cpu_is_pxa25x())
  42. clock_tick_rate = 3686400;
  43. else if (machine_is_mainstone())
  44. clock_tick_rate = 3249600;
  45. else
  46. clock_tick_rate = 3250000;
  47. return clock_tick_rate;
  48. }
  49. EXPORT_SYMBOL(get_clock_tick_rate);
  50. /*
  51. * Get the clock frequency as reflected by CCCR and the turbo flag.
  52. * We assume these values have been applied via a fcs.
  53. * If info is not 0 we also display the current settings.
  54. */
  55. unsigned int get_clk_frequency_khz(int info)
  56. {
  57. if (cpu_is_pxa25x())
  58. return pxa25x_get_clk_frequency_khz(info);
  59. else if (cpu_is_pxa27x())
  60. return pxa27x_get_clk_frequency_khz(info);
  61. else
  62. return pxa3xx_get_clk_frequency_khz(info);
  63. }
  64. EXPORT_SYMBOL(get_clk_frequency_khz);
  65. /*
  66. * Return the current memory clock frequency in units of 10kHz
  67. */
  68. unsigned int get_memclk_frequency_10khz(void)
  69. {
  70. if (cpu_is_pxa25x())
  71. return pxa25x_get_memclk_frequency_10khz();
  72. else if (cpu_is_pxa27x())
  73. return pxa27x_get_memclk_frequency_10khz();
  74. else
  75. return pxa3xx_get_memclk_frequency_10khz();
  76. }
  77. EXPORT_SYMBOL(get_memclk_frequency_10khz);
  78. /*
  79. * Intel PXA2xx internal register mapping.
  80. *
  81. * Note 1: not all PXA2xx variants implement all those addresses.
  82. *
  83. * Note 2: virtual 0xfffe0000-0xffffffff is reserved for the vector table
  84. * and cache flush area.
  85. */
  86. static struct map_desc standard_io_desc[] __initdata = {
  87. { /* Devs */
  88. .virtual = 0xf2000000,
  89. .pfn = __phys_to_pfn(0x40000000),
  90. .length = 0x02000000,
  91. .type = MT_DEVICE
  92. }, { /* Mem Ctl */
  93. .virtual = 0xf6000000,
  94. .pfn = __phys_to_pfn(0x48000000),
  95. .length = 0x00200000,
  96. .type = MT_DEVICE
  97. }, { /* Camera */
  98. .virtual = 0xfa000000,
  99. .pfn = __phys_to_pfn(0x50000000),
  100. .length = 0x00100000,
  101. .type = MT_DEVICE
  102. }, { /* IMem ctl */
  103. .virtual = 0xfe000000,
  104. .pfn = __phys_to_pfn(0x58000000),
  105. .length = 0x00100000,
  106. .type = MT_DEVICE
  107. }, { /* UNCACHED_PHYS_0 */
  108. .virtual = 0xff000000,
  109. .pfn = __phys_to_pfn(0x00000000),
  110. .length = 0x00100000,
  111. .type = MT_DEVICE
  112. }
  113. };
  114. void __init pxa_map_io(void)
  115. {
  116. iotable_init(standard_io_desc, ARRAY_SIZE(standard_io_desc));
  117. get_clk_frequency_khz(1);
  118. }
  119. /*
  120. * Configure pins for GPIO or other functions
  121. */
  122. int pxa_gpio_mode(int gpio_mode)
  123. {
  124. unsigned long flags;
  125. int gpio = gpio_mode & GPIO_MD_MASK_NR;
  126. int fn = (gpio_mode & GPIO_MD_MASK_FN) >> 8;
  127. int gafr;
  128. if (gpio > pxa_last_gpio)
  129. return -EINVAL;
  130. local_irq_save(flags);
  131. if (gpio_mode & GPIO_DFLT_LOW)
  132. GPCR(gpio) = GPIO_bit(gpio);
  133. else if (gpio_mode & GPIO_DFLT_HIGH)
  134. GPSR(gpio) = GPIO_bit(gpio);
  135. if (gpio_mode & GPIO_MD_MASK_DIR)
  136. GPDR(gpio) |= GPIO_bit(gpio);
  137. else
  138. GPDR(gpio) &= ~GPIO_bit(gpio);
  139. gafr = GAFR(gpio) & ~(0x3 << (((gpio) & 0xf)*2));
  140. GAFR(gpio) = gafr | (fn << (((gpio) & 0xf)*2));
  141. local_irq_restore(flags);
  142. return 0;
  143. }
  144. EXPORT_SYMBOL(pxa_gpio_mode);