CVE-2026-53267 PUBLISHED

netfilter: nft_ct: bail out on template ct in get eval

Assigner: Linux
Reserved: 09.06.2026 Published: 25.06.2026 Updated: 25.06.2026

In the Linux kernel, the following vulnerability has been resolved:

netfilter: nft_ct: bail out on template ct in get eval

I noticed this issue while looking at a historic syzbot report 1.

A rule like the one below is enough to trigger the bug:

<pre>table ip t { chain pre { type filter hook prerouting priority raw; ct zone set 1 ct original saddr 1.2.3.4 accept } } </pre>

The first expression attaches a per-cpu template ct via nft_ct_set_zone_eval() (nf_ct_tmpl_alloc -> kzalloc, tuple is all zero, nf_ct_l3num(ct) == 0). The next expression then calls nft_ct_get_eval() on the same skb, treats the template as a real ct and hits the 16-byte memcpy path. With dreg at NFT_REG32_15 this overflows past struct nft_regs on the kernel stack; with smaller dreg values it silently clobbers adjacent registers.

Reject template ct at the eval entry and in nft_ct_get_fast_eval(), mirroring the check nft_ct_set_eval() already has. Additionally, bound the address copy in NFT_CT_SRC / NFT_CT_DST by priv->len instead of by nf_ct_l3num(ct): nf_ct_get_tuple() zeroes the tuple before pkt_to_tuple() fills in only the protocol-relevant leading bytes, so the trailing bytes of tuple->{src,dst}.u3.all are well-defined zero. priv->len is validated at rule load, so the copy size is now bounded by the destination register rather than by an untrusted field on the conntrack.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 45d9bcda21f4c13be75e3571b0f0ef39e77934b5 to af80f78ce984649e1698b841cd33f4fa505ad828 (excl.)
  • affected from 45d9bcda21f4c13be75e3571b0f0ef39e77934b5 to 8470f676eadeab99132708acb1a85915664d6115 (excl.)
  • affected from 45d9bcda21f4c13be75e3571b0f0ef39e77934b5 to f071b0bf078146368d18e4eec386bf2ddc0ab7e0 (excl.)
  • affected from 45d9bcda21f4c13be75e3571b0f0ef39e77934b5 to 2e154b5f53f1b0b490c7b8b02499f90feb86b1d5 (excl.)
  • affected from 45d9bcda21f4c13be75e3571b0f0ef39e77934b5 to 3027ecbdb5fdf9200251c21d4818e4c447ef78e1 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 4.1 is affected
  • unaffected from 0 to 4.1 (excl.)
  • unaffected from 6.6.143 to 6.6.* (incl.)
  • unaffected from 6.12.94 to 6.12.* (incl.)
  • unaffected from 6.18.36 to 6.18.* (incl.)
  • unaffected from 7.0.13 to 7.0.* (incl.)
  • unaffected from 7.1 to * (incl.)

References