diff options
author | Igor Mammedov <niallain@gmail.com> | 2008-04-28 19:08:21 -0400 |
---|---|---|
committer | Steve French <sfrench@us.ibm.com> | 2008-04-28 19:08:21 -0400 |
commit | e9f20d6f03e8df393b001dab6dc5226c2a5daf57 (patch) | |
tree | 73e94fa5e4f83576c97e36187b809c5aad2ade30 /drivers/oprofile/cpu_buffer.c | |
parent | bf62fd887cab230f5952b611bde25e8e15acb454 (diff) | |
parent | e31a94ed371c70855eb30b77c490d6d85dd4da26 (diff) |
Merge branch 'master' of /pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'drivers/oprofile/cpu_buffer.c')
-rw-r--r-- | drivers/oprofile/cpu_buffer.c | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/drivers/oprofile/cpu_buffer.c b/drivers/oprofile/cpu_buffer.c index c93d3d2640ab..efcbf4b4579f 100644 --- a/drivers/oprofile/cpu_buffer.c +++ b/drivers/oprofile/cpu_buffer.c | |||
@@ -27,7 +27,7 @@ | |||
27 | #include "buffer_sync.h" | 27 | #include "buffer_sync.h" |
28 | #include "oprof.h" | 28 | #include "oprof.h" |
29 | 29 | ||
30 | struct oprofile_cpu_buffer cpu_buffer[NR_CPUS] __cacheline_aligned; | 30 | DEFINE_PER_CPU_SHARED_ALIGNED(struct oprofile_cpu_buffer, cpu_buffer); |
31 | 31 | ||
32 | static void wq_sync_buffer(struct work_struct *work); | 32 | static void wq_sync_buffer(struct work_struct *work); |
33 | 33 | ||
@@ -39,7 +39,7 @@ void free_cpu_buffers(void) | |||
39 | int i; | 39 | int i; |
40 | 40 | ||
41 | for_each_online_cpu(i) | 41 | for_each_online_cpu(i) |
42 | vfree(cpu_buffer[i].buffer); | 42 | vfree(per_cpu(cpu_buffer, i).buffer); |
43 | } | 43 | } |
44 | 44 | ||
45 | int alloc_cpu_buffers(void) | 45 | int alloc_cpu_buffers(void) |
@@ -49,7 +49,7 @@ int alloc_cpu_buffers(void) | |||
49 | unsigned long buffer_size = fs_cpu_buffer_size; | 49 | unsigned long buffer_size = fs_cpu_buffer_size; |
50 | 50 | ||
51 | for_each_online_cpu(i) { | 51 | for_each_online_cpu(i) { |
52 | struct oprofile_cpu_buffer * b = &cpu_buffer[i]; | 52 | struct oprofile_cpu_buffer *b = &per_cpu(cpu_buffer, i); |
53 | 53 | ||
54 | b->buffer = vmalloc_node(sizeof(struct op_sample) * buffer_size, | 54 | b->buffer = vmalloc_node(sizeof(struct op_sample) * buffer_size, |
55 | cpu_to_node(i)); | 55 | cpu_to_node(i)); |
@@ -83,7 +83,7 @@ void start_cpu_work(void) | |||
83 | work_enabled = 1; | 83 | work_enabled = 1; |
84 | 84 | ||
85 | for_each_online_cpu(i) { | 85 | for_each_online_cpu(i) { |
86 | struct oprofile_cpu_buffer * b = &cpu_buffer[i]; | 86 | struct oprofile_cpu_buffer *b = &per_cpu(cpu_buffer, i); |
87 | 87 | ||
88 | /* | 88 | /* |
89 | * Spread the work by 1 jiffy per cpu so they dont all | 89 | * Spread the work by 1 jiffy per cpu so they dont all |
@@ -100,7 +100,7 @@ void end_cpu_work(void) | |||
100 | work_enabled = 0; | 100 | work_enabled = 0; |
101 | 101 | ||
102 | for_each_online_cpu(i) { | 102 | for_each_online_cpu(i) { |
103 | struct oprofile_cpu_buffer * b = &cpu_buffer[i]; | 103 | struct oprofile_cpu_buffer *b = &per_cpu(cpu_buffer, i); |
104 | 104 | ||
105 | cancel_delayed_work(&b->work); | 105 | cancel_delayed_work(&b->work); |
106 | } | 106 | } |
@@ -227,7 +227,7 @@ static void oprofile_end_trace(struct oprofile_cpu_buffer * cpu_buf) | |||
227 | void oprofile_add_ext_sample(unsigned long pc, struct pt_regs * const regs, | 227 | void oprofile_add_ext_sample(unsigned long pc, struct pt_regs * const regs, |
228 | unsigned long event, int is_kernel) | 228 | unsigned long event, int is_kernel) |
229 | { | 229 | { |
230 | struct oprofile_cpu_buffer * cpu_buf = &cpu_buffer[smp_processor_id()]; | 230 | struct oprofile_cpu_buffer *cpu_buf = &__get_cpu_var(cpu_buffer); |
231 | 231 | ||
232 | if (!backtrace_depth) { | 232 | if (!backtrace_depth) { |
233 | log_sample(cpu_buf, pc, is_kernel, event); | 233 | log_sample(cpu_buf, pc, is_kernel, event); |
@@ -254,13 +254,13 @@ void oprofile_add_sample(struct pt_regs * const regs, unsigned long event) | |||
254 | 254 | ||
255 | void oprofile_add_pc(unsigned long pc, int is_kernel, unsigned long event) | 255 | void oprofile_add_pc(unsigned long pc, int is_kernel, unsigned long event) |
256 | { | 256 | { |
257 | struct oprofile_cpu_buffer * cpu_buf = &cpu_buffer[smp_processor_id()]; | 257 | struct oprofile_cpu_buffer *cpu_buf = &__get_cpu_var(cpu_buffer); |
258 | log_sample(cpu_buf, pc, is_kernel, event); | 258 | log_sample(cpu_buf, pc, is_kernel, event); |
259 | } | 259 | } |
260 | 260 | ||
261 | void oprofile_add_trace(unsigned long pc) | 261 | void oprofile_add_trace(unsigned long pc) |
262 | { | 262 | { |
263 | struct oprofile_cpu_buffer * cpu_buf = &cpu_buffer[smp_processor_id()]; | 263 | struct oprofile_cpu_buffer *cpu_buf = &__get_cpu_var(cpu_buffer); |
264 | 264 | ||
265 | if (!cpu_buf->tracing) | 265 | if (!cpu_buf->tracing) |
266 | return; | 266 | return; |