1 /* 2 * Aries MA5D4 configuration 3 * Copyright (C) 2015 Marek Vasut <marex@denx.de> 4 * 5 * SPDX-License-Identifier: GPL-2.0+ 6 */ 7 8 #ifndef __MA5D4EVK_CONFIG_H__ 9 #define __MA5D4EVK_CONFIG_H__ 10 11 #define CONFIG_TIMESTAMP /* Print image info with timestamp */ 12 13 #include "at91-sama5_common.h" 14 #define CONFIG_SYS_USE_SERIALFLASH 1 15 #define CONFIG_BOARD_LATE_INIT 16 17 /* 18 * Memory configurations 19 */ 20 #define CONFIG_NR_DRAM_BANKS 1 21 #define CONFIG_SYS_SDRAM_BASE ATMEL_BASE_DDRCS 22 #define CONFIG_SYS_SDRAM_SIZE 0x10000000 23 24 #ifdef CONFIG_SPL_BUILD 25 #define CONFIG_SYS_INIT_SP_ADDR 0x210000 26 #else 27 #define CONFIG_SYS_INIT_SP_ADDR \ 28 (CONFIG_SYS_SDRAM_BASE + 4 * 1024 - GENERATED_GBL_DATA_SIZE) 29 #endif 30 31 /* 32 * Environment 33 */ 34 #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE 35 #define CONFIG_SYS_CONSOLE_ENV_OVERWRITE 36 #define CONFIG_ENV_SIZE 0x4000 37 #define CONFIG_SYS_MMC_ENV_DEV 0 /* eMMC */ 38 #define CONFIG_ENV_OFFSET 512 /* just after the MBR */ 39 40 /* 41 * U-Boot general configurations 42 */ 43 44 /* 45 * Serial Driver 46 */ 47 #define CONFIG_ATMEL_USART 48 #define CONFIG_USART_BASE ATMEL_BASE_USART0 49 #define CONFIG_USART_ID ATMEL_ID_USART0 50 51 /* 52 * Ethernet 53 */ 54 #ifdef CONFIG_CMD_NET 55 #define CONFIG_MACB 56 #define CONFIG_RMII 57 #define CONFIG_NET_RETRY_COUNT 20 58 #define CONFIG_MACB_SEARCH_PHY 59 #define CONFIG_ARP_TIMEOUT 200UL 60 #define CONFIG_IP_DEFRAG 61 #endif 62 63 /* 64 * LCD 65 */ 66 #ifdef CONFIG_LCD 67 #define CONFIG_BMP_16BPP 68 #define CONFIG_BMP_24BPP 69 #define CONFIG_BMP_32BPP 70 #define LCD_BPP LCD_COLOR16 71 #define LCD_OUTPUT_BPP 24 72 #define CONFIG_ATMEL_HLCD 73 #endif 74 75 /* 76 * SD/MMC 77 */ 78 #ifdef CONFIG_CMD_MMC 79 #define CONFIG_GENERIC_ATMEL_MCI 80 #endif 81 82 /* 83 * SPI NOR (boot memory) 84 */ 85 #ifdef CONFIG_CMD_SF 86 #define CONFIG_ATMEL_SPI 87 #define CONFIG_ATMEL_SPI0 88 #define CONFIG_SPI_FLASH_ATMEL 89 #define CONFIG_SF_DEFAULT_BUS 0 90 #define CONFIG_SF_DEFAULT_CS 0 91 #define CONFIG_SF_DEFAULT_SPEED 30000000 92 #endif 93 94 /* 95 * USB 96 */ 97 #ifdef CONFIG_CMD_USB 98 99 /* USB device */ 100 #define CONFIG_USB_FUNCTION_MASS_STORAGE 101 #define CONFIG_SYS_DFU_DATA_BUF_SIZE (1 * 1024 * 1024) 102 #define DFU_DEFAULT_POLL_TIMEOUT 300 103 #endif 104 105 /* 106 * Boot Linux 107 */ 108 #define CONFIG_CMDLINE_TAG 109 #define CONFIG_INITRD_TAG 110 #define CONFIG_SETUP_MEMORY_TAGS 111 #define CONFIG_BOOTFILE "fitImage" 112 #define CONFIG_LOADADDR 0x20800000 113 #define CONFIG_BOOTCOMMAND "run mmc_mmc" 114 #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR 115 116 /* 117 * Extra Environments 118 */ 119 #define CONFIG_PREBOOT "run try_bootscript" 120 #define CONFIG_HOSTNAME ma5d4evk 121 122 #define CONFIG_EXTRA_ENV_SETTINGS \ 123 "consdev=ttyS3\0" \ 124 "baudrate=115200\0" \ 125 "bootscript=boot.scr\0" \ 126 "bootdev=/dev/mmcblk0p1\0" \ 127 "bootpart=0:1\0" \ 128 "rootdev=/dev/mmcblk0p2\0" \ 129 "netdev=eth0\0" \ 130 "dfu_alt_info=mmc raw 0 3867148288\0" \ 131 "kernel_addr_r=0x22000000\0" \ 132 "update_spi_firmware_spl_addr=0x21000000\0" \ 133 "update_spi_firmware_spl_filename=boot.bin\0" \ 134 "update_spi_firmware_addr=0x22000000\0" \ 135 "update_spi_firmware_filename=u-boot.img\0" \ 136 "update_spi_firmware=" /* Update the SPI flash firmware */ \ 137 "if sf probe ; then " \ 138 "if tftp ${update_spi_firmware_spl_addr} " \ 139 "${update_spi_firmware_spl_filename} ; then " \ 140 "setenv update_spi_firmware_spl_filesize ${filesize} ; "\ 141 "if tftp ${update_spi_firmware_addr} " \ 142 "${update_spi_firmware_filename} ; then " \ 143 "setenv update_spi_firmware_filesize ${filesize} ; " \ 144 "sf update ${update_spi_firmware_spl_addr} 0x0 " \ 145 "${update_spi_firmware_spl_filesize} ; " \ 146 "sf update ${update_spi_firmware_addr} 0x10000 " \ 147 "${update_spi_firmware_filesize} ; " \ 148 "fi ; " \ 149 "fi ; " \ 150 "fi\0" \ 151 "addcons=" \ 152 "setenv bootargs ${bootargs} " \ 153 "console=${consdev},${baudrate}\0" \ 154 "addip=" \ 155 "setenv bootargs ${bootargs} " \ 156 "ip=${ipaddr}:${serverip}:${gatewayip}:" \ 157 "${netmask}:${hostname}:${netdev}:off\0" \ 158 "addmisc=" \ 159 "setenv bootargs ${bootargs} ${miscargs}\0" \ 160 "addargs=run addcons addmisc\0" \ 161 "mmcload=" \ 162 "mmc rescan ; " \ 163 "load mmc ${bootpart} ${kernel_addr_r} ${bootfile}\0" \ 164 "netload=" \ 165 "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \ 166 "miscargs=nohlt panic=1\0" \ 167 "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \ 168 "nfsargs=" \ 169 "setenv bootargs root=/dev/nfs rw " \ 170 "nfsroot=${serverip}:${rootpath},v3,tcp\0" \ 171 "fdtimg=if test ${bootmode} = \"sf\" ; then " \ 172 "setenv kernel_fdt 1 ; " \ 173 "else ; " \ 174 "setenv kernel_fdt 2 ; " \ 175 "fi\0" \ 176 "mmc_mmc=" \ 177 "run fdtimg mmcload mmcargs addargs ; " \ 178 "bootm ${kernel_addr_r}:kernel@1 - ${kernel_addr_r}:fdt@${kernel_fdt}\0" \ 179 "mmc_nfs=" \ 180 "run fdtimg mmcload nfsargs addip addargs ; " \ 181 "bootm ${kernel_addr_r}:kernel@1 - ${kernel_addr_r}:fdt@${kernel_fdt}\0" \ 182 "net_mmc=" \ 183 "run fdtimg netload mmcargs addargs ; " \ 184 "bootm ${kernel_addr_r}:kernel@1 - ${kernel_addr_r}:fdt@${kernel_fdt}\0" \ 185 "net_nfs=" \ 186 "run fdtimg netload nfsargs addip addargs ; " \ 187 "bootm ${kernel_addr_r}:kernel@1 - ${kernel_addr_r}:fdt@${kernel_fdt}\0" \ 188 "try_bootscript=" \ 189 "mmc rescan;" \ 190 "if test -e mmc 1:1 ${bootscript} ; then " \ 191 "if load mmc 1:1 ${kernel_addr_r} ${bootscript};" \ 192 "then ; " \ 193 "echo Running bootscript... ; " \ 194 "source ${kernel_addr_r} ; " \ 195 "fi ; " \ 196 "fi\0" 197 /* SPL */ 198 #define CONFIG_SPL_FRAMEWORK 199 #define CONFIG_SPL_TEXT_BASE 0x200000 200 #define CONFIG_SPL_MAX_SIZE 0x10000 201 #define CONFIG_SPL_BSS_START_ADDR 0x20000000 202 #define CONFIG_SPL_BSS_MAX_SIZE 0x80000 203 #define CONFIG_SYS_SPL_MALLOC_START 0x20080000 204 #define CONFIG_SYS_SPL_MALLOC_SIZE 0x80000 205 206 #define CONFIG_SYS_MONITOR_LEN (512 << 10) 207 208 #define CONFIG_SPL_SPI_LOAD 209 #define CONFIG_SYS_SPI_U_BOOT_OFFS 0x10000 210 211 #define CONFIG_SYS_USE_MMC 212 #define CONFIG_SPL_MMC_SUPPORT 213 #define CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR 0x200 214 #define CONFIG_SYS_MMCSD_FS_BOOT_PARTITION 1 215 #define CONFIG_SPL_FS_LOAD_PAYLOAD_NAME "u-boot.img" 216 #define CONFIG_SPL_FAT_SUPPORT 217 #define CONFIG_SPL_LIBDISK_SUPPORT 218 219 #endif /* __MA5D4EVK_CONFIG_H__ */ 220