diff options
Diffstat (limited to 'tools/perf/util/util.c')
| -rw-r--r-- | tools/perf/util/util.c | 92 | 
1 files changed, 92 insertions, 0 deletions
| diff --git a/tools/perf/util/util.c b/tools/perf/util/util.c index 59d868add275..6d17b18e915d 100644 --- a/tools/perf/util/util.c +++ b/tools/perf/util/util.c @@ -269,3 +269,95 @@ void perf_debugfs_set_path(const char *mntpt)  	snprintf(debugfs_mountpoint, strlen(debugfs_mountpoint), "%s", mntpt);  	set_tracing_events_path(mntpt);  } + +static const char *find_debugfs(void) +{ +	const char *path = perf_debugfs_mount(NULL); + +	if (!path) +		fprintf(stderr, "Your kernel does not support the debugfs filesystem"); + +	return path; +} + +/* + * Finds the path to the debugfs/tracing + * Allocates the string and stores it. + */ +const char *find_tracing_dir(void) +{ +	static char *tracing; +	static int tracing_found; +	const char *debugfs; + +	if (tracing_found) +		return tracing; + +	debugfs = find_debugfs(); +	if (!debugfs) +		return NULL; + +	tracing = malloc(strlen(debugfs) + 9); +	if (!tracing) +		return NULL; + +	sprintf(tracing, "%s/tracing", debugfs); + +	tracing_found = 1; +	return tracing; +} + +char *get_tracing_file(const char *name) +{ +	const char *tracing; +	char *file; + +	tracing = find_tracing_dir(); +	if (!tracing) +		return NULL; + +	file = malloc(strlen(tracing) + strlen(name) + 2); +	if (!file) +		return NULL; + +	sprintf(file, "%s/%s", tracing, name); +	return file; +} + +void put_tracing_file(char *file) +{ +	free(file); +} + +int parse_nsec_time(const char *str, u64 *ptime) +{ +	u64 time_sec, time_nsec; +	char *end; + +	time_sec = strtoul(str, &end, 10); +	if (*end != '.' && *end != '\0') +		return -1; + +	if (*end == '.') { +		int i; +		char nsec_buf[10]; + +		if (strlen(++end) > 9) +			return -1; + +		strncpy(nsec_buf, end, 9); +		nsec_buf[9] = '\0'; + +		/* make it nsec precision */ +		for (i = strlen(nsec_buf); i < 9; i++) +			nsec_buf[i] = '0'; + +		time_nsec = strtoul(nsec_buf, &end, 10); +		if (*end != '\0') +			return -1; +	} else +		time_nsec = 0; + +	*ptime = time_sec * NSEC_PER_SEC + time_nsec; +	return 0; +} | 
