tools: bpftool: add pointer to file argument to print_hex()
authorQuentin Monnet <quentin.monnet@netronome.com>
Thu, 19 Oct 2017 22:46:19 +0000 (15:46 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 22 Oct 2017 01:11:31 +0000 (02:11 +0100)
Make print_hex() able to print to any file instead of standard output
only, and rename it to fprint_hex(). The function can now be called with
the info() macro, for example, without splitting the output between
standard and error outputs.

Signed-off-by: Quentin Monnet <quentin.monnet@netronome.com>
Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com>
Acked-by: Daniel Borkmann <daniel@iogearbox.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
tools/bpf/bpftool/main.c
tools/bpf/bpftool/main.h
tools/bpf/bpftool/map.c
tools/bpf/bpftool/prog.c

index e02d00d..8662199 100644 (file)
@@ -100,7 +100,7 @@ bool is_prefix(const char *pfx, const char *str)
        return !memcmp(str, pfx, strlen(pfx));
 }
 
-void print_hex(void *arg, unsigned int n, const char *sep)
+void fprint_hex(FILE *f, void *arg, unsigned int n, const char *sep)
 {
        unsigned char *data = arg;
        unsigned int i;
@@ -111,13 +111,13 @@ void print_hex(void *arg, unsigned int n, const char *sep)
                if (!i)
                        /* nothing */;
                else if (!(i % 16))
-                       printf("\n");
+                       fprintf(f, "\n");
                else if (!(i % 8))
-                       printf("  ");
+                       fprintf(f, "  ");
                else
                        pfx = sep;
 
-               printf("%s%02hhx", i ? pfx : "", data[i]);
+               fprintf(f, "%s%02hhx", i ? pfx : "", data[i]);
        }
 }
 
index 844e4ef..41e6c7d 100644 (file)
@@ -67,7 +67,7 @@ enum bpf_obj_type {
 extern const char *bin_name;
 
 bool is_prefix(const char *pfx, const char *str);
-void print_hex(void *arg, unsigned int n, const char *sep);
+void fprint_hex(FILE *f, void *arg, unsigned int n, const char *sep);
 void usage(void) __attribute__((noreturn));
 
 struct cmd {
index 0528a53..b1dad76 100644 (file)
@@ -216,12 +216,12 @@ static void print_entry(struct bpf_map_info *info, unsigned char *key,
                        !break_names;
 
                printf("key:%c", break_names ? '\n' : ' ');
-               print_hex(key, info->key_size, " ");
+               fprint_hex(stdout, key, info->key_size, " ");
 
                printf(single_line ? "  " : "\n");
 
                printf("value:%c", break_names ? '\n' : ' ');
-               print_hex(value, info->value_size, " ");
+               fprint_hex(stdout, value, info->value_size, " ");
 
                printf("\n");
        } else {
@@ -230,13 +230,13 @@ static void print_entry(struct bpf_map_info *info, unsigned char *key,
                n = get_possible_cpus();
 
                printf("key:\n");
-               print_hex(key, info->key_size, " ");
+               fprint_hex(stdout, key, info->key_size, " ");
                printf("\n");
                for (i = 0; i < n; i++) {
                        printf("value (CPU %02d):%c",
                               i, info->value_size > 16 ? '\n' : ' ');
-                       print_hex(value + i * info->value_size,
-                                 info->value_size, " ");
+                       fprint_hex(stdout, value + i * info->value_size,
+                                  info->value_size, " ");
                        printf("\n");
                }
        }
@@ -492,8 +492,8 @@ static int do_dump(int argc, char **argv)
                        print_entry(&info, key, value);
                } else {
                        info("can't lookup element with key: ");
-                       print_hex(key, info.key_size, " ");
-                       printf("\n");
+                       fprint_hex(stderr, key, info.key_size, " ");
+                       fprintf(stderr, "\n");
                }
 
                prev_key = key;
@@ -587,7 +587,7 @@ static int do_lookup(int argc, char **argv)
                print_entry(&info, key, value);
        } else if (errno == ENOENT) {
                printf("key:\n");
-               print_hex(key, info.key_size, " ");
+               fprint_hex(stdout, key, info.key_size, " ");
                printf("\n\nNot found\n");
        } else {
                err("lookup failed: %s\n", strerror(errno));
@@ -642,14 +642,14 @@ static int do_getnext(int argc, char **argv)
 
        if (key) {
                printf("key:\n");
-               print_hex(key, info.key_size, " ");
+               fprint_hex(stdout, key, info.key_size, " ");
                printf("\n");
        } else {
                printf("key: None\n");
        }
 
        printf("next key:\n");
-       print_hex(nextkey, info.key_size, " ");
+       fprint_hex(stdout, nextkey, info.key_size, " ");
        printf("\n");
 
 exit_free:
index d60f530..aa6d72e 100644 (file)
@@ -224,7 +224,7 @@ static int show_prog(int fd)
                printf("name %s  ", info.name);
 
        printf("tag ");
-       print_hex(info.tag, BPF_TAG_SIZE, "");
+       fprint_hex(stdout, info.tag, BPF_TAG_SIZE, "");
        printf("\n");
 
        if (info.load_time) {
@@ -319,7 +319,7 @@ static void dump_xlated(void *buf, unsigned int len, bool opcodes)
 
                if (opcodes) {
                        printf("       ");
-                       print_hex(insn + i, 8, " ");
+                       fprint_hex(stdout, insn + i, 8, " ");
                        printf("\n");
                }