diff options
| author | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2009-10-06 11:36:55 -0400 |
|---|---|---|
| committer | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2009-10-06 11:36:55 -0400 |
| commit | d94e5fcbf1420366dcb4102bafe04dbcfc0d0d4b (patch) | |
| tree | a9b7de7df6da5c3132cc68169b9c47ba288ccd42 /kernel/trace/trace_stack.c | |
| parent | d55651168a20078a94597a297d5cdfd807bf07b6 (diff) | |
| parent | 374576a8b6f865022c0fd1ca62396889b23d66dd (diff) | |
Merge commit 'v2.6.32-rc3'
Diffstat (limited to 'kernel/trace/trace_stack.c')
| -rw-r--r-- | kernel/trace/trace_stack.c | 47 |
1 files changed, 15 insertions, 32 deletions
diff --git a/kernel/trace/trace_stack.c b/kernel/trace/trace_stack.c index 6a2a9d484cd6..8504ac71e4e8 100644 --- a/kernel/trace/trace_stack.c +++ b/kernel/trace/trace_stack.c | |||
| @@ -186,43 +186,33 @@ static const struct file_operations stack_max_size_fops = { | |||
| 186 | }; | 186 | }; |
| 187 | 187 | ||
| 188 | static void * | 188 | static void * |
| 189 | t_next(struct seq_file *m, void *v, loff_t *pos) | 189 | __next(struct seq_file *m, loff_t *pos) |
| 190 | { | 190 | { |
| 191 | long i; | 191 | long n = *pos - 1; |
| 192 | 192 | ||
| 193 | (*pos)++; | 193 | if (n >= max_stack_trace.nr_entries || stack_dump_trace[n] == ULONG_MAX) |
| 194 | |||
| 195 | if (v == SEQ_START_TOKEN) | ||
| 196 | i = 0; | ||
| 197 | else { | ||
| 198 | i = *(long *)v; | ||
| 199 | i++; | ||
| 200 | } | ||
| 201 | |||
| 202 | if (i >= max_stack_trace.nr_entries || | ||
| 203 | stack_dump_trace[i] == ULONG_MAX) | ||
| 204 | return NULL; | 194 | return NULL; |
| 205 | 195 | ||
| 206 | m->private = (void *)i; | 196 | m->private = (void *)n; |
| 207 | |||
| 208 | return &m->private; | 197 | return &m->private; |
| 209 | } | 198 | } |
| 210 | 199 | ||
| 211 | static void *t_start(struct seq_file *m, loff_t *pos) | 200 | static void * |
| 201 | t_next(struct seq_file *m, void *v, loff_t *pos) | ||
| 212 | { | 202 | { |
| 213 | void *t = SEQ_START_TOKEN; | 203 | (*pos)++; |
| 214 | loff_t l = 0; | 204 | return __next(m, pos); |
| 205 | } | ||
| 215 | 206 | ||
| 207 | static void *t_start(struct seq_file *m, loff_t *pos) | ||
| 208 | { | ||
| 216 | local_irq_disable(); | 209 | local_irq_disable(); |
| 217 | __raw_spin_lock(&max_stack_lock); | 210 | __raw_spin_lock(&max_stack_lock); |
| 218 | 211 | ||
| 219 | if (*pos == 0) | 212 | if (*pos == 0) |
| 220 | return SEQ_START_TOKEN; | 213 | return SEQ_START_TOKEN; |
| 221 | 214 | ||
| 222 | for (; t && l < *pos; t = t_next(m, t, &l)) | 215 | return __next(m, pos); |
| 223 | ; | ||
| 224 | |||
| 225 | return t; | ||
| 226 | } | 216 | } |
| 227 | 217 | ||
| 228 | static void t_stop(struct seq_file *m, void *p) | 218 | static void t_stop(struct seq_file *m, void *p) |
| @@ -234,15 +224,8 @@ static void t_stop(struct seq_file *m, void *p) | |||
| 234 | static int trace_lookup_stack(struct seq_file *m, long i) | 224 | static int trace_lookup_stack(struct seq_file *m, long i) |
| 235 | { | 225 | { |
| 236 | unsigned long addr = stack_dump_trace[i]; | 226 | unsigned long addr = stack_dump_trace[i]; |
| 237 | #ifdef CONFIG_KALLSYMS | ||
| 238 | char str[KSYM_SYMBOL_LEN]; | ||
| 239 | |||
| 240 | sprint_symbol(str, addr); | ||
| 241 | 227 | ||
| 242 | return seq_printf(m, "%s\n", str); | 228 | return seq_printf(m, "%pF\n", (void *)addr); |
| 243 | #else | ||
| 244 | return seq_printf(m, "%p\n", (void*)addr); | ||
| 245 | #endif | ||
| 246 | } | 229 | } |
| 247 | 230 | ||
| 248 | static void print_disabled(struct seq_file *m) | 231 | static void print_disabled(struct seq_file *m) |
| @@ -313,14 +296,14 @@ static const struct file_operations stack_trace_fops = { | |||
| 313 | 296 | ||
| 314 | int | 297 | int |
| 315 | stack_trace_sysctl(struct ctl_table *table, int write, | 298 | stack_trace_sysctl(struct ctl_table *table, int write, |
| 316 | struct file *file, void __user *buffer, size_t *lenp, | 299 | void __user *buffer, size_t *lenp, |
| 317 | loff_t *ppos) | 300 | loff_t *ppos) |
| 318 | { | 301 | { |
| 319 | int ret; | 302 | int ret; |
| 320 | 303 | ||
| 321 | mutex_lock(&stack_sysctl_mutex); | 304 | mutex_lock(&stack_sysctl_mutex); |
| 322 | 305 | ||
| 323 | ret = proc_dointvec(table, write, file, buffer, lenp, ppos); | 306 | ret = proc_dointvec(table, write, buffer, lenp, ppos); |
| 324 | 307 | ||
| 325 | if (ret || !write || | 308 | if (ret || !write || |
| 326 | (last_stack_tracer_enabled == !!stack_tracer_enabled)) | 309 | (last_stack_tracer_enabled == !!stack_tracer_enabled)) |
