diff options
author | Felix Fietkau <nbd@nbd.name> | 2018-06-14 11:25:23 +0200 |
---|---|---|
committer | Felix Fietkau <nbd@nbd.name> | 2018-06-14 11:25:24 +0200 |
commit | 510151537536f539a668b0f8fb9da3719647e52d (patch) | |
tree | 9ebeebe634c820a92209d6c81a9352dcc1dc3175 /target/linux/generic/backport-4.14 | |
parent | 68ab89854fede80ab6a4279204462d6b898a653f (diff) | |
download | upstream-510151537536f539a668b0f8fb9da3719647e52d.tar.gz upstream-510151537536f539a668b0f8fb9da3719647e52d.tar.bz2 upstream-510151537536f539a668b0f8fb9da3719647e52d.zip |
kernel: fix conntrack fixup of offloaded flows on timeout
Fixes excessively long conntrack timeout of short lived connections
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Diffstat (limited to 'target/linux/generic/backport-4.14')
-rw-r--r-- | target/linux/generic/backport-4.14/371-netfilter-nf_flow_table-fix-up-ct-state-of-flows-aft.patch | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/target/linux/generic/backport-4.14/371-netfilter-nf_flow_table-fix-up-ct-state-of-flows-aft.patch b/target/linux/generic/backport-4.14/371-netfilter-nf_flow_table-fix-up-ct-state-of-flows-aft.patch new file mode 100644 index 0000000000..fb14a284ae --- /dev/null +++ b/target/linux/generic/backport-4.14/371-netfilter-nf_flow_table-fix-up-ct-state-of-flows-aft.patch @@ -0,0 +1,24 @@ +From: Felix Fietkau <nbd@nbd.name> +Date: Thu, 14 Jun 2018 11:20:09 +0200 +Subject: [PATCH] netfilter: nf_flow_table: fix up ct state of flows after + timeout + +If a connection simply times out instead of being torn down, it is left +active with a long timeout. Fix this by calling flow_offload_fixup_ct_state +here as well. + +Signed-off-by: Felix Fietkau <nbd@nbd.name> +--- + +--- a/net/netfilter/nf_flow_table_core.c ++++ b/net/netfilter/nf_flow_table_core.c +@@ -233,6 +233,9 @@ static void flow_offload_del(struct nf_f + e = container_of(flow, struct flow_offload_entry, flow); + clear_bit(IPS_OFFLOAD_BIT, &e->ct->status); + ++ if (!(flow->flags & FLOW_OFFLOAD_TEARDOWN)) ++ flow_offload_fixup_ct_state(e->ct); ++ + flow_offload_free(flow); + } + |