riscv: sifive: fu540: add SPL configuration
authorPragnesh Patel <pragnesh.patel@sifive.com>
Fri, 29 May 2020 06:03:35 +0000 (11:33 +0530)
committerAndes <uboot@andestech.com>
Thu, 4 Jun 2020 01:44:09 +0000 (09:44 +0800)
Add a support for SPL which will boot from L2 LIM (0x0800_0000) and
then SPL will boot U-Boot FIT image (OpenSBI FW_DYNAMIC + u-boot.bin)
from MMC boot devices.

SPL related code is leveraged from FSBL
(https://github.com/sifive/freedom-u540-c000-bootloader.git)

Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
Tested-by: Bin Meng <bmeng.cn@gmail.com>
Reviewed-by: Jagan Teki <jagan@amarulasolutions.com>
Tested-by: Jagan Teki <jagan@amarulasolutions.com>
arch/riscv/cpu/fu540/Makefile
arch/riscv/cpu/fu540/spl.c [new file with mode: 0644]
arch/riscv/dts/hifive-unleashed-a00-u-boot.dtsi
arch/riscv/include/asm/arch-fu540/spl.h [new file with mode: 0644]
board/sifive/fu540/Kconfig
board/sifive/fu540/Makefile
board/sifive/fu540/fu540.c
board/sifive/fu540/spl.c [new file with mode: 0644]
include/configs/sifive-fu540.h

index 44700d998c2d578793f14f7a705b7638a521f9e6..043fb961a51e99abfe6e8a976f9ee20cea74d6f0 100644 (file)
@@ -3,5 +3,9 @@
 # Copyright (C) 2020 SiFive, Inc
 # Pragnesh Patel <pragnesh.patel@sifive.com>
 
+ifeq ($(CONFIG_SPL_BUILD),y)
+obj-y += spl.o
+else
 obj-y += dram.o
 obj-y += cpu.o
+endif
diff --git a/arch/riscv/cpu/fu540/spl.c b/arch/riscv/cpu/fu540/spl.c
new file mode 100644 (file)
index 0000000..a2034e9
--- /dev/null
@@ -0,0 +1,23 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2020 SiFive, Inc
+ * Pragnesh Patel <pragnesh.patel@sifive.com>
+ */
+
+#include <dm.h>
+#include <log.h>
+
+int soc_spl_init(void)
+{
+       int ret;
+       struct udevice *dev;
+
+       /* DDR init */
+       ret = uclass_get_device(UCLASS_RAM, 0, &dev);
+       if (ret) {
+               debug("DRAM init failed: %d\n", ret);
+               return ret;
+       }
+
+       return 0;
+}
index 9787332bf1a2c89d2857d00c459e79af98f7c858..303806454b048609cc0c8fc31156d52a41b94ed8 100644 (file)
@@ -4,6 +4,7 @@
  */
 
 #include "fu540-c000-u-boot.dtsi"
+#include "fu540-hifive-unleashed-a00-ddr.dtsi"
 
 / {
        aliases {
@@ -26,3 +27,7 @@
                u-boot,dm-spl;
        };
 };
+
+&gpio {
+       u-boot,dm-spl;
+};
diff --git a/arch/riscv/include/asm/arch-fu540/spl.h b/arch/riscv/include/asm/arch-fu540/spl.h
new file mode 100644 (file)
index 0000000..0c188be
--- /dev/null
@@ -0,0 +1,14 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * Copyright (C) 2020 SiFive, Inc.
+ *
+ * Authors:
+ *   Pragnesh Patel <pragnesh.patel@sifve.com>
+ */
+
+#ifndef _SPL_SIFIVE_H
+#define _SPL_SIFIVE_H
+
+int soc_spl_init(void);
+
+#endif /* _SPL_SIFIVE_H */
index eb5ba3123d433b1d82a261790cab191125b7085f..4a77a2a37b128d2852f36676c6d78d2c4492d247 100644 (file)
@@ -13,12 +13,20 @@ config SYS_CONFIG_NAME
        default "sifive-fu540"
 
 config SYS_TEXT_BASE
+       default 0x80200000 if SPL
        default 0x80000000 if !RISCV_SMODE
        default 0x80200000 if RISCV_SMODE
 
+config SPL_TEXT_BASE
+       default 0x08000000
+
+config SPL_OPENSBI_LOAD_ADDR
+       default 0x80000000
+
 config BOARD_SPECIFIC_OPTIONS # dummy
        def_bool y
-       select GENERIC_RISCV
+       select SIFIVE_FU540
+       select SUPPORT_SPL
        select RAM
        select SPL_RAM if SPL
        imply CMD_DHCP
index 6e1862c475d4438b449e2fc5e976ae56998b5f02..b05e2f58078d6de2882535a1bfd614be4607ce2b 100644 (file)
@@ -3,3 +3,7 @@
 # Copyright (c) 2019 Western Digital Corporation or its affiliates.
 
 obj-y  += fu540.o
+
+ifdef CONFIG_SPL_BUILD
+obj-y += spl.o
+endif
index ef2c40da27c055ac22d11cbd34da490f45e6f533..fa705dea71dfcf6024c0b2fcac6e82c20eac2927 100644 (file)
@@ -14,6 +14,7 @@
 #include <linux/delay.h>
 #include <linux/io.h>
 #include <misc.h>
+#include <spl.h>
 
 /*
  * This define is a value used for error/unknown serial.
@@ -117,3 +118,23 @@ int board_init(void)
 
        return 0;
 }
+
+#ifdef CONFIG_SPL
+u32 spl_boot_device(void)
+{
+#ifdef CONFIG_SPL_MMC_SUPPORT
+       return BOOT_DEVICE_MMC1;
+#else
+       puts("Unknown boot device\n");
+       hang();
+#endif
+}
+#endif
+
+#ifdef CONFIG_SPL_LOAD_FIT
+int board_fit_config_name_match(const char *name)
+{
+       /* boot using first FIT config */
+       return 0;
+}
+#endif
diff --git a/board/sifive/fu540/spl.c b/board/sifive/fu540/spl.c
new file mode 100644 (file)
index 0000000..55325cf
--- /dev/null
@@ -0,0 +1,74 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (c) 2019 SiFive, Inc
+ *
+ * Authors:
+ *   Pragnesh Patel <pragnesh.patel@sifive.com>
+ */
+
+#include <init.h>
+#include <spl.h>
+#include <misc.h>
+#include <log.h>
+#include <linux/delay.h>
+#include <asm/gpio.h>
+#include <asm/arch/gpio.h>
+#include <asm/arch/spl.h>
+
+#define GEM_PHY_RESET  SIFIVE_GENERIC_GPIO_NR(0, 12)
+
+int init_clk_and_ddr(void)
+{
+       int ret;
+
+       ret = soc_spl_init();
+       if (ret) {
+               debug("FU540 SPL init failed: %d\n", ret);
+               return ret;
+       }
+
+       /*
+        * GEMGXL init VSC8541 PHY reset sequence;
+        * leave pull-down active for 2ms
+        */
+       udelay(2000);
+       ret = gpio_request(GEM_PHY_RESET, "gem_phy_reset");
+       if (ret) {
+               debug("gem_phy_reset gpio request failed: %d\n", ret);
+               return ret;
+       }
+
+       /* Set GPIO 12 (PHY NRESET) */
+       ret = gpio_direction_output(GEM_PHY_RESET, 1);
+       if (ret) {
+               debug("gem_phy_reset gpio direction set failed: %d\n", ret);
+               return ret;
+       }
+
+       udelay(1);
+
+       /* Reset PHY again to enter unmanaged mode */
+       gpio_set_value(GEM_PHY_RESET, 0);
+       udelay(1);
+       gpio_set_value(GEM_PHY_RESET, 1);
+       mdelay(15);
+
+       return 0;
+}
+
+void board_init_f(ulong dummy)
+{
+       int ret;
+
+       ret = spl_early_init();
+       if (ret)
+               panic("spl_early_init() failed: %d\n", ret);
+
+       arch_cpu_init_dm();
+
+       preloader_console_init();
+
+       ret = init_clk_and_ddr();
+       if (ret)
+               panic("init_clk_and_ddr() failed: %d\n", ret);
+}
index 2756ed5a77f3bdaf170e464756d5ca50e9d5e2d9..ef3ae9b650d7c9227da936758a0cc61268444a2f 100644 (file)
 
 #include <linux/sizes.h>
 
