aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/builtin-kvm.c
diff options
context:
space:
mode:
authorSage Weil <sage@inktank.com>2013-08-15 14:11:45 -0400
committerSage Weil <sage@inktank.com>2013-08-15 14:11:45 -0400
commitee3e542fec6e69bc9fb668698889a37d93950ddf (patch)
treee74ee766a4764769ef1d3d45d266b4dea64101d3 /tools/perf/builtin-kvm.c
parentfe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff)
parentf1d6e17f540af37bb1891480143669ba7636c4cf (diff)
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'tools/perf/builtin-kvm.c')
-rw-r--r--tools/perf/builtin-kvm.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/tools/perf/builtin-kvm.c b/tools/perf/builtin-kvm.c
index 533501e2b07c..24b78aecc928 100644
--- a/tools/perf/builtin-kvm.c
+++ b/tools/perf/builtin-kvm.c
@@ -328,6 +328,7 @@ static int kvm_events_hash_fn(u64 key)
328static bool kvm_event_expand(struct kvm_event *event, int vcpu_id) 328static bool kvm_event_expand(struct kvm_event *event, int vcpu_id)
329{ 329{
330 int old_max_vcpu = event->max_vcpu; 330 int old_max_vcpu = event->max_vcpu;
331 void *prev;
331 332
332 if (vcpu_id < event->max_vcpu) 333 if (vcpu_id < event->max_vcpu)
333 return true; 334 return true;
@@ -335,9 +336,11 @@ static bool kvm_event_expand(struct kvm_event *event, int vcpu_id)
335 while (event->max_vcpu <= vcpu_id) 336 while (event->max_vcpu <= vcpu_id)
336 event->max_vcpu += DEFAULT_VCPU_NUM; 337 event->max_vcpu += DEFAULT_VCPU_NUM;
337 338
339 prev = event->vcpu;
338 event->vcpu = realloc(event->vcpu, 340 event->vcpu = realloc(event->vcpu,
339 event->max_vcpu * sizeof(*event->vcpu)); 341 event->max_vcpu * sizeof(*event->vcpu));
340 if (!event->vcpu) { 342 if (!event->vcpu) {
343 free(prev);
341 pr_err("Not enough memory\n"); 344 pr_err("Not enough memory\n");
342 return false; 345 return false;
343 } 346 }