/openbmc/qemu/target/i386/hvf/ |
H A D | x86_mmu.c | 44 target_ulong gva; member 89 index = gpt_entry(pt->gva, level, pae); in get_pt_entry() 163 return (pt->pte[2] & PAE_PTE_SUPER_PAGE_MASK) | (pt->gva & 0x3fffffff); in large_page_gpa() 170 return (pt->pte[1] & PAE_PTE_LARGE_PAGE_MASK) | (pt->gva & 0x1fffff); in large_page_gpa() 174 return pse_pte_to_page(pt->pte[1]) | (pt->gva & 0x3fffff); in large_page_gpa() 191 pt->gva = addr; in walk_gpt() 209 pt->gpa = (pt->pte[0] & page_mask) | (pt->gva & 0xfff); in walk_gpt() 218 bool mmu_gva_to_gpa(CPUState *cpu, target_ulong gva, uint64_t *gpa) in mmu_gva_to_gpa() argument 225 *gpa = gva; in mmu_gva_to_gpa() 229 res = walk_gpt(cpu, gva, err_code, &pt, x86_is_pae_enabled(cpu)); in mmu_gva_to_gpa() [all …]
|
H A D | x86_mmu.h | 39 bool mmu_gva_to_gpa(CPUState *cpu, target_ulong gva, uint64_t *gpa); 41 void vmx_write_mem(CPUState *cpu, target_ulong gva, void *data, int bytes); 42 void vmx_read_mem(CPUState *cpu, void *data, target_ulong gva, int bytes);
|
/openbmc/linux/include/trace/events/ |
H A D | kvm.h | 261 TP_PROTO(u64 gva, u64 gfn), 263 TP_ARGS(gva, gfn), 266 __field(__u64, gva) 271 __entry->gva = gva; 275 TP_printk("gva = %#llx, gfn = %#llx", __entry->gva, __entry->gfn) 280 TP_PROTO(u64 gva, u64 gfn), 282 TP_ARGS(gva, gfn) 287 TP_PROTO(u64 gva, u64 gfn), 289 TP_ARGS(gva, gfn) 294 TP_PROTO(u64 token, u64 gva), [all …]
|
/openbmc/linux/tools/testing/selftests/kvm/lib/s390x/ |
H A D | processor.c | 50 void virt_arch_pg_map(struct kvm_vm *vm, uint64_t gva, uint64_t gpa) in virt_arch_pg_map() argument 55 TEST_ASSERT((gva % vm->page_size) == 0, in virt_arch_pg_map() 58 gva, vm->page_size); in virt_arch_pg_map() 60 (gva >> vm->page_shift)), in virt_arch_pg_map() 62 gva); in virt_arch_pg_map() 66 gva, vm->page_size); in virt_arch_pg_map() 70 gva, vm->max_gfn, vm->page_size); in virt_arch_pg_map() 75 idx = (gva >> (64 - 11 * ri)) & 0x7ffu; in virt_arch_pg_map() 82 idx = (gva >> 12) & 0x0ffu; /* page index */ in virt_arch_pg_map() 89 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_arch_gva2gpa() argument [all …]
|
/openbmc/linux/arch/riscv/kvm/ |
H A D | tlb.c | 79 unsigned long gva, in kvm_riscv_local_hfence_vvma_asid_gva() argument 94 for (pos = gva; pos < (gva + gvsz); pos += BIT(order)) in kvm_riscv_local_hfence_vvma_asid_gva() 99 for (pos = gva; pos < (gva + gvsz); pos += BIT(order)) in kvm_riscv_local_hfence_vvma_asid_gva() 120 unsigned long gva, unsigned long gvsz, in kvm_riscv_local_hfence_vvma_gva() argument 134 for (pos = gva; pos < (gva + gvsz); pos += BIT(order)) in kvm_riscv_local_hfence_vvma_gva() 139 for (pos = gva; pos < (gva + gvsz); pos += BIT(order)) in kvm_riscv_local_hfence_vvma_gva() 357 unsigned long gva, unsigned long gvsz, in kvm_riscv_hfence_vvma_asid_gva() argument 364 data.addr = gva; in kvm_riscv_hfence_vvma_asid_gva() 386 unsigned long gva, unsigned long gvsz, in kvm_riscv_hfence_vvma_gva() argument 393 data.addr = gva; in kvm_riscv_hfence_vvma_gva()
|
/openbmc/linux/drivers/infiniband/hw/mana/ |
H A D | mr.c | 46 req.gva.dma_region_handle = mr_params->gva.dma_region_handle; in mana_ib_gd_create_mr() 47 req.gva.virtual_address = mr_params->gva.virtual_address; in mana_ib_gd_create_mr() 48 req.gva.access_flags = mr_params->gva.access_flags; in mana_ib_gd_create_mr() 150 mr_params.gva.dma_region_handle = dma_region_handle; in mana_ib_reg_user_mr() 151 mr_params.gva.virtual_address = iova; in mana_ib_reg_user_mr() 152 mr_params.gva.access_flags = in mana_ib_reg_user_mr()
|
/openbmc/linux/arch/x86/kvm/vmx/ |
H A D | sgx.c | 25 int size, int alignment, gva_t *gva) in sgx_get_encls_gva() argument 31 *gva = offset; in sgx_get_encls_gva() 34 *gva += s.base; in sgx_get_encls_gva() 37 if (!IS_ALIGNED(*gva, alignment)) { in sgx_get_encls_gva() 40 fault = is_noncanonical_address(*gva, vcpu); in sgx_get_encls_gva() 42 *gva &= 0xffffffff; in sgx_get_encls_gva() 45 (*gva > s.limit) || in sgx_get_encls_gva() 47 (((u64)*gva + size - 1) > s.limit + 1)); in sgx_get_encls_gva() 73 static int sgx_gva_to_gpa(struct kvm_vcpu *vcpu, gva_t gva, bool write, in sgx_gva_to_gpa() argument 79 *gpa = kvm_mmu_gva_to_gpa_write(vcpu, gva, &ex); in sgx_gva_to_gpa() [all …]
|
H A D | vmx_ops.h | 17 void invvpid_error(unsigned long ext, u16 vpid, gva_t gva); 304 static inline void __invvpid(unsigned long ext, u16 vpid, gva_t gva) in __invvpid() argument 309 u64 gva; in __invvpid() member 310 } operand = { vpid, 0, gva }; in __invvpid() 312 vmx_asm2(invvpid, "r"(ext), "m"(operand), ext, vpid, gva); in __invvpid()
|
/openbmc/linux/tools/testing/selftests/kvm/lib/aarch64/ |
H A D | processor.c | 25 static uint64_t pgd_index(struct kvm_vm *vm, vm_vaddr_t gva) in pgd_index() argument 30 return (gva >> shift) & mask; in pgd_index() 33 static uint64_t pud_index(struct kvm_vm *vm, vm_vaddr_t gva) in pud_index() argument 41 return (gva >> shift) & mask; in pud_index() 44 static uint64_t pmd_index(struct kvm_vm *vm, vm_vaddr_t gva) in pmd_index() argument 52 return (gva >> shift) & mask; in pmd_index() 55 static uint64_t pte_index(struct kvm_vm *vm, vm_vaddr_t gva) in pte_index() argument 58 return (gva >> vm->page_shift) & mask; in pte_index() 160 uint64_t *virt_get_pte_hva(struct kvm_vm *vm, vm_vaddr_t gva) in virt_get_pte_hva() argument 167 ptep = addr_gpa2hva(vm, vm->pgd) + pgd_index(vm, gva) * 8; in virt_get_pte_hva() [all …]
|
/openbmc/linux/arch/x86/kvm/ |
H A D | x86.h | 219 gva_t gva, gfn_t gfn, unsigned access) in vcpu_cache_mmio_info() argument 230 vcpu->arch.mmio_gva = mmu_is_nested(vcpu) ? 0 : gva & PAGE_MASK; in vcpu_cache_mmio_info() 247 static inline void vcpu_clear_mmio_info(struct kvm_vcpu *vcpu, gva_t gva) in vcpu_clear_mmio_info() argument 249 if (gva != MMIO_GVA_ANY && vcpu->arch.mmio_gva != (gva & PAGE_MASK)) in vcpu_clear_mmio_info() 255 static inline bool vcpu_match_mmio_gva(struct kvm_vcpu *vcpu, unsigned long gva) in vcpu_match_mmio_gva() argument 258 vcpu->arch.mmio_gva == (gva & PAGE_MASK)) in vcpu_match_mmio_gva() 317 void kvm_fixup_and_inject_pf_error(struct kvm_vcpu *vcpu, gva_t gva, u16 error_code); 499 int kvm_handle_invpcid(struct kvm_vcpu *vcpu, unsigned long type, gva_t gva);
|
/openbmc/linux/tools/testing/selftests/kvm/lib/ |
H A D | memstress.c | 53 uint64_t gva; in memstress_guest_code() local 61 gva = vcpu_args->gva; in memstress_guest_code() 77 addr = gva + (page * args->guest_page_size); in memstress_guest_code() 105 vcpu_args->gva = guest_test_virt_mem + in memstress_setup_vcpus() 111 vcpu_args->gva = guest_test_virt_mem; in memstress_setup_vcpus()
|
/openbmc/linux/tools/testing/selftests/kvm/ |
H A D | access_tracking_perf_test.c | 95 static uint64_t lookup_pfn(int pagemap_fd, struct kvm_vm *vm, uint64_t gva) in lookup_pfn() argument 97 uint64_t hva = (uint64_t) addr_gva2hva(vm, gva); in lookup_pfn() 130 uint64_t base_gva = vcpu_args->gva; in mark_vcpu_memory_idle() 149 uint64_t gva = base_gva + page * memstress_args.guest_page_size; in mark_vcpu_memory_idle() local 150 uint64_t pfn = lookup_pfn(pagemap_fd, vm, gva); in mark_vcpu_memory_idle()
|
/openbmc/linux/tools/testing/selftests/kvm/lib/riscv/ |
H A D | processor.c | 46 static uint64_t pte_index(struct kvm_vm *vm, vm_vaddr_t gva, int level) in pte_index() argument 53 return (gva & pte_index_mask[level]) >> pte_index_shift[level]; in pte_index() 113 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_arch_gva2gpa() argument 121 ptep = addr_gpa2hva(vm, vm->pgd) + pte_index(vm, gva, level) * 8; in addr_arch_gva2gpa() 128 pte_index(vm, gva, level) * 8; in addr_arch_gva2gpa() 134 return pte_addr(vm, *ptep) + (gva & (vm->page_size - 1)); in addr_arch_gva2gpa() 138 gva, level); in addr_arch_gva2gpa()
|
/openbmc/linux/arch/riscv/include/asm/ |
H A D | kvm_host.h | 266 unsigned long gva, 272 unsigned long gva, unsigned long gvsz, 293 unsigned long gva, unsigned long gvsz, 300 unsigned long gva, unsigned long gvsz,
|
/openbmc/linux/arch/mips/kvm/ |
H A D | tlb.c | 166 int kvm_vz_guest_tlb_lookup(struct kvm_vcpu *vcpu, unsigned long gva, in kvm_vz_guest_tlb_lookup() argument 184 write_gc0_entryhi((o_entryhi & 0x3ff) | (gva & ~0xfffl)); in kvm_vz_guest_tlb_lookup() 226 pa = entrylo[!!(gva & pagemaskbit)]; in kvm_vz_guest_tlb_lookup() 240 pa |= gva & ~(pagemask | pagemaskbit); in kvm_vz_guest_tlb_lookup()
|
H A D | vz.c | 197 static gpa_t kvm_vz_gva_to_gpa_cb(gva_t gva) in kvm_vz_gva_to_gpa_cb() argument 200 return gva; in kvm_vz_gva_to_gpa_cb() 689 static int kvm_vz_gva_to_gpa(struct kvm_vcpu *vcpu, unsigned long gva, in kvm_vz_gva_to_gpa() argument 692 u32 gva32 = gva; in kvm_vz_gva_to_gpa() 695 if ((long)gva == (s32)gva32) { in kvm_vz_gva_to_gpa() 750 } else if ((gva & 0xc000000000000000) == 0x8000000000000000) { in kvm_vz_gva_to_gpa() 758 if (segctl & (1ull << (56 + ((gva >> 59) & 0x7)))) { in kvm_vz_gva_to_gpa() 772 *gpa = gva & 0x07ffffffffffffff; in kvm_vz_gva_to_gpa() 778 return kvm_vz_guest_tlb_lookup(vcpu, gva, gpa); in kvm_vz_gva_to_gpa()
|
/openbmc/linux/arch/s390/kvm/ |
H A D | gaccess.c | 496 static int trans_exc_ending(struct kvm_vcpu *vcpu, int code, unsigned long gva, u8 ar, in trans_exc_ending() argument 546 tec->addr = gva >> PAGE_SHIFT; in trans_exc_ending() 566 static int trans_exc(struct kvm_vcpu *vcpu, int code, unsigned long gva, u8 ar, in trans_exc() argument 569 return trans_exc_ending(vcpu, code, gva, ar, mode, prot, false); in trans_exc() 632 static unsigned long guest_translate(struct kvm_vcpu *vcpu, unsigned long gva, in guest_translate() argument 636 union vaddress vaddr = {.addr = gva}; in guest_translate() 637 union raddress raddr = {.addr = gva}; in guest_translate() 1292 int guest_translate_address_with_key(struct kvm_vcpu *vcpu, unsigned long gva, u8 ar, in guest_translate_address_with_key() argument 1299 gva = kvm_s390_logical_to_effective(vcpu, gva); in guest_translate_address_with_key() 1300 rc = get_vcpu_asce(vcpu, &asce, gva, ar, mode); in guest_translate_address_with_key() [all …]
|
H A D | gaccess.h | 189 int guest_translate_address_with_key(struct kvm_vcpu *vcpu, unsigned long gva, u8 ar, 193 int check_gva_range(struct kvm_vcpu *vcpu, unsigned long gva, u8 ar,
|
/openbmc/linux/tools/testing/selftests/kvm/x86_64/ |
H A D | cpuid_test.c | 129 vm_vaddr_t gva = vm_vaddr_alloc(vm, size, KVM_UTIL_MIN_VADDR); in vcpu_alloc_cpuid() local 130 struct kvm_cpuid2 *guest_cpuids = addr_gva2hva(vm, gva); in vcpu_alloc_cpuid() 134 *p_gva = gva; in vcpu_alloc_cpuid()
|
H A D | hyperv_tlb_flush.c | 586 vm_vaddr_t test_data_page, gva; in main() local 620 gva = vm_vaddr_unused_gap(vm, NTEST_PAGES * PAGE_SIZE, KVM_UTIL_MIN_VADDR); in main() 624 __virt_pg_map(vm, gva + PAGE_SIZE * i, gpa & PAGE_MASK, PG_LEVEL_4K); in main() 625 data->test_pages_pte[i] = gva + (gpa & ~PAGE_MASK); in main()
|
/openbmc/qemu/target/i386/kvm/ |
H A D | xen-emu.c | 55 static bool kvm_gva_to_gpa(CPUState *cs, uint64_t gva, uint64_t *gpa, in kvm_gva_to_gpa() argument 59 .linear_address = gva, in kvm_gva_to_gpa() 63 *len = TARGET_PAGE_SIZE - (gva & ~TARGET_PAGE_MASK); in kvm_gva_to_gpa() 74 static int kvm_gva_rw(CPUState *cs, uint64_t gva, void *_buf, size_t sz, in kvm_gva_rw() argument 82 if (!kvm_gva_to_gpa(cs, gva, &gpa, &len, is_write)) { in kvm_gva_rw() 93 gva += len; in kvm_gva_rw() 99 static inline int kvm_copy_from_gva(CPUState *cs, uint64_t gva, void *buf, in kvm_copy_from_gva() argument 102 return kvm_gva_rw(cs, gva, buf, sz, false); in kvm_copy_from_gva() 105 static inline int kvm_copy_to_gva(CPUState *cs, uint64_t gva, void *buf, in kvm_copy_to_gva() argument 108 return kvm_gva_rw(cs, gva, buf, sz, true); in kvm_copy_to_gva()
|
/openbmc/linux/tools/testing/selftests/kvm/include/ |
H A D | kvm_util_base.h | 342 int kvm_memcmp_hva_gva(void *hva, struct kvm_vm *vm, const vm_vaddr_t gva, 460 void *addr_gva2hva(struct kvm_vm *vm, vm_vaddr_t gva); 891 vm_paddr_t addr_arch_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva); 893 static inline vm_paddr_t addr_gva2gpa(struct kvm_vm *vm, vm_vaddr_t gva) in addr_gva2gpa() argument 895 return addr_arch_gva2gpa(vm, gva); in addr_gva2gpa()
|
H A D | memstress.h | 24 uint64_t gva; member
|
/openbmc/linux/tools/testing/selftests/kvm/include/aarch64/ |
H A D | processor.h | 133 uint64_t *virt_get_pte_hva(struct kvm_vm *vm, vm_vaddr_t gva);
|
/openbmc/qemu/target/hppa/ |
H A D | mem_helper.c | 803 uint64_t gva = hppa_form_gva(env, env->iasq_f, iaoq_f); in HELPER() local 804 HPPATLBEntry *ent = hppa_find_tlb(env, gva); in HELPER() 807 raise_exception_with_ior(env, EXCP_ITLB_MISS, GETPC(), gva, false); in HELPER()
|