 a6a69db4b6
			
		
	
	
	a6a69db4b6
	
	
	
		
			
			Move the rdtsc() function so it can be reusued. Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@gmail.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/r/1406035081-14301-24-git-send-email-adrian.hunter@intel.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			899 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			899 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <stdbool.h>
 | |
| #include <errno.h>
 | |
| 
 | |
| #include <linux/perf_event.h>
 | |
| 
 | |
| #include "../../perf.h"
 | |
| #include <linux/types.h>
 | |
| #include "../../util/debug.h"
 | |
| #include "../../util/tsc.h"
 | |
| #include "tsc.h"
 | |
| 
 | |
| int perf_read_tsc_conversion(const struct perf_event_mmap_page *pc,
 | |
| 			     struct perf_tsc_conversion *tc)
 | |
| {
 | |
| 	bool cap_user_time_zero;
 | |
| 	u32 seq;
 | |
| 	int i = 0;
 | |
| 
 | |
| 	while (1) {
 | |
| 		seq = pc->lock;
 | |
| 		rmb();
 | |
| 		tc->time_mult = pc->time_mult;
 | |
| 		tc->time_shift = pc->time_shift;
 | |
| 		tc->time_zero = pc->time_zero;
 | |
| 		cap_user_time_zero = pc->cap_user_time_zero;
 | |
| 		rmb();
 | |
| 		if (pc->lock == seq && !(seq & 1))
 | |
| 			break;
 | |
| 		if (++i > 10000) {
 | |
| 			pr_debug("failed to get perf_event_mmap_page lock\n");
 | |
| 			return -EINVAL;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if (!cap_user_time_zero)
 | |
| 		return -EOPNOTSUPP;
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| u64 rdtsc(void)
 | |
| {
 | |
| 	unsigned int low, high;
 | |
| 
 | |
| 	asm volatile("rdtsc" : "=a" (low), "=d" (high));
 | |
| 
 | |
| 	return low | ((u64)high) << 32;
 | |
| }
 |