Lines Matching refs:vm
25 struct acrn_vm *acrn_vm_create(struct acrn_vm *vm,
37 mutex_init(&vm->regions_mapping_lock);
38 INIT_LIST_HEAD(&vm->ioreq_clients);
39 spin_lock_init(&vm->ioreq_clients_lock);
40 vm->vmid = vm_param->vmid;
41 vm->vcpu_num = vm_param->vcpu_num;
43 if (acrn_ioreq_init(vm, vm_param->ioreq_buf) < 0) {
45 vm->vmid = ACRN_INVALID_VMID;
50 list_add(&vm->list, &acrn_vm_list);
53 acrn_ioeventfd_init(vm);
54 acrn_irqfd_init(vm);
55 dev_dbg(acrn_dev.this_device, "VM %u created.\n", vm->vmid);
56 return vm;
59 int acrn_vm_destroy(struct acrn_vm *vm)
63 if (vm->vmid == ACRN_INVALID_VMID ||
64 test_and_set_bit(ACRN_VM_FLAG_DESTROYED, &vm->flags))
67 ret = hcall_destroy_vm(vm->vmid);
70 "Failed to destroy VM %u\n", vm->vmid);
71 clear_bit(ACRN_VM_FLAG_DESTROYED, &vm->flags);
77 list_del_init(&vm->list);
80 acrn_ioeventfd_deinit(vm);
81 acrn_irqfd_deinit(vm);
82 acrn_ioreq_deinit(vm);
84 if (vm->monitor_page) {
85 put_page(vm->monitor_page);
86 vm->monitor_page = NULL;
89 acrn_vm_all_ram_unmap(vm);
91 dev_dbg(acrn_dev.this_device, "VM %u destroyed.\n", vm->vmid);
92 vm->vmid = ACRN_INVALID_VMID;
98 * @vm: User VM
104 int acrn_msi_inject(struct acrn_vm *vm, u64 msi_addr, u64 msi_data)
120 ret = hcall_inject_msi(vm->vmid, virt_to_phys(msi));
123 "Failed to inject MSI to VM %u!\n", vm->vmid);