+#ifdef CONFIG_SPL
+
+#define CONFIG_SPL_MAX_SIZE            0x00100000
+#define CONFIG_SPL_BSS_START_ADDR      0x85000000
+#define CONFIG_SPL_BSS_MAX_SIZE                0x00100000
+#define CONFIG_SYS_SPL_MALLOC_START    (CONFIG_SPL_BSS_START_ADDR + \
+                                        CONFIG_SPL_BSS_MAX_SIZE)
+#define CONFIG_SYS_SPL_MALLOC_SIZE     0x00100000
+
+#define CONFIG_SPL_LOAD_FIT_ADDRESS    0x84000000
+
+#define CONFIG_SPL_STACK       (0x08000000 + 0x001D0000 - \
+                                GENERATED_GBL_DATA_SIZE)
+
+#endif
+
 #define CONFIG_SYS_SDRAM_BASE          0x80000000
 #define CONFIG_SYS_INIT_SP_ADDR                (CONFIG_SYS_SDRAM_BASE + SZ_2M)
 
@@ -24,6 +40,7 @@
 
 /* Environment options */
 
+#ifndef CONFIG_SPL_BUILD
 #define BOOT_TARGET_DEVICES(func) \
        func(MMC, mmc, 0) \
        func(DHCP, dhcp, na)
@@ -43,5 +60,6 @@
 #define CONFIG_PREBOOT \
        "setenv fdt_addr ${fdtcontroladdr};" \
        "fdt addr ${fdtcontroladdr};"
+#endif
 
 #endif /* __CONFIG_H */