kp_imx6q_tpc.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. /*
  2. * K+P iMX6Q KP_IMX6Q_TPC board configuration
  3. *
  4. * Copyright (C) 2018 Lukasz Majewski <lukma@denx.de>
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #ifndef __KP_IMX6Q_TPC_IMX6_CONFIG_H_
  9. #define __KP_IMX6Q_TPC_IMX6_CONFIG_H_
  10. #include <asm/arch/imx-regs.h>
  11. #include "mx6_common.h"
  12. /* SPL */
  13. #include "imx6_spl.h" /* common IMX6 SPL configuration */
  14. /* Miscellaneous configurable options */
  15. #define CONFIG_CMDLINE_TAG
  16. #define CONFIG_SETUP_MEMORY_TAGS
  17. #define CONFIG_INITRD_TAG
  18. #define CONFIG_REVISION_TAG
  19. #define CONFIG_BOUNCE_BUFFER
  20. /* Size of malloc() pool */
  21. #define CONFIG_SYS_MALLOC_LEN (4 * SZ_1M)
  22. /* FEC ethernet */
  23. #define CONFIG_MII
  24. #define IMX_FEC_BASE ENET_BASE_ADDR
  25. #define CONFIG_FEC_XCV_TYPE RGMII
  26. #define CONFIG_ETHPRIME "FEC"
  27. #define CONFIG_FEC_MXC_PHYADDR 0
  28. #define CONFIG_ARP_TIMEOUT 200UL
  29. /* Fuses */
  30. #ifdef CONFIG_CMD_FUSE
  31. #define CONFIG_MXC_OCOTP
  32. #endif
  33. /* I2C Configs */
  34. #define CONFIG_SYS_I2C
  35. #define CONFIG_SYS_I2C_MXC
  36. #define CONFIG_SYS_I2C_MXC_I2C1 /* enable I2C bus 1 */
  37. #define CONFIG_SYS_I2C_MXC_I2C2 /* enable I2C bus 2 */
  38. #define CONFIG_SYS_I2C_SPEED 100000
  39. /* MMC Configs */
  40. #define CONFIG_FSL_ESDHC
  41. #define CONFIG_FSL_USDHC
  42. #define CONFIG_SYS_FSL_ESDHC_ADDR 0
  43. #define CONFIG_SYS_FSL_USDHC_NUM 2
  44. #define CONFIG_SYS_MMC_ENV_DEV 1 /* 0 = SDHC2, 1 = SDHC4 (eMMC) */
  45. /* UART */
  46. #define CONFIG_MXC_UART
  47. #define CONFIG_MXC_UART_BASE UART1_BASE
  48. #define CONFIG_CONS_INDEX 1
  49. #define CONFIG_BAUDRATE 115200
  50. /* USB Configs */
  51. #ifdef CONFIG_CMD_USB
  52. #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
  53. #define CONFIG_USB_HOST_ETHER
  54. #define CONFIG_USB_ETHER_ASIX
  55. #define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
  56. #define CONFIG_MXC_USB_FLAGS 0
  57. #define CONFIG_USB_MAX_CONTROLLER_COUNT 2 /* Enabled USB controller number */
  58. #endif
  59. /* Watchdog */
  60. #define CONFIG_HW_WATCHDOG
  61. #define CONFIG_IMX_WATCHDOG
  62. #define CONFIG_WATCHDOG_TIMEOUT_MSECS 60000
  63. /* allow to overwrite serial and ethaddr */
  64. #define CONFIG_ENV_OVERWRITE
  65. #define CONFIG_LOADADDR 0x12000000
  66. #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
  67. #ifndef CONFIG_SPL_BUILD
  68. #define CONFIG_EXTRA_ENV_SETTINGS \
  69. "console=ttymxc0,115200\0" \
  70. "fdt_addr=0x18000000\0" \
  71. "fdt_high=0xffffffff\0" \
  72. "initrd_high=0xffffffff\0" \
  73. "kernel_addr_r=0x10008000\0" \
  74. "fdt_addr_r=0x13000000\0" \
  75. "ramdisk_addr_r=0x18000000\0" \
  76. "scriptaddr=0x14000000\0" \
  77. "kernel_file=fitImage\0"\
  78. "rdinit=/sbin/init\0" \
  79. "addinitrd=setenv bootargs ${bootargs} rdinit=${rdinit} ${debug} \0" \
  80. "fit_config=mx6q_tpc70_conf\0" \
  81. "upd_image=st.4k\0" \
  82. "updargs=setenv bootargs console=${console} ${smp}"\
  83. "rdinit=${rdinit} ${debug} ${displayargs}\0" \
  84. "loadusb=usb start; " \
  85. "fatload usb 0 ${loadaddr} ${upd_image}\0" \
  86. "usbupd=echo Booting update from usb ...; " \
  87. "setenv bootargs; " \
  88. "run updargs; " \
  89. "run loadusb; " \
  90. "bootm ${loadaddr}#${fit_config}\0" \
  91. BOOTENV
  92. #define CONFIG_BOOTCOMMAND "run usbupd; run distro_bootcmd"
  93. #define BOOT_TARGET_DEVICES(func) \
  94. func(MMC, mmc, 0) \
  95. func(MMC, mmc, 1) \
  96. func(USB, usb, 0) \
  97. func(DHCP, dhcp, na)
  98. #include <config_distro_bootcmd.h>
  99. #endif
  100. /* Physical Memory Map */
  101. #define CONFIG_NR_DRAM_BANKS 1
  102. #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
  103. #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
  104. #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
  105. #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
  106. #define CONFIG_SYS_INIT_SP_OFFSET \
  107. (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
  108. #define CONFIG_SYS_INIT_SP_ADDR \
  109. (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
  110. /* Environment */
  111. #define CONFIG_ENV_SIZE (SZ_8K)
  112. #define CONFIG_ENV_OFFSET 0x100000
  113. #define CONFIG_ENV_OFFSET_REDUND (CONFIG_ENV_OFFSET + CONFIG_ENV_SIZE)
  114. #define CONFIG_SYS_REDUNDAND_ENVIRONMENT
  115. #endif /* __KP_IMX6Q_TPC_IMX6_CONFIG_H_ */