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/kvm_main.c | |
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/kvm_main.c')
-rw-r--r-- | virt/kvm/kvm_main.c | 12 |
1 files changed, 11 insertions, 1 deletions
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 | ||