Lines Matching full:tr
40 static void stop_irqsoff_tracer(struct trace_array *tr, int graph);
41 static int start_irqsoff_tracer(struct trace_array *tr, int graph);
65 static int irqsoff_display_graph(struct trace_array *tr, int set);
66 # define is_graph(tr) ((tr)->trace_flags & TRACE_ITER_DISPLAY_GRAPH) argument
68 static inline int irqsoff_display_graph(struct trace_array *tr, int set) in irqsoff_display_graph() argument
72 # define is_graph(tr) false argument
99 static int func_prolog_dec(struct trace_array *tr, in func_prolog_dec() argument
125 *data = per_cpu_ptr(tr->array_buffer.data, cpu); in func_prolog_dec()
143 struct trace_array *tr = irqsoff_trace; in irqsoff_tracer_call() local
148 if (!func_prolog_dec(tr, &data, &flags)) in irqsoff_tracer_call()
153 trace_function(tr, ip, parent_ip, trace_ctx, fregs); in irqsoff_tracer_call()
160 static int irqsoff_display_graph(struct trace_array *tr, int set) in irqsoff_display_graph() argument
164 if (!(is_graph(tr) ^ set)) in irqsoff_display_graph()
172 tr->max_latency = 0; in irqsoff_display_graph()
182 struct trace_array *tr = irqsoff_trace; in irqsoff_graph_entry() local
201 if (!func_prolog_dec(tr, &data, &flags)) in irqsoff_graph_entry()
208 ret = __trace_graph_entry(tr, trace, trace_ctx); in irqsoff_graph_entry()
219 struct trace_array *tr = irqsoff_trace; in irqsoff_graph_return() local
229 if (!func_prolog_dec(tr, &data, &flags)) in irqsoff_graph_return()
236 __trace_graph_return(tr, trace, trace_ctx, *calltime, rettime); in irqsoff_graph_return()
248 if (is_graph(iter->tr)) in irqsoff_trace_open()
269 if (is_graph(iter->tr)) in irqsoff_print_line()
277 struct trace_array *tr = irqsoff_trace; in irqsoff_print_header() local
279 if (is_graph(tr)) in irqsoff_print_header()
286 __trace_function(struct trace_array *tr, in __trace_function() argument
290 if (is_graph(tr)) in __trace_function()
291 trace_graph_function(tr, ip, parent_ip, trace_ctx); in __trace_function()
293 trace_function(tr, ip, parent_ip, trace_ctx, NULL); in __trace_function()
298 __trace_function(struct trace_array *tr, in __trace_function() argument
302 return trace_function(tr, ip, parent_ip, trace_ctx, NULL); in __trace_function()
329 static bool report_latency(struct trace_array *tr, u64 delta) in report_latency() argument
335 if (delta <= tr->max_latency) in report_latency()
342 check_critical_timing(struct trace_array *tr, in check_critical_timing() argument
357 if (!report_latency(tr, delta)) in check_critical_timing()
363 if (!report_latency(tr, delta)) in check_critical_timing()
366 __trace_function(tr, CALLER_ADDR0, parent_ip, trace_ctx); in check_critical_timing()
368 __trace_stack(tr, trace_ctx, 5); in check_critical_timing()
376 tr->max_latency = delta; in check_critical_timing()
377 update_max_tr_single(tr, current, cpu); in check_critical_timing()
388 __trace_function(tr, CALLER_ADDR0, parent_ip, trace_ctx); in check_critical_timing()
395 struct trace_array *tr = irqsoff_trace; in start_critical_timing() local
407 data = per_cpu_ptr(tr->array_buffer.data, cpu); in start_critical_timing()
419 __trace_function(tr, ip, parent_ip, tracing_gen_ctx()); in start_critical_timing()
431 struct trace_array *tr = irqsoff_trace; in stop_critical_timing() local
446 data = per_cpu_ptr(tr->array_buffer.data, cpu); in stop_critical_timing()
456 __trace_function(tr, ip, parent_ip, trace_ctx); in stop_critical_timing()
457 check_critical_timing(tr, data, parent_ip ? : ip, cpu); in stop_critical_timing()
484 static int register_irqsoff_function(struct trace_array *tr, int graph, int set) in register_irqsoff_function() argument
489 if (function_enabled || (!set && !(tr->trace_flags & TRACE_ITER_FUNCTION))) in register_irqsoff_function()
495 ret = register_ftrace_function(tr->ops); in register_irqsoff_function()
503 static void unregister_irqsoff_function(struct trace_array *tr, int graph) in unregister_irqsoff_function() argument
511 unregister_ftrace_function(tr->ops); in unregister_irqsoff_function()
516 static int irqsoff_function_set(struct trace_array *tr, u32 mask, int set) in irqsoff_function_set() argument
522 register_irqsoff_function(tr, is_graph(tr), 1); in irqsoff_function_set()
524 unregister_irqsoff_function(tr, is_graph(tr)); in irqsoff_function_set()
528 static int register_irqsoff_function(struct trace_array *tr, int graph, int set) in register_irqsoff_function() argument
532 static void unregister_irqsoff_function(struct trace_array *tr, int graph) { } in unregister_irqsoff_function() argument
533 static inline int irqsoff_function_set(struct trace_array *tr, u32 mask, int set) in irqsoff_function_set() argument
539 static int irqsoff_flag_changed(struct trace_array *tr, u32 mask, int set) in irqsoff_flag_changed() argument
541 struct tracer *tracer = tr->current_trace; in irqsoff_flag_changed()
543 if (irqsoff_function_set(tr, mask, set)) in irqsoff_flag_changed()
548 return irqsoff_display_graph(tr, set); in irqsoff_flag_changed()
554 static int start_irqsoff_tracer(struct trace_array *tr, int graph) in start_irqsoff_tracer() argument
558 ret = register_irqsoff_function(tr, graph, 0); in start_irqsoff_tracer()
568 static void stop_irqsoff_tracer(struct trace_array *tr, int graph) in stop_irqsoff_tracer() argument
572 unregister_irqsoff_function(tr, graph); in stop_irqsoff_tracer()
577 static int __irqsoff_tracer_init(struct trace_array *tr) in __irqsoff_tracer_init() argument
582 save_flags = tr->trace_flags; in __irqsoff_tracer_init()
585 set_tracer_flag(tr, TRACE_ITER_OVERWRITE, 1); in __irqsoff_tracer_init()
586 set_tracer_flag(tr, TRACE_ITER_LATENCY_FMT, 1); in __irqsoff_tracer_init()
588 set_tracer_flag(tr, TRACE_ITER_PAUSE_ON_TRACE, 1); in __irqsoff_tracer_init()
590 tr->max_latency = 0; in __irqsoff_tracer_init()
591 irqsoff_trace = tr; in __irqsoff_tracer_init()
595 ftrace_init_array_ops(tr, irqsoff_tracer_call); in __irqsoff_tracer_init()
598 if (start_irqsoff_tracer(tr, (tr->flags & TRACE_ARRAY_FL_GLOBAL && in __irqsoff_tracer_init()
599 is_graph(tr)))) in __irqsoff_tracer_init()
606 static void __irqsoff_tracer_reset(struct trace_array *tr) in __irqsoff_tracer_reset() argument
612 stop_irqsoff_tracer(tr, is_graph(tr)); in __irqsoff_tracer_reset()
614 set_tracer_flag(tr, TRACE_ITER_LATENCY_FMT, lat_flag); in __irqsoff_tracer_reset()
615 set_tracer_flag(tr, TRACE_ITER_OVERWRITE, overwrite_flag); in __irqsoff_tracer_reset()
616 set_tracer_flag(tr, TRACE_ITER_PAUSE_ON_TRACE, pause_flag); in __irqsoff_tracer_reset()
617 ftrace_reset_array_ops(tr); in __irqsoff_tracer_reset()
622 static void irqsoff_tracer_start(struct trace_array *tr) in irqsoff_tracer_start() argument
627 static void irqsoff_tracer_stop(struct trace_array *tr) in irqsoff_tracer_stop() argument
650 static int irqsoff_tracer_init(struct trace_array *tr) in irqsoff_tracer_init() argument
654 return __irqsoff_tracer_init(tr); in irqsoff_tracer_init()
657 static void irqsoff_tracer_reset(struct trace_array *tr) in irqsoff_tracer_reset() argument
659 __irqsoff_tracer_reset(tr); in irqsoff_tracer_reset()
696 static int preemptoff_tracer_init(struct trace_array *tr) in preemptoff_tracer_init() argument
700 return __irqsoff_tracer_init(tr); in preemptoff_tracer_init()
703 static void preemptoff_tracer_reset(struct trace_array *tr) in preemptoff_tracer_reset() argument
705 __irqsoff_tracer_reset(tr); in preemptoff_tracer_reset()
731 static int preemptirqsoff_tracer_init(struct trace_array *tr) in preemptirqsoff_tracer_init() argument
735 return __irqsoff_tracer_init(tr); in preemptirqsoff_tracer_init()
738 static void preemptirqsoff_tracer_reset(struct trace_array *tr) in preemptirqsoff_tracer_reset() argument
740 __irqsoff_tracer_reset(tr); in preemptirqsoff_tracer_reset()