1 #ifndef KVM__KVM_CONFIG_ARCH_H 2 #define KVM__KVM_CONFIG_ARCH_H 3 4 #include "kvm/parse-options.h" 5 6 struct kvm_config_arch { 7 const char *dump_dtb_filename; 8 u64 custom_mvendorid; 9 u64 custom_marchid; 10 u64 custom_mimpid; 11 bool ext_disabled[KVM_RISCV_ISA_EXT_MAX]; 12 bool sbi_ext_disabled[KVM_RISCV_SBI_EXT_MAX]; 13 }; 14 15 #define OPT_ARCH_RUN(pfx, cfg) \ 16 pfx, \ 17 OPT_STRING('\0', "dump-dtb", &(cfg)->dump_dtb_filename, \ 18 ".dtb file", "Dump generated .dtb to specified file"),\ 19 OPT_U64('\0', "custom-mvendorid", \ 20 &(cfg)->custom_mvendorid, \ 21 "Show custom mvendorid to Guest VCPU"), \ 22 OPT_U64('\0', "custom-marchid", \ 23 &(cfg)->custom_marchid, \ 24 "Show custom marchid to Guest VCPU"), \ 25 OPT_U64('\0', "custom-mimpid", \ 26 &(cfg)->custom_mimpid, \ 27 "Show custom mimpid to Guest VCPU"), \ 28 OPT_BOOLEAN('\0', "disable-smstateen", \ 29 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SMSTATEEN], \ 30 "Disable Smstateen Extension"), \ 31 OPT_BOOLEAN('\0', "disable-ssaia", \ 32 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SSAIA], \ 33 "Disable Ssaia Extension"), \ 34 OPT_BOOLEAN('\0', "disable-sstc", \ 35 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SSTC], \ 36 "Disable Sstc Extension"), \ 37 OPT_BOOLEAN('\0', "disable-svinval", \ 38 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SVINVAL], \ 39 "Disable Svinval Extension"), \ 40 OPT_BOOLEAN('\0', "disable-svnapot", \ 41 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SVNAPOT], \ 42 "Disable Svnapot Extension"), \ 43 OPT_BOOLEAN('\0', "disable-svpbmt", \ 44 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_SVPBMT], \ 45 "Disable Svpbmt Extension"), \ 46 OPT_BOOLEAN('\0', "disable-zba", \ 47 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBA], \ 48 "Disable Zba Extension"), \ 49 OPT_BOOLEAN('\0', "disable-zbb", \ 50 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBB], \ 51 "Disable Zbb Extension"), \ 52 OPT_BOOLEAN('\0', "disable-zbc", \ 53 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBC], \ 54 "Disable Zbc Extension"), \ 55 OPT_BOOLEAN('\0', "disable-zbkb", \ 56 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBKB], \ 57 "Disable Zbkb Extension"), \ 58 OPT_BOOLEAN('\0', "disable-zbkc", \ 59 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBKC], \ 60 "Disable Zbkc Extension"), \ 61 OPT_BOOLEAN('\0', "disable-zbkx", \ 62 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBKX], \ 63 "Disable Zbkx Extension"), \ 64 OPT_BOOLEAN('\0', "disable-zbs", \ 65 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBS], \ 66 "Disable Zbs Extension"), \ 67 OPT_BOOLEAN('\0', "disable-zicbom", \ 68 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICBOM], \ 69 "Disable Zicbom Extension"), \ 70 OPT_BOOLEAN('\0', "disable-zicboz", \ 71 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICBOZ], \ 72 "Disable Zicboz Extension"), \ 73 OPT_BOOLEAN('\0', "disable-zicntr", \ 74 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICNTR], \ 75 "Disable Zicntr Extension"), \ 76 OPT_BOOLEAN('\0', "disable-zicond", \ 77 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICOND], \ 78 "Disable Zicond Extension"), \ 79 OPT_BOOLEAN('\0', "disable-zicsr", \ 80 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICSR], \ 81 "Disable Zicsr Extension"), \ 82 OPT_BOOLEAN('\0', "disable-zifencei", \ 83 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIFENCEI], \ 84 "Disable Zifencei Extension"), \ 85 OPT_BOOLEAN('\0', "disable-zihintpause", \ 86 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIHINTPAUSE],\ 87 "Disable Zihintpause Extension"), \ 88 OPT_BOOLEAN('\0', "disable-zihpm", \ 89 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIHPM], \ 90 "Disable Zihpm Extension"), \ 91 OPT_BOOLEAN('\0', "disable-zknd", \ 92 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKND], \ 93 "Disable Zknd Extension"), \ 94 OPT_BOOLEAN('\0', "disable-zkne", \ 95 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKNE], \ 96 "Disable Zkne Extension"), \ 97 OPT_BOOLEAN('\0', "disable-zknh", \ 98 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKNH], \ 99 "Disable Zknh Extension"), \ 100 OPT_BOOLEAN('\0', "disable-zkr", \ 101 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKR], \ 102 "Disable Zkr Extension"), \ 103 OPT_BOOLEAN('\0', "disable-zksed", \ 104 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKSED], \ 105 "Disable Zksed Extension"), \ 106 OPT_BOOLEAN('\0', "disable-zksh", \ 107 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKSH], \ 108 "Disable Zksh Extension"), \ 109 OPT_BOOLEAN('\0', "disable-zkt", \ 110 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZKT], \ 111 "Disable Zkt Extension"), \ 112 OPT_BOOLEAN('\0', "disable-sbi-legacy", \ 113 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_V01], \ 114 "Disable SBI Legacy Extensions"), \ 115 OPT_BOOLEAN('\0', "disable-sbi-time", \ 116 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_TIME], \ 117 "Disable SBI Time Extension"), \ 118 OPT_BOOLEAN('\0', "disable-sbi-ipi", \ 119 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_IPI], \ 120 "Disable SBI IPI Extension"), \ 121 OPT_BOOLEAN('\0', "disable-sbi-rfence", \ 122 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_RFENCE], \ 123 "Disable SBI RFence Extension"), \ 124 OPT_BOOLEAN('\0', "disable-sbi-srst", \ 125 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_SRST], \ 126 "Disable SBI SRST Extension"), \ 127 OPT_BOOLEAN('\0', "disable-sbi-hsm", \ 128 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_HSM], \ 129 "Disable SBI HSM Extension"), \ 130 OPT_BOOLEAN('\0', "disable-sbi-pmu", \ 131 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_PMU], \ 132 "Disable SBI PMU Extension"), \ 133 OPT_BOOLEAN('\0', "disable-sbi-experimental", \ 134 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_EXPERIMENTAL],\ 135 "Disable SBI Experimental Extensions"), \ 136 OPT_BOOLEAN('\0', "disable-sbi-vendor", \ 137 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_VENDOR], \ 138 "Disable SBI Vendor Extensions"), \ 139 OPT_BOOLEAN('\0', "disable-sbi-dbcn", \ 140 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_DBCN], \ 141 "Disable SBI DBCN Extension"), 142 143 #endif /* KVM__KVM_CONFIG_ARCH_H */ 144