aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/trace/ftrace.c44
-rw-r--r--kernel/trace/trace.c30
2 files changed, 16 insertions, 58 deletions
diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c
index 0fa92f677c92..cf81f27ce6c6 100644
--- a/kernel/trace/ftrace.c
+++ b/kernel/trace/ftrace.c
@@ -2469,57 +2469,35 @@ static int
2469ftrace_avail_open(struct inode *inode, struct file *file) 2469ftrace_avail_open(struct inode *inode, struct file *file)
2470{ 2470{
2471 struct ftrace_iterator *iter; 2471 struct ftrace_iterator *iter;
2472 int ret;
2473 2472
2474 if (unlikely(ftrace_disabled)) 2473 if (unlikely(ftrace_disabled))
2475 return -ENODEV; 2474 return -ENODEV;
2476 2475
2477 iter = kzalloc(sizeof(*iter), GFP_KERNEL); 2476 iter = __seq_open_private(file, &show_ftrace_seq_ops, sizeof(*iter));
2478 if (!iter) 2477 if (iter) {
2479 return -ENOMEM; 2478 iter->pg = ftrace_pages_start;
2480 2479 iter->ops = &global_ops;
2481 iter->pg = ftrace_pages_start;
2482 iter->ops = &global_ops;
2483
2484 ret = seq_open(file, &show_ftrace_seq_ops);
2485 if (!ret) {
2486 struct seq_file *m = file->private_data;
2487
2488 m->private = iter;
2489 } else {
2490 kfree(iter);
2491 } 2480 }
2492 2481
2493 return ret; 2482 return iter ? 0 : -ENOMEM;
2494} 2483}
2495 2484
2496static int 2485static int
2497ftrace_enabled_open(struct inode *inode, struct file *file) 2486ftrace_enabled_open(struct inode *inode, struct file *file)
2498{ 2487{
2499 struct ftrace_iterator *iter; 2488 struct ftrace_iterator *iter;
2500 int ret;
2501 2489
2502 if (unlikely(ftrace_disabled)) 2490 if (unlikely(ftrace_disabled))
2503 return -ENODEV; 2491 return -ENODEV;
2504 2492
2505 iter = kzalloc(sizeof(*iter), GFP_KERNEL); 2493 iter = __seq_open_private(file, &show_ftrace_seq_ops, sizeof(*iter));
2506 if (!iter) 2494 if (iter) {
2507 return -ENOMEM; 2495 iter->pg = ftrace_pages_start;
2508 2496 iter->flags = FTRACE_ITER_ENABLED;
2509 iter->pg = ftrace_pages_start; 2497 iter->ops = &global_ops;
2510 iter->flags = FTRACE_ITER_ENABLED;
2511 iter->ops = &global_ops;
2512
2513 ret = seq_open(file, &show_ftrace_seq_ops);
2514 if (!ret) {
2515 struct seq_file *m = file->private_data;
2516
2517 m->private = iter;
2518 } else {
2519 kfree(iter);
2520 } 2498 }
2521 2499
2522 return ret; 2500 return iter ? 0 : -ENOMEM;
2523} 2501}
2524 2502
2525static void ftrace_filter_reset(struct ftrace_hash *hash) 2503static void ftrace_filter_reset(struct ftrace_hash *hash)
diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
index f11a285ee5bb..4fb10ef727d3 100644
--- a/kernel/trace/trace.c
+++ b/kernel/trace/trace.c
@@ -2413,15 +2413,13 @@ static struct trace_iterator *
2413__tracing_open(struct inode *inode, struct file *file) 2413__tracing_open(struct inode *inode, struct file *file)
2414{ 2414{
2415 long cpu_file = (long) inode->i_private; 2415 long cpu_file = (long) inode->i_private;
2416 void *fail_ret = ERR_PTR(-ENOMEM);
2417 struct trace_iterator *iter; 2416 struct trace_iterator *iter;
2418 struct seq_file *m; 2417 int cpu;
2419 int cpu, ret;
2420 2418
2421 if (tracing_disabled) 2419 if (tracing_disabled)
2422 return ERR_PTR(-ENODEV); 2420 return ERR_PTR(-ENODEV);
2423 2421
2424 iter = kzalloc(sizeof(*iter), GFP_KERNEL); 2422 iter = __seq_open_private(file, &tracer_seq_ops, sizeof(*iter));
2425 if (!iter) 2423 if (!iter)
2426 return ERR_PTR(-ENOMEM); 2424 return ERR_PTR(-ENOMEM);
2427 2425
@@ -2478,32 +2476,15 @@ __tracing_open(struct inode *inode, struct file *file)
2478 tracing_iter_reset(iter, cpu); 2476 tracing_iter_reset(iter, cpu);
2479 } 2477 }
2480 2478
2481 ret = seq_open(file, &tracer_seq_ops);
2482 if (ret < 0) {
2483 fail_ret = ERR_PTR(ret);
2484 goto fail_buffer;
2485 }
2486
2487 m = file->private_data;
2488 m->private = iter;
2489
2490 mutex_unlock(&trace_types_lock); 2479 mutex_unlock(&trace_types_lock);
2491 2480
2492 return iter; 2481 return iter;
2493 2482
2494 fail_buffer:
2495 for_each_tracing_cpu(cpu) {
2496 if (iter->buffer_iter[cpu])
2497 ring_buffer_read_finish(iter->buffer_iter[cpu]);
2498 }
2499 free_cpumask_var(iter->started);
2500 tracing_start();
2501 fail: 2483 fail:
2502 mutex_unlock(&trace_types_lock); 2484 mutex_unlock(&trace_types_lock);
2503 kfree(iter->trace); 2485 kfree(iter->trace);
2504 kfree(iter); 2486 seq_release_private(inode, file);
2505 2487 return ERR_PTR(-ENOMEM);
2506 return fail_ret;
2507} 2488}
2508 2489
2509int tracing_open_generic(struct inode *inode, struct file *filp) 2490int tracing_open_generic(struct inode *inode, struct file *filp)
@@ -2539,11 +2520,10 @@ static int tracing_release(struct inode *inode, struct file *file)
2539 tracing_start(); 2520 tracing_start();
2540 mutex_unlock(&trace_types_lock); 2521 mutex_unlock(&trace_types_lock);
2541 2522
2542 seq_release(inode, file);
2543 mutex_destroy(&iter->mutex); 2523 mutex_destroy(&iter->mutex);
2544 free_cpumask_var(iter->started); 2524 free_cpumask_var(iter->started);
2545 kfree(iter->trace); 2525 kfree(iter->trace);
2546 kfree(iter); 2526 seq_release_private(inode, file);
2547 return 0; 2527 return 0;
2548} 2528}
2549 2529