Message ID | 7f34bd3ce377d9d89626c2df8fa584e0@208suo.com |
---|---|
State | New |
Headers | show |
Series | selftests/bpf: Fix the address is NULL | expand |
On 6/14/23 12:42 AM, wuyonggang001@208suo.com wrote: > Fix the following coccicheck error: > > tools/testing/selftests/bpf/progs/test_ksyms_weak.c:53:6-20: ERROR: test > of a variable/field address I didn't see clang/gcc compiler warns about this. Maybe need some additional flags beyond what current selftest/bpf already has in order to trigger this warning? If you feel this warning has some merit, could you propose it to gcc/llvm community? > > Signed-off-by: Yonggang Wu <wuyonggang001@208suo.com> > --- > tools/testing/selftests/bpf/progs/test_ksyms_weak.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > index d00268c91e19..768a4d6ee6f5 100644 > --- a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > +++ b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > @@ -50,7 +50,7 @@ int pass_handler(const void *ctx) > /* tests non-existent symbols. */ > out__non_existent_typed = (__u64)&bpf_link_fops2; > > - if (&bpf_link_fops2) /* can't happen */ > + if (&bpf_link_fops2 != NULL) /* can't happen */ > out__non_existent_typed = > (__u64)bpf_per_cpu_ptr(&bpf_link_fops2, 0); > > if (!bpf_ksym_exists(bpf_task_acquire)) >
On Wed, Jun 14, 2023 at 7:09 AM Yonghong Song <yhs@meta.com> wrote: > > > > On 6/14/23 12:42 AM, wuyonggang001@208suo.com wrote: > > Fix the following coccicheck error: > > > > tools/testing/selftests/bpf/progs/test_ksyms_weak.c:53:6-20: ERROR: test > > of a variable/field address > > I didn't see clang/gcc compiler warns about this. Maybe need some > additional flags beyond what current selftest/bpf already has > in order to trigger this warning? > If you feel this warning has some merit, could you propose > it to gcc/llvm community? bpf_link_fops2 is a weak symbol, this check is totally valid and reasonable. There are two problems here, though: a) coccicheck shouldn't warn about "test of a variable/field address" for weak symbols, because they can be NULL. b) this patch is not even fixing that warning, it does a no-op change from implicit non-NULL check to explicit non-NULL check. And the former is actually the preferred style. So this patch is doubly wrong. > > > > > Signed-off-by: Yonggang Wu <wuyonggang001@208suo.com> > > --- > > tools/testing/selftests/bpf/progs/test_ksyms_weak.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > > b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > > index d00268c91e19..768a4d6ee6f5 100644 > > --- a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > > +++ b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c > > @@ -50,7 +50,7 @@ int pass_handler(const void *ctx) > > /* tests non-existent symbols. */ > > out__non_existent_typed = (__u64)&bpf_link_fops2; > > > > - if (&bpf_link_fops2) /* can't happen */ > > + if (&bpf_link_fops2 != NULL) /* can't happen */ > > out__non_existent_typed = > > (__u64)bpf_per_cpu_ptr(&bpf_link_fops2, 0); > > > > if (!bpf_ksym_exists(bpf_task_acquire)) > >
diff --git a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c index d00268c91e19..768a4d6ee6f5 100644 --- a/tools/testing/selftests/bpf/progs/test_ksyms_weak.c +++ b/tools/testing/selftests/bpf/progs/test_ksyms_weak.c @@ -50,7 +50,7 @@ int pass_handler(const void *ctx) /* tests non-existent symbols. */ out__non_existent_typed = (__u64)&bpf_link_fops2; - if (&bpf_link_fops2) /* can't happen */ + if (&bpf_link_fops2 != NULL) /* can't happen */ out__non_existent_typed = (__u64)bpf_per_cpu_ptr(&bpf_link_fops2, 0);
Fix the following coccicheck error: tools/testing/selftests/bpf/progs/test_ksyms_weak.c:53:6-20: ERROR: test of a variable/field address Signed-off-by: Yonggang Wu <wuyonggang001@208suo.com> --- tools/testing/selftests/bpf/progs/test_ksyms_weak.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) if (!bpf_ksym_exists(bpf_task_acquire))