mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	tracing/kprobes: Add a helper method to return number of probe hits
The number of probe hits is stored in a percpu variable and therefore can't be read directly. Add a helper method trace_kprobe_nhit() that performs the required calculation. It will be used in a follow-up commit that changes kprobe selftests to verify the number of probe hits. Link: http://lkml.kernel.org/r/1481293178-3128-1-git-send-email-marcin.nowakowski@imgtec.com Acked-by: Masami Hiramatsu <mhiramat@kernel.org> Signed-off-by: Marcin Nowakowski <marcin.nowakowski@imgtec.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
		
							parent
							
								
									99e6f6e813
								
							
						
					
					
						commit
						f18f97ac43
					
				
					 1 changed files with 13 additions and 6 deletions
				
			
		| 
						 | 
					@ -73,6 +73,17 @@ static nokprobe_inline bool trace_kprobe_is_on_module(struct trace_kprobe *tk)
 | 
				
			||||||
	return !!strchr(trace_kprobe_symbol(tk), ':');
 | 
						return !!strchr(trace_kprobe_symbol(tk), ':');
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static nokprobe_inline unsigned long trace_kprobe_nhit(struct trace_kprobe *tk)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						unsigned long nhit = 0;
 | 
				
			||||||
 | 
						int cpu;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for_each_possible_cpu(cpu)
 | 
				
			||||||
 | 
							nhit += *per_cpu_ptr(tk->nhit, cpu);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return nhit;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int register_kprobe_event(struct trace_kprobe *tk);
 | 
					static int register_kprobe_event(struct trace_kprobe *tk);
 | 
				
			||||||
static int unregister_kprobe_event(struct trace_kprobe *tk);
 | 
					static int unregister_kprobe_event(struct trace_kprobe *tk);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -882,14 +893,10 @@ static const struct file_operations kprobe_events_ops = {
 | 
				
			||||||
static int probes_profile_seq_show(struct seq_file *m, void *v)
 | 
					static int probes_profile_seq_show(struct seq_file *m, void *v)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct trace_kprobe *tk = v;
 | 
						struct trace_kprobe *tk = v;
 | 
				
			||||||
	unsigned long nhit = 0;
 | 
					 | 
				
			||||||
	int cpu;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	for_each_possible_cpu(cpu)
 | 
					 | 
				
			||||||
		nhit += *per_cpu_ptr(tk->nhit, cpu);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	seq_printf(m, "  %-44s %15lu %15lu\n",
 | 
						seq_printf(m, "  %-44s %15lu %15lu\n",
 | 
				
			||||||
		   trace_event_name(&tk->tp.call), nhit,
 | 
							   trace_event_name(&tk->tp.call),
 | 
				
			||||||
 | 
							   trace_kprobe_nhit(tk),
 | 
				
			||||||
		   tk->rp.kp.nmissed);
 | 
							   tk->rp.kp.nmissed);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 0;
 | 
						return 0;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue