diff options
author | Avi Kivity <avi@redhat.com> | 2010-05-10 06:08:26 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2010-08-01 03:47:06 -0400 |
commit | 0719837c0832a7b305e42327caa7d330462360ea (patch) | |
tree | 73f574529aa588d5270da0a9cf048a65e863ba93 | |
parent | a8eeb04a44dd6dc4c8158953d9bae48849c9a188 (diff) |
KVM: Reduce atomic operations on vcpu->requests
Usually the vcpu->requests bitmap is sparse, so a test_and_clear_bit() for
each request generates a large number of unneeded atomics if a bit is set.
Replace with a separate test/clear sequence. This is safe since there is
no clear_bit() outside the vcpu thread.
Signed-off-by: Avi Kivity <avi@redhat.com>
-rw-r--r-- | include/linux/kvm_host.h | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h index c8a9d628898e..e820eb579108 100644 --- a/include/linux/kvm_host.h +++ b/include/linux/kvm_host.h | |||
@@ -636,7 +636,12 @@ static inline bool kvm_make_check_request(int req, struct kvm_vcpu *vcpu) | |||
636 | 636 | ||
637 | static inline bool kvm_check_request(int req, struct kvm_vcpu *vcpu) | 637 | static inline bool kvm_check_request(int req, struct kvm_vcpu *vcpu) |
638 | { | 638 | { |
639 | return test_and_clear_bit(req, &vcpu->requests); | 639 | if (test_bit(req, &vcpu->requests)) { |
640 | clear_bit(req, &vcpu->requests); | ||
641 | return true; | ||
642 | } else { | ||
643 | return false; | ||
644 | } | ||
640 | } | 645 | } |
641 | 646 | ||
642 | #endif | 647 | #endif |