1c1747970SPierre Aubert /* 2c1747970SPierre Aubert * Copyright (C) 2012 Freescale Semiconductor, Inc. 3c1747970SPierre Aubert * 4c1747970SPierre Aubert * Configuration settings for the Freescale i.MX6Q SabreSD board. 5c1747970SPierre Aubert * 61a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 7c1747970SPierre Aubert */ 8c1747970SPierre Aubert 9c1747970SPierre Aubert #ifndef __MX6QSABRE_COMMON_CONFIG_H 10c1747970SPierre Aubert #define __MX6QSABRE_COMMON_CONFIG_H 11c1747970SPierre Aubert 12c1747970SPierre Aubert #include "mx6_common.h" 13c1747970SPierre Aubert 141368f993SAdrian Alonso #define CONFIG_IMX_THERMAL 156c920ee9SYe.Li 16c1747970SPierre Aubert /* Size of malloc() pool */ 1758cc9787SPardeep Kumar Singla #define CONFIG_SYS_MALLOC_LEN (10 * SZ_1M) 18c1747970SPierre Aubert 19c1747970SPierre Aubert #define CONFIG_BOARD_EARLY_INIT_F 20c1747970SPierre Aubert #define CONFIG_BOARD_LATE_INIT 21c1747970SPierre Aubert 22c1747970SPierre Aubert #define CONFIG_MXC_UART 23c1747970SPierre Aubert 24c1747970SPierre Aubert /* MMC Configs */ 25c1747970SPierre Aubert #define CONFIG_SYS_FSL_ESDHC_ADDR 0 26c1747970SPierre Aubert 27c1747970SPierre Aubert #define CONFIG_CMD_PING 28c1747970SPierre Aubert #define CONFIG_CMD_DHCP 29c1747970SPierre Aubert #define CONFIG_CMD_MII 30c1747970SPierre Aubert #define CONFIG_FEC_MXC 31c1747970SPierre Aubert #define CONFIG_MII 32c1747970SPierre Aubert #define IMX_FEC_BASE ENET_BASE_ADDR 33c1747970SPierre Aubert #define CONFIG_FEC_XCV_TYPE RGMII 34c1747970SPierre Aubert #define CONFIG_ETHPRIME "FEC" 35c1747970SPierre Aubert #define CONFIG_FEC_MXC_PHYADDR 1 36c1747970SPierre Aubert 37c1747970SPierre Aubert #define CONFIG_PHYLIB 38c1747970SPierre Aubert #define CONFIG_PHY_ATHEROS 39c1747970SPierre Aubert 408bfa9c69SFabio Estevam #define CONFIG_CMD_SF 418bfa9c69SFabio Estevam #ifdef CONFIG_CMD_SF 428bfa9c69SFabio Estevam #define CONFIG_MXC_SPI 438bfa9c69SFabio Estevam #define CONFIG_SF_DEFAULT_BUS 0 44155fa9afSNikita Kiryanov #define CONFIG_SF_DEFAULT_CS 0 458bfa9c69SFabio Estevam #define CONFIG_SF_DEFAULT_SPEED 20000000 468bfa9c69SFabio Estevam #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0 478bfa9c69SFabio Estevam #endif 488bfa9c69SFabio Estevam 49c1747970SPierre Aubert /* Command definition */ 50c1747970SPierre Aubert #define CONFIG_CMD_BMODE 51c1747970SPierre Aubert 5203ce3302SOtavio Salvador #ifdef CONFIG_SUPPORT_EMMC_BOOT 5303ce3302SOtavio Salvador #define EMMC_ENV \ 5403ce3302SOtavio Salvador "emmcdev=2\0" \ 5503ce3302SOtavio Salvador "update_emmc_firmware=" \ 5603ce3302SOtavio Salvador "if test ${ip_dyn} = yes; then " \ 5703ce3302SOtavio Salvador "setenv get_cmd dhcp; " \ 5803ce3302SOtavio Salvador "else " \ 5903ce3302SOtavio Salvador "setenv get_cmd tftp; " \ 6003ce3302SOtavio Salvador "fi; " \ 6103ce3302SOtavio Salvador "if ${get_cmd} ${update_sd_firmware_filename}; then " \ 624bf83961Smaxin.john@enea.com "if mmc dev ${emmcdev} 1; then " \ 6303ce3302SOtavio Salvador "setexpr fw_sz ${filesize} / 0x200; " \ 6403ce3302SOtavio Salvador "setexpr fw_sz ${fw_sz} + 1; " \ 6503ce3302SOtavio Salvador "mmc write ${loadaddr} 0x2 ${fw_sz}; " \ 6603ce3302SOtavio Salvador "fi; " \ 6703ce3302SOtavio Salvador "fi\0" 6803ce3302SOtavio Salvador #else 6903ce3302SOtavio Salvador #define EMMC_ENV "" 7003ce3302SOtavio Salvador #endif 7103ce3302SOtavio Salvador 72e6fc8995SPeng Fan #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG 73e6fc8995SPeng Fan 74c1747970SPierre Aubert #define CONFIG_EXTRA_ENV_SETTINGS \ 75c1747970SPierre Aubert "script=boot.scr\0" \ 76f2e4288aSOtavio Salvador "image=zImage\0" \ 77e6fc8995SPeng Fan "fdt_file=undefined\0" \ 786584a1b5SOtavio Salvador "fdt_addr=0x18000000\0" \ 79c1747970SPierre Aubert "boot_fdt=try\0" \ 80c1747970SPierre Aubert "ip_dyn=yes\0" \ 81c1747970SPierre Aubert "console=" CONFIG_CONSOLE_DEV "\0" \ 827daaac52SFabio Estevam "dfuspi=dfu 0 sf 0:0:10000000:0\0" \ 837daaac52SFabio Estevam "dfu_alt_info_spl=spl raw 0x400\0" \ 847daaac52SFabio Estevam "dfu_alt_info_img=u-boot raw 0x10000\0" \ 857daaac52SFabio Estevam "dfu_alt_info=spl raw 0x400\0" \ 86c1747970SPierre Aubert "fdt_high=0xffffffff\0" \ 87c1747970SPierre Aubert "initrd_high=0xffffffff\0" \ 88c1747970SPierre Aubert "mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \ 89c1747970SPierre Aubert "mmcpart=1\0" \ 90c1747970SPierre Aubert "mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \ 91c1747970SPierre Aubert "update_sd_firmware=" \ 92c1747970SPierre Aubert "if test ${ip_dyn} = yes; then " \ 93c1747970SPierre Aubert "setenv get_cmd dhcp; " \ 94c1747970SPierre Aubert "else " \ 95c1747970SPierre Aubert "setenv get_cmd tftp; " \ 96c1747970SPierre Aubert "fi; " \ 97c1747970SPierre Aubert "if mmc dev ${mmcdev}; then " \ 98c1747970SPierre Aubert "if ${get_cmd} ${update_sd_firmware_filename}; then " \ 99c1747970SPierre Aubert "setexpr fw_sz ${filesize} / 0x200; " \ 100c1747970SPierre Aubert "setexpr fw_sz ${fw_sz} + 1; " \ 101c1747970SPierre Aubert "mmc write ${loadaddr} 0x2 ${fw_sz}; " \ 102c1747970SPierre Aubert "fi; " \ 103c1747970SPierre Aubert "fi\0" \ 10403ce3302SOtavio Salvador EMMC_ENV \ 105c1747970SPierre Aubert "mmcargs=setenv bootargs console=${console},${baudrate} " \ 106c1747970SPierre Aubert "root=${mmcroot}\0" \ 107c1747970SPierre Aubert "loadbootscript=" \ 108c1747970SPierre Aubert "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \ 109c1747970SPierre Aubert "bootscript=echo Running bootscript from mmc ...; " \ 110c1747970SPierre Aubert "source\0" \ 111f2e4288aSOtavio Salvador "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \ 112c1747970SPierre Aubert "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \ 113c1747970SPierre Aubert "mmcboot=echo Booting from mmc ...; " \ 114c1747970SPierre Aubert "run mmcargs; " \ 115c1747970SPierre Aubert "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \ 116c1747970SPierre Aubert "if run loadfdt; then " \ 117f2e4288aSOtavio Salvador "bootz ${loadaddr} - ${fdt_addr}; " \ 118c1747970SPierre Aubert "else " \ 119c1747970SPierre Aubert "if test ${boot_fdt} = try; then " \ 120f2e4288aSOtavio Salvador "bootz; " \ 121c1747970SPierre Aubert "else " \ 122c1747970SPierre Aubert "echo WARN: Cannot load the DT; " \ 123c1747970SPierre Aubert "fi; " \ 124c1747970SPierre Aubert "fi; " \ 125c1747970SPierre Aubert "else " \ 126f2e4288aSOtavio Salvador "bootz; " \ 127c1747970SPierre Aubert "fi;\0" \ 128c1747970SPierre Aubert "netargs=setenv bootargs console=${console},${baudrate} " \ 129c1747970SPierre Aubert "root=/dev/nfs " \ 130c1747970SPierre Aubert "ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \ 131c1747970SPierre Aubert "netboot=echo Booting from net ...; " \ 132c1747970SPierre Aubert "run netargs; " \ 133c1747970SPierre Aubert "if test ${ip_dyn} = yes; then " \ 134c1747970SPierre Aubert "setenv get_cmd dhcp; " \ 135c1747970SPierre Aubert "else " \ 136c1747970SPierre Aubert "setenv get_cmd tftp; " \ 137c1747970SPierre Aubert "fi; " \ 138f2e4288aSOtavio Salvador "${get_cmd} ${image}; " \ 139c1747970SPierre Aubert "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \ 140c1747970SPierre Aubert "if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \ 141f2e4288aSOtavio Salvador "bootz ${loadaddr} - ${fdt_addr}; " \ 142c1747970SPierre Aubert "else " \ 143c1747970SPierre Aubert "if test ${boot_fdt} = try; then " \ 144f2e4288aSOtavio Salvador "bootz; " \ 145c1747970SPierre Aubert "else " \ 146c1747970SPierre Aubert "echo WARN: Cannot load the DT; " \ 147c1747970SPierre Aubert "fi; " \ 148c1747970SPierre Aubert "fi; " \ 149c1747970SPierre Aubert "else " \ 150f2e4288aSOtavio Salvador "bootz; " \ 151e6fc8995SPeng Fan "fi;\0" \ 152e6fc8995SPeng Fan "findfdt="\ 153e6fc8995SPeng Fan "if test $fdt_file = undefined; then " \ 154361b715bSPeng Fan "if test $board_name = SABREAUTO && test $board_rev = MX6QP; then " \ 155361b715bSPeng Fan "setenv fdt_file imx6qp-sabreauto.dtb; fi; " \ 156e6fc8995SPeng Fan "if test $board_name = SABREAUTO && test $board_rev = MX6Q; then " \ 157e6fc8995SPeng Fan "setenv fdt_file imx6q-sabreauto.dtb; fi; " \ 158e6fc8995SPeng Fan "if test $board_name = SABREAUTO && test $board_rev = MX6DL; then " \ 159e6fc8995SPeng Fan "setenv fdt_file imx6dl-sabreauto.dtb; fi; " \ 160e469719cSPeng Fan "if test $board_name = SABRESD && test $board_rev = MX6QP; then " \ 161e469719cSPeng Fan "setenv fdt_file imx6qp-sabresd.dtb; fi; " \ 162e6fc8995SPeng Fan "if test $board_name = SABRESD && test $board_rev = MX6Q; then " \ 163e6fc8995SPeng Fan "setenv fdt_file imx6q-sabresd.dtb; fi; " \ 164e6fc8995SPeng Fan "if test $board_name = SABRESD && test $board_rev = MX6DL; then " \ 165e6fc8995SPeng Fan "setenv fdt_file imx6dl-sabresd.dtb; fi; " \ 166e6fc8995SPeng Fan "if test $fdt_file = undefined; then " \ 167e6fc8995SPeng Fan "echo WARNING: Could not determine dtb to use; fi; " \ 168e6fc8995SPeng Fan "fi;\0" \ 169e6fc8995SPeng Fan 170c1747970SPierre Aubert 171c1747970SPierre Aubert #define CONFIG_BOOTCOMMAND \ 172e6fc8995SPeng Fan "run findfdt;" \ 173c1747970SPierre Aubert "mmc dev ${mmcdev};" \ 174c1747970SPierre Aubert "if mmc rescan; then " \ 175c1747970SPierre Aubert "if run loadbootscript; then " \ 176c1747970SPierre Aubert "run bootscript; " \ 177c1747970SPierre Aubert "else " \ 178f2e4288aSOtavio Salvador "if run loadimage; then " \ 179c1747970SPierre Aubert "run mmcboot; " \ 180c1747970SPierre Aubert "else run netboot; " \ 181c1747970SPierre Aubert "fi; " \ 182c1747970SPierre Aubert "fi; " \ 183c1747970SPierre Aubert "else run netboot; fi" 184c1747970SPierre Aubert 185c1747970SPierre Aubert #define CONFIG_ARP_TIMEOUT 200UL 186c1747970SPierre Aubert 187c1747970SPierre Aubert #define CONFIG_SYS_MEMTEST_START 0x10000000 188c1747970SPierre Aubert #define CONFIG_SYS_MEMTEST_END 0x10010000 189c1747970SPierre Aubert #define CONFIG_SYS_MEMTEST_SCRATCH 0x10800000 190c1747970SPierre Aubert 191c1747970SPierre Aubert #define CONFIG_STACKSIZE (128 * 1024) 192c1747970SPierre Aubert 193c1747970SPierre Aubert /* Physical Memory Map */ 194c1747970SPierre Aubert #define CONFIG_NR_DRAM_BANKS 1 195c1747970SPierre Aubert #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR 196c1747970SPierre Aubert 197c1747970SPierre Aubert #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM 198c1747970SPierre Aubert #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR 199c1747970SPierre Aubert #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE 200c1747970SPierre Aubert 201c1747970SPierre Aubert #define CONFIG_SYS_INIT_SP_OFFSET \ 202c1747970SPierre Aubert (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 203c1747970SPierre Aubert #define CONFIG_SYS_INIT_SP_ADDR \ 204c1747970SPierre Aubert (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) 205c1747970SPierre Aubert 206056845c2SPeter Robinson /* Environment organization */ 207c1747970SPierre Aubert #define CONFIG_ENV_SIZE (8 * 1024) 208c1747970SPierre Aubert 209c1747970SPierre Aubert #define CONFIG_ENV_IS_IN_MMC 210c1747970SPierre Aubert 211c1747970SPierre Aubert #if defined(CONFIG_ENV_IS_IN_MMC) 212*8fb9eea5SFabio Estevam #define CONFIG_ENV_OFFSET (768 * 1024) 213c1747970SPierre Aubert #endif 214c1747970SPierre Aubert 21504451ba3SFabio Estevam /* Framebuffer */ 21604451ba3SFabio Estevam #define CONFIG_VIDEO 21704451ba3SFabio Estevam #define CONFIG_VIDEO_IPUV3 21804451ba3SFabio Estevam #define CONFIG_CFB_CONSOLE 21904451ba3SFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE 22004451ba3SFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV 22104451ba3SFabio Estevam #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE 22204451ba3SFabio Estevam #define CONFIG_VIDEO_BMP_RLE8 22304451ba3SFabio Estevam #define CONFIG_SPLASH_SCREEN 22404451ba3SFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN 22504451ba3SFabio Estevam #define CONFIG_BMP_16BPP 22604451ba3SFabio Estevam #define CONFIG_VIDEO_LOGO 22704451ba3SFabio Estevam #define CONFIG_VIDEO_BMP_LOGO 22851674985SPeng Fan #ifdef CONFIG_MX6DL 22951674985SPeng Fan #define CONFIG_IPUV3_CLK 198000000 23051674985SPeng Fan #else 23151674985SPeng Fan #define CONFIG_IPUV3_CLK 264000000 23251674985SPeng Fan #endif 23304451ba3SFabio Estevam #define CONFIG_IMX_HDMI 23404451ba3SFabio Estevam #define CONFIG_IMX_VIDEO_SKIP 23504451ba3SFabio Estevam 236d5eb6dcfSFabio Estevam #ifndef CONFIG_SPL 237ad8aae82SFabio Estevam #define CONFIG_CI_UDC 238ad8aae82SFabio Estevam #define CONFIG_USBD_HS 239ad8aae82SFabio Estevam #define CONFIG_USB_GADGET_DUALSPEED 240ad8aae82SFabio Estevam 241ad8aae82SFabio Estevam #define CONFIG_USB_GADGET 242ad8aae82SFabio Estevam #define CONFIG_CMD_USB_MASS_STORAGE 24301acd6abSPaul Kocialkowski #define CONFIG_USB_FUNCTION_MASS_STORAGE 24401acd6abSPaul Kocialkowski #define CONFIG_USB_GADGET_DOWNLOAD 245ad8aae82SFabio Estevam #define CONFIG_USB_GADGET_VBUS_DRAW 2 246ad8aae82SFabio Estevam 247ad8aae82SFabio Estevam #define CONFIG_G_DNL_VENDOR_NUM 0x0525 248ad8aae82SFabio Estevam #define CONFIG_G_DNL_PRODUCT_NUM 0xa4a5 249ad8aae82SFabio Estevam #define CONFIG_G_DNL_MANUFACTURER "FSL" 250559964e7SFabio Estevam 251559964e7SFabio Estevam #define CONFIG_USB_FUNCTION_FASTBOOT 252559964e7SFabio Estevam #define CONFIG_CMD_FASTBOOT 253559964e7SFabio Estevam #define CONFIG_ANDROID_BOOT_IMAGE 254559964e7SFabio Estevam #define CONFIG_FASTBOOT_BUF_ADDR CONFIG_SYS_LOAD_ADDR 255559964e7SFabio Estevam #define CONFIG_FASTBOOT_BUF_SIZE 0x07000000 2567daaac52SFabio Estevam 2577daaac52SFabio Estevam /* USB Device Firmware Update support */ 2587daaac52SFabio Estevam #define CONFIG_CMD_DFU 2597daaac52SFabio Estevam #define CONFIG_USB_FUNCTION_DFU 2607daaac52SFabio Estevam #define CONFIG_DFU_MMC 2617daaac52SFabio Estevam #define CONFIG_DFU_SF 262d5eb6dcfSFabio Estevam #endif 263ad8aae82SFabio Estevam 264c1747970SPierre Aubert #endif /* __MX6QSABRE_COMMON_CONFIG_H */ 265