]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
netfilter: nf_tables: reject immediate NF_QUEUE verdict
authorPablo Neira Ayuso <pablo@netfilter.org>
Tue, 31 Mar 2026 21:08:02 +0000 (23:08 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Wed, 1 Apr 2026 09:55:30 +0000 (11:55 +0200)
nft_queue is always used from userspace nftables to deliver the NF_QUEUE
verdict. Immediately emitting an NF_QUEUE verdict is never used by the
userspace nft tools, so reject immediate NF_QUEUE verdicts.

The arp family does not provide queue support, but such an immediate
verdict is still reachable. Globally reject NF_QUEUE immediate verdicts
to address this issue.

Fixes: f342de4e2f33 ("netfilter: nf_tables: reject QUEUE/DROP verdict parameters")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nf_tables_api.c

index 3922cff1bb3d96da36f048b8d47d20b35941eb47..8c42247a176c7b103ea0f0f8623a2d41b1c4a896 100644 (file)
@@ -11667,8 +11667,6 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,
        switch (data->verdict.code) {
        case NF_ACCEPT:
        case NF_DROP:
-       case NF_QUEUE:
-               break;
        case NFT_CONTINUE:
        case NFT_BREAK:
        case NFT_RETURN:
@@ -11703,6 +11701,11 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,
 
                data->verdict.chain = chain;
                break;
+       case NF_QUEUE:
+               /* The nft_queue expression is used for this purpose, an
+                * immediate NF_QUEUE verdict should not ever be seen here.
+                */
+               fallthrough;
        default:
                return -EINVAL;
        }