diff options
author | Michael S. Tsirkin <mst@redhat.com> | 2009-06-29 15:24:26 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2009-09-10 01:33:05 -0400 |
commit | 6c474694530f377507f9aca438c17206e051e6e7 (patch) | |
tree | 11590f6cca777716e7dfbc16c2d98fc7d64c11b0 /virt/kvm | |
parent | 108b56690f35e083c5559116d6656f59a557a815 (diff) |
KVM: convert bus to slots_lock
Use slots_lock to protect device list on the bus. slots_lock is already
taken for read everywhere, so we only need to take it for write when
registering devices. This is in preparation to removing in_range and
kvm->lock around it.
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'virt/kvm')
-rw-r--r-- | virt/kvm/coalesced_mmio.c | 2 | ||||
-rw-r--r-- | virt/kvm/ioapic.c | 2 | ||||
-rw-r--r-- | virt/kvm/kvm_main.c | 12 |
3 files changed, 13 insertions, 3 deletions
diff --git a/virt/kvm/coalesced_mmio.c b/virt/kvm/coalesced_mmio.c index b40946c1237d..7b7cc9fe5ee3 100644 --- a/virt/kvm/coalesced_mmio.c +++ b/virt/kvm/coalesced_mmio.c | |||
@@ -102,7 +102,7 @@ int kvm_coalesced_mmio_init(struct kvm *kvm) | |||
102 | kvm_iodevice_init(&dev->dev, &coalesced_mmio_ops); | 102 | kvm_iodevice_init(&dev->dev, &coalesced_mmio_ops); |
103 | dev->kvm = kvm; | 103 | dev->kvm = kvm; |
104 | kvm->coalesced_mmio_dev = dev; | 104 | kvm->coalesced_mmio_dev = dev; |
105 | kvm_io_bus_register_dev(&kvm->mmio_bus, &dev->dev); | 105 | kvm_io_bus_register_dev(kvm, &kvm->mmio_bus, &dev->dev); |
106 | 106 | ||
107 | return 0; | 107 | return 0; |
108 | } | 108 | } |
diff --git a/virt/kvm/ioapic.c b/virt/kvm/ioapic.c index 0532fa68f5d1..0eca54e06326 100644 --- a/virt/kvm/ioapic.c +++ b/virt/kvm/ioapic.c | |||
@@ -343,7 +343,7 @@ int kvm_ioapic_init(struct kvm *kvm) | |||
343 | kvm_ioapic_reset(ioapic); | 343 | kvm_ioapic_reset(ioapic); |
344 | kvm_iodevice_init(&ioapic->dev, &ioapic_mmio_ops); | 344 | kvm_iodevice_init(&ioapic->dev, &ioapic_mmio_ops); |
345 | ioapic->kvm = kvm; | 345 | ioapic->kvm = kvm; |
346 | kvm_io_bus_register_dev(&kvm->mmio_bus, &ioapic->dev); | 346 | kvm_io_bus_register_dev(kvm, &kvm->mmio_bus, &ioapic->dev); |
347 | return 0; | 347 | return 0; |
348 | } | 348 | } |
349 | 349 | ||
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index bbb4029d7c4d..0edc366ecf89 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
@@ -2527,7 +2527,17 @@ struct kvm_io_device *kvm_io_bus_find_dev(struct kvm_io_bus *bus, | |||
2527 | return NULL; | 2527 | return NULL; |
2528 | } | 2528 | } |
2529 | 2529 | ||
2530 | void kvm_io_bus_register_dev(struct kvm_io_bus *bus, struct kvm_io_device *dev) | 2530 | void kvm_io_bus_register_dev(struct kvm *kvm, struct kvm_io_bus *bus, |
2531 | struct kvm_io_device *dev) | ||
2532 | { | ||
2533 | down_write(&kvm->slots_lock); | ||
2534 | __kvm_io_bus_register_dev(bus, dev); | ||
2535 | up_write(&kvm->slots_lock); | ||
2536 | } | ||
2537 | |||
2538 | /* An unlocked version. Caller must have write lock on slots_lock. */ | ||
2539 | void __kvm_io_bus_register_dev(struct kvm_io_bus *bus, | ||
2540 | struct kvm_io_device *dev) | ||
2531 | { | 2541 | { |
2532 | BUG_ON(bus->dev_count > (NR_IOBUS_DEVS-1)); | 2542 | BUG_ON(bus->dev_count > (NR_IOBUS_DEVS-1)); |
2533 | 2543 | ||