From bad5168e7b1ebe327d5dcc5aef8c52353cbeae5c Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Sat, 2 Aug 2014 18:50:50 +0000 Subject: kernel: add a small xfrm related performance optimization Signed-off-by: Felix Fietkau git-svn-id: svn://svn.openwrt.org/openwrt/trunk@41950 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../generic/patches-3.10/616-net_optimize_xfrm_calls.patch | 13 +++++++++++++ .../generic/patches-3.14/616-net_optimize_xfrm_calls.patch | 13 +++++++++++++ 2 files changed, 26 insertions(+) create mode 100644 target/linux/generic/patches-3.10/616-net_optimize_xfrm_calls.patch create mode 100644 target/linux/generic/patches-3.14/616-net_optimize_xfrm_calls.patch (limited to 'target/linux/generic') diff --git a/target/linux/generic/patches-3.10/616-net_optimize_xfrm_calls.patch b/target/linux/generic/patches-3.10/616-net_optimize_xfrm_calls.patch new file mode 100644 index 0000000000..a21fec70c6 --- /dev/null +++ b/target/linux/generic/patches-3.10/616-net_optimize_xfrm_calls.patch @@ -0,0 +1,13 @@ +--- a/net/netfilter/nf_nat_core.c ++++ b/net/netfilter/nf_nat_core.c +@@ -89,6 +89,9 @@ int nf_xfrm_me_harder(struct sk_buff *sk + struct dst_entry *dst; + int err; + ++ if (!dev_net(skb->dev)->xfrm.policy_count[XFRM_POLICY_OUT]) ++ return 0; ++ + err = xfrm_decode_session(skb, &fl, family); + if (err < 0) + return err; + diff --git a/target/linux/generic/patches-3.14/616-net_optimize_xfrm_calls.patch b/target/linux/generic/patches-3.14/616-net_optimize_xfrm_calls.patch new file mode 100644 index 0000000000..088d32d407 --- /dev/null +++ b/target/linux/generic/patches-3.14/616-net_optimize_xfrm_calls.patch @@ -0,0 +1,13 @@ +--- a/net/netfilter/nf_nat_core.c ++++ b/net/netfilter/nf_nat_core.c +@@ -90,6 +90,9 @@ int nf_xfrm_me_harder(struct sk_buff *sk + struct dst_entry *dst; + int err; + ++ if (!dev_net(skb->dev)->xfrm.policy_count[XFRM_POLICY_OUT]) ++ return 0; ++ + err = xfrm_decode_session(skb, &fl, family); + if (err < 0) + return err; + -- cgit v1.2.3