DK1S10.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510
  1. /*
  2. * (C) Copyright 2003, Li-Pro.Net <www.li-pro.net>
  3. * Stephan Linz <linz@li-pro.net>
  4. *
  5. * See file CREDITS for list of people who contributed to this
  6. * project.
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License as
  10. * published by the Free Software Foundation; either version 2 of
  11. * the License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  21. * MA 02111-1307 USA
  22. */
  23. #ifndef __CONFIG_H
  24. #define __CONFIG_H
  25. /***********************************************************************
  26. * Include the whole NIOS CPU configuration.
  27. *
  28. * !!! HAVE TO BE HERE !!! DON'T MOVE THIS PART !!!
  29. *
  30. ***********************************************************************/
  31. #if defined(CONFIG_NIOS_SAFE_32)
  32. #include <configs/DK1S10_safe_32.h>
  33. #elif defined(CONFIG_NIOS_STANDARD_32)
  34. #include <configs/DK1S10_standard_32.h>
  35. #elif defined(CONFIG_NIOS_MTX_LDK_20)
  36. #include <configs/DK1S10_mtx_ldk_20.h>
  37. #else
  38. #error *** CFG_ERROR: you have to setup right NIOS CPU configuration
  39. #endif
  40. /*------------------------------------------------------------------------
  41. * BOARD/CPU -- TOP-LEVEL
  42. *----------------------------------------------------------------------*/
  43. #define CONFIG_NIOS 1 /* NIOS-32 core */
  44. #define CONFIG_DK1S10 1 /* Stratix DK-1S10 board*/
  45. #define CONFIG_SYS_CLK_FREQ CFG_NIOS_CPU_CLK/* 50 MHz core clock */
  46. #define CFG_HZ 1000 /* 1 msec time tick */
  47. #undef CFG_CLKS_IN_HZ
  48. #define CONFIG_BOARD_EARLY_INIT_F 1 /* enable early board-spec. init*/
  49. /*------------------------------------------------------------------------
  50. * BASE ADDRESSES / SIZE (Flash, SRAM, SDRAM)
  51. *----------------------------------------------------------------------*/
  52. #if (CFG_NIOS_CPU_SDRAM_SIZE != 0)
  53. #define CFG_SDRAM_BASE CFG_NIOS_CPU_SDRAM_BASE
  54. #define CFG_SDRAM_SIZE CFG_NIOS_CPU_SDRAM_SIZE
  55. #else
  56. #error *** CFG_ERROR: you have to setup any SDRAM in NIOS CPU config
  57. #endif
  58. #if defined(CFG_NIOS_CPU_SRAM_BASE) && defined(CFG_NIOS_CPU_SRAM_SIZE)
  59. #define CFG_SRAM_BASE CFG_NIOS_CPU_SRAM_BASE
  60. #define CFG_SRAM_SIZE CFG_NIOS_CPU_SRAM_SIZE
  61. #else
  62. #undef CFG_SRAM_BASE
  63. #undef CFG_SRAM_SIZE
  64. #endif
  65. #define CFG_VECT_BASE CFG_NIOS_CPU_VEC_BASE
  66. /*------------------------------------------------------------------------
  67. * MEMORY ORGANIZATION - For the most part, you can put things pretty
  68. * much anywhere. This is pretty flexible for Nios. So here we make some
  69. * arbitrary choices & assume that the monitor is placed at the end of
  70. * a memory resource (so you must make sure TEXT_BASE is chosen
  71. * appropriately).
  72. *
  73. * -The heap is placed below the monitor.
  74. * -Global data is placed below the heap.
  75. * -The stack is placed below global data (&grows down).
  76. *----------------------------------------------------------------------*/
  77. #define CFG_MONITOR_LEN (256 * 1024) /* Reserve 256k */
  78. #define CFG_GBL_DATA_SIZE 128 /* Global data size rsvd*/
  79. #define CFG_MALLOC_LEN (CFG_ENV_SIZE + 128*1024)
  80. #define CFG_MONITOR_BASE TEXT_BASE
  81. #define CFG_MALLOC_BASE (CFG_MONITOR_BASE - CFG_MALLOC_LEN)
  82. #define CFG_GBL_DATA_OFFSET (CFG_MALLOC_BASE - CFG_GBL_DATA_SIZE)
  83. #define CFG_INIT_SP CFG_GBL_DATA_OFFSET
  84. /*------------------------------------------------------------------------
  85. * FLASH (AM29LV065D)
  86. *----------------------------------------------------------------------*/
  87. #if (CFG_NIOS_CPU_FLASH_SIZE != 0)
  88. #define CFG_FLASH_BASE CFG_NIOS_CPU_FLASH_BASE
  89. #define CFG_FLASH_SIZE CFG_NIOS_CPU_FLASH_SIZE
  90. #define CFG_MAX_FLASH_SECT 128 /* Max # sects per bank */
  91. #define CFG_MAX_FLASH_BANKS 1 /* Max # of flash banks */
  92. #define CFG_FLASH_ERASE_TOUT 8000 /* Erase timeout (msec) */
  93. #define CFG_FLASH_WRITE_TOUT 100 /* Write timeout (msec) */
  94. #define CFG_FLASH_WORD_SIZE unsigned char /* flash word size */
  95. #else
  96. #error *** CFG_ERROR: you have to setup any Flash memory in NIOS CPU config
  97. #endif
  98. /*------------------------------------------------------------------------
  99. * ENVIRONMENT
  100. *----------------------------------------------------------------------*/
  101. #if (CFG_NIOS_CPU_FLASH_SIZE != 0)
  102. #define CFG_ENV_IS_IN_FLASH 1 /* Environment in flash */
  103. #if defined(CONFIG_NIOS_STANDARD_32)
  104. #define CFG_ENV_ADDR CFG_FLASH_BASE /* Mem addr of env */
  105. #elif defined(CONFIG_NIOS_MTX_LDK_20)
  106. #define CFG_ENV_ADDR (CFG_FLASH_BASE + CFG_MONITOR_LEN)
  107. #else
  108. #error *** CFG_ERROR: you have to setup the environment base address CFG_ENV_ADDR
  109. #endif
  110. #define CFG_ENV_SIZE (64 * 1024) /* 64 KByte (1 sector) */
  111. #define CONFIG_ENV_OVERWRITE /* Serial/eth change Ok */
  112. #else
  113. #define CFG_ENV_IS_NOWHERE 1 /* NO Environment */
  114. #endif
  115. /*------------------------------------------------------------------------
  116. * CONSOLE
  117. *----------------------------------------------------------------------*/
  118. #if (CFG_NIOS_CPU_UART_NUMS != 0)
  119. #define CFG_NIOS_CONSOLE CFG_NIOS_CPU_UART0 /* 1st UART is Cons. */
  120. #if (CFG_NIOS_CPU_UART0_BR != 0)
  121. #define CFG_NIOS_FIXEDBAUD 1 /* Baudrate is fixed */
  122. #define CONFIG_BAUDRATE CFG_NIOS_CPU_UART0_BR
  123. #else
  124. #undef CFG_NIOS_FIXEDBAUD
  125. #define CONFIG_BAUDRATE 115200
  126. #endif
  127. #define CFG_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 }
  128. #else
  129. #error *** CFG_ERROR: you have to setup at least one UART in NIOS CPU config
  130. #endif
  131. /*------------------------------------------------------------------------
  132. * TIMER FOR TIMEBASE -- Nios doesn't have the equivalent of ppc PIT,
  133. * so an avalon bus timer is required.
  134. *----------------------------------------------------------------------*/
  135. #if (CFG_NIOS_CPU_TIMER_NUMS != 0) && defined(CFG_NIOS_CPU_TICK_TIMER)
  136. #if (CFG_NIOS_CPU_TICK_TIMER == 0)
  137. #define CFG_NIOS_TMRBASE CFG_NIOS_CPU_TIMER0 /* TIMER0 as tick */
  138. #define CFG_NIOS_TMRIRQ CFG_NIOS_CPU_TIMER0_IRQ
  139. #if (CFG_NIOS_CPU_TIMER0_PER >= CFG_HZ)
  140. #define CFG_NIOS_TMRMS (CFG_NIOS_CPU_TIMER0_PER / CFG_HZ)
  141. #else
  142. #error *** CFG_ERROR: you have to use a timer periode of more than CFG_HZ
  143. #endif
  144. #elif (CFG_NIOS_CPU_TICK_TIMER == 1)
  145. #define CFG_NIOS_TMRBASE CFG_NIOS_CPU_TIMER1 /* TIMER1 as tick */
  146. #define CFG_NIOS_TMRIRQ CFG_NIOS_CPU_TIMER1_IRQ
  147. #if (CFG_NIOS_CPU_TIMER1_PER >= CFG_HZ)
  148. #define CFG_NIOS_TMRMS (CFG_NIOS_CPU_TIMER1_PER / CFG_HZ)
  149. #else
  150. #error *** CFG_ERROR: you have to use a timer periode of more than CFG_HZ
  151. #endif
  152. #endif /* CFG_NIOS_CPU_TICK_TIMER */
  153. #else
  154. #error *** CFG_ERROR: you have to setup at least one TIMER in NIOS CPU config
  155. #endif
  156. /*------------------------------------------------------------------------
  157. * Ethernet -- needs work!
  158. *----------------------------------------------------------------------*/
  159. #if (CFG_NIOS_CPU_LAN_NUMS == 1)
  160. #if (CFG_NIOS_CPU_LAN0_TYPE == 0) /* LAN91C111 */
  161. #define CONFIG_DRIVER_SMC91111 /* Using SMC91c111 */
  162. #undef CONFIG_SMC91111_EXT_PHY /* Internal PHY */
  163. #define CONFIG_SMC91111_BASE (CFG_NIOS_CPU_LAN0_BASE + CFG_NIOS_CPU_LAN0_OFFS)
  164. #if (CFG_NIOS_CPU_LAN0_BUSW == 32)
  165. #define CONFIG_SMC_USE_32_BIT 1
  166. #else /* no */
  167. #undef CONFIG_SMC_USE_32_BIT
  168. #endif
  169. #elif (CFG_NIOS_CPU_LAN0_TYPE == 1) /* CS8900A */
  170. /********************************************/
  171. /* !!! CS8900 is __not__ tested on NIOS !!! */
  172. /********************************************/
  173. #define CONFIG_DRIVER_CS8900 /* Using CS8900 */
  174. #define CS8900_BASE (CFG_NIOS_CPU_LAN0_BASE + CFG_NIOS_CPU_LAN0_OFFS)
  175. #if (CFG_NIOS_CPU_LAN0_BUSW == 32)
  176. #undef CS8900_BUS16
  177. #define CS8900_BUS32 1
  178. #else /* no */
  179. #define CS8900_BUS16 1
  180. #undef CS8900_BUS32
  181. #endif
  182. #else
  183. #error *** CFG_ERROR: invalid LAN0 chip type, check your NIOS CPU config
  184. #endif
  185. #define CONFIG_ETHADDR 08:00:3e:26:0a:5b
  186. #define CONFIG_NETMASK 255.255.255.0
  187. #define CONFIG_IPADDR 192.168.2.21
  188. #define CONFIG_SERVERIP 192.168.2.16
  189. #else
  190. #error *** CFG_ERROR: you have to setup just one LAN only or expand your config.h
  191. #endif
  192. /*------------------------------------------------------------------------
  193. * STATUS LEDs
  194. *----------------------------------------------------------------------*/
  195. #if (CFG_NIOS_CPU_PIO_NUMS != 0) && defined(CFG_NIOS_CPU_LED_PIO)
  196. #if (CFG_NIOS_CPU_LED_PIO == 0)
  197. #error *** CFG_ERROR: status LEDs at PIO0 not supported, expand your config.h
  198. #elif (CFG_NIOS_CPU_LED_PIO == 1)
  199. #error *** CFG_ERROR: status LEDs at PIO1 not supported, expand your config.h
  200. #elif (CFG_NIOS_CPU_LED_PIO == 2)
  201. #define STATUS_LED_BASE CFG_NIOS_CPU_PIO2
  202. #define STATUS_LED_BITS CFG_NIOS_CPU_PIO2_BITS
  203. #define STATUS_LED_ACTIVE 1 /* LED on for bit == 1 */
  204. #if (CFG_NIOS_CPU_PIO2_TYPE == 1)
  205. #define STATUS_LED_WRONLY 1
  206. #else
  207. #undef STATUS_LED_WRONLY
  208. #endif
  209. #elif (CFG_NIOS_CPU_LED_PIO == 3)
  210. #error *** CFG_ERROR: status LEDs at PIO3 not supported, expand your config.h
  211. #elif (CFG_NIOS_CPU_LED_PIO == 4)
  212. #error *** CFG_ERROR: status LEDs at PIO4 not supported, expand your config.h
  213. #elif (CFG_NIOS_CPU_LED_PIO == 5)
  214. #error *** CFG_ERROR: status LEDs at PIO5 not supported, expand your config.h
  215. #elif (CFG_NIOS_CPU_LED_PIO == 6)
  216. #error *** CFG_ERROR: status LEDs at PIO6 not supported, expand your config.h
  217. #elif (CFG_NIOS_CPU_LED_PIO == 7)
  218. #error *** CFG_ERROR: status LEDs at PIO7 not supported, expand your config.h
  219. #elif (CFG_NIOS_CPU_LED_PIO == 8)
  220. #error *** CFG_ERROR: status LEDs at PIO8 not supported, expand your config.h
  221. #elif (CFG_NIOS_CPU_LED_PIO == 9)
  222. #error *** CFG_ERROR: status LEDs at PIO9 not supported, expand your config.h
  223. #else
  224. #error *** CFG_ERROR: you have to set CFG_NIOS_CPU_LED_PIO in right case
  225. #endif
  226. #define CONFIG_STATUS_LED 1 /* enable status led driver */
  227. #define STATUS_LED_BIT (1 << 0) /* LED[0] */
  228. #define STATUS_LED_STATE STATUS_LED_BLINKING
  229. #define STATUS_LED_BOOT_STATE STATUS_LED_OFF
  230. #define STATUS_LED_PERIOD (CFG_HZ / 10) /* ca. 1 Hz */
  231. #define STATUS_LED_BOOT 0 /* boot LED */
  232. #if (STATUS_LED_BITS > 1)
  233. #define STATUS_LED_BIT1 (1 << 1) /* LED[1] */
  234. #define STATUS_LED_STATE1 STATUS_LED_OFF
  235. #define STATUS_LED_PERIOD1 (CFG_HZ / 50) /* ca. 5 Hz */
  236. #define STATUS_LED_RED 1 /* fail LED */
  237. #endif
  238. #if (STATUS_LED_BITS > 2)
  239. #define STATUS_LED_BIT2 (1 << 2) /* LED[2] */
  240. #define STATUS_LED_STATE2 STATUS_LED_OFF
  241. #define STATUS_LED_PERIOD2 (CFG_HZ / 10) /* ca. 1 Hz */
  242. #define STATUS_LED_YELLOW 2 /* info LED */
  243. #endif
  244. #if (STATUS_LED_BITS > 3)
  245. #define STATUS_LED_BIT3 (1 << 3) /* LED[3] */
  246. #define STATUS_LED_STATE3 STATUS_LED_OFF
  247. #define STATUS_LED_PERIOD3 (CFG_HZ / 10) /* ca. 1 Hz */
  248. #define STATUS_LED_GREEN 3 /* info LED */
  249. #endif
  250. #define STATUS_LED_PAR 1 /* makes status_led.h happy */
  251. #endif /* CFG_NIOS_CPU_PIO_NUMS */
  252. /*------------------------------------------------------------------------
  253. * SEVEN SEGMENT LED DISPLAY
  254. *----------------------------------------------------------------------*/
  255. #if (CFG_NIOS_CPU_PIO_NUMS != 0) && defined(CFG_NIOS_CPU_SEVENSEG_PIO)
  256. #if (CFG_NIOS_CPU_SEVENSEG_PIO == 0)
  257. #error *** CFG_ERROR: seven segment display at PIO0 not supported, expand your config.h
  258. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 1)
  259. #error *** CFG_ERROR: seven segment display at PIO1 not supported, expand your config.h
  260. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 2)
  261. #error *** CFG_ERROR: seven segment display at PIO2 not supported, expand your config.h
  262. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 3)
  263. #define SEVENSEG_BASE CFG_NIOS_CPU_PIO3
  264. #define SEVENSEG_BITS CFG_NIOS_CPU_PIO3_BITS
  265. #define SEVENSEG_ACTIVE 0 /* LED on for bit == 1 */
  266. #if (CFG_NIOS_CPU_PIO3_TYPE == 1)
  267. #define SEVENSEG_WRONLY 1
  268. #else
  269. #undef SEVENSEG_WRONLY
  270. #endif
  271. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 4)
  272. #error *** CFG_ERROR: seven segment display at PIO4 not supported, expand your config.h
  273. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 5)
  274. #error *** CFG_ERROR: seven segment display at PIO5 not supported, expand your config.h
  275. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 6)
  276. #error *** CFG_ERROR: seven segment display at PIO6 not supported, expand your config.h
  277. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 7)
  278. #error *** CFG_ERROR: seven segment display at PIO7 not supported, expand your config.h
  279. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 8)
  280. #error *** CFG_ERROR: seven segment display at PIO8 not supported, expand your config.h
  281. #elif (CFG_NIOS_CPU_SEVENSEG_PIO == 9)
  282. #error *** CFG_ERROR: seven segment display at PIO9 not supported, expand your config.h
  283. #else
  284. #error *** CFG_ERROR: you have to set CFG_NIOS_CPU_SEVENSEG_PIO in right case
  285. #endif
  286. #define CONFIG_SEVENSEG 1 /* enable seven segment led driver */
  287. /*
  288. * Dual 7-Segment Display pin assignment -- read more in your
  289. * "Nios Development Board Reference Manual"
  290. *
  291. *
  292. * (U8) HI:D[15..8] (U9) LO:D[7..0]
  293. * ______ ______
  294. * | D14 | | D6 |
  295. * | | | |
  296. * D9| |D13 D1| |D5
  297. * |______| |______| ___
  298. * | D8 | | D0 | | A |
  299. * | | | | F|___|B
  300. * D10| |D12 D2| |D4 | G |
  301. * |______| |______| E|___|C
  302. * D11 * D3 * D *
  303. * D15 D7 DP
  304. *
  305. */
  306. #define SEVENSEG_DIGIT_HI_LO_EQUAL 1 /* high nibble equal low nibble */
  307. #define SEVENSEG_DIGIT_A (1 << 6) /* bit 6 is segment A */
  308. #define SEVENSEG_DIGIT_B (1 << 5) /* bit 5 is segment B */
  309. #define SEVENSEG_DIGIT_C (1 << 4) /* bit 4 is segment C */
  310. #define SEVENSEG_DIGIT_D (1 << 3) /* bit 3 is segment D */
  311. #define SEVENSEG_DIGIT_E (1 << 2) /* bit 2 is segment E */
  312. #define SEVENSEG_DIGIT_F (1 << 1) /* bit 1 is segment F */
  313. #define SEVENSEG_DIGIT_G (1 << 0) /* bit 0 is segment G */
  314. #define SEVENSEG_DIGIT_DP (1 << 7) /* bit 7 is decimal point */
  315. #endif /* CFG_NIOS_CPU_PIO_NUMS */
  316. /*------------------------------------------------------------------------
  317. * COMMANDS
  318. *----------------------------------------------------------------------*/
  319. #define CONFIG_COMMANDS (CFG_CMD_ALL & ~( \
  320. CFG_CMD_ASKENV | \
  321. CFG_CMD_BEDBUG | \
  322. CFG_CMD_BMP | \
  323. CFG_CMD_BSP | \
  324. CFG_CMD_CACHE | \
  325. CFG_CMD_DATE | \
  326. CFG_CMD_DOC | \
  327. CFG_CMD_DTT | \
  328. CFG_CMD_EEPROM | \
  329. CFG_CMD_ELF | \
  330. CFG_CMD_FAT | \
  331. CFG_CMD_FDC | \
  332. CFG_CMD_FDOS | \
  333. CFG_CMD_HWFLOW | \
  334. CFG_CMD_IDE | \
  335. CFG_CMD_I2C | \
  336. CFG_CMD_JFFS2 | \
  337. CFG_CMD_KGDB | \
  338. CFG_CMD_NAND | \
  339. CFG_CMD_MMC | \
  340. CFG_CMD_MII | \
  341. CFG_CMD_PCI | \
  342. CFG_CMD_PCMCIA | \
  343. CFG_CMD_SCSI | \
  344. CFG_CMD_SPI | \
  345. CFG_CMD_VFD | \
  346. CFG_CMD_USB ) )
  347. #include <cmd_confdefs.h>
  348. /*------------------------------------------------------------------------
  349. * KGDB
  350. *----------------------------------------------------------------------*/
  351. #if (CONFIG_COMMANDS & CFG_CMD_KGDB)
  352. #define CONFIG_KGDB_BAUDRATE 9600
  353. #endif
  354. /*------------------------------------------------------------------------
  355. * MISC
  356. *----------------------------------------------------------------------*/
  357. #define CFG_LONGHELP /* undef to save memory */
  358. #define CFG_PROMPT "DK1S10 > " /* Monitor Command Prompt */
  359. #define CFG_CBSIZE 256 /* Console I/O Buffer Size */
  360. #define CFG_PBSIZE (CFG_CBSIZE+sizeof(CFG_PROMPT)+16) /* Print Buffer Size */
  361. #define CFG_MAXARGS 16 /* max number of command args*/
  362. #define CFG_BARGSIZE CFG_CBSIZE /* Boot Argument Buffer Size */
  363. /* Default load address */
  364. #if (CFG_SRAM_SIZE != 0)
  365. /* default in SRAM */
  366. #define CFG_LOAD_ADDR CFG_SRAM_BASE
  367. #elif (CFG_SDRAM_SIZE != 0)
  368. /* default in SDRAM */
  369. #if (CFG_SDRAM_BASE == CFG_NIOS_CPU_VEC_BASE)
  370. #define CFG_LOAD_ADDR (CFG_SDRAM_BASE + CFG_NIOS_CPU_VEC_SIZE)
  371. #else
  372. #define CFG_LOAD_ADDR CFG_SDRAM_BASE
  373. #endif
  374. #else
  375. #undef CFG_LOAD_ADDR /* force error break */
  376. #endif
  377. /* MEM test area */
  378. #if (CFG_SDRAM_SIZE != 0)
  379. /* SDRAM begin to stack area (1MB stack) */
  380. #if (CFG_SDRAM_BASE == CFG_NIOS_CPU_VEC_BASE)
  381. #define CFG_MEMTEST_START (CFG_SDRAM_BASE + CFG_NIOS_CPU_VEC_SIZE)
  382. #define CFG_MEMTEST_END (CFG_INIT_SP - (1024 * 1024))
  383. #else
  384. #define CFG_MEMTEST_START CFG_SDRAM_BASE
  385. #define CFG_MEMTEST_END (CFG_INIT_SP - (1024 * 1024))
  386. #endif
  387. #else
  388. #undef CFG_MEMTEST_START /* force error break */
  389. #undef CFG_MEMTEST_END
  390. #endif
  391. #endif /* __CONFIG_H */