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 <[email protected]>
---
 .../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


Reply via email to