[<prev] [next>] [day] [month] [year] [list]
Message-Id: <20180530212818.190430-1-tracywwnj@gmail.com>
Date: Wed, 30 May 2018 14:28:18 -0700
From: Wei Wang <weiwan@...gle.com>
To: netdev@...r.kernel.org, John Fastabend <john.fastabend@...il.com>
Cc: Eric Dumazet <edumazet@...gle.com>,
Willem de Bruijn <willemb@...gle.com>,
Wei Wang <weiwan@...gle.com>
Subject: [PATCH bpf] bpf: prevent non-ipv4 socket to be added into sock map
From: Wei Wang <weiwan@...gle.com>
Sock map only supports IPv4 socket proto right now.
If a non-IPv4 socket gets stored in the BPF map, sk->sk_prot gets
overwritten with the v4 tcp prot.
It could potentially cause issues when invoking functions from
sk->sk_prot later in the stack.
Fixes: 174a79ff9515 ("bpf: sockmap with sk redirect support")
Signed-off-by: Wei Wang <weiwan@...gle.com>
Acked-by: Eric Dumazet <edumazet@...gle.com>
Acked-by: Willem de Bruijn <willemb@...gle.com>
---
kernel/bpf/sockmap.c | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/kernel/bpf/sockmap.c b/kernel/bpf/sockmap.c
index 95a84b2f10ce..1984922f99ee 100644
--- a/kernel/bpf/sockmap.c
+++ b/kernel/bpf/sockmap.c
@@ -1873,6 +1873,11 @@ static int sock_map_update_elem(struct bpf_map *map,
return -EOPNOTSUPP;
}
+ if (skops.sk->sk_family != AF_INET) {
+ fput(socket->file);
+ return -EAFNOSUPPORT;
+ }
+
err = sock_map_ctx_update_elem(&skops, map, key, flags);
fput(socket->file);
return err;
--
2.17.1.1185.g55be947832-goog
Powered by blists - more mailing lists