.../testing/selftests/bpf/progs/bpf_iter_netlink.c | 13 ++----------- 1 file changed, 2 insertions(+), 11 deletions(-)
Use direct field access instead of bpf_probe_read_kernel() for
nlk->groups[0] and inode->i_ino, and clean up related code.
Removes obsolete FIXME comments and unused variable.
Signed-off-by: Suchit Karunakaran <suchitkarunakaran@gmail.com>
---
.../testing/selftests/bpf/progs/bpf_iter_netlink.c | 13 ++-----------
1 file changed, 2 insertions(+), 11 deletions(-)
diff --git a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
index 00b2ceae81fb..5930bf8899d2 100644
--- a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
+++ b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
@@ -17,7 +17,6 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
struct seq_file *seq = ctx->meta->seq;
struct netlink_sock *nlk = ctx->sk;
unsigned long group, ino;
- struct inode *inode;
struct socket *sk;
struct sock *s;
@@ -35,10 +34,7 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
if (!nlk->groups) {
group = 0;
} else {
- /* FIXME: temporary use bpf_probe_read_kernel here, needs
- * verifier support to do direct access.
- */
- bpf_probe_read_kernel(&group, sizeof(group), &nlk->groups[0]);
+ group = nlk->groups[0];
}
BPF_SEQ_PRINTF(seq, "%-10u %08x %-8d %-8d %-5d %-8d ",
nlk->portid, (u32)group,
@@ -50,12 +46,7 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
if (!sk) {
ino = 0;
} else {
- /* FIXME: container_of inside SOCK_INODE has a forced
- * type conversion, and direct access cannot be used
- * with current verifier.
- */
- inode = SOCK_INODE(sk);
- bpf_probe_read_kernel(&ino, sizeof(ino), &inode->i_ino);
+ ino = SOCK_INODE(sk)->i_ino;
}
BPF_SEQ_PRINTF(seq, "%-8u %-8lu\n", s->sk_drops.counter, ino);
--
2.53.0
On Wed, Apr 22, 2026 at 11:38 AM Suchit Karunakaran
<suchitkarunakaran@gmail.com> wrote:
>
> Use direct field access instead of bpf_probe_read_kernel() for
> nlk->groups[0] and inode->i_ino, and clean up related code.
>
> Removes obsolete FIXME comments and unused variable.
>
> Signed-off-by: Suchit Karunakaran <suchitkarunakaran@gmail.com>
> ---
> .../testing/selftests/bpf/progs/bpf_iter_netlink.c | 13 ++-----------
> 1 file changed, 2 insertions(+), 11 deletions(-)
>
> diff --git a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> index 00b2ceae81fb..5930bf8899d2 100644
> --- a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> +++ b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> @@ -17,7 +17,6 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
> struct seq_file *seq = ctx->meta->seq;
> struct netlink_sock *nlk = ctx->sk;
> unsigned long group, ino;
> - struct inode *inode;
> struct socket *sk;
> struct sock *s;
>
> @@ -35,10 +34,7 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
> if (!nlk->groups) {
> group = 0;
> } else {
> - /* FIXME: temporary use bpf_probe_read_kernel here, needs
> - * verifier support to do direct access.
> - */
> - bpf_probe_read_kernel(&group, sizeof(group), &nlk->groups[0]);
Please stop sending patches to remove TODO and FIXME.
pw-bot: cr
On Thu, 23 Apr 2026 at 02:51, Alexei Starovoitov
<alexei.starovoitov@gmail.com> wrote:
>
> On Wed, Apr 22, 2026 at 11:38 AM Suchit Karunakaran
> <suchitkarunakaran@gmail.com> wrote:
> >
> > Use direct field access instead of bpf_probe_read_kernel() for
> > nlk->groups[0] and inode->i_ino, and clean up related code.
> >
> > Removes obsolete FIXME comments and unused variable.
> >
> > Signed-off-by: Suchit Karunakaran <suchitkarunakaran@gmail.com>
> > ---
> > .../testing/selftests/bpf/progs/bpf_iter_netlink.c | 13 ++-----------
> > 1 file changed, 2 insertions(+), 11 deletions(-)
> >
> > diff --git a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> > index 00b2ceae81fb..5930bf8899d2 100644
> > --- a/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> > +++ b/tools/testing/selftests/bpf/progs/bpf_iter_netlink.c
> > @@ -17,7 +17,6 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
> > struct seq_file *seq = ctx->meta->seq;
> > struct netlink_sock *nlk = ctx->sk;
> > unsigned long group, ino;
> > - struct inode *inode;
> > struct socket *sk;
> > struct sock *s;
> >
> > @@ -35,10 +34,7 @@ int dump_netlink(struct bpf_iter__netlink *ctx)
> > if (!nlk->groups) {
> > group = 0;
> > } else {
> > - /* FIXME: temporary use bpf_probe_read_kernel here, needs
> > - * verifier support to do direct access.
> > - */
> > - bpf_probe_read_kernel(&group, sizeof(group), &nlk->groups[0]);
>
> Please stop sending patches to remove TODO and FIXME.
>
> pw-bot: cr
Sorry about that. I'll test it more rigorously next time and ensure
the patch is sensible.
© 2016 - 2026 Red Hat, Inc.