ls1046a_common.h 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. /*
  2. * Copyright 2016 Freescale Semiconductor
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef __LS1046A_COMMON_H
  7. #define __LS1046A_COMMON_H
  8. #define CONFIG_REMAKE_ELF
  9. #define CONFIG_FSL_LAYERSCAPE
  10. #define CONFIG_MP
  11. #define CONFIG_SYS_FSL_CLK
  12. #define CONFIG_GICV2
  13. #include <asm/arch/config.h>
  14. /* Link Definitions */
  15. #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_FSL_OCRAM_BASE + 0xfff0)
  16. #define CONFIG_SUPPORT_RAW_INITRD
  17. #define CONFIG_SKIP_LOWLEVEL_INIT
  18. #define CONFIG_BOARD_EARLY_INIT_F 1
  19. #define CONFIG_VERY_BIG_RAM
  20. #define CONFIG_SYS_DDR_SDRAM_BASE 0x80000000
  21. #define CONFIG_SYS_FSL_DDR_SDRAM_BASE_PHY 0
  22. #define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_SDRAM_BASE
  23. #define CONFIG_SYS_DDR_BLOCK2_BASE 0x880000000ULL
  24. #define CPU_RELEASE_ADDR secondary_boot_func
  25. /* Generic Timer Definitions */
  26. #define COUNTER_FREQUENCY 25000000 /* 25MHz */
  27. /* Size of malloc() pool */
  28. #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 1024 * 1024)
  29. /* Serial Port */
  30. #define CONFIG_CONS_INDEX 1
  31. #define CONFIG_SYS_NS16550_SERIAL
  32. #define CONFIG_SYS_NS16550_REG_SIZE 1
  33. #define CONFIG_SYS_NS16550_CLK (get_bus_freq(0)/2)
  34. #define CONFIG_BAUDRATE 115200
  35. #define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 }
  36. /* SD boot SPL */
  37. #ifdef CONFIG_SD_BOOT
  38. #define CONFIG_SPL_FRAMEWORK
  39. #define CONFIG_SPL_LDSCRIPT "arch/arm/cpu/armv8/u-boot-spl.lds"
  40. #define CONFIG_SPL_TARGET "u-boot-with-spl.bin"
  41. #define CONFIG_SPL_LIBCOMMON_SUPPORT
  42. #define CONFIG_SPL_LIBGENERIC_SUPPORT
  43. #define CONFIG_SPL_ENV_SUPPORT
  44. #define CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT
  45. #define CONFIG_SPL_WATCHDOG_SUPPORT
  46. #define CONFIG_SPL_I2C_SUPPORT
  47. #define CONFIG_SPL_SERIAL_SUPPORT
  48. #define CONFIG_SPL_DRIVERS_MISC_SUPPORT
  49. #define CONFIG_SPL_MMC_SUPPORT
  50. #define CONFIG_SPL_TEXT_BASE 0x10000000
  51. #define CONFIG_SPL_MAX_SIZE 0x1f000 /* 124 KiB */
  52. #define CONFIG_SPL_STACK 0x10020000
  53. #define CONFIG_SPL_PAD_TO 0x21000 /* 132 KiB */
  54. #define CONFIG_SPL_BSS_START_ADDR 0x8f000000
  55. #define CONFIG_SPL_BSS_MAX_SIZE 0x80000
  56. #define CONFIG_SYS_SPL_MALLOC_START (CONFIG_SPL_BSS_START_ADDR + \
  57. CONFIG_SPL_BSS_MAX_SIZE)
  58. #define CONFIG_SYS_SPL_MALLOC_SIZE 0x100000
  59. #define CONFIG_SYS_MONITOR_LEN 0xa0000
  60. #endif
  61. /* NAND SPL */
  62. #ifdef CONFIG_NAND_BOOT
  63. #define CONFIG_SPL_PBL_PAD
  64. #define CONFIG_SPL_FRAMEWORK
  65. #define CONFIG_SPL_LDSCRIPT "arch/arm/cpu/armv8/u-boot-spl.lds"
  66. #define CONFIG_SPL_TARGET "u-boot-with-spl.bin"
  67. #define CONFIG_SPL_LIBCOMMON_SUPPORT
  68. #define CONFIG_SPL_LIBGENERIC_SUPPORT
  69. #define CONFIG_SPL_ENV_SUPPORT
  70. #define CONFIG_SPL_WATCHDOG_SUPPORT
  71. #define CONFIG_SPL_I2C_SUPPORT
  72. #define CONFIG_SPL_SERIAL_SUPPORT
  73. #define CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT
  74. #define CONFIG_SPL_NAND_SUPPORT
  75. #define CONFIG_SPL_DRIVERS_MISC_SUPPORT
  76. #define CONFIG_SPL_TEXT_BASE 0x10000000
  77. #define CONFIG_SPL_MAX_SIZE 0x1d000 /* 116 KiB */
  78. #define CONFIG_SPL_STACK 0x1001f000
  79. #define CONFIG_SYS_NAND_U_BOOT_DST CONFIG_SYS_TEXT_BASE
  80. #define CONFIG_SYS_NAND_U_BOOT_START CONFIG_SYS_TEXT_BASE
  81. #define CONFIG_SPL_BSS_START_ADDR 0x8f000000
  82. #define CONFIG_SPL_BSS_MAX_SIZE 0x80000
  83. #define CONFIG_SYS_SPL_MALLOC_START (CONFIG_SPL_BSS_START_ADDR + \
  84. CONFIG_SPL_BSS_MAX_SIZE)
  85. #define CONFIG_SYS_SPL_MALLOC_SIZE 0x100000
  86. #define CONFIG_SYS_MONITOR_LEN 0xa0000
  87. #endif
  88. /* I2C */
  89. #define CONFIG_SYS_I2C
  90. #define CONFIG_SYS_I2C_MXC
  91. #define CONFIG_SYS_I2C_MXC_I2C1
  92. #define CONFIG_SYS_I2C_MXC_I2C2
  93. #define CONFIG_SYS_I2C_MXC_I2C3
  94. #define CONFIG_SYS_I2C_MXC_I2C4
  95. /* Command line configuration */
  96. #define CONFIG_CMD_ENV
  97. /* MMC */
  98. #ifdef CONFIG_MMC
  99. #define CONFIG_FSL_ESDHC
  100. #define CONFIG_SYS_FSL_MMC_HAS_CAPBLT_VS33
  101. #define CONFIG_GENERIC_MMC
  102. #define CONFIG_DOS_PARTITION
  103. #endif
  104. #define CONFIG_FSL_CAAM /* Enable SEC/CAAM */
  105. #define CONFIG_SYS_DPAA_QBMAN /* Support Q/Bman */
  106. /* FMan ucode */
  107. #define CONFIG_SYS_DPAA_FMAN
  108. #ifdef CONFIG_SYS_DPAA_FMAN
  109. #define CONFIG_SYS_FM_MURAM_SIZE 0x60000
  110. #ifdef CONFIG_SD_BOOT
  111. /*
  112. * PBL SD boot image should stored at 0x1000(8 blocks), the size of the image is
  113. * about 1MB (2048 blocks), Env is stored after the image, and the env size is
  114. * 0x2000 (16 blocks), 8 + 2048 + 16 = 2072, enlarge it to 2080(0x820).
  115. */
  116. #define CONFIG_SYS_QE_FMAN_FW_IN_MMC
  117. #define CONFIG_SYS_FMAN_FW_ADDR (512 * 0x820)
  118. #elif defined(CONFIG_QSPI_BOOT)
  119. #define CONFIG_SYS_QE_FW_IN_SPIFLASH
  120. #define CONFIG_SYS_FMAN_FW_ADDR 0x40300000
  121. #define CONFIG_ENV_SPI_BUS 0
  122. #define CONFIG_ENV_SPI_CS 0
  123. #define CONFIG_ENV_SPI_MAX_HZ 1000000
  124. #define CONFIG_ENV_SPI_MODE 0x03
  125. #elif defined(CONFIG_NAND_BOOT)
  126. #define CONFIG_SYS_QE_FMAN_FW_IN_NAND
  127. #define CONFIG_SYS_FMAN_FW_ADDR (6 * CONFIG_SYS_NAND_BLOCK_SIZE)
  128. #else
  129. #define CONFIG_SYS_QE_FMAN_FW_IN_NOR
  130. #define CONFIG_SYS_FMAN_FW_ADDR 0x60300000
  131. #endif
  132. #define CONFIG_SYS_QE_FMAN_FW_LENGTH 0x10000
  133. #define CONFIG_SYS_FDT_PAD (0x3000 + CONFIG_SYS_QE_FMAN_FW_LENGTH)
  134. #endif
  135. /* Miscellaneous configurable options */
  136. #define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_DDR_SDRAM_BASE + 0x10000000)
  137. #define CONFIG_ARCH_EARLY_INIT_R
  138. #define CONFIG_BOARD_LATE_INIT
  139. #define CONFIG_HWCONFIG
  140. #define HWCONFIG_BUFFER_SIZE 128
  141. /* Initial environment variables */
  142. #define CONFIG_EXTRA_ENV_SETTINGS \
  143. "hwconfig=fsl_ddr:bank_intlv=auto\0" \
  144. "loadaddr=0x80100000\0" \
  145. "ramdisk_addr=0x800000\0" \
  146. "ramdisk_size=0x2000000\0" \
  147. "fdt_high=0xffffffffffffffff\0" \
  148. "initrd_high=0xffffffffffffffff\0" \
  149. "kernel_start=0x1000000\0" \
  150. "kernel_load=0xa0000000\0" \
  151. "kernel_size=0x2800000\0" \
  152. "console=ttyS0,115200\0" \
  153. MTDPARTS_DEFAULT "\0"
  154. #define CONFIG_BOOTARGS "console=ttyS0,115200 root=/dev/ram0 " \
  155. "earlycon=uart8250,mmio,0x21c0500 " \
  156. MTDPARTS_DEFAULT
  157. /* Monitor Command Prompt */
  158. #define CONFIG_SYS_CBSIZE 512 /* Console I/O Buffer Size */
  159. #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \
  160. sizeof(CONFIG_SYS_PROMPT) + 16)
  161. #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot args buffer */
  162. #define CONFIG_SYS_LONGHELP
  163. #define CONFIG_CMDLINE_EDITING 1
  164. #define CONFIG_AUTO_COMPLETE
  165. #define CONFIG_SYS_MAXARGS 64 /* max command args */
  166. #define CONFIG_SYS_BOOTM_LEN (64 << 20) /* Increase max gunzip size */
  167. /* Hash command with SHA acceleration supported in hardware */
  168. #ifdef CONFIG_FSL_CAAM
  169. #define CONFIG_CMD_HASH
  170. #define CONFIG_SHA_HW_ACCEL
  171. #endif
  172. #endif /* __LS1046A_COMMON_H */