Explorar el Código

bpf: Verify flags in bpf_fib_lookup

Verify flags argument contains only known flags. Allows programs to probe
for support as more are added.

Signed-off-by: David Ahern <dsahern@gmail.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
David Ahern hace 7 años
padre
commit
9ce64f192d
Se han modificado 1 ficheros con 6 adiciones y 0 borrados
  1. 6 0
      net/core/filter.c

+ 6 - 0
net/core/filter.c

@@ -4270,6 +4270,9 @@ BPF_CALL_4(bpf_xdp_fib_lookup, struct xdp_buff *, ctx,
 	if (plen < sizeof(*params))
 	if (plen < sizeof(*params))
 		return -EINVAL;
 		return -EINVAL;
 
 
+	if (flags & ~(BPF_FIB_LOOKUP_DIRECT | BPF_FIB_LOOKUP_OUTPUT))
+		return -EINVAL;
+
 	switch (params->family) {
 	switch (params->family) {
 #if IS_ENABLED(CONFIG_INET)
 #if IS_ENABLED(CONFIG_INET)
 	case AF_INET:
 	case AF_INET:
@@ -4304,6 +4307,9 @@ BPF_CALL_4(bpf_skb_fib_lookup, struct sk_buff *, skb,
 	if (plen < sizeof(*params))
 	if (plen < sizeof(*params))
 		return -EINVAL;
 		return -EINVAL;
 
 
+	if (flags & ~(BPF_FIB_LOOKUP_DIRECT | BPF_FIB_LOOKUP_OUTPUT))
+		return -EINVAL;
+
 	switch (params->family) {
 	switch (params->family) {
 #if IS_ENABLED(CONFIG_INET)
 #if IS_ENABLED(CONFIG_INET)
 	case AF_INET:
 	case AF_INET: