ARM64: zynqmp: List secondary software boot modes
authorMichal Simek <michal.simek@xilinx.com>
Wed, 26 Oct 2016 07:24:32 +0000 (09:24 +0200)
committerMichal Simek <michal.simek@xilinx.com>
Fri, 2 Dec 2016 13:35:57 +0000 (14:35 +0100)
Using alternative bootmode field to support automatic secondary boot
modes. It is purely software setting where SW modes are using free
bootmode combinations.

Signed-off-by: Michal Simek <michal.simek@xilinx.com>
arch/arm/cpu/armv8/zynqmp/Kconfig
arch/arm/cpu/armv8/zynqmp/spl.c
arch/arm/include/asm/arch-zynqmp/hardware.h

index d20af041915db4c086d60a0bf9d8fdde22970dba..f354aae3fc2463b9d434190302336acf086fa9d6 100644 (file)
@@ -71,6 +71,8 @@ config SPL_ZYNQMP_ALT_BOOTMODE
        default 0x5 if SD_MODE1
        default 0x6 if EMMC_MODE
        default 0x7 if USB_MODE
+       default 0xa if SW_USBHOST_MODE
+       default 0xb if SW_SATA_MODE
 
 choice
        prompt "Boot mode"
@@ -101,6 +103,12 @@ config EMMC_MODE
 config USB_MODE
        bool "USB"
 
+config SW_USBHOST_MODE
+       bool "SW USBHOST_MODE"
+
+config SW_SATA_MODE
+       bool "SW SATA_MODE"
+
 endchoice
 
 endif
index bdbd61380ab7aa8323b118128e48fd8a2b85717b..f5f550f9e2b4707de3ecd05bea8ed4013b756afa 100644 (file)
@@ -91,6 +91,10 @@ u32 spl_boot_device(void)
 #ifdef CONFIG_SPL_DFU_SUPPORT
        case USB_MODE:
                return BOOT_DEVICE_DFU;
+#endif
+#ifdef CONFIG_SPL_SATA_SUPPORT
+       case SW_SATA_MODE:
+               return BOOT_DEVICE_SATA;
 #endif
        default:
                printf("Invalid Boot Mode:0x%x\n", bootmode);
index e7738faaf896d4b04576acd90c8ce817fb12fa0a..5908c50d09460a359150a73d65a1a60d9da0d914 100644 (file)
@@ -83,6 +83,9 @@ struct iou_scntr_secure {
 #define JTAG_MODE      0x00000000
 #define BOOT_MODE_USE_ALT      0x100
 #define BOOT_MODE_ALT_SHIFT    12
+/* SW secondary boot modes 0xa - 0xd */
+#define SW_USBHOST_MODE        0x0000000A
+#define SW_SATA_MODE   0x0000000B
 
 #define ZYNQMP_IOU_SLCR_BASEADDR       0xFF180000