| /linux/tools/testing/selftests/kvm/include/ |
| H A D | kvm_util.h | 63 struct kvm_vm *vm; 99 struct kvm_vm { struct 167 memslot2region(struct kvm_vm *vm, uint32_t memslot); 169 static inline struct userspace_mem_region *vm_get_mem_region(struct kvm_vm *vm, in vm_get_mem_region() 336 static __always_inline void static_assert_is_vm(struct kvm_vm *vm) { } in static_assert_is_vm() 399 static inline int vm_check_cap(struct kvm_vm *vm, long cap) in vm_check_cap() 407 static inline int __vm_enable_cap(struct kvm_vm *vm, uint32_t cap, uint64_t arg0) in __vm_enable_cap() 413 static inline void vm_enable_cap(struct kvm_vm *vm, uint32_t cap, uint64_t arg0) in vm_enable_cap() 420 static inline void vm_set_memory_attributes(struct kvm_vm *vm, uint64_t gpa, in vm_set_memory_attributes() 441 static inline void vm_mem_set_private(struct kvm_vm *vm, uint64_t gpa, in vm_mem_set_private() [all …]
|
| H A D | memstress.h | 33 struct kvm_vm *vm; 58 struct kvm_vm *memstress_create_vm(enum vm_guest_mode mode, int nr_vcpus, 62 void memstress_destroy_vm(struct kvm_vm *vm); 64 void memstress_set_write_percent(struct kvm_vm *vm, uint32_t write_percent); 65 void memstress_set_random_access(struct kvm_vm *vm, bool random_access); 72 void memstress_setup_nested(struct kvm_vm *vm, int nr_vcpus, struct kvm_vcpu *vcpus[]); 74 void memstress_enable_dirty_logging(struct kvm_vm *vm, int slots); 75 void memstress_disable_dirty_logging(struct kvm_vm *vm, int slots); 76 void memstress_get_dirty_log(struct kvm_vm *vm, unsigned long *bitmaps[], int slots); 77 void memstress_clear_dirty_log(struct kvm_vm *vm, unsigned long *bitmaps[],
|
| /linux/tools/testing/selftests/kvm/include/x86/ |
| H A D | sev.h | 34 static inline bool is_sev_snp_vm(struct kvm_vm *vm) in is_sev_snp_vm() 39 static inline bool is_sev_es_vm(struct kvm_vm *vm) in is_sev_es_vm() 44 static inline bool is_sev_vm(struct kvm_vm *vm) in is_sev_vm() 49 void sev_vm_launch(struct kvm_vm *vm, uint32_t policy); 50 void sev_vm_launch_measure(struct kvm_vm *vm, uint8_t *measurement); 51 void sev_vm_launch_finish(struct kvm_vm *vm); 52 void snp_vm_launch_start(struct kvm_vm *vm, uint64_t policy); 53 void snp_vm_launch_update(struct kvm_vm *vm); 54 void snp_vm_launch_finish(struct kvm_vm *vm); 56 struct kvm_vm *vm_sev_create_with_one_vcpu(uint32_t type, void *guest_code, [all …]
|
| /linux/tools/testing/selftests/kvm/x86/ |
| H A D | sev_migrate_tests.c | 23 static struct kvm_vm *sev_vm_create(bool es) in sev_vm_create() 25 struct kvm_vm *vm; in sev_vm_create() 44 static struct kvm_vm *aux_vm_create(bool with_vcpus) in aux_vm_create() 46 struct kvm_vm *vm; in aux_vm_create() 59 static int __sev_migrate_from(struct kvm_vm *dst, struct kvm_vm *src) in __sev_migrate_from() 65 static void sev_migrate_from(struct kvm_vm *dst, struct kvm_vm *src) in sev_migrate_from() 75 struct kvm_vm *src_vm; in test_sev_migrate_from() 76 struct kvm_vm *dst_vms[NR_MIGRATE_TEST_VMS]; in test_sev_migrate_from() 101 struct kvm_vm *vm; 102 struct kvm_vm *source_vms[NR_LOCK_TESTING_THREADS]; [all …]
|
| H A D | set_boot_cpu_id.c | 36 static void test_set_invalid_bsp(struct kvm_vm *vm) in test_set_invalid_bsp() 89 static struct kvm_vm *create_vm(uint32_t nr_vcpus, uint32_t bsp_vcpu_id, in create_vm() 92 struct kvm_vm *vm; in create_vm() 110 struct kvm_vm *vm; in run_vm_bsp() 123 struct kvm_vm *vm; in check_set_bsp_busy()
|
| /linux/tools/testing/selftests/kvm/arm64/ |
| H A D | smccc_filter.c | 27 struct kvm_vm *vm = vm_create(1); in test_runs_at_el2() 52 static int __set_smccc_filter(struct kvm_vm *vm, uint32_t start, uint32_t nr_functions, in __set_smccc_filter() 65 static void set_smccc_filter(struct kvm_vm *vm, uint32_t start, uint32_t nr_functions, in set_smccc_filter() 73 static struct kvm_vm *setup_vm(struct kvm_vcpu **vcpu) in setup_vm() 76 struct kvm_vm *vm; in setup_vm() 95 struct kvm_vm *vm = setup_vm(&vcpu); in test_pad_must_be_zero() 114 struct kvm_vm *vm = setup_vm(&vcpu); in test_filter_reserved_range() 136 struct kvm_vm *vm = setup_vm(&vcpu); in test_invalid_nr_functions() 149 struct kvm_vm *vm = setup_vm(&vcpu); in test_overflow_nr_functions() 162 struct kvm_vm *vm = setup_vm(&vcpu); in test_reserved_action() [all …]
|
| H A D | external_aborts.c | 31 static struct kvm_vm *vm_create_with_dabt_handler(struct kvm_vcpu **vcpu, void *guest_code, in vm_create_with_dabt_handler() 34 struct kvm_vm *vm = vm_create_with_one_vcpu(vcpu, guest_code); in vm_create_with_dabt_handler() 125 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_mmio_abort_guest, in test_mmio_abort() 160 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_mmio_nisv_guest, in test_mmio_nisv() 176 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_mmio_nisv_guest, in test_mmio_nisv_abort() 208 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_serror_masked_guest, in test_serror_masked() 243 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_serror_guest, in test_serror() 281 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_s1ptw_abort_guest, in test_s1ptw_abort() 308 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_serror_emulated_guest, in test_serror_emulated() 334 struct kvm_vm *vm = vm_create_with_dabt_handler(&vcpu, test_mmio_ease_guest, in test_mmio_ease() [all …]
|
| H A D | vcpu_width_config.c | 25 struct kvm_vm *vm; in add_init_2vcpus() 51 struct kvm_vm *vm; in add_2vcpus_init_2vcpus() 82 struct kvm_vm *vm; in main()
|
| /linux/tools/testing/selftests/kvm/lib/x86/ |
| H A D | sev.c | 17 static void encrypt_region(struct kvm_vm *vm, struct userspace_mem_region *region, in encrypt_region() 48 void sev_vm_init(struct kvm_vm *vm) in sev_vm_init() 61 void sev_es_vm_init(struct kvm_vm *vm) in sev_es_vm_init() 74 void snp_vm_init(struct kvm_vm *vm) in snp_vm_init() 82 void sev_vm_launch(struct kvm_vm *vm, uint32_t policy) in sev_vm_launch() 106 void sev_vm_launch_measure(struct kvm_vm *vm, uint8_t *measurement) in sev_vm_launch_measure() 119 void sev_vm_launch_finish(struct kvm_vm *vm) in sev_vm_launch_finish() 134 void snp_vm_launch_start(struct kvm_vm *vm, uint64_t policy) in snp_vm_launch_start() 143 void snp_vm_launch_update(struct kvm_vm *vm) in snp_vm_launch_update() 154 void snp_vm_launch_finish(struct kvm_vm *vm) in snp_vm_launch_finish() [all …]
|
| H A D | processor.c | 162 static void virt_mmu_init(struct kvm_vm *vm, struct kvm_mmu *mmu, in virt_mmu_init() 177 void virt_arch_pgd_alloc(struct kvm_vm *vm) in virt_arch_pgd_alloc() 198 void tdp_mmu_init(struct kvm_vm *vm, int pgtable_levels, in tdp_mmu_init() 207 static void *virt_get_pte(struct kvm_vm *vm, struct kvm_mmu *mmu, in virt_get_pte() 221 static uint64_t *virt_create_upper_pte(struct kvm_vm *vm, in virt_create_upper_pte() 257 void __virt_pg_map(struct kvm_vm *vm, struct kvm_mmu *mmu, uint64_t vaddr, in __virt_pg_map() 316 void virt_arch_pg_map(struct kvm_vm *vm, uint64_t vaddr, uint64_t paddr) in virt_arch_pg_map() 321 void virt_map_level(struct kvm_vm *vm, uint64_t vaddr, uint64_t paddr, in virt_map_level() 355 static uint64_t *__vm_get_page_table_entry(struct kvm_vm *vm, in __vm_get_page_table_entry() 394 uint64_t *tdp_get_pte(struct kvm_vm *vm, uint64_t l2_gpa) in tdp_get_pte() [all …]
|
| /linux/tools/testing/selftests/kvm/s390/ |
| H A D | cmma_test.c | 97 static void create_main_memslot(struct kvm_vm *vm) in create_main_memslot() 107 static void create_test_memslot(struct kvm_vm *vm) in create_test_memslot() 119 static void create_memslots(struct kvm_vm *vm) in create_memslots() 139 static void finish_vm_setup(struct kvm_vm *vm) in finish_vm_setup() 151 static struct kvm_vm *create_vm_two_memslots(void) in create_vm_two_memslots() 153 struct kvm_vm *vm; in create_vm_two_memslots() 164 static void enable_cmma(struct kvm_vm *vm) in enable_cmma() 172 static void enable_dirty_tracking(struct kvm_vm *vm) in enable_dirty_tracking() 178 static int __enable_migration_mode(struct kvm_vm *vm) in __enable_migration_mode() 187 static void enable_migration_mode(struct kvm_vm *vm) in enable_migration_mode() [all …]
|
| H A D | memop.c | 116 struct kvm_vm *vm; 237 struct kvm_vm *kvm_vm; member 250 t.kvm_vm = vm_create_with_one_vcpu(&vcpu, guest_code); in test_default_init() 251 t.vm = (struct test_info) { t.kvm_vm, NULL }; in test_default_init() 252 t.vcpu = (struct test_info) { t.kvm_vm, vcpu }; in test_default_init() 374 kvm_vm_free(t.kvm_vm); in test_copy() 400 kvm_vm_free(t.kvm_vm); in test_copy_access_register() 466 kvm_vm_free(t.kvm_vm); in test_copy_key() 479 kvm_vm_free(t.kvm_vm); in test_cmpxchg_key() 710 kvm_vm_free(t.kvm_vm); in test_cmpxchg_key_concurrent() [all …]
|
| H A D | debug_test.c | 19 static struct kvm_vm *test_step_int_1(struct kvm_vcpu **vcpu, void *guest_code, in test_step_int_1() 24 struct kvm_vm *vm; in test_step_int_1() 46 struct kvm_vm *vm; in test_step_int() 83 struct kvm_vm *vm; in test_step_pgm_diag()
|
| /linux/tools/testing/selftests/kvm/lib/arm64/ |
| H A D | processor.c | 24 static uint64_t pgd_index(struct kvm_vm *vm, vm_vaddr_t gva) in pgd_index() 32 static uint64_t pud_index(struct kvm_vm *vm, vm_vaddr_t gva) in pud_index() 43 static uint64_t pmd_index(struct kvm_vm *vm, vm_vaddr_t gva) in pmd_index() 54 static uint64_t pte_index(struct kvm_vm *vm, vm_vaddr_t gva) in pte_index() 60 static inline bool use_lpa2_pte_format(struct kvm_vm *vm) in use_lpa2_pte_format() 66 static uint64_t addr_pte(struct kvm_vm *vm, uint64_t pa, uint64_t attrs) in addr_pte() 84 static uint64_t pte_addr(struct kvm_vm *vm, uint64_t pte) in pte_addr() 100 static uint64_t ptrs_per_pgd(struct kvm_vm *vm) in ptrs_per_pgd() 106 static uint64_t __maybe_unused ptrs_per_pte(struct kvm_vm *vm) in ptrs_per_pte() 111 void virt_arch_pgd_alloc(struct kvm_vm *vm) in virt_arch_pgd_alloc() [all …]
|
| H A D | vgic.c | 20 struct kvm_vm *vm = vm_create_barebones(); in kvm_supports_vgic_v3() 44 int __vgic_v3_setup(struct kvm_vm *vm, unsigned int nr_vcpus, uint32_t nr_irqs) in __vgic_v3_setup() 80 int vgic_v3_setup(struct kvm_vm *vm, unsigned int nr_vcpus, uint32_t nr_irqs) in vgic_v3_setup() 132 int _kvm_arm_irq_line(struct kvm_vm *vm, uint32_t intid, int level) in _kvm_arm_irq_line() 147 void kvm_arm_irq_line(struct kvm_vm *vm, uint32_t intid, int level) in kvm_arm_irq_line() 196 int vgic_its_setup(struct kvm_vm *vm) in vgic_its_setup()
|
| /linux/tools/testing/selftests/kvm/lib/ |
| H A D | kvm_util.c | 168 void vm_enable_dirty_ring(struct kvm_vm *vm, uint32_t ring_size) in vm_enable_dirty_ring() 177 static void vm_open(struct kvm_vm *vm) in vm_open() 270 __weak void vm_vaddr_populate_bitmap(struct kvm_vm *vm) in vm_vaddr_populate_bitmap() 279 struct kvm_vm *____vm_create(struct vm_shape shape) in ____vm_create() 281 struct kvm_vm *vm; in ____vm_create() 479 struct kvm_vm *__vm_create(struct vm_shape shape, uint32_t nr_runnable_vcpus, in __vm_create() 485 struct kvm_vm *vm; in __vm_create() 549 struct kvm_vm *__vm_create_with_vcpus(struct vm_shape shape, uint32_t nr_vcpus, in __vm_create_with_vcpus() 553 struct kvm_vm *vm; in __vm_create_with_vcpus() 567 struct kvm_vm *__vm_create_shape_with_one_vcpu(struct vm_shape shape, in __vm_create_shape_with_one_vcpu() [all …]
|
| H A D | memstress.c | 88 void memstress_setup_vcpus(struct kvm_vm *vm, int nr_vcpus, in memstress_setup_vcpus() 124 struct kvm_vm *memstress_create_vm(enum vm_guest_mode mode, int nr_vcpus, in memstress_create_vm() 130 struct kvm_vm *vm; in memstress_create_vm() 234 void memstress_destroy_vm(struct kvm_vm *vm) in memstress_destroy_vm() 239 void memstress_set_write_percent(struct kvm_vm *vm, uint32_t write_percent) in memstress_set_write_percent() 245 void memstress_set_random_access(struct kvm_vm *vm, bool random_access) in memstress_set_random_access() 256 void __weak memstress_setup_nested(struct kvm_vm *vm, int nr_vcpus, struct kvm_vcpu **vcpus) in memstress_setup_nested() 322 static void toggle_dirty_logging(struct kvm_vm *vm, int slots, bool enable) in toggle_dirty_logging() 334 void memstress_enable_dirty_logging(struct kvm_vm *vm, int slots) in memstress_enable_dirty_logging() 339 void memstress_disable_dirty_logging(struct kvm_vm *vm, int slots) in memstress_disable_dirty_logging() [all …]
|
| /linux/tools/testing/selftests/kvm/include/arm64/ |
| H A D | vgic.h | 20 int __vgic_v3_setup(struct kvm_vm *vm, unsigned int nr_vcpus, uint32_t nr_irqs); 22 int vgic_v3_setup(struct kvm_vm *vm, unsigned int nr_vcpus, uint32_t nr_irqs); 29 void kvm_arm_irq_line(struct kvm_vm *vm, uint32_t intid, int level); 30 int _kvm_arm_irq_line(struct kvm_vm *vm, uint32_t intid, int level); 38 int vgic_its_setup(struct kvm_vm *vm);
|
| H A D | processor.h | 131 struct kvm_vcpu *aarch64_vcpu_add(struct kvm_vm *vm, uint32_t vcpu_id, 173 void vm_init_descriptor_tables(struct kvm_vm *vm); 177 void vm_install_exception_handler(struct kvm_vm *vm, 179 void vm_install_sync_handler(struct kvm_vm *vm, 182 uint64_t *virt_get_pte_hva_at_level(struct kvm_vm *vm, vm_vaddr_t gva, int level); 183 uint64_t *virt_get_pte_hva(struct kvm_vm *vm, vm_vaddr_t gva); 311 bool vm_supports_el2(struct kvm_vm *vm); 315 struct kvm_vm *vm = vm_create(1); in test_supports_el2() 376 void kvm_get_default_vcpu_target(struct kvm_vm *vm, struct kvm_vcpu_init *init);
|
| /linux/tools/testing/selftests/kvm/lib/loongarch/ |
| H A D | processor.c | 17 static uint64_t virt_pte_index(struct kvm_vm *vm, vm_vaddr_t gva, int level) in virt_pte_index() 27 static uint64_t pte_addr(struct kvm_vm *vm, uint64_t entry) in pte_addr() 32 static uint64_t ptrs_per_pte(struct kvm_vm *vm) in ptrs_per_pte() 37 static void virt_set_pgtable(struct kvm_vm *vm, vm_paddr_t table, vm_paddr_t child) in virt_set_pgtable() 48 void virt_arch_pgd_alloc(struct kvm_vm *vm) in virt_arch_pgd_alloc() 74 static uint64_t *virt_populate_pte(struct kvm_vm *vm, vm_vaddr_t gva, int alloc) in virt_populate_pte() 108 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_arch_gva2gpa() 118 void virt_arch_pg_map(struct kvm_vm *vm, uint64_t vaddr, uint64_t paddr) in virt_arch_pg_map() 142 static void pte_dump(FILE *stream, struct kvm_vm *vm, uint8_t indent, uint64_t page, int level) in pte_dump() 160 void virt_arch_dump(FILE *stream, struct kvm_vm *vm, uint8_t indent) in virt_arch_dump() [all …]
|
| /linux/tools/testing/selftests/kvm/lib/s390/ |
| H A D | processor.c | 13 void virt_arch_pgd_alloc(struct kvm_vm *vm) in virt_arch_pgd_alloc() 37 static uint64_t virt_alloc_region(struct kvm_vm *vm, int ri) in virt_alloc_region() 50 void virt_arch_pg_map(struct kvm_vm *vm, uint64_t gva, uint64_t gpa) in virt_arch_pg_map() 89 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_arch_gva2gpa() 114 static void virt_dump_ptes(FILE *stream, struct kvm_vm *vm, uint8_t indent, in virt_dump_ptes() 128 static void virt_dump_region(FILE *stream, struct kvm_vm *vm, uint8_t indent, in virt_dump_region() 150 void virt_arch_dump(FILE *stream, struct kvm_vm *vm, uint8_t indent) in virt_arch_dump() 163 struct kvm_vcpu *vm_arch_vcpu_add(struct kvm_vm *vm, uint32_t vcpu_id) in vm_arch_vcpu_add()
|
| /linux/tools/testing/selftests/kvm/ |
| H A D | set_memory_region_test.c | 110 static struct kvm_vm *spawn_vm(struct kvm_vcpu **vcpu, pthread_t *vcpu_thread, in spawn_vm() 113 struct kvm_vm *vm; in spawn_vm() 182 struct kvm_vm *vm; in test_move_memory_region() 278 struct kvm_vm *vm; in test_delete_memory_region() 331 struct kvm_vm *vm; in test_zero_memory_regions() 350 struct kvm_vm *vm; in test_invalid_memory_region_flags() 412 struct kvm_vm *vm; in test_add_max_memory_regions() 465 static void test_invalid_guest_memfd(struct kvm_vm *vm, int memfd, in test_invalid_guest_memfd() 476 struct kvm_vm *vm, *vm2; in test_add_private_memory_region() 512 struct kvm_vm *vm; in test_add_overlapping_private_memory_regions() [all …]
|
| H A D | access_tracking_perf_test.c | 126 static uint64_t lookup_pfn(int pagemap_fd, struct kvm_vm *vm, uint64_t gva) in lookup_pfn() 173 static void pageidle_mark_vcpu_memory_idle(struct kvm_vm *vm, in pageidle_mark_vcpu_memory_idle() 267 static void lru_gen_mark_memory_idle(struct kvm_vm *vm) in lru_gen_mark_memory_idle() 328 struct kvm_vm *vm = memstress_args.vm; in vcpu_thread_main() 361 static void run_iteration(struct kvm_vm *vm, int nr_vcpus, const char *description) in run_iteration() 381 static void access_memory(struct kvm_vm *vm, int nr_vcpus, in access_memory() 389 static void mark_memory_idle(struct kvm_vm *vm, int nr_vcpus) in mark_memory_idle() 408 struct kvm_vm *vm; in run_test()
|
| H A D | irqfd_test.c | 13 static struct kvm_vm *vm1; 14 static struct kvm_vm *vm2; 28 static void juggle_eventfd_secondary(struct kvm_vm *vm, int eventfd) in juggle_eventfd_secondary() 63 static void juggle_eventfd_primary(struct kvm_vm *vm, int eventfd) in juggle_eventfd_primary()
|
| /linux/tools/testing/selftests/kvm/lib/riscv/ |
| H A D | processor.c | 30 static uint64_t pte_addr(struct kvm_vm *vm, uint64_t entry) in pte_addr() 36 static uint64_t ptrs_per_pte(struct kvm_vm *vm) in ptrs_per_pte() 55 static uint64_t pte_index(struct kvm_vm *vm, vm_vaddr_t gva, int level) in pte_index() 65 void virt_arch_pgd_alloc(struct kvm_vm *vm) in virt_arch_pgd_alloc() 78 void virt_arch_pg_map(struct kvm_vm *vm, uint64_t vaddr, uint64_t paddr) in virt_arch_pg_map() 122 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_arch_gva2gpa() 151 static void pte_dump(FILE *stream, struct kvm_vm *vm, uint8_t indent, in pte_dump() 173 void virt_arch_dump(FILE *stream, struct kvm_vm *vm, uint8_t indent) in virt_arch_dump() 195 struct kvm_vm *vm = vcpu->vm; in riscv_vcpu_mmu_setup() 314 struct kvm_vcpu *vm_arch_vcpu_add(struct kvm_vm *vm, uint32_t vcpu_id) in vm_arch_vcpu_add() [all …]
|