uboot/include/configs/colibri_imx6.h
<<
>>
Prefs
   1/*
   2 * Copyright 2013-2015 Toradex, Inc.
   3 *
   4 * Configuration settings for the Toradex Colibri iMX6
   5 *
   6 * SPDX-License-Identifier:     GPL-2.0+
   7 */
   8
   9#ifndef __CONFIG_H
  10#define __CONFIG_H
  11
  12#include "mx6_common.h"
  13#define CONFIG_SYS_THUMB_BUILD
  14
  15#undef CONFIG_DISPLAY_BOARDINFO
  16#define CONFIG_DISPLAY_BOARDINFO_LATE   /* Calls show_board_info() */
  17
  18#define CONFIG_SYS_GENERIC_BOARD
  19
  20#include <asm/arch/imx-regs.h>
  21#include <asm/imx-common/gpio.h>
  22
  23#ifdef CONFIG_SPL
  24#include "imx6_spl.h"
  25#define CONFIG_SPL_PAD_TO               0x11000 /* 4k IVT/DCD, 64k SPL */
  26#endif
  27
  28#define CONFIG_CMDLINE_TAG
  29#define CONFIG_SETUP_MEMORY_TAGS
  30#define CONFIG_INITRD_TAG
  31#define CONFIG_REVISION_TAG
  32#define CONFIG_SERIAL_TAG
  33
  34/* Size of malloc() pool */
  35#define CONFIG_SYS_MALLOC_LEN           (32 * 1024 * 1024)
  36
  37#define CONFIG_BOARD_EARLY_INIT_F
  38#define CONFIG_BOARD_LATE_INIT
  39#define CONFIG_MISC_INIT_R
  40
  41#define CONFIG_MXC_UART
  42#define CONFIG_MXC_UART_BASE            UART1_BASE
  43
  44/* Make the HW version stuff available in U-Boot env */
  45#define CONFIG_VERSION_VARIABLE         /* ver environment variable */
  46#define CONFIG_ENV_VARS_UBOOT_CONFIG
  47#define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
  48
  49/* I2C Configs */
  50#define CONFIG_SYS_I2C
  51#define CONFIG_SYS_I2C_MXC
  52#define CONFIG_SYS_I2C_MXC_I2C1         /* enable I2C bus 1 */
  53#define CONFIG_SYS_I2C_MXC_I2C2         /* enable I2C bus 2 */
  54#define CONFIG_SYS_I2C_MXC_I2C3         /* enable I2C bus 3 */
  55#define CONFIG_SYS_I2C_SPEED            100000
  56
  57/* OCOTP Configs */
  58#define CONFIG_CMD_FUSE
  59#ifdef CONFIG_CMD_FUSE
  60#define CONFIG_MXC_OCOTP
  61#endif
  62
  63/* MMC Configs */
  64#define CONFIG_FSL_ESDHC
  65#define CONFIG_FSL_USDHC
  66#define CONFIG_SYS_FSL_ESDHC_ADDR       0
  67#define CONFIG_SYS_FSL_USDHC_NUM        2
  68
  69#define CONFIG_SUPPORT_EMMC_BOOT        /* eMMC specific */
  70#define CONFIG_GENERIC_MMC
  71#define CONFIG_BOUNCE_BUFFER
  72#define CONFIG_FAT_WRITE
  73#define CONFIG_DOS_PARTITION
  74
  75/* Network */
  76#define CONFIG_FEC_MXC
  77#define CONFIG_MII
  78#define IMX_FEC_BASE                    ENET_BASE_ADDR
  79#define CONFIG_FEC_XCV_TYPE             RMII
  80#define CONFIG_ETHPRIME                 "FEC"
  81#define CONFIG_FEC_MXC_PHYADDR          1
  82#define CONFIG_PHYLIB
  83#define CONFIG_PHY_MICREL
  84#define CONFIG_IP_DEFRAG
  85#define CONFIG_TFTP_BLOCKSIZE           16352
  86#define CONFIG_TFTP_TSIZE
  87
  88/* USB Configs */
  89/* Host */
  90#define CONFIG_USB_HOST_ETHER
  91#define CONFIG_USB_MAX_CONTROLLER_COUNT         2
  92#define CONFIG_EHCI_HCD_INIT_AFTER_RESET        /* For OTG port */
  93#define CONFIG_MXC_USB_PORTSC           (PORT_PTS_UTMI | PORT_PTS_PTW)
  94#define CONFIG_MXC_USB_FLAGS            0
  95#define CONFIG_USB_KEYBOARD
  96#ifdef CONFIG_USB_KEYBOARD
  97#define CONFIG_SYS_USB_EVENT_POLL
  98#endif /* CONFIG_USB_KEYBOARD */
  99/* Client */
 100#define CONFIG_USB_GADGET_VBUS_DRAW     2
 101#define CONFIG_USBD_HS
 102
 103#define CONFIG_USB_GADGET_MASS_STORAGE
 104#define CONFIG_USB_FUNCTION_MASS_STORAGE
 105#define CONFIG_G_DNL_MANUFACTURER       "Toradex"
 106/* USB DFU */
 107#define CONFIG_DFU_MMC
 108
 109/* Miscellaneous commands */
 110#define CONFIG_CMD_BMODE
 111#define CONFIG_MXC_GPIO
 112
 113/* Framebuffer and LCD */
 114#define CONFIG_VIDEO_IPUV3
 115#define CONFIG_SYS_CONSOLE_IS_IN_ENV
 116#define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
 117#define CONFIG_VIDEO_BMP_RLE8
 118#define CONFIG_SPLASH_SCREEN
 119#define CONFIG_SPLASH_SCREEN_ALIGN
 120#define CONFIG_BMP_16BPP
 121#define CONFIG_VIDEO_LOGO
 122#define CONFIG_VIDEO_BMP_LOGO
 123#define CONFIG_IPUV3_CLK                260000000
 124#define CONFIG_CMD_HDMIDETECT
 125#define CONFIG_CONSOLE_MUX
 126#define CONFIG_IMX_HDMI
 127#define CONFIG_IMX_VIDEO_SKIP
 128#define CONFIG_CMD_BMP
 129
 130/* allow to overwrite serial and ethaddr */
 131#define CONFIG_ENV_OVERWRITE
 132#define CONFIG_CONS_INDEX               1
 133#define CONFIG_BAUDRATE                 115200
 134
 135/* Command definition */
 136#undef CONFIG_CMD_LOADB
 137#undef CONFIG_CMD_LOADS
 138#undef CONFIG_CMD_NFS
 139#undef CONFIG_CMD_FLASH
 140
 141#undef CONFIG_IPADDR
 142#define CONFIG_IPADDR                   192.168.10.2
 143#define CONFIG_NETMASK                  255.255.255.0
 144#undef CONFIG_SERVERIP
 145#define CONFIG_SERVERIP                 192.168.10.1
 146
 147#define CONFIG_LOADADDR                 0x12000000
 148#define CONFIG_SYS_TEXT_BASE            0x17800000
 149
 150#ifdef CONFIG_CMD_MMC
 151#define CONFIG_DRIVE_MMC "mmc "
 152#else
 153#define CONFIG_DRIVE_MMC
 154#endif
 155
 156#define CONFIG_DRIVE_TYPES CONFIG_DRIVE_MMC
 157
 158#define DFU_ALT_EMMC_INFO \
 159        "u-boot.imx raw 0x2 0x3ff mmcpart 0;" \
 160        "boot part 0 1;" \
 161        "rootfs part 0 2;" \
 162        "uImage fat 0 1;" \
 163        "imx6q-colibri-eval-v3.dtb fat 0 1;" \
 164        "imx6q-colibri-cam-eval-v3.dtb fat 0 1"
 165
 166#define EMMC_BOOTCMD \
 167        "emmcargs=ip=off root=/dev/mmcblk0p2 rw,noatime rootfstype=ext3 " \
 168                "rootwait\0" \
 169        "emmcboot=run setup; " \
 170                "setenv bootargs ${defargs} ${emmcargs} ${setupargs} " \
 171                "${vidargs}; echo Booting from internal eMMC chip...; " \
 172                "run emmcdtbload; load mmc 0:1 ${kernel_addr_r} " \
 173                "${boot_file} && run fdt_fixup && " \
 174                "bootm ${kernel_addr_r} ${dtbparam}\0" \
 175        "emmcdtbload=setenv dtbparam; load mmc 0:1 ${fdt_addr_r} " \
 176                "${fdt_file} && setenv dtbparam \" - ${fdt_addr_r}\" && true\0"
 177
 178#define MEM_LAYOUT_ENV_SETTINGS \
 179        "fdt_addr_r=0x12000000\0" \
 180        "fdt_high=0xffffffff\0" \
 181        "initrd_high=0xffffffff\0" \
 182        "kernel_addr_r=0x11000000\0" \
 183        "ramdisk_addr_r=0x12100000\0"
 184
 185#define NFS_BOOTCMD \
 186        "nfsargs=ip=:::::eth0:on root=/dev/nfs rw\0" \
 187        "nfsboot=run setup; " \
 188                "setenv bootargs ${defargs} ${nfsargs} ${setupargs} " \
 189                "${vidargs}; echo Booting via DHCP/TFTP/NFS...; " \
 190                "run nfsdtbload; dhcp ${kernel_addr_r} " \
 191                "&& run fdt_fixup && bootm ${kernel_addr_r} ${dtbparam}\0" \
 192        "nfsdtbload=setenv dtbparam; tftp ${fdt_addr_r} ${fdt_file} " \
 193                "&& setenv dtbparam \" - ${fdt_addr_r}\" && true\0"
 194
 195#define SD_BOOTCMD                                              \
 196        "sdargs=ip=off root=/dev/mmcblk1p2 rw,noatime rootfstype=ext3 " \
 197                "rootwait\0" \
 198        "sdboot=run setup; " \
 199                "setenv bootargs ${defargs} ${sdargs} ${setupargs} " \
 200                "${vidargs}; echo Booting from SD card; " \
 201                "run sddtbload; load mmc 1:1 ${kernel_addr_r} " \
 202                "${boot_file} && run fdt_fixup && " \
 203                "bootm ${kernel_addr_r} ${dtbparam}\0" \
 204        "sddtbload=setenv dtbparam; load mmc 1:1 ${fdt_addr_r} " \
 205                "${fdt_file} && setenv dtbparam \" - ${fdt_addr_r}\" && true\0"
 206
 207#define USB_BOOTCMD \
 208        "usbargs=ip=off root=/dev/sda2 rw,noatime rootfstype=ext3 " \
 209                "rootwait\0" \
 210        "usbboot=run setup; setenv bootargs ${defargs} ${setupargs} " \
 211                "${usbargs} ${vidargs}; echo Booting from USB stick...; " \
 212                "usb start && run usbdtbload; load usb 0:1 ${kernel_addr_r} " \
 213                "${boot_file} && run fdt_fixup && " \
 214                "bootm ${kernel_addr_r} ${dtbparam}\0" \
 215        "usbdtbload=setenv dtbparam; load usb 0:1 ${fdt_addr_r} " \
 216                "${fdt_file} && setenv dtbparam \" - ${fdt_addr_r}\" && true\0"
 217
 218#define FDT_FILE "imx6dl-colibri-eval-v3.dtb"
 219#define CONFIG_EXTRA_ENV_SETTINGS \
 220        "bootcmd=run emmcboot ; echo ; echo emmcboot failed ; " \
 221                "run nfsboot ; echo ; echo nfsboot failed ; " \
 222                "usb start ;" \
 223                "setenv stdout serial,vga ; setenv stdin serial,usbkbd\0" \
 224        "boot_file=uImage\0" \
 225        "console=ttymxc0\0" \
 226        "defargs=enable_wait_mode=off galcore.contiguousSize=50331648\0" \
 227        "dfu_alt_info=" DFU_ALT_EMMC_INFO "\0" \
 228        EMMC_BOOTCMD \
 229        "fdt_file=" FDT_FILE "\0" \
 230        "fdt_fixup=;\0" \
 231        MEM_LAYOUT_ENV_SETTINGS \
 232        NFS_BOOTCMD \
 233        SD_BOOTCMD \
 234        "setethupdate=if env exists ethaddr; then; else setenv ethaddr " \
 235                "00:14:2d:00:00:00; fi; tftpboot ${loadaddr} " \
 236                "flash_eth.img && source ${loadaddr}\0" \
 237        "setsdupdate=setenv interface mmc; setenv drive 1; mmc rescan; load " \
 238                "${interface} ${drive}:1 ${loadaddr} flash_blk.img && " \
 239                "source ${loadaddr}\0" \
 240        "setup=setenv setupargs fec_mac=${ethaddr} " \
 241                "consoleblank=0 no_console_suspend=1 console=tty1 " \
 242                "console=${console},${baudrate}n8\0 " \
 243        "setupdate=run setsdupdate || run setusbupdate || run setethupdate\0" \
 244        "setusbupdate=usb start && setenv interface usb; setenv drive 0; " \
 245                "load ${interface} ${drive}:1 ${loadaddr} flash_blk.img && " \
 246                "source ${loadaddr}\0" \
 247        "splashpos=m,m\0" \
 248        "vidargs=video=mxcfb0:dev=lcd,640x480M@60,if=RGB666 " \
 249                "video=mxcfb1:off fbmem=8M\0 "
 250
 251/* Miscellaneous configurable options */
 252#define CONFIG_SYS_LONGHELP
 253#define CONFIG_AUTO_COMPLETE
 254#undef CONFIG_SYS_CBSIZE
 255#define CONFIG_SYS_CBSIZE               1024
 256#undef CONFIG_SYS_MAXARGS
 257#define CONFIG_SYS_MAXARGS              48
 258
 259#define CONFIG_SYS_ALT_MEMTEST
 260#define CONFIG_SYS_MEMTEST_START        0x10000000
 261#define CONFIG_SYS_MEMTEST_END          0x10010000
 262#define CONFIG_SYS_MEMTEST_SCRATCH      0x10800000
 263
 264#define CONFIG_SYS_LOAD_ADDR            CONFIG_LOADADDR
 265
 266#define CONFIG_CMDLINE_EDITING
 267
 268/* Physical Memory Map */
 269#define CONFIG_NR_DRAM_BANKS            1
 270#define PHYS_SDRAM                      MMDC0_ARB_BASE_ADDR
 271
 272#define CONFIG_SYS_SDRAM_BASE           PHYS_SDRAM
 273#define CONFIG_SYS_INIT_RAM_ADDR        IRAM_BASE_ADDR
 274#define CONFIG_SYS_INIT_RAM_SIZE        IRAM_SIZE
 275
 276#define CONFIG_SYS_INIT_SP_OFFSET \
 277        (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
 278#define CONFIG_SYS_INIT_SP_ADDR \
 279        (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
 280
 281/* FLASH and environment organization */
 282#define CONFIG_SYS_NO_FLASH
 283
 284#define CONFIG_ENV_SIZE                 (8 * 1024)
 285
 286#define CONFIG_ENV_IS_IN_MMC
 287
 288#if defined(CONFIG_ENV_IS_IN_MMC)
 289/* Environment in eMMC, before config block at the end of 1st "boot sector" */
 290#define CONFIG_ENV_OFFSET               (-CONFIG_ENV_SIZE + \
 291                                         CONFIG_TDX_CFG_BLOCK_OFFSET)
 292#define CONFIG_SYS_MMC_ENV_DEV          0
 293#define CONFIG_SYS_MMC_ENV_PART         1
 294#endif
 295
 296#define CONFIG_OF_SYSTEM_SETUP
 297
 298#define CONFIG_CMD_TIME
 299
 300#define CONFIG_SUPPORT_RAW_INITRD
 301
 302#define CONFIG_CRC32_VERIFY
 303
 304#endif  /* __CONFIG_H */
 305