Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0+ |
| 2 | /* |
| 3 | * The 'sbi' command displays information about the SBI implementation. |
| 4 | * |
| 5 | * Copyright (c) 2020, Heinrich Schuchardt <xypron.glpk@gmx.de> |
| 6 | */ |
| 7 | |
| 8 | #include <common.h> |
| 9 | #include <command.h> |
| 10 | #include <asm/sbi.h> |
| 11 | |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 12 | struct sbi_imp { |
| 13 | const long id; |
| 14 | const char *name; |
| 15 | }; |
| 16 | |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 17 | struct sbi_ext { |
| 18 | const u32 id; |
| 19 | const char *name; |
| 20 | }; |
| 21 | |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 22 | static struct sbi_imp implementations[] = { |
| 23 | { 0, "Berkeley Boot Loader (BBL)" }, |
| 24 | { 1, "OpenSBI" }, |
| 25 | { 2, "Xvisor" }, |
| 26 | { 3, "KVM" }, |
| 27 | { 4, "RustSBI" }, |
| 28 | { 5, "Diosix" }, |
Heinrich Schuchardt | 73872eb | 2022-05-07 14:42:10 +0200 | [diff] [blame] | 29 | { 6, "Coffer" }, |
Heinrich Schuchardt | 6982e6b | 2023-08-02 22:39:46 +0200 | [diff] [blame^] | 30 | { 7, "Xen Project" }, |
| 31 | { 8, "PolarFire Hart Software Services" }, |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 32 | }; |
| 33 | |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 34 | static struct sbi_ext extensions[] = { |
Heinrich Schuchardt | f22db44 | 2022-10-04 10:09:54 +0200 | [diff] [blame] | 35 | { SBI_EXT_0_1_SET_TIMER, "Set Timer" }, |
| 36 | { SBI_EXT_0_1_CONSOLE_PUTCHAR, "Console Putchar" }, |
| 37 | { SBI_EXT_0_1_CONSOLE_GETCHAR, "Console Getchar" }, |
| 38 | { SBI_EXT_0_1_CLEAR_IPI, "Clear IPI" }, |
| 39 | { SBI_EXT_0_1_SEND_IPI, "Send IPI" }, |
| 40 | { SBI_EXT_0_1_REMOTE_FENCE_I, "Remote FENCE.I" }, |
| 41 | { SBI_EXT_0_1_REMOTE_SFENCE_VMA, "Remote SFENCE.VMA" }, |
| 42 | { SBI_EXT_0_1_REMOTE_SFENCE_VMA_ASID, "Remote SFENCE.VMA with ASID" }, |
| 43 | { SBI_EXT_0_1_SHUTDOWN, "System Shutdown" }, |
Heinrich Schuchardt | 09d7cc3 | 2021-09-12 21:11:45 +0200 | [diff] [blame] | 44 | { SBI_EXT_BASE, "SBI Base Functionality" }, |
| 45 | { SBI_EXT_TIME, "Timer Extension" }, |
| 46 | { SBI_EXT_IPI, "IPI Extension" }, |
| 47 | { SBI_EXT_RFENCE, "RFENCE Extension" }, |
| 48 | { SBI_EXT_HSM, "Hart State Management Extension" }, |
| 49 | { SBI_EXT_SRST, "System Reset Extension" }, |
Heinrich Schuchardt | 70ae54b | 2022-03-16 21:21:18 +0100 | [diff] [blame] | 50 | { SBI_EXT_PMU, "Performance Monitoring Unit Extension" }, |
Heinrich Schuchardt | 7906155 | 2023-04-12 10:38:16 +0200 | [diff] [blame] | 51 | { SBI_EXT_DBCN, "Debug Console Extension" }, |
| 52 | { SBI_EXT_SUSP, "System Suspend Extension" }, |
| 53 | { SBI_EXT_CPPC, "Collaborative Processor Performance Control Extension" }, |
Heinrich Schuchardt | 6982e6b | 2023-08-02 22:39:46 +0200 | [diff] [blame^] | 54 | { SBI_EXT_NACL, "Nested Acceleration Extension" }, |
| 55 | { SBI_EXT_STA, "Steal-time Accounting Extension" }, |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 56 | }; |
| 57 | |
| 58 | static int do_sbi(struct cmd_tbl *cmdtp, int flag, int argc, |
| 59 | char *const argv[]) |
| 60 | { |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 61 | int i, impl_id; |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 62 | long ret; |
Heinrich Schuchardt | cfb31e0 | 2022-03-17 07:36:15 +0100 | [diff] [blame] | 63 | long mvendorid, marchid, mimpid; |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 64 | |
| 65 | ret = sbi_get_spec_version(); |
Heinrich Schuchardt | 72c1f5f | 2022-10-04 10:09:53 +0200 | [diff] [blame] | 66 | if (ret < 0) { |
| 67 | printf("No SBI 0.2+\n"); |
| 68 | return CMD_RET_FAILURE; |
| 69 | } |
| 70 | printf("SBI %ld.%ld", ret >> 24, ret & 0xffffff); |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 71 | impl_id = sbi_get_impl_id(); |
| 72 | if (impl_id >= 0) { |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 73 | for (i = 0; i < ARRAY_SIZE(implementations); ++i) { |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 74 | if (impl_id == implementations[i].id) { |
| 75 | long vers; |
| 76 | |
| 77 | printf("\n%s ", implementations[i].name); |
| 78 | ret = sbi_get_impl_version(&vers); |
| 79 | if (ret < 0) |
| 80 | break; |
Heinrich Schuchardt | aa8aa48 | 2022-08-14 21:57:14 +0200 | [diff] [blame] | 81 | switch (impl_id) { |
| 82 | case 1: /* OpenSBI */ |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 83 | printf("%ld.%ld", |
| 84 | vers >> 16, vers & 0xffff); |
Heinrich Schuchardt | aa8aa48 | 2022-08-14 21:57:14 +0200 | [diff] [blame] | 85 | break; |
| 86 | case 3: /* KVM */ |
Heinrich Schuchardt | 9487764 | 2022-10-04 10:09:52 +0200 | [diff] [blame] | 87 | case 4: /* RustSBI */ |
Heinrich Schuchardt | aa8aa48 | 2022-08-14 21:57:14 +0200 | [diff] [blame] | 88 | printf("%ld.%ld.%ld", |
| 89 | vers >> 16, |
| 90 | (vers >> 8) & 0xff, |
| 91 | vers & 0xff); |
| 92 | break; |
| 93 | default: |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 94 | printf("0x%lx", vers); |
Heinrich Schuchardt | aa8aa48 | 2022-08-14 21:57:14 +0200 | [diff] [blame] | 95 | break; |
| 96 | } |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 97 | break; |
| 98 | } |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 99 | } |
Heinrich Schuchardt | 7fd892b | 2021-01-19 19:44:45 +0000 | [diff] [blame] | 100 | if (i == ARRAY_SIZE(implementations)) |
Heinrich Schuchardt | 89a86dc | 2021-10-25 15:09:35 +0200 | [diff] [blame] | 101 | printf("Unknown implementation ID %ld", ret); |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 102 | } |
Heinrich Schuchardt | cfb31e0 | 2022-03-17 07:36:15 +0100 | [diff] [blame] | 103 | printf("\nMachine:\n"); |
| 104 | ret = sbi_get_mvendorid(&mvendorid); |
| 105 | if (!ret) |
| 106 | printf(" Vendor ID %lx\n", mvendorid); |
| 107 | ret = sbi_get_marchid(&marchid); |
| 108 | if (!ret) |
| 109 | printf(" Architecture ID %lx\n", marchid); |
| 110 | ret = sbi_get_mimpid(&mimpid); |
| 111 | if (!ret) |
| 112 | printf(" Implementation ID %lx\n", mimpid); |
| 113 | printf("Extensions:\n"); |
Heinrich Schuchardt | c92b50a | 2020-08-20 19:43:39 +0200 | [diff] [blame] | 114 | for (i = 0; i < ARRAY_SIZE(extensions); ++i) { |
| 115 | ret = sbi_probe_extension(extensions[i].id); |
| 116 | if (ret > 0) |
| 117 | printf(" %s\n", extensions[i].name); |
| 118 | } |
| 119 | return 0; |
| 120 | } |
| 121 | |
| 122 | #ifdef CONFIG_SYS_LONGHELP |
| 123 | static char sbi_help_text[] = |
| 124 | "- display SBI spec version, implementation, and available extensions"; |
| 125 | |
| 126 | #endif |
| 127 | |
| 128 | U_BOOT_CMD_COMPLETE( |
| 129 | sbi, 1, 0, do_sbi, |
| 130 | "display SBI information", |
| 131 | sbi_help_text, NULL |
| 132 | ); |