|
@@ -3496,6 +3496,30 @@ int kvm_io_bus_unregister_dev(struct kvm *kvm, enum kvm_bus bus_idx,
|
|
|
return r;
|
|
|
}
|
|
|
|
|
|
+struct kvm_io_device *kvm_io_bus_get_dev(struct kvm *kvm, enum kvm_bus bus_idx,
|
|
|
+ gpa_t addr)
|
|
|
+{
|
|
|
+ struct kvm_io_bus *bus;
|
|
|
+ int dev_idx, srcu_idx;
|
|
|
+ struct kvm_io_device *iodev = NULL;
|
|
|
+
|
|
|
+ srcu_idx = srcu_read_lock(&kvm->srcu);
|
|
|
+
|
|
|
+ bus = srcu_dereference(kvm->buses[bus_idx], &kvm->srcu);
|
|
|
+
|
|
|
+ dev_idx = kvm_io_bus_get_first_dev(bus, addr, 1);
|
|
|
+ if (dev_idx < 0)
|
|
|
+ goto out_unlock;
|
|
|
+
|
|
|
+ iodev = bus->range[dev_idx].dev;
|
|
|
+
|
|
|
+out_unlock:
|
|
|
+ srcu_read_unlock(&kvm->srcu, srcu_idx);
|
|
|
+
|
|
|
+ return iodev;
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(kvm_io_bus_get_dev);
|
|
|
+
|
|
|
static struct notifier_block kvm_cpu_notifier = {
|
|
|
.notifier_call = kvm_cpu_hotplug,
|
|
|
};
|