aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/cpu
diff options
context:
space:
mode:
authorPeter Zijlstra <a.p.zijlstra@chello.nl>2010-10-19 08:37:23 -0400
committerIngo Molnar <mingo@elte.hu>2010-10-22 08:18:25 -0400
commit65af94baca56beb3514d6cfce782634db9cf676d (patch)
treecaeba23895f0948bfcef58ec1a27a86b1ff8d6d7 /arch/x86/kernel/cpu
parent5ee25c87318fa3722026fd77089fa7ba0db8d447 (diff)
perf, x86: Extract DS alloc/free functions
Again, mostly a cleanup to unclutter the reserve_ds_buffer() code. Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> Acked-by: Stephane Eranian <eranian@google.com> LKML-Reference: <20101019134808.304495776@chello.nl> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/cpu')
-rw-r--r--arch/x86/kernel/cpu/perf_event_intel_ds.c40
1 files changed, 26 insertions, 14 deletions
diff --git a/arch/x86/kernel/cpu/perf_event_intel_ds.c b/arch/x86/kernel/cpu/perf_event_intel_ds.c
index 14d98bd52055..3c86f4d2f02d 100644
--- a/arch/x86/kernel/cpu/perf_event_intel_ds.c
+++ b/arch/x86/kernel/cpu/perf_event_intel_ds.c
@@ -148,6 +148,30 @@ static void release_bts_buffer(int cpu)
148 ds->bts_buffer_base = 0; 148 ds->bts_buffer_base = 0;
149} 149}
150 150
151static int alloc_ds_buffer(int cpu)
152{
153 struct debug_store *ds;
154
155 ds = kzalloc(sizeof(*ds), GFP_KERNEL);
156 if (unlikely(!ds))
157 return -ENOMEM;
158
159 per_cpu(cpu_hw_events, cpu).ds = ds;
160
161 return 0;
162}
163
164static void release_ds_buffer(int cpu)
165{
166 struct debug_store *ds = per_cpu(cpu_hw_events, cpu).ds;
167
168 if (!ds)
169 return;
170
171 per_cpu(cpu_hw_events, cpu).ds = NULL;
172 kfree(ds);
173}
174
151static void release_ds_buffers(void) 175static void release_ds_buffers(void)
152{ 176{
153 int cpu; 177 int cpu;
@@ -160,16 +184,9 @@ static void release_ds_buffers(void)
160 fini_debug_store_on_cpu(cpu); 184 fini_debug_store_on_cpu(cpu);
161 185
162 for_each_possible_cpu(cpu) { 186 for_each_possible_cpu(cpu) {
163 struct debug_store *ds = per_cpu(cpu_hw_events, cpu).ds;
164
165 if (!ds)
166 continue;
167
168 release_pebs_buffer(cpu); 187 release_pebs_buffer(cpu);
169 release_bts_buffer(cpu); 188 release_bts_buffer(cpu);
170 189 release_ds_buffer(cpu);
171 per_cpu(cpu_hw_events, cpu).ds = NULL;
172 kfree(ds);
173 } 190 }
174 put_online_cpus(); 191 put_online_cpus();
175} 192}
@@ -184,13 +201,8 @@ static int reserve_ds_buffers(void)
184 get_online_cpus(); 201 get_online_cpus();
185 202
186 for_each_possible_cpu(cpu) { 203 for_each_possible_cpu(cpu) {
187 struct debug_store *ds; 204 if (alloc_ds_buffer(cpu))
188
189 err = -ENOMEM;
190 ds = kzalloc(sizeof(*ds), GFP_KERNEL);
191 if (unlikely(!ds))
192 break; 205 break;
193 per_cpu(cpu_hw_events, cpu).ds = ds;
194 206
195 if (alloc_bts_buffer(cpu)) 207 if (alloc_bts_buffer(cpu))
196 break; 208 break;