diff options
author | Namhyung Kim <namhyung.kim@lge.com> | 2012-08-22 03:00:31 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-08-22 15:04:05 -0400 |
commit | e1aa7c30c599e99b4544f9e5b4c275c8a5325bdc (patch) | |
tree | 7d6bc8f37c52b63f49508aa1e0ab4ba2699be790 /tools/lib | |
parent | 2f197b9d7eeaa723a80243610956fe4a17e7b5a4 (diff) |
tools lib traceevent: Fix strerror_r() use in pevent_strerror
glibc-2.16 starts to mark the function with attribute warn_unused_result
so that it can cause a build warning.
Since GNU version of strerror_r() can return a pointer to a string
without setting @buf, check the return value and copy/truncate it to our
buffer if needed.
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Acked-by: Kirill A. Shutemov <kirill@shutemov.name>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Kirill A. Shutemov <kirill@shutemov.name>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Steven Rostedt <rostedt@goodmis.org>
Link: http://lkml.kernel.org/r/1345618831-9148-5-git-send-email-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/lib')
-rw-r--r-- | tools/lib/traceevent/event-parse.c | 7 | ||||
-rw-r--r-- | tools/lib/traceevent/event-utils.h | 6 |
2 files changed, 12 insertions, 1 deletions
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c index 1373e4cf109e..f978c59f67bf 100644 --- a/tools/lib/traceevent/event-parse.c +++ b/tools/lib/traceevent/event-parse.c | |||
@@ -4809,7 +4809,12 @@ int pevent_strerror(struct pevent *pevent, enum pevent_errno errnum, | |||
4809 | const char *msg; | 4809 | const char *msg; |
4810 | 4810 | ||
4811 | if (errnum >= 0) { | 4811 | if (errnum >= 0) { |
4812 | strerror_r(errnum, buf, buflen); | 4812 | msg = strerror_r(errnum, buf, buflen); |
4813 | if (msg != buf) { | ||
4814 | size_t len = strlen(msg); | ||
4815 | char *c = mempcpy(buf, msg, min(buflen-1, len)); | ||
4816 | *c = '\0'; | ||
4817 | } | ||
4813 | return 0; | 4818 | return 0; |
4814 | } | 4819 | } |
4815 | 4820 | ||
diff --git a/tools/lib/traceevent/event-utils.h b/tools/lib/traceevent/event-utils.h index 08296383d1e6..bc075006966e 100644 --- a/tools/lib/traceevent/event-utils.h +++ b/tools/lib/traceevent/event-utils.h | |||
@@ -39,6 +39,12 @@ void __vdie(const char *fmt, ...); | |||
39 | void __vwarning(const char *fmt, ...); | 39 | void __vwarning(const char *fmt, ...); |
40 | void __vpr_stat(const char *fmt, ...); | 40 | void __vpr_stat(const char *fmt, ...); |
41 | 41 | ||
42 | #define min(x, y) ({ \ | ||
43 | typeof(x) _min1 = (x); \ | ||
44 | typeof(y) _min2 = (y); \ | ||
45 | (void) (&_min1 == &_min2); \ | ||
46 | _min1 < _min2 ? _min1 : _min2; }) | ||
47 | |||
42 | static inline char *strim(char *string) | 48 | static inline char *strim(char *string) |
43 | { | 49 | { |
44 | char *ret; | 50 | char *ret; |