From: Nicolas Dichtel <nicolas.dichtel@6wind.com>
To: sfeldma@gmail.com, netdev@vger.kernel.org
Cc: jiri@resnulli.us, roopa@cumulusnetworks.com, simon.horman@netronome.com
Subject: Re: [PATCH net-next v2 1/5] net: don't reforward packets already forwarded by offload device
Date: Fri, 17 Jul 2015 16:37:55 +0200 [thread overview]
Message-ID: <55A91343.1090208@6wind.com> (raw)
In-Reply-To: <1437033897-8050-2-git-send-email-sfeldma@gmail.com>
Le 16/07/2015 10:04, sfeldma@gmail.com a écrit :
> From: Scott Feldman <sfeldma@gmail.com>
>
> Just before queuing skb for xmit on port, check if skb has been marked by
> switchdev port driver as already fordwarded by device. If so, drop skb. A
> non-zero skb->offload_fwd_mark field is set by the switchdev port
> driver/device on ingress to indicate the skb has already been forwarded by
> the device to egress ports with matching dev->skb_mark. The switchdev port
> driver would assign a non-zero dev->skb_mark for each device port netdev
> during registration, for example.
>
> Signed-off-by: Scott Feldman <sfeldma@gmail.com>
> ---
> include/linux/netdevice.h | 6 ++++++
> include/linux/skbuff.h | 11 ++++++++++-
> net/core/dev.c | 10 ++++++++++
> 3 files changed, 26 insertions(+), 1 deletion(-)
>
> diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
> index 45cfd79..8364f29 100644
> --- a/include/linux/netdevice.h
> +++ b/include/linux/netdevice.h
> @@ -1456,6 +1456,8 @@ enum netdev_priv_flags {
> *
> * @xps_maps: XXX: need comments on this one
> *
> + * @offload_fwd_mark: Offload device fwding mark
> + *
> * @trans_start: Time (in jiffies) of last Tx
> * @watchdog_timeo: Represents the timeout that is used by
> * the watchdog ( see dev_watchdog() )
> @@ -1697,6 +1699,10 @@ struct net_device {
> struct xps_dev_maps __rcu *xps_maps;
> #endif
>
> +#ifdef CONFIG_NET_SWITCHDEV
> + u32 offload_fwd_mark;
> +#endif
> +
> /* These may be needed for future network-power-down code. */
>
> /*
> diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h
> index d6cdd6e..2edcf50 100644
> --- a/include/linux/skbuff.h
> +++ b/include/linux/skbuff.h
> @@ -506,6 +506,7 @@ static inline u32 skb_mstamp_us_delta(const struct skb_mstamp *t1,
> * @no_fcs: Request NIC to treat last 4 bytes as Ethernet FCS
> * @napi_id: id of the NAPI struct this skb came from
> * @secmark: security marking
> + * @offload_fwd_mark: fwding offload mark
> * @mark: Generic packet mark
> * @vlan_proto: vlan encapsulation protocol
> * @vlan_tci: vlan tag control information
> @@ -650,9 +651,17 @@ struct sk_buff {
> unsigned int sender_cpu;
> };
> #endif
> + union {
> #ifdef CONFIG_NETWORK_SECMARK
> - __u32 secmark;
> + __u32 secmark;
> +#endif
> +#ifdef CONFIG_NET_SWITCHDEV
> + __u32 offload_fwd_mark;
> #endif
> + };
> +
> + union {};
> +
Everybody seems to ack. For my knowledge, why did you put this empty union?
Thank you,
Nicolas
next prev parent reply other threads:[~2015-07-17 14:37 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-16 8:04 [PATCH net-next v2 0/5] switchdev: avoid duplicate packet forwarding sfeldma
2015-07-16 8:04 ` [PATCH net-next v2 1/5] net: don't reforward packets already forwarded by offload device sfeldma
2015-07-16 8:22 ` Jiri Pirko
2015-07-17 3:32 ` roopa
2015-07-17 14:37 ` Nicolas Dichtel [this message]
2015-07-17 19:59 ` Scott Feldman
2015-07-16 8:04 ` [PATCH net-next v2 2/5] net: add phys ID compare helper to test if two IDs are the same sfeldma
2015-07-16 8:22 ` Jiri Pirko
2015-07-16 8:04 ` [PATCH net-next v2 3/5] switchdev: add offload_fwd_mark generator helper sfeldma
2015-07-16 8:22 ` Jiri Pirko
2015-07-16 8:04 ` [PATCH net-next v2 4/5] rocker: add offload_fwd_mark support sfeldma
2015-07-16 8:22 ` Jiri Pirko
2015-07-16 8:04 ` [PATCH net-next v2 5/5] switchdev: update documentation for offload_fwd_mark sfeldma
2015-07-16 8:22 ` Jiri Pirko
2015-07-16 8:23 ` [PATCH net-next v2 0/5] switchdev: avoid duplicate packet forwarding Jiri Pirko
2015-07-16 9:33 ` Simon Horman
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=55A91343.1090208@6wind.com \
--to=nicolas.dichtel@6wind.com \
--cc=jiri@resnulli.us \
--cc=netdev@vger.kernel.org \
--cc=roopa@cumulusnetworks.com \
--cc=sfeldma@gmail.com \
--cc=simon.horman@netronome.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).