mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	My earlier patch to just enable --reltime with --time was a little too
optimistic.  The --time parsing would accept absolute time, which is
very confusing to the user.
Support relative time in --time parsing too. This only works with recent
perf record that records the first sample time. Otherwise we error out.
Fixes: 3714437d3f ("perf script: Allow --time with --reltime")
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Link: http://lore.kernel.org/lkml/20191011182140.8353-1-andi@firstfloor.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
	
			
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef _TIME_UTILS_H_
 | 
						|
#define _TIME_UTILS_H_
 | 
						|
 | 
						|
#include <stddef.h>
 | 
						|
#include <time.h>
 | 
						|
#include <linux/types.h>
 | 
						|
 | 
						|
struct perf_time_interval {
 | 
						|
	u64 start, end;
 | 
						|
};
 | 
						|
 | 
						|
int parse_nsec_time(const char *str, u64 *ptime);
 | 
						|
 | 
						|
int perf_time__parse_str(struct perf_time_interval *ptime, const char *ostr);
 | 
						|
 | 
						|
int perf_time__percent_parse_str(struct perf_time_interval *ptime_buf, int num,
 | 
						|
				 const char *ostr, u64 start, u64 end);
 | 
						|
 | 
						|
struct perf_time_interval *perf_time__range_alloc(const char *ostr, int *size);
 | 
						|
 | 
						|
bool perf_time__skip_sample(struct perf_time_interval *ptime, u64 timestamp);
 | 
						|
 | 
						|
bool perf_time__ranges_skip_sample(struct perf_time_interval *ptime_buf,
 | 
						|
				   int num, u64 timestamp);
 | 
						|
 | 
						|
struct perf_session;
 | 
						|
 | 
						|
int perf_time__parse_for_ranges_reltime(const char *str, struct perf_session *session,
 | 
						|
				struct perf_time_interval **ranges,
 | 
						|
				int *range_size, int *range_num,
 | 
						|
				bool reltime);
 | 
						|
 | 
						|
int perf_time__parse_for_ranges(const char *str, struct perf_session *session,
 | 
						|
				struct perf_time_interval **ranges,
 | 
						|
				int *range_size, int *range_num);
 | 
						|
 | 
						|
int timestamp__scnprintf_usec(u64 timestamp, char *buf, size_t sz);
 | 
						|
int timestamp__scnprintf_nsec(u64 timestamp, char *buf, size_t sz);
 | 
						|
 | 
						|
int fetch_current_timestamp(char *buf, size_t sz);
 | 
						|
 | 
						|
static inline unsigned long long rdclock(void)
 | 
						|
{
 | 
						|
	struct timespec ts;
 | 
						|
 | 
						|
	clock_gettime(CLOCK_MONOTONIC, &ts);
 | 
						|
	return ts.tv_sec * 1000000000ULL + ts.tv_nsec;
 | 
						|
}
 | 
						|
 | 
						|
#endif
 |