Merge tag 'efi-2020-07-rc2-2' of https://gitlab.denx.de/u-boot/custodians/u-boot-efi
[platform/kernel/u-boot.git] / include / configs / socfpga_arria5_secu1.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Copyright (C) 2017-2020 ABB
4  *
5  */
6 #ifndef __CONFIG_SOCFPGA_SECU1_H__
7 #define __CONFIG_SOCFPGA_SECU1_H__
8
9 #include <asm/arch/base_addr_ac5.h>
10
11 /* Call misc_init_r */
12 #define CONFIG_MISC_INIT_R
13
14 #define CONFIG_HUSH_INIT_VAR
15 /* Eternal oscillator */
16 #define CONFIG_SYS_TIMER_RATE   40000000
17
18 /* Memory configurations */
19 #define PHYS_SDRAM_1_SIZE       0x20000000      /* 512MiB on SECU1 */
20
21 /*
22  * We use bootcounter in i2c nvram of the RTC (0x68)
23  * The offset fopr the bootcounter is 0x9e, which are
24  * the last two bytes of the 128 bytes large NVRAM in the
25  * RTC which begin at address 0x20
26  */
27 #define CONFIG_SYS_I2C_RTC_ADDR         0x68
28
29 /* Booting Linux */
30 #define CONFIG_BOOTDELAY        2
31 #define CONFIG_BOOTFILE         "zImage"
32 #define CONFIG_BOOTARGS         \
33         "console=ttyS0," __stringify(CONFIG_BAUDRATE) \
34         " ubi.fm_autoconvert=1" \
35         " uio_pdrv_genirq.of_id=\"idq,regbank\""
36
37 #define CONFIG_BOOTCOMMAND      \
38         "setenv bootcmd '"      \
39                 "bridge enable; "       \
40                 "if test ${bootnum} = \"b\"; " \
41                       "then run _fpga_loadsafe; " \
42                 "else if test ${bootcount} -eq 4; then echo \"Switching copy...\"; setexpr x $bootnum % 2 && setexpr bootnum $x + 1; saveenv; fi; " \
43                       "run _fpga_loaduser; " \
44                 "fi;" \
45                 "echo \"Booting bank $bootnum\" && run userload && run userboot;" \
46         "' && " \
47         "setenv altbootcmd 'setenv bootnum b && saveenv && boot;' && " \
48         "saveenv && saveenv && boot;"
49
50 #define CONFIG_CMDLINE_TAG
51 #define CONFIG_SYS_BOOTM_LEN            (64 << 20)
52
53 /* Environment settings */
54 #define CONFIG_ENV_OVERWRITE
55
56 /*
57  * Autoboot
58  *
59  * After 45s of inactivity in the prompt, the board will reset.
60  * Set 'bootretry' in the environment to -1 to disable this behavior
61  */
62 #define CONFIG_BOOT_RETRY_TIME 45
63 #define CONFIG_RESET_TO_RETRY
64
65 #define CONFIG_LOADADDR         0x01000000
66 #define CONFIG_SYS_LOAD_ADDR   CONFIG_KM_KERNEL_ADDR
67
68 /*
69  * FPGA Remote Update related environment
70  *
71  * Note that since those commands access the FPGA, the HPS-to-FPGA
72  * bridges MUST have been previously enabled (for example
73  * with 'bridge enable').
74  */
75 #define FPGA_RMTU_ENV \
76         "rmtu_page=0xFF29000C\0" \
77         "rmtu_reconfig=0xFF290018\0" \
78         "fpga_safebase=0x0\0" \
79         "fpga_userbase=0x2000000\0" \
80         "_fpga_loaduser=echo Loading FPGA USER image..." \
81                 " && mw ${rmtu_page} ${fpga_userbase} && mw ${rmtu_reconfig} 1\0" \
82         "_fpga_loadsafe=echo Loading FPGA SAFE image..." \
83                 " && mw ${rmtu_page} ${fpga_safebase} && mw ${rmtu_reconfig} 1\0" \
84
85 #define CONFIG_KM_NEW_ENV \
86         "newenv=" \
87                 "nand erase 0x100000 0x40000\0"
88
89 #define CONFIG_KM_DEF_ENV_BOOTTARGETS \
90         "release=" \
91                 "run newenv; reset\0" \
92         "develop=" \
93                 "tftp 0x200000 scripts/develop-secu.txt && env import -t 0x200000 ${filesize} && saveenv && reset\0"
94
95 #define CONFIG_EXTRA_ENV_SETTINGS \
96         FPGA_RMTU_ENV \
97         CONFIG_KM_DEF_ENV_BOOTTARGETS \
98         CONFIG_KM_NEW_ENV \
99         "socfpga_legacy_reset_compat=1\0"       \
100         "altbootcmd=run bootcmd;\0"     \
101         "bootlimit=6\0" \
102         "bootnum=1\0" \
103         "bootretry=" __stringify(CONFIG_BOOT_RETRY_TIME) "\0" \
104         "fdt_addr=" __stringify(CONFIG_KM_FDT_ADDR) "\0" \
105         "load=tftpboot ${loadaddr} u-boot-with-nand-spl.sfp\0" \
106         "loadaddr=" __stringify(CONFIG_KM_KERNEL_ADDR) "\0" \
107         "mtdids=" CONFIG_MTDIDS_DEFAULT "\0" \
108         "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0" \
109         "update=nand erase 0x0 0x00100000 && nand write ${loadaddr} 0x0 ${filesize}\0" \
110         "userload=ubi part nand.ubi &&" \
111                 "ubi check rootfs$bootnum &&" \
112                 "ubi read $fdt_addr dtb$bootnum &&" \
113                 "ubi read $loadaddr kernel$bootnum\0" \
114         "userboot=setenv bootargs " CONFIG_BOOTARGS \
115                 " ubi.mtd=1 ubi.block=0,rootfs$bootnum root=/dev/ubiblock0_$ubivolid"   \
116                 " ro rootfstype=squashfs init=sbin/preinit;" \
117                 "bootz ${loadaddr} - ${fdt_addr}\0" \
118         "verify=y\0"
119
120 /* The rest of the configuration is shared */
121 #include <configs/socfpga_common.h>
122
123 #ifdef CONFIG_SPL_NAND_SUPPORT
124 #undef CONFIG_SYS_NAND_U_BOOT_OFFS
125 #define CONFIG_SYS_NAND_U_BOOT_OFFS     0x80000
126 #endif
127
128 #undef CONFIG_WATCHDOG_TIMEOUT_MSECS
129 #define CONFIG_WATCHDOG_TIMEOUT_MSECS   60000
130
131 #endif  /* __CONFIG_SOCFPGA_SECU1_H__ */