1*f91c09acSMarek Vasut /* 2*f91c09acSMarek Vasut * Configuration settings for the Novena U-boot. 3*f91c09acSMarek Vasut * 4*f91c09acSMarek Vasut * Copyright (C) 2014 Marek Vasut <marex@denx.de> 5*f91c09acSMarek Vasut * 6*f91c09acSMarek Vasut * SPDX-License-Identifier: GPL-2.0+ 7*f91c09acSMarek Vasut */ 8*f91c09acSMarek Vasut 9*f91c09acSMarek Vasut #ifndef __CONFIG_H 10*f91c09acSMarek Vasut #define __CONFIG_H 11*f91c09acSMarek Vasut 12*f91c09acSMarek Vasut /* System configurations */ 13*f91c09acSMarek Vasut #define CONFIG_MX6 14*f91c09acSMarek Vasut #define CONFIG_BOARD_EARLY_INIT_F 15*f91c09acSMarek Vasut #define CONFIG_MISC_INIT_R 16*f91c09acSMarek Vasut #define CONFIG_DISPLAY_BOARDINFO 17*f91c09acSMarek Vasut #define CONFIG_DISPLAY_CPUINFO 18*f91c09acSMarek Vasut #define CONFIG_DOS_PARTITION 19*f91c09acSMarek Vasut #define CONFIG_FAT_WRITE 20*f91c09acSMarek Vasut #define CONFIG_FIT 21*f91c09acSMarek Vasut #define CONFIG_KEYBOARD 22*f91c09acSMarek Vasut #define CONFIG_MXC_GPIO 23*f91c09acSMarek Vasut #define CONFIG_OF_LIBFDT 24*f91c09acSMarek Vasut #define CONFIG_REGEX 25*f91c09acSMarek Vasut #define CONFIG_SYS_GENERIC_BOARD 26*f91c09acSMarek Vasut #define CONFIG_SYS_NO_FLASH 27*f91c09acSMarek Vasut 28*f91c09acSMarek Vasut #include "configs/mx6_common.h" 29*f91c09acSMarek Vasut #include <asm/arch/imx-regs.h> 30*f91c09acSMarek Vasut #include <asm/imx-common/gpio.h> 31*f91c09acSMarek Vasut #include <config_cmd_default.h> 32*f91c09acSMarek Vasut 33*f91c09acSMarek Vasut /* U-Boot Commands */ 34*f91c09acSMarek Vasut #define CONFIG_CMD_ASKENV 35*f91c09acSMarek Vasut #define CONFIG_CMD_BMODE 36*f91c09acSMarek Vasut #define CONFIG_CMD_BOOTZ 37*f91c09acSMarek Vasut #define CONFIG_CMD_CACHE 38*f91c09acSMarek Vasut #define CONFIG_CMD_DHCP 39*f91c09acSMarek Vasut #define CONFIG_CMD_EEPROM 40*f91c09acSMarek Vasut #define CONFIG_CMD_EXT4 41*f91c09acSMarek Vasut #define CONFIG_CMD_EXT4_WRITE 42*f91c09acSMarek Vasut #define CONFIG_CMD_FAT 43*f91c09acSMarek Vasut #define CONFIG_CMD_FS_GENERIC 44*f91c09acSMarek Vasut #define CONFIG_CMD_I2C 45*f91c09acSMarek Vasut #define CONFIG_CMD_FUSE 46*f91c09acSMarek Vasut #define CONFIG_CMD_MII 47*f91c09acSMarek Vasut #define CONFIG_CMD_MMC 48*f91c09acSMarek Vasut #define CONFIG_CMD_NET 49*f91c09acSMarek Vasut #define CONFIG_CMD_PCI 50*f91c09acSMarek Vasut #define CONFIG_CMD_PING 51*f91c09acSMarek Vasut #define CONFIG_CMD_SATA 52*f91c09acSMarek Vasut #define CONFIG_CMD_SETEXPR 53*f91c09acSMarek Vasut #define CONFIG_CMD_TIME 54*f91c09acSMarek Vasut #define CONFIG_CMD_USB 55*f91c09acSMarek Vasut #define CONFIG_VIDEO 56*f91c09acSMarek Vasut 57*f91c09acSMarek Vasut /* U-Boot general configurations */ 58*f91c09acSMarek Vasut #define CONFIG_SYS_LONGHELP 59*f91c09acSMarek Vasut #define CONFIG_SYS_CBSIZE 1024 /* Console I/O buffer size */ 60*f91c09acSMarek Vasut #define CONFIG_SYS_PBSIZE \ 61*f91c09acSMarek Vasut (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 62*f91c09acSMarek Vasut /* Print buffer size */ 63*f91c09acSMarek Vasut #define CONFIG_SYS_MAXARGS 32 /* Max number of command args */ 64*f91c09acSMarek Vasut #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 65*f91c09acSMarek Vasut /* Boot argument buffer size */ 66*f91c09acSMarek Vasut #define CONFIG_VERSION_VARIABLE /* U-BOOT version */ 67*f91c09acSMarek Vasut #define CONFIG_AUTO_COMPLETE /* Command auto complete */ 68*f91c09acSMarek Vasut #define CONFIG_CMDLINE_EDITING /* Command history etc */ 69*f91c09acSMarek Vasut #define CONFIG_SYS_HUSH_PARSER 70*f91c09acSMarek Vasut 71*f91c09acSMarek Vasut /* U-Boot environment */ 72*f91c09acSMarek Vasut #define CONFIG_ENV_OVERWRITE 73*f91c09acSMarek Vasut #define CONFIG_ENV_SIZE (16 * 1024) 74*f91c09acSMarek Vasut /* 75*f91c09acSMarek Vasut * Environment is on MMC, starting at offset 512KiB from start of the card. 76*f91c09acSMarek Vasut * Please place first partition at offset 1MiB from the start of the card 77*f91c09acSMarek Vasut * as recommended by GNU/fdisk. See below for details: 78*f91c09acSMarek Vasut * http://homepage.ntlworld.com./jonathan.deboynepollard/FGA/disc-partition-alignment.html 79*f91c09acSMarek Vasut */ 80*f91c09acSMarek Vasut #ifdef CONFIG_CMD_MMC 81*f91c09acSMarek Vasut #define CONFIG_ENV_IS_IN_MMC 82*f91c09acSMarek Vasut #define CONFIG_SYS_MMC_ENV_DEV 0 83*f91c09acSMarek Vasut #define CONFIG_ENV_OFFSET (512 * 1024) 84*f91c09acSMarek Vasut #define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE 85*f91c09acSMarek Vasut #define CONFIG_ENV_OFFSET_REDUND \ 86*f91c09acSMarek Vasut (CONFIG_ENV_OFFSET + CONFIG_ENV_SIZE) 87*f91c09acSMarek Vasut #else 88*f91c09acSMarek Vasut #define CONFIG_ENV_IS_NOWHERE 89*f91c09acSMarek Vasut #endif 90*f91c09acSMarek Vasut 91*f91c09acSMarek Vasut /* Booting Linux */ 92*f91c09acSMarek Vasut #define CONFIG_BOOTDELAY 5 93*f91c09acSMarek Vasut #define CONFIG_BOOTFILE "fitImage" 94*f91c09acSMarek Vasut #define CONFIG_BOOTARGS "console=ttymxc1,115200 " 95*f91c09acSMarek Vasut #define CONFIG_BOOTCOMMAND "run net_nfs" 96*f91c09acSMarek Vasut #define CONFIG_LOADADDR 0x18000000 97*f91c09acSMarek Vasut #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR 98*f91c09acSMarek Vasut #define CONFIG_HOSTNAME novena 99*f91c09acSMarek Vasut 100*f91c09acSMarek Vasut /* Physical Memory Map */ 101*f91c09acSMarek Vasut #define CONFIG_NR_DRAM_BANKS 1 102*f91c09acSMarek Vasut #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR 103*f91c09acSMarek Vasut #define PHYS_SDRAM_SIZE 0xF0000000 104*f91c09acSMarek Vasut 105*f91c09acSMarek Vasut #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM 106*f91c09acSMarek Vasut #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR 107*f91c09acSMarek Vasut #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE 108*f91c09acSMarek Vasut 109*f91c09acSMarek Vasut #define CONFIG_SYS_INIT_SP_OFFSET \ 110*f91c09acSMarek Vasut (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 111*f91c09acSMarek Vasut #define CONFIG_SYS_INIT_SP_ADDR \ 112*f91c09acSMarek Vasut (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) 113*f91c09acSMarek Vasut 114*f91c09acSMarek Vasut #define CONFIG_SYS_MEMTEST_START 0x10000000 115*f91c09acSMarek Vasut #define CONFIG_SYS_MEMTEST_END 0x20000000 116*f91c09acSMarek Vasut 117*f91c09acSMarek Vasut #define CONFIG_SYS_MALLOC_LEN (64 * 1024 * 1024) 118*f91c09acSMarek Vasut 119*f91c09acSMarek Vasut /* SPL */ 120*f91c09acSMarek Vasut #define CONFIG_SPL_FAT_SUPPORT 121*f91c09acSMarek Vasut #define CONFIG_SPL_MMC_SUPPORT 122*f91c09acSMarek Vasut #include "imx6_spl.h" /* common IMX6 SPL configuration */ 123*f91c09acSMarek Vasut 124*f91c09acSMarek Vasut #define CONFIG_CMDLINE_TAG 125*f91c09acSMarek Vasut #define CONFIG_SETUP_MEMORY_TAGS 126*f91c09acSMarek Vasut #define CONFIG_INITRD_TAG 127*f91c09acSMarek Vasut #define CONFIG_REVISION_TAG 128*f91c09acSMarek Vasut 129*f91c09acSMarek Vasut /* Ethernet Configuration */ 130*f91c09acSMarek Vasut #ifdef CONFIG_CMD_NET 131*f91c09acSMarek Vasut #define CONFIG_FEC_MXC 132*f91c09acSMarek Vasut #define CONFIG_MII 133*f91c09acSMarek Vasut #define IMX_FEC_BASE ENET_BASE_ADDR 134*f91c09acSMarek Vasut #define CONFIG_FEC_XCV_TYPE RGMII 135*f91c09acSMarek Vasut #define CONFIG_ETHPRIME "FEC" 136*f91c09acSMarek Vasut #define CONFIG_FEC_MXC_PHYADDR 0x7 137*f91c09acSMarek Vasut #define CONFIG_PHYLIB 138*f91c09acSMarek Vasut #define CONFIG_PHY_MICREL 139*f91c09acSMarek Vasut #define CONFIG_PHY_MICREL_KSZ9021 140*f91c09acSMarek Vasut #define CONFIG_ARP_TIMEOUT 200UL 141*f91c09acSMarek Vasut #endif 142*f91c09acSMarek Vasut 143*f91c09acSMarek Vasut /* I2C */ 144*f91c09acSMarek Vasut #define CONFIG_SYS_I2C 145*f91c09acSMarek Vasut #define CONFIG_SYS_I2C_MXC 146*f91c09acSMarek Vasut #define CONFIG_I2C_MULTI_BUS 147*f91c09acSMarek Vasut #define CONFIG_I2C_MXC 148*f91c09acSMarek Vasut #define CONFIG_SYS_I2C_SPEED 100000 149*f91c09acSMarek Vasut 150*f91c09acSMarek Vasut /* I2C EEPROM */ 151*f91c09acSMarek Vasut #ifdef CONFIG_CMD_EEPROM 152*f91c09acSMarek Vasut #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 2 153*f91c09acSMarek Vasut #define CONFIG_SYS_SPD_BUS_NUM 2 154*f91c09acSMarek Vasut #endif 155*f91c09acSMarek Vasut 156*f91c09acSMarek Vasut /* MMC Configs */ 157*f91c09acSMarek Vasut #ifdef CONFIG_CMD_MMC 158*f91c09acSMarek Vasut #define CONFIG_MMC 159*f91c09acSMarek Vasut #define CONFIG_GENERIC_MMC 160*f91c09acSMarek Vasut #define CONFIG_BOUNCE_BUFFER 161*f91c09acSMarek Vasut #define CONFIG_FSL_ESDHC 162*f91c09acSMarek Vasut #define CONFIG_FSL_USDHC 163*f91c09acSMarek Vasut #define CONFIG_SYS_FSL_ESDHC_ADDR 0 164*f91c09acSMarek Vasut #define CONFIG_SYS_FSL_USDHC_NUM 2 165*f91c09acSMarek Vasut #endif 166*f91c09acSMarek Vasut 167*f91c09acSMarek Vasut /* OCOTP Configs */ 168*f91c09acSMarek Vasut #ifdef CONFIG_CMD_FUSE 169*f91c09acSMarek Vasut #define CONFIG_MXC_OCOTP 170*f91c09acSMarek Vasut #endif 171*f91c09acSMarek Vasut 172*f91c09acSMarek Vasut /* PCI express */ 173*f91c09acSMarek Vasut #ifdef CONFIG_CMD_PCI 174*f91c09acSMarek Vasut #define CONFIG_PCI 175*f91c09acSMarek Vasut #define CONFIG_PCI_PNP 176*f91c09acSMarek Vasut #define CONFIG_PCI_SCAN_SHOW 177*f91c09acSMarek Vasut #define CONFIG_PCIE_IMX 178*f91c09acSMarek Vasut #define CONFIG_PCIE_IMX_PERST_GPIO IMX_GPIO_NR(3, 29) 179*f91c09acSMarek Vasut #define CONFIG_PCIE_IMX_POWER_GPIO IMX_GPIO_NR(7, 12) 180*f91c09acSMarek Vasut #endif 181*f91c09acSMarek Vasut 182*f91c09acSMarek Vasut /* PMIC */ 183*f91c09acSMarek Vasut #define CONFIG_POWER 184*f91c09acSMarek Vasut #define CONFIG_POWER_I2C 185*f91c09acSMarek Vasut #define CONFIG_POWER_PFUZE100 186*f91c09acSMarek Vasut #define CONFIG_POWER_PFUZE100_I2C_ADDR 0x08 187*f91c09acSMarek Vasut 188*f91c09acSMarek Vasut /* SATA Configs */ 189*f91c09acSMarek Vasut #ifdef CONFIG_CMD_SATA 190*f91c09acSMarek Vasut #define CONFIG_DWC_AHSATA 191*f91c09acSMarek Vasut #define CONFIG_SYS_SATA_MAX_DEVICE 1 192*f91c09acSMarek Vasut #define CONFIG_DWC_AHSATA_PORT_ID 0 193*f91c09acSMarek Vasut #define CONFIG_DWC_AHSATA_BASE_ADDR SATA_ARB_BASE_ADDR 194*f91c09acSMarek Vasut #define CONFIG_LBA48 195*f91c09acSMarek Vasut #define CONFIG_LIBATA 196*f91c09acSMarek Vasut #endif 197*f91c09acSMarek Vasut 198*f91c09acSMarek Vasut /* UART */ 199*f91c09acSMarek Vasut #define CONFIG_MXC_UART 200*f91c09acSMarek Vasut #define CONFIG_MXC_UART_BASE UART2_BASE 201*f91c09acSMarek Vasut #define CONFIG_BAUDRATE 115200 202*f91c09acSMarek Vasut #define CONFIG_CONS_INDEX 1 203*f91c09acSMarek Vasut 204*f91c09acSMarek Vasut /* USB Configs */ 205*f91c09acSMarek Vasut #ifdef CONFIG_CMD_USB 206*f91c09acSMarek Vasut #define CONFIG_USB_EHCI 207*f91c09acSMarek Vasut #define CONFIG_USB_EHCI_MX6 208*f91c09acSMarek Vasut #define CONFIG_USB_STORAGE 209*f91c09acSMarek Vasut #define CONFIG_USB_KEYBOARD 210*f91c09acSMarek Vasut #define CONFIG_SYS_USB_EVENT_POLL_VIA_CONTROL_EP 211*f91c09acSMarek Vasut #define CONFIG_USB_HOST_ETHER 212*f91c09acSMarek Vasut #define CONFIG_USB_ETHER_ASIX 213*f91c09acSMarek Vasut #define CONFIG_USB_ETHER_SMSC95XX 214*f91c09acSMarek Vasut #define CONFIG_USB_MAX_CONTROLLER_COUNT 2 215*f91c09acSMarek Vasut #define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW) 216*f91c09acSMarek Vasut #define CONFIG_MXC_USB_FLAGS 0 217*f91c09acSMarek Vasut /* Gadget part */ 218*f91c09acSMarek Vasut #define CONFIG_CI_UDC 219*f91c09acSMarek Vasut #define CONFIG_USBD_HS 220*f91c09acSMarek Vasut #define CONFIG_USB_GADGET_DUALSPEED 221*f91c09acSMarek Vasut #define CONFIG_USB_ETHER 222*f91c09acSMarek Vasut #define CONFIG_USB_ETH_CDC 223*f91c09acSMarek Vasut #define CONFIG_NETCONSOLE 224*f91c09acSMarek Vasut #endif 225*f91c09acSMarek Vasut 226*f91c09acSMarek Vasut /* Video output */ 227*f91c09acSMarek Vasut #ifdef CONFIG_VIDEO 228*f91c09acSMarek Vasut #define CONFIG_VIDEO 229*f91c09acSMarek Vasut #define CONFIG_VIDEO_IPUV3 230*f91c09acSMarek Vasut #define CONFIG_CFB_CONSOLE 231*f91c09acSMarek Vasut #define CONFIG_VGA_AS_SINGLE_DEVICE 232*f91c09acSMarek Vasut #define CONFIG_SYS_CONSOLE_IS_IN_ENV 233*f91c09acSMarek Vasut #define CONFIG_VIDEO_BMP_RLE8 234*f91c09acSMarek Vasut #define CONFIG_SPLASH_SCREEN 235*f91c09acSMarek Vasut #define CONFIG_BMP_16BPP 236*f91c09acSMarek Vasut #define CONFIG_VIDEO_LOGO 237*f91c09acSMarek Vasut #define CONFIG_IPUV3_CLK 260000000 238*f91c09acSMarek Vasut #define CONFIG_CMD_HDMIDETECT 239*f91c09acSMarek Vasut #define CONFIG_CONSOLE_MUX 240*f91c09acSMarek Vasut #define CONFIG_IMX_HDMI 241*f91c09acSMarek Vasut #define CONFIG_IMX_VIDEO_SKIP 242*f91c09acSMarek Vasut #endif 243*f91c09acSMarek Vasut 244*f91c09acSMarek Vasut /* Extra U-Boot environment. */ 245*f91c09acSMarek Vasut #define CONFIG_EXTRA_ENV_SETTINGS \ 246*f91c09acSMarek Vasut "fdt_high=0xffffffff\0" \ 247*f91c09acSMarek Vasut "initrd_high=0xffffffff\0" \ 248*f91c09acSMarek Vasut "consdev=ttymxc1\0" \ 249*f91c09acSMarek Vasut "baudrate=115200\0" \ 250*f91c09acSMarek Vasut "bootdev=/dev/mmcblk0p1\0" \ 251*f91c09acSMarek Vasut "rootdev=/dev/mmcblk0p2\0" \ 252*f91c09acSMarek Vasut "netdev=eth0\0" \ 253*f91c09acSMarek Vasut "kernel_addr_r=0x18000000\0" \ 254*f91c09acSMarek Vasut "addcons=" \ 255*f91c09acSMarek Vasut "setenv bootargs ${bootargs} " \ 256*f91c09acSMarek Vasut "console=${consdev},${baudrate}\0" \ 257*f91c09acSMarek Vasut "addip=" \ 258*f91c09acSMarek Vasut "setenv bootargs ${bootargs} " \ 259*f91c09acSMarek Vasut "ip=${ipaddr}:${serverip}:${gatewayip}:" \ 260*f91c09acSMarek Vasut "${netmask}:${hostname}:${netdev}:off\0" \ 261*f91c09acSMarek Vasut "addmisc=" \ 262*f91c09acSMarek Vasut "setenv bootargs ${bootargs} ${miscargs}\0" \ 263*f91c09acSMarek Vasut "addargs=run addcons addmisc\0" \ 264*f91c09acSMarek Vasut "mmcload=" \ 265*f91c09acSMarek Vasut "mmc rescan ; " \ 266*f91c09acSMarek Vasut "ext4load mmc 0:1 ${kernel_addr_r} ${bootfile}\0" \ 267*f91c09acSMarek Vasut "netload=" \ 268*f91c09acSMarek Vasut "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \ 269*f91c09acSMarek Vasut "miscargs=nohlt panic=1\0" \ 270*f91c09acSMarek Vasut "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \ 271*f91c09acSMarek Vasut "nfsargs=" \ 272*f91c09acSMarek Vasut "setenv bootargs root=/dev/nfs rw " \ 273*f91c09acSMarek Vasut "nfsroot=${serverip}:${rootpath},v3,tcp\0" \ 274*f91c09acSMarek Vasut "mmc_mmc=" \ 275*f91c09acSMarek Vasut "run mmcload mmcargs addargs ; " \ 276*f91c09acSMarek Vasut "bootm ${kernel_addr_r}\0" \ 277*f91c09acSMarek Vasut "mmc_nfs=" \ 278*f91c09acSMarek Vasut "run mmcload nfsargs addip addargs ; " \ 279*f91c09acSMarek Vasut "bootm ${kernel_addr_r}\0" \ 280*f91c09acSMarek Vasut "net_mmc=" \ 281*f91c09acSMarek Vasut "run netload mmcargs addargs ; " \ 282*f91c09acSMarek Vasut "bootm ${kernel_addr_r}\0" \ 283*f91c09acSMarek Vasut "net_nfs=" \ 284*f91c09acSMarek Vasut "run netload nfsargs addip addargs ; " \ 285*f91c09acSMarek Vasut "bootm ${kernel_addr_r}\0" \ 286*f91c09acSMarek Vasut "update_sd_spl_filename=SPL\0" \ 287*f91c09acSMarek Vasut "update_sd_uboot_filename=u-boot.img\0" \ 288*f91c09acSMarek Vasut "update_sd_firmware=" /* Update the SD firmware partition */ \ 289*f91c09acSMarek Vasut "if mmc rescan ; then " \ 290*f91c09acSMarek Vasut "if dhcp ${update_sd_spl_filename} ; then " \ 291*f91c09acSMarek Vasut "mmc write ${loadaddr} 2 0x200 ; " \ 292*f91c09acSMarek Vasut "fi ; " \ 293*f91c09acSMarek Vasut "if dhcp ${update_sd_uboot_filename} ; then " \ 294*f91c09acSMarek Vasut "fatwrite mmc 0:1 ${loadaddr} u-boot.img ${filesize} ; "\ 295*f91c09acSMarek Vasut "fi ; " \ 296*f91c09acSMarek Vasut "fi\0" \ 297*f91c09acSMarek Vasut 298*f91c09acSMarek Vasut #endif /* __CONFIG_H */ 299