| /* SPDX-License-Identifier: BSD-2-Clause */ |
| /* |
| * Copyright (c) 2019 Western Digital Corporation or its affiliates. |
| * |
| * Based on include/sbi/{fw_dynamic.h,sbi_scratch.h} from the OpenSBI project. |
| */ |
| |
| #ifndef RISCV_BOOT_OPENSBI_H |
| #define RISCV_BOOT_OPENSBI_H |
| |
| #include "exec/cpu-defs.h" |
| |
| /** Expected value of info magic ('OSBI' ascii string in hex) */ |
| #define FW_DYNAMIC_INFO_MAGIC_VALUE 0x4942534f |
| |
| /** Maximum supported info version */ |
| #define FW_DYNAMIC_INFO_VERSION 0x2 |
| |
| /** Possible next mode values */ |
| #define FW_DYNAMIC_INFO_NEXT_MODE_U 0x0 |
| #define FW_DYNAMIC_INFO_NEXT_MODE_S 0x1 |
| #define FW_DYNAMIC_INFO_NEXT_MODE_M 0x3 |
| |
| enum sbi_scratch_options { |
| /** Disable prints during boot */ |
| SBI_SCRATCH_NO_BOOT_PRINTS = (1 << 0), |
| /** Enable runtime debug prints */ |
| SBI_SCRATCH_DEBUG_PRINTS = (1 << 1), |
| }; |
| |
| /** Representation dynamic info passed by previous booting stage */ |
| struct fw_dynamic_info { |
| /** Info magic */ |
| target_long magic; |
| /** Info version */ |
| target_long version; |
| /** Next booting stage address */ |
| target_long next_addr; |
| /** Next booting stage mode */ |
| target_long next_mode; |
| /** Options for OpenSBI library */ |
| target_long options; |
| /** |
| * Preferred boot HART id |
| * |
| * It is possible that the previous booting stage uses same link |
| * address as the FW_DYNAMIC firmware. In this case, the relocation |
| * lottery mechanism can potentially overwrite the previous booting |
| * stage while other HARTs are still running in the previous booting |
| * stage leading to boot-time crash. To avoid this boot-time crash, |
| * the previous booting stage can specify last HART that will jump |
| * to the FW_DYNAMIC firmware as the preferred boot HART. |
| * |
| * To avoid specifying a preferred boot HART, the previous booting |
| * stage can set it to -1UL which will force the FW_DYNAMIC firmware |
| * to use the relocation lottery mechanism. |
| */ |
| target_long boot_hart; |
| }; |
| |
| /** Representation dynamic info passed by previous booting stage */ |
| struct fw_dynamic_info32 { |
| /** Info magic */ |
| int32_t magic; |
| /** Info version */ |
| int32_t version; |
| /** Next booting stage address */ |
| int32_t next_addr; |
| /** Next booting stage mode */ |
| int32_t next_mode; |
| /** Options for OpenSBI library */ |
| int32_t options; |
| /** |
| * Preferred boot HART id |
| * |
| * It is possible that the previous booting stage uses same link |
| * address as the FW_DYNAMIC firmware. In this case, the relocation |
| * lottery mechanism can potentially overwrite the previous booting |
| * stage while other HARTs are still running in the previous booting |
| * stage leading to boot-time crash. To avoid this boot-time crash, |
| * the previous booting stage can specify last HART that will jump |
| * to the FW_DYNAMIC firmware as the preferred boot HART. |
| * |
| * To avoid specifying a preferred boot HART, the previous booting |
| * stage can set it to -1UL which will force the FW_DYNAMIC firmware |
| * to use the relocation lottery mechanism. |
| */ |
| int32_t boot_hart; |
| }; |
| #endif |