netfilter: nft_socket: Break evaluation if no socket found
authorMáté Eckl <ecklm94@gmail.com>
Thu, 12 Jul 2018 15:18:46 +0000 (17:18 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Wed, 18 Jul 2018 09:26:51 +0000 (11:26 +0200)
Actual implementation stores 0 in the destination register if no socket
is found by the lookup, but that is not intentional as it is not really
a value of any socket metadata.

This patch fixes this and breaks rule evaluation in this case.

Fixes: 554ced0a6e29 ("netfilter: nf_tables: add support for native socket matching")
Signed-off-by: Máté Eckl <ecklm94@gmail.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nft_socket.c

index e43c193..622ac20 100644 (file)
@@ -43,7 +43,7 @@ static void nft_socket_eval(const struct nft_expr *expr,
                }
 
        if (!sk) {
-               nft_reg_store8(dest, 0);
+               regs->verdict.code = NFT_BREAK;
                return;
        }