ar7.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /*
  2. * Copyright (C) 2006,2007 Felix Fietkau <nbd@openwrt.org>
  3. * Copyright (C) 2006,2007 Eugene Konev <ejka@openwrt.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  18. */
  19. #ifndef __AR7_H__
  20. #define __AR7_H__
  21. #include <linux/delay.h>
  22. #include <linux/io.h>
  23. #include <linux/errno.h>
  24. #include <asm/addrspace.h>
  25. #define AR7_SDRAM_BASE 0x14000000
  26. #define AR7_REGS_BASE 0x08610000
  27. #define AR7_REGS_MAC0 (AR7_REGS_BASE + 0x0000)
  28. #define AR7_REGS_GPIO (AR7_REGS_BASE + 0x0900)
  29. /* 0x08610A00 - 0x08610BFF (512 bytes, 128 bytes / clock) */
  30. #define AR7_REGS_POWER (AR7_REGS_BASE + 0x0a00)
  31. #define AR7_REGS_CLOCKS (AR7_REGS_POWER + 0x80)
  32. #define UR8_REGS_CLOCKS (AR7_REGS_POWER + 0x20)
  33. #define AR7_REGS_UART0 (AR7_REGS_BASE + 0x0e00)
  34. #define AR7_REGS_USB (AR7_REGS_BASE + 0x1200)
  35. #define AR7_REGS_RESET (AR7_REGS_BASE + 0x1600)
  36. #define AR7_REGS_VLYNQ0 (AR7_REGS_BASE + 0x1800)
  37. #define AR7_REGS_DCL (AR7_REGS_BASE + 0x1a00)
  38. #define AR7_REGS_VLYNQ1 (AR7_REGS_BASE + 0x1c00)
  39. #define AR7_REGS_MDIO (AR7_REGS_BASE + 0x1e00)
  40. #define AR7_REGS_IRQ (AR7_REGS_BASE + 0x2400)
  41. #define AR7_REGS_MAC1 (AR7_REGS_BASE + 0x2800)
  42. #define AR7_REGS_WDT (AR7_REGS_BASE + 0x1f00)
  43. #define UR8_REGS_WDT (AR7_REGS_BASE + 0x0b00)
  44. #define UR8_REGS_UART1 (AR7_REGS_BASE + 0x0f00)
  45. #define AR7_RESET_PEREPHERIAL 0x0
  46. #define AR7_RESET_SOFTWARE 0x4
  47. #define AR7_RESET_STATUS 0x8
  48. #define AR7_RESET_BIT_CPMAC_LO 17
  49. #define AR7_RESET_BIT_CPMAC_HI 21
  50. #define AR7_RESET_BIT_MDIO 22
  51. #define AR7_RESET_BIT_EPHY 26
  52. /* GPIO control registers */
  53. #define AR7_GPIO_INPUT 0x0
  54. #define AR7_GPIO_OUTPUT 0x4
  55. #define AR7_GPIO_DIR 0x8
  56. #define AR7_GPIO_ENABLE 0xc
  57. #define AR7_CHIP_7100 0x18
  58. #define AR7_CHIP_7200 0x2b
  59. #define AR7_CHIP_7300 0x05
  60. /* Interrupts */
  61. #define AR7_IRQ_UART0 15
  62. #define AR7_IRQ_UART1 16
  63. /* Clocks */
  64. #define AR7_AFE_CLOCK 35328000
  65. #define AR7_REF_CLOCK 25000000
  66. #define AR7_XTAL_CLOCK 24000000
  67. struct plat_cpmac_data {
  68. int reset_bit;
  69. int power_bit;
  70. u32 phy_mask;
  71. char dev_addr[6];
  72. };
  73. struct plat_dsl_data {
  74. int reset_bit_dsl;
  75. int reset_bit_sar;
  76. };
  77. extern int ar7_cpu_clock, ar7_bus_clock, ar7_dsp_clock;
  78. static inline u16 ar7_chip_id(void)
  79. {
  80. return readl((void *)KSEG1ADDR(AR7_REGS_GPIO + 0x14)) & 0xffff;
  81. }
  82. static inline u8 ar7_chip_rev(void)
  83. {
  84. return (readl((void *)KSEG1ADDR(AR7_REGS_GPIO + 0x14)) >> 16) & 0xff;
  85. }
  86. static inline int ar7_cpu_freq(void)
  87. {
  88. return ar7_cpu_clock;
  89. }
  90. static inline int ar7_bus_freq(void)
  91. {
  92. return ar7_bus_clock;
  93. }
  94. static inline int ar7_vbus_freq(void)
  95. {
  96. return ar7_bus_clock / 2;
  97. }
  98. #define ar7_cpmac_freq ar7_vbus_freq
  99. static inline int ar7_dsp_freq(void)
  100. {
  101. return ar7_dsp_clock;
  102. }
  103. static inline int ar7_has_high_cpmac(void)
  104. {
  105. u16 chip_id = ar7_chip_id();
  106. switch (chip_id) {
  107. case AR7_CHIP_7100:
  108. case AR7_CHIP_7200:
  109. return 0;
  110. case AR7_CHIP_7300:
  111. return 1;
  112. default:
  113. return -ENXIO;
  114. }
  115. }
  116. #define ar7_has_high_vlynq ar7_has_high_cpmac
  117. #define ar7_has_second_uart ar7_has_high_cpmac
  118. static inline void ar7_device_enable(u32 bit)
  119. {
  120. void *reset_reg =
  121. (void *)KSEG1ADDR(AR7_REGS_RESET + AR7_RESET_PEREPHERIAL);
  122. writel(readl(reset_reg) | (1 << bit), reset_reg);
  123. msleep(20);
  124. }
  125. static inline void ar7_device_disable(u32 bit)
  126. {
  127. void *reset_reg =
  128. (void *)KSEG1ADDR(AR7_REGS_RESET + AR7_RESET_PEREPHERIAL);
  129. writel(readl(reset_reg) & ~(1 << bit), reset_reg);
  130. msleep(20);
  131. }
  132. static inline void ar7_device_reset(u32 bit)
  133. {
  134. ar7_device_disable(bit);
  135. ar7_device_enable(bit);
  136. }
  137. static inline void ar7_device_on(u32 bit)
  138. {
  139. void *power_reg = (void *)KSEG1ADDR(AR7_REGS_POWER);
  140. writel(readl(power_reg) | (1 << bit), power_reg);
  141. msleep(20);
  142. }
  143. static inline void ar7_device_off(u32 bit)
  144. {
  145. void *power_reg = (void *)KSEG1ADDR(AR7_REGS_POWER);
  146. writel(readl(power_reg) & ~(1 << bit), power_reg);
  147. msleep(20);
  148. }
  149. #endif /* __AR7_H__ */