kernel: backport mtd support for subpartitions in DT
[oweals/openwrt.git] / target / linux / generic / pending-4.14 / 644-net-pppoe-support-hardware-flow-table-offload.patch
index 9565412c00453148be7eccc108b07d2a59a6f5bb..935b79d1dd58387f4fefca00809a4a4201f4a5ab 100644 (file)
@@ -9,20 +9,23 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
 
 --- a/drivers/net/ppp/ppp_generic.c
 +++ b/drivers/net/ppp/ppp_generic.c
-@@ -56,6 +56,9 @@
+@@ -56,6 +56,11 @@
  #include <net/net_namespace.h>
  #include <net/netns/generic.h>
  
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +#include <linux/netfilter.h>
 +#include <net/netfilter/nf_flow_table.h>
++#endif
 +
  #define PPP_VERSION   "2.4.2"
  
  /*
-@@ -1382,12 +1385,33 @@ static void ppp_dev_priv_destructor(stru
+@@ -1382,12 +1387,37 @@ static void ppp_dev_priv_destructor(stru
                ppp_destroy_interface(ppp);
  }
  
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +static int ppp_flow_offload_check(struct flow_offload_hw_path *path)
 +{
 +      struct ppp *ppp = netdev_priv(path->dev);
@@ -42,6 +45,7 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
 +
 +      return chan->ops->flow_offload_check(chan, path);
 +}
++#endif /* CONFIG_NF_FLOW_TABLE */
 +
  static const struct net_device_ops ppp_netdev_ops = {
        .ndo_init        = ppp_dev_init,
@@ -49,25 +53,31 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
        .ndo_start_xmit  = ppp_start_xmit,
        .ndo_do_ioctl    = ppp_net_ioctl,
        .ndo_get_stats64 = ppp_get_stats64,
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +      .ndo_flow_offload_check = ppp_flow_offload_check,
++#endif
  };
  
  static struct device_type ppp_type = {
 --- a/drivers/net/ppp/pppoe.c
 +++ b/drivers/net/ppp/pppoe.c
-@@ -77,6 +77,8 @@
- #include <linux/file.h>
+@@ -78,6 +78,11 @@
  #include <linux/proc_fs.h>
  #include <linux/seq_file.h>
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +#include <linux/netfilter.h>
 +#include <net/netfilter/nf_flow_table.h>
++#endif
++
  #include <linux/nsproxy.h>
  #include <net/net_namespace.h>
-@@ -970,8 +972,32 @@ static int pppoe_xmit(struct ppp_channel
+ #include <net/netns/generic.h>
+@@ -974,8 +979,36 @@ static int pppoe_xmit(struct ppp_channel
        return __pppoe_xmit(sk, skb);
  }
  
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +static int pppoe_flow_offload_check(struct ppp_channel *chan,
 +                                  struct flow_offload_hw_path *path)
 +{
@@ -90,21 +100,26 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
 +
 +      return 0;
 +}
++#endif /* CONFIG_NF_FLOW_TABLE */
 +
  static const struct ppp_channel_ops pppoe_chan_ops = {
        .start_xmit = pppoe_xmit,
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +      .flow_offload_check = pppoe_flow_offload_check,
++#endif
  };
  
  static int pppoe_recvmsg(struct socket *sock, struct msghdr *m,
 --- a/include/linux/ppp_channel.h
 +++ b/include/linux/ppp_channel.h
-@@ -32,6 +32,8 @@ struct ppp_channel_ops {
+@@ -32,6 +32,10 @@ struct ppp_channel_ops {
        int     (*start_xmit)(struct ppp_channel *, struct sk_buff *);
        /* Handle an ioctl call that has come in via /dev/ppp. */
        int     (*ioctl)(struct ppp_channel *, unsigned int, unsigned long);
 +
++#if IS_ENABLED(CONFIG_NF_FLOW_TABLE)
 +      int     (*flow_offload_check)(struct ppp_channel *, struct flow_offload_hw_path *);
++#endif
  };
  
  struct ppp_channel {