Home
last modified time | relevance | path

Searched refs:svm (Results 1 – 25 of 33) sorted by relevance

12

/Linux-v5.10/arch/x86/kvm/svm/
Dnested.c35 struct vcpu_svm *svm = to_svm(vcpu); in nested_svm_inject_npf_exit() local
37 if (svm->vmcb->control.exit_code != SVM_EXIT_NPF) { in nested_svm_inject_npf_exit()
42 svm->vmcb->control.exit_code = SVM_EXIT_NPF; in nested_svm_inject_npf_exit()
43 svm->vmcb->control.exit_code_hi = 0; in nested_svm_inject_npf_exit()
44 svm->vmcb->control.exit_info_1 = (1ULL << 32); in nested_svm_inject_npf_exit()
45 svm->vmcb->control.exit_info_2 = fault->address; in nested_svm_inject_npf_exit()
48 svm->vmcb->control.exit_info_1 &= ~0xffffffffULL; in nested_svm_inject_npf_exit()
49 svm->vmcb->control.exit_info_1 |= fault->error_code; in nested_svm_inject_npf_exit()
51 nested_svm_vmexit(svm); in nested_svm_inject_npf_exit()
56 struct vcpu_svm *svm = to_svm(vcpu); in nested_svm_get_tdp_pdptr() local
[all …]
Dsvm.c198 static void svm_complete_interrupts(struct vcpu_svm *svm);
268 struct vcpu_svm *svm = to_svm(vcpu); in svm_set_efer() local
282 svm_leave_nested(svm); in svm_set_efer()
283 svm_set_gif(svm, true); in svm_set_efer()
290 if (!is_smm(&svm->vcpu)) in svm_set_efer()
291 svm_free_nested(svm); in svm_set_efer()
294 int ret = svm_allocate_nested(svm); in svm_set_efer()
303 svm->vmcb->save.efer = efer | EFER_SVME; in svm_set_efer()
304 vmcb_mark_dirty(svm->vmcb, VMCB_CR); in svm_set_efer()
316 struct vcpu_svm *svm = to_svm(vcpu); in svm_get_interrupt_shadow() local
[all …]
Dsvm.h189 void recalc_intercepts(struct vcpu_svm *svm);
217 static inline struct vmcb *get_host_vmcb(struct vcpu_svm *svm) in get_host_vmcb() argument
219 if (is_guest_mode(&svm->vcpu)) in get_host_vmcb()
220 return svm->nested.hsave; in get_host_vmcb()
222 return svm->vmcb; in get_host_vmcb()
243 static inline void set_dr_intercepts(struct vcpu_svm *svm) in set_dr_intercepts() argument
245 struct vmcb *vmcb = get_host_vmcb(svm); in set_dr_intercepts()
264 recalc_intercepts(svm); in set_dr_intercepts()
267 static inline void clr_dr_intercepts(struct vcpu_svm *svm) in clr_dr_intercepts() argument
269 struct vmcb *vmcb = get_host_vmcb(svm); in clr_dr_intercepts()
[all …]
Davic.c194 void avic_init_vmcb(struct vcpu_svm *svm) in avic_init_vmcb() argument
196 struct vmcb *vmcb = svm->vmcb; in avic_init_vmcb()
197 struct kvm_svm *kvm_svm = to_kvm_svm(svm->vcpu.kvm); in avic_init_vmcb()
198 phys_addr_t bpa = __sme_set(page_to_phys(svm->avic_backing_page)); in avic_init_vmcb()
206 if (kvm_apicv_activated(svm->vcpu.kvm)) in avic_init_vmcb()
265 struct vcpu_svm *svm = to_svm(vcpu); in avic_init_backing_page() local
270 if (!svm->vcpu.arch.apic->regs) in avic_init_backing_page()
281 svm->avic_backing_page = virt_to_page(svm->vcpu.arch.apic->regs); in avic_init_backing_page()
288 new_entry = __sme_set((page_to_phys(svm->avic_backing_page) & in avic_init_backing_page()
293 svm->avic_physical_id_cache = entry; in avic_init_backing_page()
[all …]
Dsev.c1184 void pre_sev_run(struct vcpu_svm *svm, int cpu) in pre_sev_run() argument
1187 int asid = sev_get_asid(svm->vcpu.kvm); in pre_sev_run()
1190 svm->vmcb->control.asid = asid; in pre_sev_run()
1198 if (sd->sev_vmcbs[asid] == svm->vmcb && in pre_sev_run()
1199 svm->vcpu.arch.last_vmentry_cpu == cpu) in pre_sev_run()
1202 sd->sev_vmcbs[asid] = svm->vmcb; in pre_sev_run()
1203 svm->vmcb->control.tlb_ctl = TLB_CONTROL_FLUSH_ASID; in pre_sev_run()
1204 vmcb_mark_dirty(svm->vmcb, VMCB_ASID); in pre_sev_run()
/Linux-v5.10/drivers/iommu/intel/
Dsvm.c121 static void intel_flush_svm_range_dev (struct intel_svm *svm, struct intel_svm_dev *sdev, in intel_flush_svm_range_dev() argument
127 desc.qw0 = QI_EIOTLB_PASID(svm->pasid) | in intel_flush_svm_range_dev()
135 desc.qw0 = QI_EIOTLB_PASID(svm->pasid) | in intel_flush_svm_range_dev()
145 qi_submit_sync(svm->iommu, &desc, 1, 0); in intel_flush_svm_range_dev()
148 desc.qw0 = QI_DEV_EIOTLB_PASID(svm->pasid) | in intel_flush_svm_range_dev()
169 qi_submit_sync(svm->iommu, &desc, 1, 0); in intel_flush_svm_range_dev()
173 static void intel_flush_svm_range(struct intel_svm *svm, unsigned long address, in intel_flush_svm_range() argument
179 list_for_each_entry_rcu(sdev, &svm->devs, list) in intel_flush_svm_range()
180 intel_flush_svm_range_dev(svm, sdev, address, pages, ih); in intel_flush_svm_range()
189 struct intel_svm *svm = container_of(mn, struct intel_svm, notifier); in intel_invalidate_range() local
[all …]
DMakefile6 obj-$(CONFIG_INTEL_IOMMU_SVM) += svm.o
/Linux-v5.10/drivers/gpu/drm/nouveau/
Dnouveau_svm.c86 nouveau_ivmm_find(struct nouveau_svm *svm, u64 inst) in nouveau_ivmm_find() argument
89 list_for_each_entry(ivmm, &svm->inst, head) { in nouveau_ivmm_find()
161 if (!cli->svm.svmm) { in nouveau_svmm_bind()
177 nouveau_dmem_migrate_vma(cli->drm, cli->svm.svmm, vma, addr, in nouveau_svmm_bind()
201 mutex_lock(&svmm->vmm->cli->drm->svm->mutex); in nouveau_svmm_part()
202 ivmm = nouveau_ivmm_find(svmm->vmm->cli->drm->svm, inst); in nouveau_svmm_part()
207 mutex_unlock(&svmm->vmm->cli->drm->svm->mutex); in nouveau_svmm_part()
222 mutex_lock(&svmm->vmm->cli->drm->svm->mutex); in nouveau_svmm_join()
223 list_add(&ivmm->head, &svmm->vmm->cli->drm->svm->inst); in nouveau_svmm_join()
224 mutex_unlock(&svmm->vmm->cli->drm->svm->mutex); in nouveau_svmm_join()
[all …]
Dnouveau_drv.h102 struct nouveau_vmm svm; member
220 struct nouveau_svm *svm; member
Dnouveau_gem.c70 struct nouveau_vmm *vmm = cli->svm.cli ? &cli->svm : &cli->vmm; in nouveau_gem_object_open()
147 struct nouveau_vmm *vmm = cli->svm.cli ? &cli->svm : & cli->vmm; in nouveau_gem_object_close()
224 struct nouveau_vmm *vmm = cli->svm.cli ? &cli->svm : &cli->vmm; in nouveau_gem_info()
/Linux-v5.10/tools/testing/selftests/kvm/lib/x86_64/
Dsvm.c35 struct svm_test_data *svm = addr_gva2hva(vm, svm_gva); in vcpu_alloc_svm() local
37 svm->vmcb = (void *)vm_vaddr_alloc(vm, getpagesize(), in vcpu_alloc_svm()
39 svm->vmcb_hva = addr_gva2hva(vm, (uintptr_t)svm->vmcb); in vcpu_alloc_svm()
40 svm->vmcb_gpa = addr_gva2gpa(vm, (uintptr_t)svm->vmcb); in vcpu_alloc_svm()
42 svm->save_area = (void *)vm_vaddr_alloc(vm, getpagesize(), in vcpu_alloc_svm()
44 svm->save_area_hva = addr_gva2hva(vm, (uintptr_t)svm->save_area); in vcpu_alloc_svm()
45 svm->save_area_gpa = addr_gva2gpa(vm, (uintptr_t)svm->save_area); in vcpu_alloc_svm()
48 return svm; in vcpu_alloc_svm()
60 void generic_svm_setup(struct svm_test_data *svm, void *guest_rip, void *guest_rsp) in generic_svm_setup() argument
62 struct vmcb *vmcb = svm->vmcb; in generic_svm_setup()
[all …]
/Linux-v5.10/arch/arm/mm/
Dioremap.c50 struct static_vm *svm; in find_static_vm_paddr() local
53 list_for_each_entry(svm, &static_vmlist, list) { in find_static_vm_paddr()
54 vm = &svm->vm; in find_static_vm_paddr()
64 return svm; in find_static_vm_paddr()
72 struct static_vm *svm; in find_static_vm_vaddr() local
75 list_for_each_entry(svm, &static_vmlist, list) { in find_static_vm_vaddr()
76 vm = &svm->vm; in find_static_vm_vaddr()
83 return svm; in find_static_vm_vaddr()
89 void __init add_static_vm_early(struct static_vm *svm) in add_static_vm_early() argument
95 vm = &svm->vm; in add_static_vm_early()
[all …]
Dmmu.c984 struct static_vm *svm; in iotable_init() local
989 svm = memblock_alloc(sizeof(*svm) * nr, __alignof__(*svm)); in iotable_init()
990 if (!svm) in iotable_init()
992 __func__, sizeof(*svm) * nr, __alignof__(*svm)); in iotable_init()
997 vm = &svm->vm; in iotable_init()
1004 add_static_vm_early(svm++); in iotable_init()
1012 struct static_vm *svm; in vm_reserve_area_early() local
1014 svm = memblock_alloc(sizeof(*svm), __alignof__(*svm)); in vm_reserve_area_early()
1015 if (!svm) in vm_reserve_area_early()
1017 __func__, sizeof(*svm), __alignof__(*svm)); in vm_reserve_area_early()
[all …]
Dmm.h75 extern __init void add_static_vm_early(struct static_vm *svm);
/Linux-v5.10/arch/x86/kvm/
DMakefile23 kvm-amd-y += svm/svm.o svm/vmenter.o svm/pmu.o svm/nested.o svm/avic.o svm/sev.o
/Linux-v5.10/tools/testing/selftests/kvm/x86_64/
Dsvm_vmcall_test.c19 static void l2_guest_code(struct svm_test_data *svm) in l2_guest_code() argument
24 static void l1_guest_code(struct svm_test_data *svm) in l1_guest_code() argument
28 struct vmcb *vmcb = svm->vmcb; in l1_guest_code()
31 generic_svm_setup(svm, l2_guest_code, in l1_guest_code()
34 run_guest(vmcb, svm->vmcb_gpa); in l1_guest_code()
Dstate_test.c36 static void svm_l1_guest_code(struct svm_test_data *svm) in svm_l1_guest_code() argument
39 struct vmcb *vmcb = svm->vmcb; in svm_l1_guest_code()
41 GUEST_ASSERT(svm->vmcb_gpa); in svm_l1_guest_code()
43 generic_svm_setup(svm, svm_l2_guest_code, in svm_l1_guest_code()
47 run_guest(vmcb, svm->vmcb_gpa); in svm_l1_guest_code()
51 run_guest(vmcb, svm->vmcb_gpa); in svm_l1_guest_code()
/Linux-v5.10/tools/testing/vsock/
Dutil.c91 struct sockaddr_vm svm; in vsock_stream_connect() member
93 .svm = { in vsock_stream_connect()
108 ret = connect(fd, &addr.sa, sizeof(addr.svm)); in vsock_stream_connect()
131 struct sockaddr_vm svm; in vsock_stream_accept() member
133 .svm = { in vsock_stream_accept()
141 struct sockaddr_vm svm; in vsock_stream_accept() member
143 socklen_t clientaddr_len = sizeof(clientaddr.svm); in vsock_stream_accept()
150 if (bind(fd, &addr.sa, sizeof(addr.svm)) < 0) { in vsock_stream_accept()
176 if (clientaddr_len != sizeof(clientaddr.svm)) { in vsock_stream_accept()
188 *clientaddrp = clientaddr.svm; in vsock_stream_accept()
Dvsock_test.c26 struct sockaddr_vm svm; in test_stream_connection_reset() member
28 .svm = { in test_stream_connection_reset()
41 ret = connect(fd, &addr.sa, sizeof(addr.svm)); in test_stream_connection_reset()
62 struct sockaddr_vm svm; in test_stream_bind_only_client() member
64 .svm = { in test_stream_bind_only_client()
80 ret = connect(fd, &addr.sa, sizeof(addr.svm)); in test_stream_bind_only_client()
104 struct sockaddr_vm svm; in test_stream_bind_only_server() member
106 .svm = { in test_stream_bind_only_server()
116 if (bind(fd, &addr.sa, sizeof(addr.svm)) < 0) { in test_stream_bind_only_server()
Dvsock_diag_test.c343 struct sockaddr_vm svm; in test_listen_socket_server() member
345 .svm = { in test_listen_socket_server()
357 if (bind(fd, &addr.sa, sizeof(addr.svm)) < 0) { in test_listen_socket_server()
/Linux-v5.10/tools/testing/selftests/kvm/include/x86_64/
Dsvm_util.h34 void generic_svm_setup(struct svm_test_data *svm, void *guest_rip, void *guest_rsp);
/Linux-v5.10/arch/powerpc/platforms/pseries/
DMakefile29 obj-$(CONFIG_PPC_SVM) += svm.o
/Linux-v5.10/arch/x86/include/uapi/asm/
Dkvm.h459 struct kvm_svm_nested_state_hdr svm; member
472 struct kvm_svm_nested_state_data svm[0]; member
/Linux-v5.10/tools/arch/x86/include/uapi/asm/
Dkvm.h459 struct kvm_svm_nested_state_hdr svm; member
472 struct kvm_svm_nested_state_data svm[0]; member
/Linux-v5.10/tools/testing/selftests/kvm/
DMakefile37 LIBKVM_x86_64 = lib/x86_64/processor.c lib/x86_64/vmx.c lib/x86_64/svm.c lib/x86_64/ucall.c lib/x86…

12