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 | |
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>
-rw-r--r-- | arch/x86/kvm/i8254.c | 5 | ||||
-rw-r--r-- | arch/x86/kvm/i8259.c | 2 | ||||
-rw-r--r-- | include/linux/kvm_host.h | 5 | ||||
-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 |
6 files changed, 21 insertions, 7 deletions
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c index bcd00c76d69e..4082cdd468ed 100644 --- a/arch/x86/kvm/i8254.c +++ b/arch/x86/kvm/i8254.c | |||
@@ -583,6 +583,7 @@ static const struct kvm_io_device_ops speaker_dev_ops = { | |||
583 | .in_range = speaker_in_range, | 583 | .in_range = speaker_in_range, |
584 | }; | 584 | }; |
585 | 585 | ||
586 | /* Caller must have writers lock on slots_lock */ | ||
586 | struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags) | 587 | struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags) |
587 | { | 588 | { |
588 | struct kvm_pit *pit; | 589 | struct kvm_pit *pit; |
@@ -621,11 +622,11 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm, u32 flags) | |||
621 | kvm_register_irq_mask_notifier(kvm, 0, &pit->mask_notifier); | 622 | kvm_register_irq_mask_notifier(kvm, 0, &pit->mask_notifier); |
622 | 623 | ||
623 | kvm_iodevice_init(&pit->dev, &pit_dev_ops); | 624 | kvm_iodevice_init(&pit->dev, &pit_dev_ops); |
624 | kvm_io_bus_register_dev(&kvm->pio_bus, &pit->dev); | 625 | __kvm_io_bus_register_dev(&kvm->pio_bus, &pit->dev); |
625 | 626 | ||
626 | if (flags & KVM_PIT_SPEAKER_DUMMY) { | 627 | if (flags & KVM_PIT_SPEAKER_DUMMY) { |
627 | kvm_iodevice_init(&pit->speaker_dev, &speaker_dev_ops); | 628 | kvm_iodevice_init(&pit->speaker_dev, &speaker_dev_ops); |
628 | kvm_io_bus_register_dev(&kvm->pio_bus, &pit->speaker_dev); | 629 | __kvm_io_bus_register_dev(&kvm->pio_bus, &pit->speaker_dev); |
629 | } | 630 | } |
630 | 631 | ||
631 | return pit; | 632 | return pit; |
diff --git a/arch/x86/kvm/i8259.c b/arch/x86/kvm/i8259.c index 148c52a608d6..1851aec8a7da 100644 --- a/arch/x86/kvm/i8259.c +++ b/arch/x86/kvm/i8259.c | |||
@@ -548,6 +548,6 @@ struct kvm_pic *kvm_create_pic(struct kvm *kvm) | |||
548 | * Initialize PIO device | 548 | * Initialize PIO device |
549 | */ | 549 | */ |
550 | kvm_iodevice_init(&s->dev, &picdev_ops); | 550 | kvm_iodevice_init(&s->dev, &picdev_ops); |
551 | kvm_io_bus_register_dev(&kvm->pio_bus, &s->dev); | 551 | kvm_io_bus_register_dev(kvm, &kvm->pio_bus, &s->dev); |
552 | return s; | 552 | return s; |
553 | } | 553 | } |
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index 4ea42c950539..96c8c0b01929 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h | |||
@@ -42,6 +42,7 @@ | |||
42 | 42 | ||
43 | #define KVM_USERSPACE_IRQ_SOURCE_ID 0 | 43 | #define KVM_USERSPACE_IRQ_SOURCE_ID 0 |
44 | 44 | ||
45 | struct kvm; | ||
45 | struct kvm_vcpu; | 46 | struct kvm_vcpu; |
46 | extern struct kmem_cache *kvm_vcpu_cache; | 47 | extern struct kmem_cache *kvm_vcpu_cache; |
47 | 48 | ||
@@ -61,7 +62,9 @@ void kvm_io_bus_init(struct kvm_io_bus *bus); | |||
61 | void kvm_io_bus_destroy(struct kvm_io_bus *bus); | 62 | void kvm_io_bus_destroy(struct kvm_io_bus *bus); |
62 | struct kvm_io_device *kvm_io_bus_find_dev(struct kvm_io_bus *bus, | 63 | struct kvm_io_device *kvm_io_bus_find_dev(struct kvm_io_bus *bus, |
63 | gpa_t addr, int len, int is_write); | 64 | gpa_t addr, int len, int is_write); |
64 | void kvm_io_bus_register_dev(struct kvm_io_bus *bus, | 65 | void __kvm_io_bus_register_dev(struct kvm_io_bus *bus, |
66 | struct kvm_io_device *dev); | ||
67 | void kvm_io_bus_register_dev(struct kvm *kvm, struct kvm_io_bus *bus, | ||
65 | struct kvm_io_device *dev); | 68 | struct kvm_io_device *dev); |
66 | 69 | ||
67 | struct kvm_vcpu { | 70 | struct kvm_vcpu { |
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 | ||