[openwrt/openwrt] kernel: fix offloading connections with SNAT + DNAT

LEDE Commits lede-commits at lists.infradead.org
Fri Mar 23 11:18:12 PDT 2018


nbd pushed a commit to openwrt/openwrt.git, branch master:
https://git.lede-project.org/99d511dcd39c3ce56d424c56e4096c7fc59590bb

commit 99d511dcd39c3ce56d424c56e4096c7fc59590bb
Author: Felix Fietkau <nbd at nbd.name>
AuthorDate: Fri Mar 23 19:15:58 2018 +0100

    kernel: fix offloading connections with SNAT + DNAT
    
    Signed-off-by: Felix Fietkau <nbd at nbd.name>
---
 ...f_flow_table-fix-offloading-connections-w.patch | 23 ++++++++++++++++++++++
 1 file changed, 23 insertions(+)

diff --git a/target/linux/generic/backport-4.14/368-netfilter-nf_flow_table-fix-offloading-connections-w.patch b/target/linux/generic/backport-4.14/368-netfilter-nf_flow_table-fix-offloading-connections-w.patch
new file mode 100644
index 0000000..28c3817
--- /dev/null
+++ b/target/linux/generic/backport-4.14/368-netfilter-nf_flow_table-fix-offloading-connections-w.patch
@@ -0,0 +1,23 @@
+From: Felix Fietkau <nbd at nbd.name>
+Date: Fri, 23 Mar 2018 19:12:30 +0100
+Subject: [PATCH] netfilter: nf_flow_table: fix offloading connections with
+ SNAT+DNAT
+
+Pass all NAT types to the flow offload struct, otherwise parts of the
+address/port pair do not get translated properly, causing connection
+stalls
+
+Signed-off-by: Felix Fietkau <nbd at nbd.name>
+---
+
+--- a/net/netfilter/nf_flow_table_core.c
++++ b/net/netfilter/nf_flow_table_core.c
+@@ -83,7 +83,7 @@ flow_offload_alloc(struct nf_conn *ct, s
+ 
+ 	if (ct->status & IPS_SRC_NAT)
+ 		flow->flags |= FLOW_OFFLOAD_SNAT;
+-	else if (ct->status & IPS_DST_NAT)
++	if (ct->status & IPS_DST_NAT)
+ 		flow->flags |= FLOW_OFFLOAD_DNAT;
+ 
+ 	return flow;



More information about the lede-commits mailing list