diff options
Diffstat (limited to 'tools/lib/api')
| -rw-r--r-- | tools/lib/api/fs/fs.c | 44 | ||||
| -rw-r--r-- | tools/lib/api/fs/fs.h | 2 | 
2 files changed, 37 insertions, 9 deletions
diff --git a/tools/lib/api/fs/fs.c b/tools/lib/api/fs/fs.c index b24afc0e6e81..6a12bbf39f7b 100644 --- a/tools/lib/api/fs/fs.c +++ b/tools/lib/api/fs/fs.c @@ -315,12 +315,8 @@ int filename__read_int(const char *filename, int *value)  	return err;  } -/* - * Parses @value out of @filename with strtoull. - * By using 0 for base, the strtoull detects the - * base automatically (see man strtoull). - */ -int filename__read_ull(const char *filename, unsigned long long *value) +static int filename__read_ull_base(const char *filename, +				   unsigned long long *value, int base)  {  	char line[64];  	int fd = open(filename, O_RDONLY), err = -1; @@ -329,7 +325,7 @@ int filename__read_ull(const char *filename, unsigned long long *value)  		return -1;  	if (read(fd, line, sizeof(line)) > 0) { -		*value = strtoull(line, NULL, 0); +		*value = strtoull(line, NULL, base);  		if (*value != ULLONG_MAX)  			err = 0;  	} @@ -338,6 +334,25 @@ int filename__read_ull(const char *filename, unsigned long long *value)  	return err;  } +/* + * Parses @value out of @filename with strtoull. + * By using 16 for base to treat the number as hex. + */ +int filename__read_xll(const char *filename, unsigned long long *value) +{ +	return filename__read_ull_base(filename, value, 16); +} + +/* + * Parses @value out of @filename with strtoull. + * By using 0 for base, the strtoull detects the + * base automatically (see man strtoull). + */ +int filename__read_ull(const char *filename, unsigned long long *value) +{ +	return filename__read_ull_base(filename, value, 0); +} +  #define STRERR_BUFSIZE  128     /* For the buffer size of strerror_r */  int filename__read_str(const char *filename, char **buf, size_t *sizep) @@ -417,7 +432,8 @@ int procfs__read_str(const char *entry, char **buf, size_t *sizep)  	return filename__read_str(path, buf, sizep);  } -int sysfs__read_ull(const char *entry, unsigned long long *value) +static int sysfs__read_ull_base(const char *entry, +				unsigned long long *value, int base)  {  	char path[PATH_MAX];  	const char *sysfs = sysfs__mountpoint(); @@ -427,7 +443,17 @@ int sysfs__read_ull(const char *entry, unsigned long long *value)  	snprintf(path, sizeof(path), "%s/%s", sysfs, entry); -	return filename__read_ull(path, value); +	return filename__read_ull_base(path, value, base); +} + +int sysfs__read_xll(const char *entry, unsigned long long *value) +{ +	return sysfs__read_ull_base(entry, value, 16); +} + +int sysfs__read_ull(const char *entry, unsigned long long *value) +{ +	return sysfs__read_ull_base(entry, value, 0);  }  int sysfs__read_int(const char *entry, int *value) diff --git a/tools/lib/api/fs/fs.h b/tools/lib/api/fs/fs.h index dda49deefb52..92d03b8396b1 100644 --- a/tools/lib/api/fs/fs.h +++ b/tools/lib/api/fs/fs.h @@ -30,6 +30,7 @@ FS(bpf_fs)  int filename__read_int(const char *filename, int *value);  int filename__read_ull(const char *filename, unsigned long long *value); +int filename__read_xll(const char *filename, unsigned long long *value);  int filename__read_str(const char *filename, char **buf, size_t *sizep);  int filename__write_int(const char *filename, int value); @@ -39,6 +40,7 @@ int procfs__read_str(const char *entry, char **buf, size_t *sizep);  int sysctl__read_int(const char *sysctl, int *value);  int sysfs__read_int(const char *entry, int *value);  int sysfs__read_ull(const char *entry, unsigned long long *value); +int sysfs__read_xll(const char *entry, unsigned long long *value);  int sysfs__read_str(const char *entry, char **buf, size_t *sizep);  int sysfs__read_bool(const char *entry, bool *value);  | 
