favr-32-ezkit.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. /*
  2. * Copyright (C) 2008 Atmel Corporation
  3. *
  4. * Configuration settings for the Favr-32 EarthLCD LCD kit.
  5. *
  6. * See file CREDITS for list of people who contributed to this project.
  7. *
  8. * This program is free software; you can redistribute it and/or modify it
  9. * under the terms of the GNU General Public License as published by the Free
  10. * Software Foundation; either version 2 of the License, or (at your option)
  11. * any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful, but WITHOUT
  14. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  15. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  16. * more details.
  17. *
  18. * You should have received a copy of the GNU General Public License along with
  19. * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
  20. * Place, Suite 330, Boston, MA 02111-1307 USA
  21. */
  22. #ifndef __CONFIG_H
  23. #define __CONFIG_H
  24. #include <asm/arch/memory-map.h>
  25. #define CONFIG_AVR32 1
  26. #define CONFIG_AT32AP 1
  27. #define CONFIG_AT32AP7000 1
  28. #define CONFIG_FAVR32_EZKIT 1
  29. #define CONFIG_FAVR32_EZKIT_EXT_FLASH 1
  30. /*
  31. * Timer clock frequency. We're using the CPU-internal COUNT register
  32. * for this, so this is equivalent to the CPU core clock frequency
  33. */
  34. #define CONFIG_SYS_HZ 1000
  35. /*
  36. * Set up the PLL to run at 140 MHz, the CPU to run at the PLL
  37. * frequency, the HSB and PBB at 1/2, and the PBA to run at 1/4 the
  38. * PLL frequency.
  39. * (CONFIG_SYS_OSC0_HZ * CONFIG_SYS_PLL0_MUL) / CONFIG_SYS_PLL0_DIV = PLL MHz
  40. */
  41. #define CONFIG_PLL 1
  42. #define CONFIG_SYS_POWER_MANAGER 1
  43. #define CONFIG_SYS_OSC0_HZ 20000000
  44. #define CONFIG_SYS_PLL0_DIV 1
  45. #define CONFIG_SYS_PLL0_MUL 7
  46. #define CONFIG_SYS_PLL0_SUPPRESS_CYCLES 16
  47. /*
  48. * Set the CPU running at:
  49. * PLL / (2^CONFIG_SYS_CLKDIV_CPU) = CPU MHz
  50. */
  51. #define CONFIG_SYS_CLKDIV_CPU 0
  52. /*
  53. * Set the HSB running at:
  54. * PLL / (2^CONFIG_SYS_CLKDIV_HSB) = HSB MHz
  55. */
  56. #define CONFIG_SYS_CLKDIV_HSB 1
  57. /*
  58. * Set the PBA running at:
  59. * PLL / (2^CONFIG_SYS_CLKDIV_PBA) = PBA MHz
  60. */
  61. #define CONFIG_SYS_CLKDIV_PBA 2
  62. /*
  63. * Set the PBB running at:
  64. * PLL / (2^CONFIG_SYS_CLKDIV_PBB) = PBB MHz
  65. */
  66. #define CONFIG_SYS_CLKDIV_PBB 1
  67. /* Reserve VM regions for SDRAM and NOR flash */
  68. #define CONFIG_SYS_NR_VM_REGIONS 2
  69. /*
  70. * The PLLOPT register controls the PLL like this:
  71. * icp = PLLOPT<2>
  72. * ivco = PLLOPT<1:0>
  73. *
  74. * We want icp=1 (default) and ivco=0 (80-160 MHz) or ivco=2 (150-240MHz).
  75. */
  76. #define CONFIG_SYS_PLL0_OPT 0x04
  77. #undef CONFIG_USART0
  78. #undef CONFIG_USART1
  79. #undef CONFIG_USART2
  80. #define CONFIG_USART3 1
  81. /* User serviceable stuff */
  82. #define CONFIG_DOS_PARTITION 1
  83. #define CONFIG_CMDLINE_TAG 1
  84. #define CONFIG_SETUP_MEMORY_TAGS 1
  85. #define CONFIG_INITRD_TAG 1
  86. #define CONFIG_STACKSIZE (2048)
  87. #define CONFIG_BAUDRATE 115200
  88. #define CONFIG_BOOTARGS \
  89. "root=/dev/mtdblock1 rootfstype=jffs fbmem=1800k"
  90. #define CONFIG_BOOTCOMMAND \
  91. "fsload; bootm $(fileaddr)"
  92. /*
  93. * Only interrupt autoboot if <space> is pressed. Otherwise, garbage
  94. * data on the serial line may interrupt the boot sequence.
  95. */
  96. #define CONFIG_BOOTDELAY 1
  97. #define CONFIG_AUTOBOOT 1
  98. #define CONFIG_AUTOBOOT_KEYED 1
  99. #define CONFIG_AUTOBOOT_PROMPT \
  100. "Press SPACE to abort autoboot in %d seconds\n", bootdelay
  101. #define CONFIG_AUTOBOOT_DELAY_STR "d"
  102. #define CONFIG_AUTOBOOT_STOP_STR " "
  103. /*
  104. * After booting the board for the first time, new ethernet addresses
  105. * should be generated and assigned to the environment variables
  106. * "ethaddr" and "eth1addr". This is normally done during production.
  107. */
  108. #define CONFIG_OVERWRITE_ETHADDR_ONCE 1
  109. #define CONFIG_NET_MULTI 1
  110. /*
  111. * BOOTP options
  112. */
  113. #define CONFIG_BOOTP_SUBNETMASK
  114. #define CONFIG_BOOTP_GATEWAY
  115. /*
  116. * Command line configuration.
  117. */
  118. #include <config_cmd_default.h>
  119. #define CONFIG_CMD_ASKENV
  120. #define CONFIG_CMD_DHCP
  121. #define CONFIG_CMD_EXT2
  122. #define CONFIG_CMD_FAT
  123. #define CONFIG_CMD_JFFS2
  124. #define CONFIG_CMD_MMC
  125. #undef CONFIG_CMD_FPGA
  126. #undef CONFIG_CMD_SETGETDCR
  127. #undef CONFIG_CMD_SOURCE
  128. #undef CONFIG_CMD_XIMG
  129. #define CONFIG_ATMEL_USART 1
  130. #define CONFIG_MACB 1
  131. #define CONFIG_PORTMUX_PIO 1
  132. #define CONFIG_SYS_NR_PIOS 5
  133. #define CONFIG_SYS_HSDRAMC 1
  134. #define CONFIG_MMC 1
  135. #define CONFIG_ATMEL_MCI 1
  136. #define CONFIG_SYS_DCACHE_LINESZ 32
  137. #define CONFIG_SYS_ICACHE_LINESZ 32
  138. #define CONFIG_NR_DRAM_BANKS 1
  139. /* External flash on Favr-32 */
  140. #if 0
  141. #define CONFIG_SYS_FLASH_CFI 1
  142. #define CONFIG_FLASH_CFI_DRIVER 1
  143. #endif
  144. #define CONFIG_SYS_FLASH_BASE 0x00000000
  145. #define CONFIG_SYS_FLASH_SIZE 0x800000
  146. #define CONFIG_SYS_MAX_FLASH_BANKS 1
  147. #define CONFIG_SYS_MAX_FLASH_SECT 135
  148. #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_FLASH_BASE
  149. #define CONFIG_SYS_INTRAM_BASE INTERNAL_SRAM_BASE
  150. #define CONFIG_SYS_INTRAM_SIZE INTERNAL_SRAM_SIZE
  151. #define CONFIG_SYS_SDRAM_BASE EBI_SDRAM_BASE
  152. #define CONFIG_ENV_IS_IN_FLASH 1
  153. #define CONFIG_ENV_SIZE 65536
  154. #define CONFIG_ENV_ADDR (CONFIG_SYS_FLASH_BASE + CONFIG_SYS_FLASH_SIZE - CONFIG_ENV_SIZE)
  155. #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INTRAM_BASE + CONFIG_SYS_INTRAM_SIZE)
  156. #define CONFIG_SYS_MALLOC_LEN (256*1024)
  157. #define CONFIG_SYS_DMA_ALLOC_LEN (16384)
  158. /* Allow 4MB for the kernel run-time image */
  159. #define CONFIG_SYS_LOAD_ADDR (EBI_SDRAM_BASE + 0x00400000)
  160. #define CONFIG_SYS_BOOTPARAMS_LEN (16 * 1024)
  161. /* Other configuration settings that shouldn't have to change all that often */
  162. #define CONFIG_SYS_PROMPT "U-Boot> "
  163. #define CONFIG_SYS_CBSIZE 256
  164. #define CONFIG_SYS_MAXARGS 16
  165. #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
  166. #define CONFIG_SYS_LONGHELP 1
  167. #define CONFIG_SYS_MEMTEST_START EBI_SDRAM_BASE
  168. #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START + 0x700000)
  169. #define CONFIG_SYS_BAUDRATE_TABLE { 115200, 38400, 19200, 9600, 2400 }
  170. #endif /* __CONFIG_H */