diff options
author | Gleb Natapov <gleb@redhat.com> | 2009-08-04 08:30:29 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2009-09-10 01:33:22 -0400 |
commit | 88ba63c2653b9b4857148fedba47ba2d8a4652c9 (patch) | |
tree | 83fc7039a1892d9bd092572cf1e6ea050befbd4a /arch/x86 | |
parent | 938396a2341a4a96eaa5bea93a2bcdd69827c70c (diff) |
KVM: Replace pic_lock()/pic_unlock() with direct call to spinlock functions
They are not doing anything else now.
Signed-off-by: Gleb Natapov <gleb@redhat.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/kvm/i8259.c | 36 |
1 files changed, 12 insertions, 24 deletions
diff --git a/arch/x86/kvm/i8259.c b/arch/x86/kvm/i8259.c index 3aacd331e2de..01f151682802 100644 --- a/arch/x86/kvm/i8259.c +++ b/arch/x86/kvm/i8259.c | |||
@@ -32,18 +32,6 @@ | |||
32 | #include <linux/kvm_host.h> | 32 | #include <linux/kvm_host.h> |
33 | #include "trace.h" | 33 | #include "trace.h" |
34 | 34 | ||
35 | static void pic_lock(struct kvm_pic *s) | ||
36 | __acquires(&s->lock) | ||
37 | { | ||
38 | spin_lock(&s->lock); | ||
39 | } | ||
40 | |||
41 | static void pic_unlock(struct kvm_pic *s) | ||
42 | __releases(&s->lock) | ||
43 | { | ||
44 | spin_unlock(&s->lock); | ||
45 | } | ||
46 | |||
47 | static void pic_clear_isr(struct kvm_kpic_state *s, int irq) | 35 | static void pic_clear_isr(struct kvm_kpic_state *s, int irq) |
48 | { | 36 | { |
49 | s->isr &= ~(1 << irq); | 37 | s->isr &= ~(1 << irq); |
@@ -56,10 +44,10 @@ static void pic_clear_isr(struct kvm_kpic_state *s, int irq) | |||
56 | void kvm_pic_clear_isr_ack(struct kvm *kvm) | 44 | void kvm_pic_clear_isr_ack(struct kvm *kvm) |
57 | { | 45 | { |
58 | struct kvm_pic *s = pic_irqchip(kvm); | 46 | struct kvm_pic *s = pic_irqchip(kvm); |
59 | pic_lock(s); | 47 | spin_lock(&s->lock); |
60 | s->pics[0].isr_ack = 0xff; | 48 | s->pics[0].isr_ack = 0xff; |
61 | s->pics[1].isr_ack = 0xff; | 49 | s->pics[1].isr_ack = 0xff; |
62 | pic_unlock(s); | 50 | spin_unlock(&s->lock); |
63 | } | 51 | } |
64 | 52 | ||
65 | /* | 53 | /* |
@@ -160,9 +148,9 @@ static void pic_update_irq(struct kvm_pic *s) | |||
160 | 148 | ||
161 | void kvm_pic_update_irq(struct kvm_pic *s) | 149 | void kvm_pic_update_irq(struct kvm_pic *s) |
162 | { | 150 | { |
163 | pic_lock(s); | 151 | spin_lock(&s->lock); |
164 | pic_update_irq(s); | 152 | pic_update_irq(s); |
165 | pic_unlock(s); | 153 | spin_unlock(&s->lock); |
166 | } | 154 | } |
167 | 155 | ||
168 | int kvm_pic_set_irq(void *opaque, int irq, int level) | 156 | int kvm_pic_set_irq(void *opaque, int irq, int level) |
@@ -170,14 +158,14 @@ int kvm_pic_set_irq(void *opaque, int irq, int level) | |||
170 | struct kvm_pic *s = opaque; | 158 | struct kvm_pic *s = opaque; |
171 | int ret = -1; | 159 | int ret = -1; |
172 | 160 | ||
173 | pic_lock(s); | 161 | spin_lock(&s->lock); |
174 | if (irq >= 0 && irq < PIC_NUM_PINS) { | 162 | if (irq >= 0 && irq < PIC_NUM_PINS) { |
175 | ret = pic_set_irq1(&s->pics[irq >> 3], irq & 7, level); | 163 | ret = pic_set_irq1(&s->pics[irq >> 3], irq & 7, level); |
176 | pic_update_irq(s); | 164 | pic_update_irq(s); |
177 | trace_kvm_pic_set_irq(irq >> 3, irq & 7, s->pics[irq >> 3].elcr, | 165 | trace_kvm_pic_set_irq(irq >> 3, irq & 7, s->pics[irq >> 3].elcr, |
178 | s->pics[irq >> 3].imr, ret == 0); | 166 | s->pics[irq >> 3].imr, ret == 0); |
179 | } | 167 | } |
180 | pic_unlock(s); | 168 | spin_unlock(&s->lock); |
181 | 169 | ||
182 | return ret; | 170 | return ret; |
183 | } | 171 | } |
@@ -205,7 +193,7 @@ int kvm_pic_read_irq(struct kvm *kvm) | |||
205 | int irq, irq2, intno; | 193 | int irq, irq2, intno; |
206 | struct kvm_pic *s = pic_irqchip(kvm); | 194 | struct kvm_pic *s = pic_irqchip(kvm); |
207 | 195 | ||
208 | pic_lock(s); | 196 | spin_lock(&s->lock); |
209 | irq = pic_get_irq(&s->pics[0]); | 197 | irq = pic_get_irq(&s->pics[0]); |
210 | if (irq >= 0) { | 198 | if (irq >= 0) { |
211 | pic_intack(&s->pics[0], irq); | 199 | pic_intack(&s->pics[0], irq); |
@@ -230,7 +218,7 @@ int kvm_pic_read_irq(struct kvm *kvm) | |||
230 | intno = s->pics[0].irq_base + irq; | 218 | intno = s->pics[0].irq_base + irq; |
231 | } | 219 | } |
232 | pic_update_irq(s); | 220 | pic_update_irq(s); |
233 | pic_unlock(s); | 221 | spin_unlock(&s->lock); |
234 | 222 | ||
235 | return intno; | 223 | return intno; |
236 | } | 224 | } |
@@ -448,7 +436,7 @@ static int picdev_write(struct kvm_io_device *this, | |||
448 | printk(KERN_ERR "PIC: non byte write\n"); | 436 | printk(KERN_ERR "PIC: non byte write\n"); |
449 | return 0; | 437 | return 0; |
450 | } | 438 | } |
451 | pic_lock(s); | 439 | spin_lock(&s->lock); |
452 | switch (addr) { | 440 | switch (addr) { |
453 | case 0x20: | 441 | case 0x20: |
454 | case 0x21: | 442 | case 0x21: |
@@ -461,7 +449,7 @@ static int picdev_write(struct kvm_io_device *this, | |||
461 | elcr_ioport_write(&s->pics[addr & 1], addr, data); | 449 | elcr_ioport_write(&s->pics[addr & 1], addr, data); |
462 | break; | 450 | break; |
463 | } | 451 | } |
464 | pic_unlock(s); | 452 | spin_unlock(&s->lock); |
465 | return 0; | 453 | return 0; |
466 | } | 454 | } |
467 | 455 | ||
@@ -478,7 +466,7 @@ static int picdev_read(struct kvm_io_device *this, | |||
478 | printk(KERN_ERR "PIC: non byte read\n"); | 466 | printk(KERN_ERR "PIC: non byte read\n"); |
479 | return 0; | 467 | return 0; |
480 | } | 468 | } |
481 | pic_lock(s); | 469 | spin_lock(&s->lock); |
482 | switch (addr) { | 470 | switch (addr) { |
483 | case 0x20: | 471 | case 0x20: |
484 | case 0x21: | 472 | case 0x21: |
@@ -492,7 +480,7 @@ static int picdev_read(struct kvm_io_device *this, | |||
492 | break; | 480 | break; |
493 | } | 481 | } |
494 | *(unsigned char *)val = data; | 482 | *(unsigned char *)val = data; |
495 | pic_unlock(s); | 483 | spin_unlock(&s->lock); |
496 | return 0; | 484 | return 0; |
497 | } | 485 | } |
498 | 486 | ||