Commit 6baddfc6 authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

tools lib api fs: Add filename__read_xll function

Adding filename__read_xll function to be able to read files with hex
numbers in, which do not have 0x prefix.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20180206181813.10943-5-jolsa@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 3233b37a
...@@ -315,12 +315,8 @@ int filename__read_int(const char *filename, int *value) ...@@ -315,12 +315,8 @@ int filename__read_int(const char *filename, int *value)
return err; return err;
} }
/* static int filename__read_ull_base(const char *filename,
* Parses @value out of @filename with strtoull. unsigned long long *value, int base)
* 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)
{ {
char line[64]; char line[64];
int fd = open(filename, O_RDONLY), err = -1; int fd = open(filename, O_RDONLY), err = -1;
...@@ -329,7 +325,7 @@ int filename__read_ull(const char *filename, unsigned long long *value) ...@@ -329,7 +325,7 @@ int filename__read_ull(const char *filename, unsigned long long *value)
return -1; return -1;
if (read(fd, line, sizeof(line)) > 0) { if (read(fd, line, sizeof(line)) > 0) {
*value = strtoull(line, NULL, 0); *value = strtoull(line, NULL, base);
if (*value != ULLONG_MAX) if (*value != ULLONG_MAX)
err = 0; err = 0;
} }
...@@ -338,6 +334,25 @@ int filename__read_ull(const char *filename, unsigned long long *value) ...@@ -338,6 +334,25 @@ int filename__read_ull(const char *filename, unsigned long long *value)
return err; 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 */ #define STRERR_BUFSIZE 128 /* For the buffer size of strerror_r */
int filename__read_str(const char *filename, char **buf, size_t *sizep) int filename__read_str(const char *filename, char **buf, size_t *sizep)
......
...@@ -30,6 +30,7 @@ FS(bpf_fs) ...@@ -30,6 +30,7 @@ FS(bpf_fs)
int filename__read_int(const char *filename, int *value); int filename__read_int(const char *filename, int *value);
int filename__read_ull(const char *filename, unsigned long long *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__read_str(const char *filename, char **buf, size_t *sizep);
int filename__write_int(const char *filename, int value); int filename__write_int(const char *filename, int value);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment