lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <ec094a06-e61b-0138-d258-d1952934f6b2@intel.com>
Date: Wed, 2 Aug 2023 12:42:51 -0700
From: "Nambiar, Amritha" <amritha.nambiar@...el.com>
To: Jakub Kicinski <kuba@...nel.org>, <ast@...nel.org>
CC: <netdev@...r.kernel.org>, <bpf@...r.kernel.org>, <hawk@...nel.org>,
	<aleksander.lobakin@...el.com>, <mst@...hat.com>, <jasowang@...hat.com>,
	<xuanzhuo@...ux.alibaba.com>, <daniel@...earbox.net>, <andrii@...nel.org>,
	<martin.lau@...ux.dev>, <song@...nel.org>, <yonghong.song@...ux.dev>,
	<john.fastabend@...il.com>, <kpsingh@...nel.org>, <sdf@...gle.com>,
	<haoluo@...gle.com>, <jolsa@...nel.org>, <bjorn@...nel.org>,
	<magnus.karlsson@...el.com>, <maciej.fijalkowski@...el.com>,
	<jonathan.lemon@...il.com>, <gregkh@...uxfoundation.org>,
	<wangyufen@...wei.com>, <virtualization@...ts.linux-foundation.org>
Subject: Re: [PATCH bpf-next 2/3] net: move struct netdev_rx_queue out of
 netdevice.h

On 8/1/2023 5:32 PM, Jakub Kicinski wrote:
> struct netdev_rx_queue is touched in only a few places
> and having it defined in netdevice.h brings in the dependency
> on xdp.h, because struct xdp_rxq_info gets embedded in
> struct netdev_rx_queue.
> 
> In prep for removal of xdp.h from netdevice.h move all
> the netdev_rx_queue stuff to a new header.
> 
> We could technically break the new header up to avoid
> the sysfs.h include but it's so rarely included it
> doesn't seem to be worth it at this point.
> 
> Signed-off-by: Jakub Kicinski <kuba@...nel.org>
> ---
> CC: mst@...hat.com
> CC: jasowang@...hat.com
> CC: xuanzhuo@...ux.alibaba.com
> CC: ast@...nel.org
> CC: daniel@...earbox.net
> CC: andrii@...nel.org
> CC: martin.lau@...ux.dev
> CC: song@...nel.org
> CC: yonghong.song@...ux.dev
> CC: john.fastabend@...il.com
> CC: kpsingh@...nel.org
> CC: sdf@...gle.com
> CC: haoluo@...gle.com
> CC: jolsa@...nel.org
> CC: bjorn@...nel.org
> CC: magnus.karlsson@...el.com
> CC: maciej.fijalkowski@...el.com
> CC: jonathan.lemon@...il.com
> CC: hawk@...nel.org
> CC: gregkh@...uxfoundation.org
> CC: wangyufen@...wei.com
> CC: virtualization@...ts.linux-foundation.org
> CC: bpf@...r.kernel.org
> ---
>   drivers/net/virtio_net.c      |  1 +
>   include/linux/netdevice.h     | 44 -----------------------------
>   include/net/netdev_rx_queue.h | 53 +++++++++++++++++++++++++++++++++++
>   net/bpf/test_run.c            |  1 +
>   net/core/dev.c                |  1 +
>   net/core/net-sysfs.c          |  1 +
>   net/xdp/xsk.c                 |  1 +
>   7 files changed, 58 insertions(+), 44 deletions(-)
>   create mode 100644 include/net/netdev_rx_queue.h
> 

Reviewed-by: Amritha Nambiar <amritha.nambiar@...el.com>

> diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c
> index 0db14f6b87d3..5bcfd69333ea 100644
> --- a/drivers/net/virtio_net.c
> +++ b/drivers/net/virtio_net.c
> @@ -22,6 +22,7 @@
>   #include <net/route.h>
>   #include <net/xdp.h>
>   #include <net/net_failover.h>
> +#include <net/netdev_rx_queue.h>
>   
>   static int napi_weight = NAPI_POLL_WEIGHT;
>   module_param(napi_weight, int, 0444);
> diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
> index 3800d0479698..5563c8a210b5 100644
> --- a/include/linux/netdevice.h
> +++ b/include/linux/netdevice.h
> @@ -782,32 +782,6 @@ bool rps_may_expire_flow(struct net_device *dev, u16 rxq_index, u32 flow_id,
>   #endif
>   #endif /* CONFIG_RPS */
>   
> -/* This structure contains an instance of an RX queue. */
> -struct netdev_rx_queue {
> -	struct xdp_rxq_info		xdp_rxq;
> -#ifdef CONFIG_RPS
> -	struct rps_map __rcu		*rps_map;
> -	struct rps_dev_flow_table __rcu	*rps_flow_table;
> -#endif
> -	struct kobject			kobj;
> -	struct net_device		*dev;
> -	netdevice_tracker		dev_tracker;
> -
> -#ifdef CONFIG_XDP_SOCKETS
> -	struct xsk_buff_pool            *pool;
> -#endif
> -} ____cacheline_aligned_in_smp;
> -
> -/*
> - * RX queue sysfs structures and functions.
> - */
> -struct rx_queue_attribute {
> -	struct attribute attr;
> -	ssize_t (*show)(struct netdev_rx_queue *queue, char *buf);
> -	ssize_t (*store)(struct netdev_rx_queue *queue,
> -			 const char *buf, size_t len);
> -};
> -
>   /* XPS map type and offset of the xps map within net_device->xps_maps[]. */
>   enum xps_map_type {
>   	XPS_CPUS = 0,
> @@ -3828,24 +3802,6 @@ static inline int netif_set_real_num_rx_queues(struct net_device *dev,
>   int netif_set_real_num_queues(struct net_device *dev,
>   			      unsigned int txq, unsigned int rxq);
>   
> -static inline struct netdev_rx_queue *
> -__netif_get_rx_queue(struct net_device *dev, unsigned int rxq)
> -{
> -	return dev->_rx + rxq;
> -}
> -
> -#ifdef CONFIG_SYSFS
> -static inline unsigned int get_netdev_rx_queue_index(
> -		struct netdev_rx_queue *queue)
> -{
> -	struct net_device *dev = queue->dev;
> -	int index = queue - dev->_rx;
> -
> -	BUG_ON(index >= dev->num_rx_queues);
> -	return index;
> -}
> -#endif
> -
>   int netif_get_num_default_rss_queues(void);
>   
>   void dev_kfree_skb_irq_reason(struct sk_buff *skb, enum skb_drop_reason reason);
> diff --git a/include/net/netdev_rx_queue.h b/include/net/netdev_rx_queue.h
> new file mode 100644
> index 000000000000..cdcafb30d437
> --- /dev/null
> +++ b/include/net/netdev_rx_queue.h
> @@ -0,0 +1,53 @@
> +/* SPDX-License-Identifier: GPL-2.0 */
> +#ifndef _LINUX_NETDEV_RX_QUEUE_H
> +#define _LINUX_NETDEV_RX_QUEUE_H
> +
> +#include <linux/kobject.h>
> +#include <linux/netdevice.h>
> +#include <linux/sysfs.h>
> +#include <net/xdp.h>
> +
> +/* This structure contains an instance of an RX queue. */
> +struct netdev_rx_queue {
> +	struct xdp_rxq_info		xdp_rxq;
> +#ifdef CONFIG_RPS
> +	struct rps_map __rcu		*rps_map;
> +	struct rps_dev_flow_table __rcu	*rps_flow_table;
> +#endif
> +	struct kobject			kobj;
> +	struct net_device		*dev;
> +	netdevice_tracker		dev_tracker;
> +
> +#ifdef CONFIG_XDP_SOCKETS
> +	struct xsk_buff_pool            *pool;
> +#endif
> +} ____cacheline_aligned_in_smp;
> +
> +/*
> + * RX queue sysfs structures and functions.
> + */
> +struct rx_queue_attribute {
> +	struct attribute attr;
> +	ssize_t (*show)(struct netdev_rx_queue *queue, char *buf);
> +	ssize_t (*store)(struct netdev_rx_queue *queue,
> +			 const char *buf, size_t len);
> +};
> +
> +static inline struct netdev_rx_queue *
> +__netif_get_rx_queue(struct net_device *dev, unsigned int rxq)
> +{
> +	return dev->_rx + rxq;
> +}
> +
> +#ifdef CONFIG_SYSFS
> +static inline unsigned int
> +get_netdev_rx_queue_index(struct netdev_rx_queue *queue)
> +{
> +	struct net_device *dev = queue->dev;
> +	int index = queue - dev->_rx;
> +
> +	BUG_ON(index >= dev->num_rx_queues);
> +	return index;
> +}
> +#endif
> +#endif
> diff --git a/net/bpf/test_run.c b/net/bpf/test_run.c
> index 7d47f53f20c1..4ed68141d9a3 100644
> --- a/net/bpf/test_run.c
> +++ b/net/bpf/test_run.c
> @@ -21,6 +21,7 @@
>   #include <linux/sock_diag.h>
>   #include <linux/netfilter.h>
>   #include <net/xdp.h>
> +#include <net/netdev_rx_queue.h>
>   #include <net/netfilter/nf_bpf_link.h>
>   
>   #define CREATE_TRACE_POINTS
> diff --git a/net/core/dev.c b/net/core/dev.c
> index 8e7d0cb540cd..1fee2372b633 100644
> --- a/net/core/dev.c
> +++ b/net/core/dev.c
> @@ -151,6 +151,7 @@
>   #include <linux/pm_runtime.h>
>   #include <linux/prandom.h>
>   #include <linux/once_lite.h>
> +#include <net/netdev_rx_queue.h>
>   
>   #include "dev.h"
>   #include "net-sysfs.h"
> diff --git a/net/core/net-sysfs.c b/net/core/net-sysfs.c
> index 15e3f4606b5f..fccaa5bac0ed 100644
> --- a/net/core/net-sysfs.c
> +++ b/net/core/net-sysfs.c
> @@ -23,6 +23,7 @@
>   #include <linux/of.h>
>   #include <linux/of_net.h>
>   #include <linux/cpu.h>
> +#include <net/netdev_rx_queue.h>
>   
>   #include "dev.h"
>   #include "net-sysfs.h"
> diff --git a/net/xdp/xsk.c b/net/xdp/xsk.c
> index 4f1e0599146e..82aaec1b079f 100644
> --- a/net/xdp/xsk.c
> +++ b/net/xdp/xsk.c
> @@ -25,6 +25,7 @@
>   #include <linux/vmalloc.h>
>   #include <net/xdp_sock_drv.h>
>   #include <net/busy_poll.h>
> +#include <net/netdev_rx_queue.h>
>   #include <net/xdp.h>
>   
>   #include "xsk_queue.h"

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