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