tracing: Add "uptime" trace clock that uses jiffies
Add a simple trace clock called "uptime" for those that are interested in the uptime of the trace. It uses jiffies as that's the safest method, as other uptime clocks grab seq locks, which could cause a deadlock if taken from an event or function tracer. Requested-by: Mauro Carvalho Chehab <mchehab@redhat.com> Cc: Thomas Gleixner <tglx@linutronix.de Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Frederic Weisbecker <fweisbec@gmail.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
		
					parent
					
						
							
								328df4759c
							
						
					
				
			
			
				commit
				
					
						8aacf017b0
					
				
			
		
					 3 changed files with 12 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -16,6 +16,7 @@
 | 
			
		|||
 | 
			
		||||
extern u64 notrace trace_clock_local(void);
 | 
			
		||||
extern u64 notrace trace_clock(void);
 | 
			
		||||
extern u64 notrace trace_clock_jiffies(void);
 | 
			
		||||
extern u64 notrace trace_clock_global(void);
 | 
			
		||||
extern u64 notrace trace_clock_counter(void);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -647,6 +647,7 @@ static struct {
 | 
			
		|||
	{ trace_clock_local,	"local",	1 },
 | 
			
		||||
	{ trace_clock_global,	"global",	1 },
 | 
			
		||||
	{ trace_clock_counter,	"counter",	0 },
 | 
			
		||||
	{ trace_clock_jiffies,	"uptime",	1 },
 | 
			
		||||
	ARCH_TRACE_CLOCKS
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -57,6 +57,16 @@ u64 notrace trace_clock(void)
 | 
			
		|||
	return local_clock();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * trace_jiffy_clock(): Simply use jiffies as a clock counter.
 | 
			
		||||
 */
 | 
			
		||||
u64 notrace trace_clock_jiffies(void)
 | 
			
		||||
{
 | 
			
		||||
	u64 jiffy = jiffies - INITIAL_JIFFIES;
 | 
			
		||||
 | 
			
		||||
	/* Return nsecs */
 | 
			
		||||
	return (u64)jiffies_to_usecs(jiffy) * 1000ULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * trace_clock_global(): special globally coherent trace clock
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue