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-zbs", \ 53 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZBS], \ 54 "Disable Zbs Extension"), \ 55 OPT_BOOLEAN('\0', "disable-zicbom", \ 56 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICBOM], \ 57 "Disable Zicbom Extension"), \ 58 OPT_BOOLEAN('\0', "disable-zicboz", \ 59 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICBOZ], \ 60 "Disable Zicboz Extension"), \ 61 OPT_BOOLEAN('\0', "disable-zicntr", \ 62 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICNTR], \ 63 "Disable Zicntr Extension"), \ 64 OPT_BOOLEAN('\0', "disable-zicond", \ 65 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICOND], \ 66 "Disable Zicond Extension"), \ 67 OPT_BOOLEAN('\0', "disable-zicsr", \ 68 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZICSR], \ 69 "Disable Zicsr Extension"), \ 70 OPT_BOOLEAN('\0', "disable-zifencei", \ 71 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIFENCEI], \ 72 "Disable Zifencei Extension"), \ 73 OPT_BOOLEAN('\0', "disable-zihintpause", \ 74 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIHINTPAUSE],\ 75 "Disable Zihintpause Extension"), \ 76 OPT_BOOLEAN('\0', "disable-zihpm", \ 77 &(cfg)->ext_disabled[KVM_RISCV_ISA_EXT_ZIHPM], \ 78 "Disable Zihpm Extension"), \ 79 OPT_BOOLEAN('\0', "disable-sbi-legacy", \ 80 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_V01], \ 81 "Disable SBI Legacy Extensions"), \ 82 OPT_BOOLEAN('\0', "disable-sbi-time", \ 83 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_TIME], \ 84 "Disable SBI Time Extension"), \ 85 OPT_BOOLEAN('\0', "disable-sbi-ipi", \ 86 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_IPI], \ 87 "Disable SBI IPI Extension"), \ 88 OPT_BOOLEAN('\0', "disable-sbi-rfence", \ 89 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_RFENCE], \ 90 "Disable SBI RFence Extension"), \ 91 OPT_BOOLEAN('\0', "disable-sbi-srst", \ 92 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_SRST], \ 93 "Disable SBI SRST Extension"), \ 94 OPT_BOOLEAN('\0', "disable-sbi-hsm", \ 95 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_HSM], \ 96 "Disable SBI HSM Extension"), \ 97 OPT_BOOLEAN('\0', "disable-sbi-pmu", \ 98 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_PMU], \ 99 "Disable SBI PMU Extension"), \ 100 OPT_BOOLEAN('\0', "disable-sbi-experimental", \ 101 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_EXPERIMENTAL],\ 102 "Disable SBI Experimental Extensions"), \ 103 OPT_BOOLEAN('\0', "disable-sbi-vendor", \ 104 &(cfg)->sbi_ext_disabled[KVM_RISCV_SBI_EXT_VENDOR], \ 105 "Disable SBI Vendor Extensions"), 106 107 #endif /* KVM__KVM_CONFIG_ARCH_H */ 108