]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
bpf: Fixes a snprintf truncation warning
authorAndrea Claudi <aclaudi@redhat.com>
Tue, 26 May 2020 16:04:11 +0000 (18:04 +0200)
committerStephen Hemminger <stephen@networkplumber.org>
Wed, 27 May 2020 22:05:25 +0000 (15:05 -0700)
gcc v9.3.1 reports:

bpf.c: In function ‘bpf_get_work_dir’:
bpf.c:784:49: warning: ‘snprintf’ output may be truncated before the last format character [-Wformat-truncation=]
  784 |  snprintf(bpf_wrk_dir, sizeof(bpf_wrk_dir), "%s/", mnt);
      |                                                 ^
bpf.c:784:2: note: ‘snprintf’ output between 2 and 4097 bytes into a destination of size 4096
  784 |  snprintf(bpf_wrk_dir, sizeof(bpf_wrk_dir), "%s/", mnt);
      |  ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Fix this simply checking snprintf return code and properly handling the error.

Fixes: e42256699cac ("bpf: make tc's bpf loader generic and move into lib")
Signed-off-by: Andrea Claudi <aclaudi@redhat.com>
Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
lib/bpf.c

index 23cb0d96a85ba94dc83dd1c316d6d0dedc5c4994..c7d45077c14e58f55a72237a9a55d7667c417c30 100644 (file)
--- a/lib/bpf.c
+++ b/lib/bpf.c
@@ -781,7 +781,11 @@ static const char *bpf_get_work_dir(enum bpf_prog_type type)
                }
        }
 
-       snprintf(bpf_wrk_dir, sizeof(bpf_wrk_dir), "%s/", mnt);
+       ret = snprintf(bpf_wrk_dir, sizeof(bpf_wrk_dir), "%s/", mnt);
+       if (ret < 0 || ret >= sizeof(bpf_wrk_dir)) {
+               mnt = NULL;
+               goto out;
+       }
 
        ret = bpf_gen_hierarchy(bpf_wrk_dir);
        if (ret) {