 8cbd9cc625
			
		
	
	
	8cbd9cc625
	
	
	
		
			
			In order to promote interoperability between userspace tracers and ftrace, add a trace_clock that reports raw TSC values which will then be recorded in the ring buffer. Userspace tracers that also record TSCs are then on exactly the same time base as the kernel and events can be unambiguously interlaced. Tested: Enabled a tracepoint and the "tsc" trace_clock and saw very large timestamp values. v2: Move arch-specific bits out of generic code. v3: Rename "x86-tsc", cleanups v7: Generic arch bits in Kbuild. Google-Bug-Id: 6980623 Link: http://lkml.kernel.org/r/1352837903-32191-1-git-send-email-dhsharp@google.com Acked-by: Ingo Molnar <mingo@kernel.org> Cc: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: "H. Peter Anvin" <hpa@linux.intel.com> Signed-off-by: David Sharp <dhsharp@google.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
		
			
				
	
	
		
			21 lines
		
	
	
	
		
			335 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			21 lines
		
	
	
	
		
			335 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * X86 trace clocks
 | |
|  */
 | |
| #include <asm/trace_clock.h>
 | |
| #include <asm/barrier.h>
 | |
| #include <asm/msr.h>
 | |
| 
 | |
| /*
 | |
|  * trace_clock_x86_tsc(): A clock that is just the cycle counter.
 | |
|  *
 | |
|  * Unlike the other clocks, this is not in nanoseconds.
 | |
|  */
 | |
| u64 notrace trace_clock_x86_tsc(void)
 | |
| {
 | |
| 	u64 ret;
 | |
| 
 | |
| 	rdtsc_barrier();
 | |
| 	rdtscll(ret);
 | |
| 
 | |
| 	return ret;
 | |
| }
 |