Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 1 | /* |
Masahiro Yamada | 0ae5c5a | 2016-08-10 16:08:49 +0900 | [diff] [blame] | 2 | * Copyright (C) 2012-2015 Panasonic Corporation |
| 3 | * Copyright (C) 2015-2016 Socionext Inc. |
| 4 | * Author: Masahiro Yamada <yamada.masahiro@socionext.com> |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 5 | * |
| 6 | * SPDX-License-Identifier: GPL-2.0+ |
| 7 | */ |
| 8 | |
Bin Meng | 7557405 | 2016-02-05 19:30:11 -0800 | [diff] [blame] | 9 | /* U-Boot - Common settings for UniPhier Family */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 10 | |
| 11 | #ifndef __CONFIG_UNIPHIER_COMMON_H__ |
| 12 | #define __CONFIG_UNIPHIER_COMMON_H__ |
| 13 | |
Masahiro Yamada | a788892 | 2016-08-25 21:03:41 +0900 | [diff] [blame] | 14 | #define CONFIG_ARMV7_PSCI_1_0 |
Masahiro Yamada | 0ae5c5a | 2016-08-10 16:08:49 +0900 | [diff] [blame] | 15 | |
Masahiro Yamada | a8dd201 | 2015-01-13 12:44:39 +0900 | [diff] [blame] | 16 | #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 10 |
| 17 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 18 | /*----------------------------------------------------------------------- |
| 19 | * MMU and Cache Setting |
| 20 | *----------------------------------------------------------------------*/ |
| 21 | |
| 22 | /* Comment out the following to enable L1 cache */ |
| 23 | /* #define CONFIG_SYS_ICACHE_OFF */ |
| 24 | /* #define CONFIG_SYS_DCACHE_OFF */ |
| 25 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 26 | #define CONFIG_SYS_MALLOC_LEN (4 * 1024 * 1024) |
| 27 | |
| 28 | #define CONFIG_TIMESTAMP |
| 29 | |
| 30 | /* FLASH related */ |
| 31 | #define CONFIG_MTD_DEVICE |
| 32 | |
Masahiro Yamada | a71c65a | 2016-10-08 13:25:28 +0900 | [diff] [blame] | 33 | #define CONFIG_SMC911X_32_BIT |
| 34 | /* dummy: referenced by examples/standalone/smc911x_eeprom.c */ |
| 35 | #define CONFIG_SMC911X_BASE 0 |
| 36 | |
| 37 | #ifdef CONFIG_MICRO_SUPPORT_CARD |
| 38 | #define CONFIG_SMC911X |
Masahiro Yamada | 7a70d35 | 2016-10-08 13:25:27 +0900 | [diff] [blame] | 39 | #endif |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 40 | |
| 41 | #define CONFIG_FLASH_CFI_DRIVER |
| 42 | #define CONFIG_SYS_FLASH_CFI |
| 43 | |
| 44 | #define CONFIG_SYS_MAX_FLASH_SECT 256 |
| 45 | #define CONFIG_SYS_MONITOR_BASE 0 |
Masahiro Yamada | ea5da9f | 2016-03-23 01:40:05 +0900 | [diff] [blame] | 46 | #define CONFIG_SYS_MONITOR_LEN 0x00080000 /* 512KB */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 47 | #define CONFIG_SYS_FLASH_BASE 0 |
| 48 | |
| 49 | /* |
Masahiro Yamada | 41ab948 | 2016-10-08 13:25:26 +0900 | [diff] [blame] | 50 | * flash_toggle does not work for our support card. |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 51 | * We need to use flash_status_poll. |
| 52 | */ |
| 53 | #define CONFIG_SYS_CFI_FLASH_STATUS_POLL |
| 54 | |
| 55 | #define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */ |
| 56 | |
Masahiro Yamada | 4903b6d | 2015-09-11 20:17:45 +0900 | [diff] [blame] | 57 | #define CONFIG_SYS_MAX_FLASH_BANKS_DETECT 1 |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 58 | |
| 59 | /* serial console configuration */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 60 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 61 | #define CONFIG_SYS_LONGHELP /* undef to save memory */ |
| 62 | |
| 63 | #define CONFIG_CMDLINE_EDITING /* add command line history */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 64 | #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ |
| 65 | /* Print Buffer Size */ |
| 66 | #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) |
| 67 | #define CONFIG_SYS_MAXARGS 16 /* max number of command */ |
| 68 | /* Boot Argument Buffer Size */ |
| 69 | #define CONFIG_SYS_BARGSIZE (CONFIG_SYS_CBSIZE) |
| 70 | |
| 71 | #define CONFIG_CONS_INDEX 1 |
| 72 | |
Masahiro Yamada | 547ca3b | 2016-02-16 17:08:42 +0900 | [diff] [blame] | 73 | /* #define CONFIG_ENV_IS_NOWHERE */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 74 | /* #define CONFIG_ENV_IS_IN_NAND */ |
Masahiro Yamada | 547ca3b | 2016-02-16 17:08:42 +0900 | [diff] [blame] | 75 | #define CONFIG_ENV_IS_IN_MMC |
Masahiro Yamada | 0dd7602 | 2017-01-28 06:53:52 +0900 | [diff] [blame] | 76 | #define CONFIG_ENV_OFFSET 0x100000 |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 77 | #define CONFIG_ENV_SIZE 0x2000 |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 78 | /* #define CONFIG_ENV_OFFSET_REDUND (CONFIG_ENV_OFFSET + CONFIG_ENV_SIZE) */ |
| 79 | |
Masahiro Yamada | 547ca3b | 2016-02-16 17:08:42 +0900 | [diff] [blame] | 80 | #define CONFIG_SYS_MMC_ENV_DEV 0 |
| 81 | #define CONFIG_SYS_MMC_ENV_PART 1 |
| 82 | |
Masahiro Yamada | dabee24 | 2017-01-21 18:05:22 +0900 | [diff] [blame] | 83 | #ifdef CONFIG_ARMV8_MULTIENTRY |
Masahiro Yamada | f3bf3ec | 2016-06-15 14:46:09 +0900 | [diff] [blame] | 84 | #define CPU_RELEASE_ADDR 0x80000000 |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 85 | #define COUNTER_FREQUENCY 50000000 |
| 86 | #define CONFIG_GICV3 |
| 87 | #define GICD_BASE 0x5fe00000 |
Masahiro Yamada | 8bbbcbd | 2016-05-24 21:14:01 +0900 | [diff] [blame] | 88 | #if defined(CONFIG_ARCH_UNIPHIER_LD11) |
| 89 | #define GICR_BASE 0x5fe40000 |
| 90 | #elif defined(CONFIG_ARCH_UNIPHIER_LD20) |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 91 | #define GICR_BASE 0x5fe80000 |
Masahiro Yamada | 8bbbcbd | 2016-05-24 21:14:01 +0900 | [diff] [blame] | 92 | #endif |
Masahiro Yamada | dabee24 | 2017-01-21 18:05:22 +0900 | [diff] [blame] | 93 | #elif !defined(CONFIG_ARM64) |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 94 | /* Time clock 1MHz */ |
| 95 | #define CONFIG_SYS_TIMER_RATE 1000000 |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 96 | #endif |
| 97 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 98 | #define CONFIG_SYS_MAX_NAND_DEVICE 1 |
| 99 | #define CONFIG_SYS_NAND_MAX_CHIPS 2 |
| 100 | #define CONFIG_SYS_NAND_ONFI_DETECTION |
| 101 | |
| 102 | #define CONFIG_NAND_DENALI_ECC_SIZE 1024 |
| 103 | |
Masahiro Yamada | 53c59ae | 2016-03-18 16:41:43 +0900 | [diff] [blame] | 104 | #ifdef CONFIG_ARCH_UNIPHIER_SLD3 |
Masahiro Yamada | fa71441 | 2015-07-21 14:04:22 +0900 | [diff] [blame] | 105 | #define CONFIG_SYS_NAND_REGS_BASE 0xf8100000 |
| 106 | #define CONFIG_SYS_NAND_DATA_BASE 0xf8000000 |
| 107 | #else |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 108 | #define CONFIG_SYS_NAND_REGS_BASE 0x68100000 |
| 109 | #define CONFIG_SYS_NAND_DATA_BASE 0x68000000 |
Masahiro Yamada | fa71441 | 2015-07-21 14:04:22 +0900 | [diff] [blame] | 110 | #endif |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 111 | |
| 112 | #define CONFIG_SYS_NAND_BASE (CONFIG_SYS_NAND_DATA_BASE + 0x10) |
| 113 | |
| 114 | #define CONFIG_SYS_NAND_USE_FLASH_BBT |
| 115 | #define CONFIG_SYS_NAND_BAD_BLOCK_POS 0 |
| 116 | |
Masahiro Yamada | 0b7e1df | 2014-11-07 18:48:34 +0900 | [diff] [blame] | 117 | /* USB */ |
Masahiro Yamada | d50f336 | 2015-02-27 02:27:01 +0900 | [diff] [blame] | 118 | #define CONFIG_SYS_USB_XHCI_MAX_ROOT_PORTS 4 |
Masahiro Yamada | 0b7e1df | 2014-11-07 18:48:34 +0900 | [diff] [blame] | 119 | #define CONFIG_FAT_WRITE |
Masahiro Yamada | 0b7e1df | 2014-11-07 18:48:34 +0900 | [diff] [blame] | 120 | |
Masahiro Yamada | 867453e | 2016-02-18 19:52:49 +0900 | [diff] [blame] | 121 | /* SD/MMC */ |
Masahiro Yamada | eac5acf | 2016-02-16 17:08:39 +0900 | [diff] [blame] | 122 | #define CONFIG_SUPPORT_EMMC_BOOT |
Masahiro Yamada | 867453e | 2016-02-18 19:52:49 +0900 | [diff] [blame] | 123 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 124 | /* memtest works on */ |
| 125 | #define CONFIG_SYS_MEMTEST_START CONFIG_SYS_SDRAM_BASE |
| 126 | #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_SDRAM_BASE + 0x01000000) |
| 127 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 128 | /* |
| 129 | * Network Configuration |
| 130 | */ |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 131 | #define CONFIG_SERVERIP 192.168.11.1 |
| 132 | #define CONFIG_IPADDR 192.168.11.10 |
| 133 | #define CONFIG_GATEWAYIP 192.168.11.1 |
| 134 | #define CONFIG_NETMASK 255.255.255.0 |
| 135 | |
| 136 | #define CONFIG_LOADADDR 0x84000000 |
| 137 | #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 138 | |
| 139 | #define CONFIG_CMDLINE_EDITING /* add command line history */ |
| 140 | |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 141 | #if defined(CONFIG_ARM64) && !defined(CONFIG_ARMV8_MULTIENTRY) |
| 142 | /* ARM Trusted Firmware */ |
| 143 | #define BOOT_IMAGES \ |
Masahiro Yamada | e52c101 | 2017-02-12 18:21:16 +0900 | [diff] [blame] | 144 | "second_image=unph_bl.bin\0" \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 145 | "third_image=fip.bin\0" |
| 146 | #else |
| 147 | #define BOOT_IMAGES \ |
| 148 | "second_image=u-boot-spl.bin\0" \ |
| 149 | "third_image=u-boot.bin\0" |
| 150 | #endif |
| 151 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 152 | #define CONFIG_BOOTCOMMAND "run $bootmode" |
| 153 | |
| 154 | #define CONFIG_ROOTPATH "/nfs/root/path" |
| 155 | #define CONFIG_NFSBOOTCOMMAND \ |
| 156 | "setenv bootargs $bootargs root=/dev/nfs rw " \ |
| 157 | "nfsroot=$serverip:$rootpath " \ |
| 158 | "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:$netdev:off;" \ |
Masahiro Yamada | 6c2fec1 | 2016-01-21 14:56:09 +0900 | [diff] [blame] | 159 | "run __nfsboot" |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 160 | |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 161 | #ifdef CONFIG_FIT |
| 162 | #define CONFIG_BOOTFILE "fitImage" |
| 163 | #define LINUXBOOT_ENV_SETTINGS \ |
| 164 | "fit_addr=0x00100000\0" \ |
| 165 | "fit_addr_r=0x84100000\0" \ |
| 166 | "fit_size=0x00f00000\0" \ |
Masahiro Yamada | 4b85fb1 | 2015-09-22 00:27:38 +0900 | [diff] [blame] | 167 | "norboot=setexpr fit_addr $nor_base + $fit_addr &&" \ |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 168 | "bootm $fit_addr\0" \ |
Masahiro Yamada | 4b85fb1 | 2015-09-22 00:27:38 +0900 | [diff] [blame] | 169 | "nandboot=nand read $fit_addr_r $fit_addr $fit_size &&" \ |
Masahiro Yamada | eebc129 | 2015-07-21 14:04:19 +0900 | [diff] [blame] | 170 | "bootm $fit_addr_r\0" \ |
Masahiro Yamada | 4b85fb1 | 2015-09-22 00:27:38 +0900 | [diff] [blame] | 171 | "tftpboot=tftpboot $fit_addr_r $bootfile &&" \ |
Masahiro Yamada | 6c2fec1 | 2016-01-21 14:56:09 +0900 | [diff] [blame] | 172 | "bootm $fit_addr_r\0" \ |
| 173 | "__nfsboot=run tftpboot\0" |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 174 | #else |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 175 | #ifdef CONFIG_ARM64 |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 176 | #define CONFIG_BOOTFILE "Image.gz" |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 177 | #define LINUXBOOT_CMD "booti" |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 178 | #define KERNEL_ADDR_LOAD "kernel_addr_load=0x84200000\0" |
Masahiro Yamada | b8d6721 | 2017-05-16 14:35:15 +0900 | [diff] [blame] | 179 | #define KERNEL_ADDR_R "kernel_addr_r=0x82080000\0" |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 180 | #else |
Masahiro Yamada | fe8ef76 | 2015-12-18 14:52:32 +0900 | [diff] [blame] | 181 | #define CONFIG_BOOTFILE "zImage" |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 182 | #define LINUXBOOT_CMD "bootz" |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 183 | #define KERNEL_ADDR_LOAD "kernel_addr_load=0x80208000\0" |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 184 | #define KERNEL_ADDR_R "kernel_addr_r=0x80208000\0" |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 185 | #endif |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 186 | #define LINUXBOOT_ENV_SETTINGS \ |
| 187 | "fdt_addr=0x00100000\0" \ |
| 188 | "fdt_addr_r=0x84100000\0" \ |
| 189 | "fdt_size=0x00008000\0" \ |
| 190 | "kernel_addr=0x00200000\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 191 | KERNEL_ADDR_LOAD \ |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 192 | KERNEL_ADDR_R \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 193 | "kernel_size=0x00800000\0" \ |
| 194 | "ramdisk_addr=0x00a00000\0" \ |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 195 | "ramdisk_addr_r=0x84a00000\0" \ |
| 196 | "ramdisk_size=0x00600000\0" \ |
Masahiro Yamada | eebc129 | 2015-07-21 14:04:19 +0900 | [diff] [blame] | 197 | "ramdisk_file=rootfs.cpio.uboot\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 198 | "boot_common=setexpr bootm_low $kernel_addr_r '&' fe000000 && " \ |
| 199 | "if test $kernel_addr_load = $kernel_addr_r; then " \ |
| 200 | "true; " \ |
| 201 | "else " \ |
| 202 | "unzip $kernel_addr_load $kernel_addr_r; " \ |
| 203 | "fi && " \ |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 204 | LINUXBOOT_CMD " $kernel_addr_r $ramdisk_addr_r $fdt_addr_r\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 205 | "norboot=setexpr kernel_addr_nor $nor_base + $kernel_addr && " \ |
| 206 | "setexpr kernel_size_div4 $kernel_size / 4 && " \ |
| 207 | "cp $kernel_addr_nor $kernel_addr_load $kernel_size_div4 && " \ |
Masahiro Yamada | 0bb5576 | 2017-01-28 06:53:51 +0900 | [diff] [blame] | 208 | "setexpr ramdisk_addr_nor $nor_base + $ramdisk_addr && " \ |
| 209 | "setexpr ramdisk_size_div4 $ramdisk_size / 4 && " \ |
| 210 | "cp $ramdisk_addr_nor $ramdisk_addr_r $ramdisk_size_div4 && " \ |
| 211 | "setexpr fdt_addr_nor $nor_base + $fdt_addr && " \ |
| 212 | "setexpr fdt_size_div4 $fdt_size / 4 && " \ |
| 213 | "cp $fdt_addr_nor $fdt_addr_r $fdt_size_div4 && " \ |
Masahiro Yamada | d74a3a2 | 2016-01-21 14:56:08 +0900 | [diff] [blame] | 214 | "run boot_common\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 215 | "nandboot=nand read $kernel_addr_load $kernel_addr $kernel_size && " \ |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 216 | "nand read $ramdisk_addr_r $ramdisk_addr $ramdisk_size &&" \ |
| 217 | "nand read $fdt_addr_r $fdt_addr $fdt_size &&" \ |
Masahiro Yamada | d74a3a2 | 2016-01-21 14:56:08 +0900 | [diff] [blame] | 218 | "run boot_common\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 219 | "tftpboot=tftpboot $kernel_addr_load $bootfile && " \ |
Masahiro Yamada | eebc129 | 2015-07-21 14:04:19 +0900 | [diff] [blame] | 220 | "tftpboot $ramdisk_addr_r $ramdisk_file &&" \ |
| 221 | "tftpboot $fdt_addr_r $fdt_file &&" \ |
Masahiro Yamada | 6c2fec1 | 2016-01-21 14:56:09 +0900 | [diff] [blame] | 222 | "run boot_common\0" \ |
Masahiro Yamada | ea32caa | 2017-01-28 06:53:50 +0900 | [diff] [blame] | 223 | "__nfsboot=tftpboot $kernel_addr_load $bootfile && " \ |
Masahiro Yamada | 6c2fec1 | 2016-01-21 14:56:09 +0900 | [diff] [blame] | 224 | "tftpboot $fdt_addr_r $fdt_file &&" \ |
Masahiro Yamada | 6c2fec1 | 2016-01-21 14:56:09 +0900 | [diff] [blame] | 225 | "setenv ramdisk_addr_r - &&" \ |
Masahiro Yamada | d74a3a2 | 2016-01-21 14:56:08 +0900 | [diff] [blame] | 226 | "run boot_common\0" |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 227 | #endif |
| 228 | |
| 229 | #define CONFIG_EXTRA_ENV_SETTINGS \ |
| 230 | "netdev=eth0\0" \ |
| 231 | "verify=n\0" \ |
Masahiro Yamada | 0bb5576 | 2017-01-28 06:53:51 +0900 | [diff] [blame] | 232 | "initrd_high=0xffffffffffffffff\0" \ |
Masahiro Yamada | 9e81697 | 2016-01-21 14:56:06 +0900 | [diff] [blame] | 233 | "nor_base=0x42000000\0" \ |
Masahiro Yamada | 309eeb5 | 2016-03-24 22:23:36 +0900 | [diff] [blame] | 234 | "sramupdate=setexpr tmp_addr $nor_base + 0x50000 &&" \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 235 | "tftpboot $tmp_addr $second_image && " \ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 236 | "setexpr tmp_addr $nor_base + 0x70000 && " \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 237 | "tftpboot $tmp_addr $third_image\0" \ |
Masahiro Yamada | bffeee9 | 2016-02-16 17:08:41 +0900 | [diff] [blame] | 238 | "emmcupdate=mmcsetn &&" \ |
| 239 | "mmc partconf $mmc_first_dev 0 1 1 &&" \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 240 | "tftpboot $second_image && " \ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 241 | "mmc write $loadaddr 0 100 && " \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 242 | "tftpboot $third_image && " \ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 243 | "mmc write $loadaddr 100 700\0" \ |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 244 | "nandupdate=nand erase 0 0x00100000 &&" \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 245 | "tftpboot $second_image && " \ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 246 | "nand write $loadaddr 0 0x00020000 && " \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 247 | "tftpboot $third_image && " \ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 248 | "nand write $loadaddr 0x00020000 0x000e0000\0" \ |
Masahiro Yamada | 29b98e6 | 2017-05-10 20:57:39 +0900 | [diff] [blame] | 249 | "usbupdate=usb start &&" \ |
| 250 | "tftpboot $second_image && " \ |
| 251 | "usb write $loadaddr 0 100 && " \ |
| 252 | "tftpboot $third_image && " \ |
| 253 | "usb write $loadaddr 100 700\0" \ |
Masahiro Yamada | 434813b | 2017-01-28 06:53:54 +0900 | [diff] [blame] | 254 | BOOT_IMAGES \ |
Masahiro Yamada | ec81fb5 | 2015-07-21 14:04:18 +0900 | [diff] [blame] | 255 | LINUXBOOT_ENV_SETTINGS |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 256 | |
Masahiro Yamada | fe1a2cf | 2016-01-09 02:12:26 +0900 | [diff] [blame] | 257 | #define CONFIG_SYS_BOOTMAPSZ 0x20000000 |
| 258 | |
Masahiro Yamada | b4782cd | 2015-09-11 20:17:49 +0900 | [diff] [blame] | 259 | #define CONFIG_SYS_SDRAM_BASE 0x80000000 |
Masahiro Yamada | d97c1cb | 2017-01-28 06:53:43 +0900 | [diff] [blame] | 260 | #define CONFIG_NR_DRAM_BANKS 3 |
Masahiro Yamada | ea6cdf2 | 2016-04-21 14:43:19 +0900 | [diff] [blame] | 261 | /* for LD20; the last 64 byte is used for dynamic DDR PHY training */ |
| 262 | #define CONFIG_SYS_MEM_TOP_HIDE 64 |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 263 | |
Masahiro Yamada | 19d4437 | 2017-01-28 06:53:49 +0900 | [diff] [blame] | 264 | #define CONFIG_PANIC_HANG |
| 265 | |
| 266 | #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_TEXT_BASE) |
| 267 | |
| 268 | /* only for SPL */ |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 269 | #if defined(CONFIG_ARM64) |
| 270 | #define CONFIG_SPL_TEXT_BASE 0x30000000 |
| 271 | #elif defined(CONFIG_ARCH_UNIPHIER_SLD3) || \ |
| 272 | defined(CONFIG_ARCH_UNIPHIER_LD4) || \ |
Masahiro Yamada | 53c59ae | 2016-03-18 16:41:43 +0900 | [diff] [blame] | 273 | defined(CONFIG_ARCH_UNIPHIER_SLD8) |
Masahiro Yamada | 1e72b1c | 2014-12-06 00:03:22 +0900 | [diff] [blame] | 274 | #define CONFIG_SPL_TEXT_BASE 0x00040000 |
Masahiro Yamada | 75f16f8 | 2015-09-22 00:27:39 +0900 | [diff] [blame] | 275 | #else |
Masahiro Yamada | 1e72b1c | 2014-12-06 00:03:22 +0900 | [diff] [blame] | 276 | #define CONFIG_SPL_TEXT_BASE 0x00100000 |
| 277 | #endif |
| 278 | |
Masahiro Yamada | 8bbbcbd | 2016-05-24 21:14:01 +0900 | [diff] [blame] | 279 | #if defined(CONFIG_ARCH_UNIPHIER_LD11) |
| 280 | #define CONFIG_SPL_STACK (0x30014c00) |
| 281 | #elif defined(CONFIG_ARCH_UNIPHIER_LD20) |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 282 | #define CONFIG_SPL_STACK (0x3001c000) |
| 283 | #else |
Masahiro Yamada | 4a16289 | 2016-02-02 21:11:28 +0900 | [diff] [blame] | 284 | #define CONFIG_SPL_STACK (0x00100000) |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 285 | #endif |
Masahiro Yamada | 3779753 | 2015-03-23 00:07:24 +0900 | [diff] [blame] | 286 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 287 | #define CONFIG_SPL_FRAMEWORK |
Masahiro Yamada | d69e409 | 2016-06-04 22:39:08 +0900 | [diff] [blame] | 288 | #ifdef CONFIG_ARM64 |
| 289 | #define CONFIG_SPL_BOARD_LOAD_IMAGE |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 290 | #endif |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 291 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 292 | #define CONFIG_SPL_BOARD_INIT |
| 293 | |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 294 | #define CONFIG_SYS_NAND_U_BOOT_OFFS 0x20000 |
Masahiro Yamada | e97f27c | 2016-03-23 01:40:04 +0900 | [diff] [blame] | 295 | |
Masahiro Yamada | ea5da9f | 2016-03-23 01:40:05 +0900 | [diff] [blame] | 296 | /* subtract sizeof(struct image_header) */ |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 297 | #define CONFIG_SYS_UBOOT_BASE (0x70000 - 0x40) |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 298 | |
Masahiro Yamada | ea5da9f | 2016-03-23 01:40:05 +0900 | [diff] [blame] | 299 | #define CONFIG_SPL_TARGET "u-boot-with-spl.bin" |
Masahiro Yamada | b4f865d | 2015-03-23 00:07:27 +0900 | [diff] [blame] | 300 | #define CONFIG_SPL_MAX_FOOTPRINT 0x10000 |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 301 | #if defined(CONFIG_ARCH_UNIPHIER_LD20) |
| 302 | #define CONFIG_SPL_MAX_SIZE 0x14000 |
| 303 | #else |
Masahiro Yamada | 09c8ffb | 2016-03-24 22:22:23 +0900 | [diff] [blame] | 304 | #define CONFIG_SPL_MAX_SIZE 0x10000 |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 305 | #endif |
Masahiro Yamada | 8bbbcbd | 2016-05-24 21:14:01 +0900 | [diff] [blame] | 306 | #if defined(CONFIG_ARCH_UNIPHIER_LD11) |
| 307 | #define CONFIG_SPL_BSS_START_ADDR 0x30012000 |
| 308 | #elif defined(CONFIG_ARCH_UNIPHIER_LD20) |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 309 | #define CONFIG_SPL_BSS_START_ADDR 0x30016000 |
Masahiro Yamada | 8bbbcbd | 2016-05-24 21:14:01 +0900 | [diff] [blame] | 310 | #endif |
Masahiro Yamada | 063eb1e | 2016-04-21 14:43:18 +0900 | [diff] [blame] | 311 | #define CONFIG_SPL_BSS_MAX_SIZE 0x2000 |
Masahiro Yamada | b4f865d | 2015-03-23 00:07:27 +0900 | [diff] [blame] | 312 | |
Masahiro Yamada | 43ccfaf | 2017-01-28 06:53:53 +0900 | [diff] [blame] | 313 | #define CONFIG_SPL_PAD_TO 0x20000 |
| 314 | |
Masahiro Yamada | bb2ff9d | 2014-10-03 19:21:06 +0900 | [diff] [blame] | 315 | #endif /* __CONFIG_UNIPHIER_COMMON_H__ */ |