aboutsummaryrefslogtreecommitdiffstats
path: root/tools/bpf/bpftool/json_writer.h
diff options
context:
space:
mode:
authorQuentin Monnet <quentin.monnet@netronome.com>2019-08-15 10:32:20 -0400
committerAlexei Starovoitov <ast@kernel.org>2019-08-16 01:06:46 -0400
commit8918dc42dc85ba6981028f65a989c478eb80bc02 (patch)
treefb4d3e3897a5731d4d7bf7a856eb8dc197157c62 /tools/bpf/bpftool/json_writer.h
parentb0ead6d75a5b335287337e602e6b815e1115481c (diff)
tools: bpftool: move "__printf()" attributes to header file
Some functions in bpftool have a "__printf()" format attributes to tell the compiler they should expect printf()-like arguments. But because these attributes are not used for the function prototypes in the header files, the compiler does not run the checks everywhere the functions are used, and some mistakes on format string and corresponding arguments slipped in over time. Let's move the __printf() attributes to the correct places. Note: We add guards around the definition of GCC_VERSION in tools/include/linux/compiler-gcc.h to prevent a conflict in jit_disasm.c on GCC_VERSION from headers pulled via libbfd. Fixes: c101189bc968 ("tools: bpftool: fix -Wmissing declaration warnings") Reported-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Quentin Monnet <quentin.monnet@netronome.com> Reviewed-by: Jakub Kicinski <jakub.kicinski@netronome.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'tools/bpf/bpftool/json_writer.h')
-rw-r--r--tools/bpf/bpftool/json_writer.h6
1 files changed, 4 insertions, 2 deletions
diff --git a/tools/bpf/bpftool/json_writer.h b/tools/bpf/bpftool/json_writer.h
index cb9a1993681c..35cf1f00f96c 100644
--- a/tools/bpf/bpftool/json_writer.h
+++ b/tools/bpf/bpftool/json_writer.h
@@ -14,6 +14,7 @@
14#include <stdbool.h> 14#include <stdbool.h>
15#include <stdint.h> 15#include <stdint.h>
16#include <stdarg.h> 16#include <stdarg.h>
17#include <linux/compiler.h>
17 18
18/* Opaque class structure */ 19/* Opaque class structure */
19typedef struct json_writer json_writer_t; 20typedef struct json_writer json_writer_t;
@@ -30,8 +31,9 @@ void jsonw_pretty(json_writer_t *self, bool on);
30void jsonw_name(json_writer_t *self, const char *name); 31void jsonw_name(json_writer_t *self, const char *name);
31 32
32/* Add value */ 33/* Add value */
33void jsonw_vprintf_enquote(json_writer_t *self, const char *fmt, va_list ap); 34void __printf(2, 0) jsonw_vprintf_enquote(json_writer_t *self, const char *fmt,
34void jsonw_printf(json_writer_t *self, const char *fmt, ...); 35 va_list ap);
36void __printf(2, 3) jsonw_printf(json_writer_t *self, const char *fmt, ...);
35void jsonw_string(json_writer_t *self, const char *value); 37void jsonw_string(json_writer_t *self, const char *value);
36void jsonw_bool(json_writer_t *self, bool value); 38void jsonw_bool(json_writer_t *self, bool value);
37void jsonw_float(json_writer_t *self, double number); 39void jsonw_float(json_writer_t *self, double number);