pic32mzdask.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. /*
  2. * (c) 2015 Purna Chandra Mandal <purna.mandal@microchip.com>
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. *
  6. * Microchip PIC32MZ[DA] Starter Kit.
  7. */
  8. #ifndef __PIC32MZDASK_CONFIG_H
  9. #define __PIC32MZDASK_CONFIG_H
  10. /* System Configuration */
  11. /*--------------------------------------------
  12. * CPU configuration
  13. */
  14. /* CPU Timer rate */
  15. #define CONFIG_SYS_MIPS_TIMER_FREQ 100000000
  16. /* Cache Configuration */
  17. #define CONFIG_SYS_MIPS_CACHE_MODE CONF_CM_CACHABLE_NONCOHERENT
  18. /*----------------------------------------------------------------------
  19. * Memory Layout
  20. */
  21. #define CONFIG_SYS_SRAM_BASE 0x80000000
  22. #define CONFIG_SYS_SRAM_SIZE 0x00080000 /* 512K */
  23. /* Initial RAM for temporary stack, global data */
  24. #define CONFIG_SYS_INIT_RAM_SIZE 0x10000
  25. #define CONFIG_SYS_INIT_RAM_ADDR \
  26. (CONFIG_SYS_SRAM_BASE + CONFIG_SYS_SRAM_SIZE - CONFIG_SYS_INIT_RAM_SIZE)
  27. #define CONFIG_SYS_INIT_SP_ADDR \
  28. (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_RAM_SIZE - 1)
  29. /* SDRAM Configuration (for final code, data, stack, heap) */
  30. #define CONFIG_SYS_SDRAM_BASE 0x88000000
  31. #define CONFIG_SYS_MALLOC_LEN (256 << 10)
  32. #define CONFIG_SYS_BOOTPARAMS_LEN (4 << 10)
  33. #define CONFIG_STACKSIZE (4 << 10) /* regular stack */
  34. #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE
  35. #define CONFIG_SYS_MONITOR_LEN (192 << 10)
  36. #define CONFIG_SYS_LOAD_ADDR 0x88500000 /* default load address */
  37. #define CONFIG_SYS_ENV_ADDR 0x88300000
  38. #define CONFIG_SYS_FDT_ADDR 0x89d00000
  39. /* Memory Test */
  40. #define CONFIG_SYS_MEMTEST_START 0x88000000
  41. #define CONFIG_SYS_MEMTEST_END 0x88080000
  42. /*----------------------------------------------------------------------
  43. * Commands
  44. */
  45. #define CONFIG_SYS_LONGHELP /* undef to save memory */
  46. #define CONFIG_CMD_CLK
  47. /*-------------------------------------------------
  48. * FLASH configuration
  49. */
  50. #define CONFIG_SYS_NO_FLASH
  51. /*------------------------------------------------------------
  52. * Console Configuration
  53. */
  54. #define CONFIG_BAUDRATE 115200
  55. #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
  56. #define CONFIG_SYS_MAXARGS 16 /* max number of command args*/
  57. #define CONFIG_SYS_PBSIZE \
  58. (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
  59. #define CONFIG_CMDLINE_EDITING 1
  60. /*-----------------------------------------------------------------------
  61. * Networking Configuration
  62. */
  63. #define CONFIG_MII
  64. #define CONFIG_PHY_SMSC
  65. #define CONFIG_SYS_RX_ETH_BUFFER 8
  66. #define CONFIG_NET_RETRY_COUNT 20
  67. #define CONFIG_ARP_TIMEOUT 500 /* millisec */
  68. /*
  69. * BOOTP options
  70. */
  71. #define CONFIG_BOOTP_BOOTFILESIZE
  72. #define CONFIG_BOOTP_BOOTPATH
  73. #define CONFIG_BOOTP_GATEWAY
  74. #define CONFIG_BOOTP_HOSTNAME
  75. /*-----------------------------------------------------------------------
  76. * SDHC Configuration
  77. */
  78. #define CONFIG_GENERIC_MMC
  79. /*--------------------------------------------------
  80. * USB Configuration
  81. */
  82. #define CONFIG_USB_MUSB_PIO_ONLY
  83. /*-----------------------------------------------------------------------
  84. * File System Configuration
  85. */
  86. /* FAT FS */
  87. #define CONFIG_DOS_PARTITION
  88. #define CONFIG_PARTITION_UUIDS
  89. #define CONFIG_SUPPORT_VFAT
  90. #define CONFIG_FS_FAT
  91. #define CONFIG_FAT_WRITE
  92. #define CONFIG_CMD_PART
  93. /* EXT4 FS */
  94. #define CONFIG_FS_EXT4
  95. /* -------------------------------------------------
  96. * Environment
  97. */
  98. #define CONFIG_ENV_IS_NOWHERE 1
  99. #define CONFIG_ENV_SIZE 0x4000
  100. /* ---------------------------------------------------------------------
  101. * Board boot configuration
  102. */
  103. #define CONFIG_TIMESTAMP /* Print image info with timestamp */
  104. #define MEM_LAYOUT_ENV_SETTINGS \
  105. "kernel_addr_r="__stringify(CONFIG_SYS_LOAD_ADDR)"\0" \
  106. "fdt_addr_r="__stringify(CONFIG_SYS_FDT_ADDR)"\0" \
  107. "scriptaddr="__stringify(CONFIG_SYS_ENV_ADDR)"\0"
  108. #define CONFIG_LEGACY_BOOTCMD_ENV \
  109. "legacy_bootcmd= " \
  110. "if load mmc 0 ${scriptaddr} uEnv.txt; then " \
  111. "env import -tr ${scriptaddr} ${filesize}; " \
  112. "if test -n \"${bootcmd_uenv}\" ; then " \
  113. "echo Running bootcmd_uenv ...; " \
  114. "run bootcmd_uenv; " \
  115. "fi; " \
  116. "fi; \0"
  117. #define BOOT_TARGET_DEVICES(func) \
  118. func(MMC, mmc, 0) \
  119. func(USB, usb, 0) \
  120. func(DHCP, dhcp, na)
  121. #include <config_distro_bootcmd.h>
  122. #define CONFIG_EXTRA_ENV_SETTINGS \
  123. MEM_LAYOUT_ENV_SETTINGS \
  124. CONFIG_LEGACY_BOOTCMD_ENV \
  125. BOOTENV
  126. #undef CONFIG_BOOTCOMMAND
  127. #define CONFIG_BOOTCOMMAND "run distro_bootcmd || run legacy_bootcmd"
  128. #endif /* __PIC32MZDASK_CONFIG_H */