mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-10-22 15:03:53 +02:00
net: move HDS config from ethtool state
Separate the HDS config from the ethtool state struct. The HDS config contains just simple parameters, not state. Having it as a separate struct will make it easier to clone / copy and also long term potentially make it per-queue. Reviewed-by: Michael Chan <michael.chan@broadcom.com> Link: https://patch.msgid.link/20250119020518.1962249-2-kuba@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
e81fdf7078
commit
3c836451ca
|
@ -4610,7 +4610,7 @@ void bnxt_set_tpa_flags(struct bnxt *bp)
|
|||
static void bnxt_init_ring_params(struct bnxt *bp)
|
||||
{
|
||||
bp->rx_copybreak = BNXT_DEFAULT_RX_COPYBREAK;
|
||||
bp->dev->ethtool->hds_thresh = BNXT_DEFAULT_RX_COPYBREAK;
|
||||
bp->dev->cfg->hds_thresh = BNXT_DEFAULT_RX_COPYBREAK;
|
||||
}
|
||||
|
||||
/* bp->rx_ring_size, bp->tx_ring_size, dev->mtu, BNXT_FLAG_{G|L}RO flags must
|
||||
|
@ -6585,7 +6585,7 @@ static void bnxt_hwrm_update_rss_hash_cfg(struct bnxt *bp)
|
|||
|
||||
static int bnxt_hwrm_vnic_set_hds(struct bnxt *bp, struct bnxt_vnic_info *vnic)
|
||||
{
|
||||
u16 hds_thresh = (u16)bp->dev->ethtool->hds_thresh;
|
||||
u16 hds_thresh = (u16)bp->dev->cfg->hds_thresh;
|
||||
struct hwrm_vnic_plcmodes_cfg_input *req;
|
||||
int rc;
|
||||
|
||||
|
|
|
@ -24,6 +24,7 @@
|
|||
#include <linux/ptp_clock_kernel.h>
|
||||
#include <linux/net_tstamp.h>
|
||||
#include <linux/timecounter.h>
|
||||
#include <net/netdev_queues.h>
|
||||
#include <net/netlink.h>
|
||||
#include "bnxt_hsi.h"
|
||||
#include "bnxt.h"
|
||||
|
@ -834,7 +835,7 @@ static void bnxt_get_ringparam(struct net_device *dev,
|
|||
ering->rx_jumbo_pending = bp->rx_agg_ring_size;
|
||||
ering->tx_pending = bp->tx_ring_size;
|
||||
|
||||
kernel_ering->hds_thresh = dev->ethtool->hds_thresh;
|
||||
kernel_ering->hds_thresh = dev->cfg->hds_thresh;
|
||||
kernel_ering->hds_thresh_max = BNXT_HDS_THRESHOLD_MAX;
|
||||
}
|
||||
|
||||
|
@ -852,7 +853,7 @@ static int bnxt_set_ringparam(struct net_device *dev,
|
|||
(ering->tx_pending < BNXT_MIN_TX_DESC_CNT))
|
||||
return -EINVAL;
|
||||
|
||||
hds_config_mod = tcp_data_split != dev->ethtool->hds_config;
|
||||
hds_config_mod = tcp_data_split != dev->cfg->hds_config;
|
||||
if (tcp_data_split == ETHTOOL_TCP_DATA_SPLIT_DISABLED && hds_config_mod)
|
||||
return -EINVAL;
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
|
||||
#include <linux/debugfs.h>
|
||||
#include <linux/random.h>
|
||||
#include <net/netdev_queues.h>
|
||||
|
||||
#include "netdevsim.h"
|
||||
|
||||
|
@ -71,8 +72,8 @@ static void nsim_get_ringparam(struct net_device *dev,
|
|||
struct netdevsim *ns = netdev_priv(dev);
|
||||
|
||||
memcpy(ring, &ns->ethtool.ring, sizeof(ns->ethtool.ring));
|
||||
kernel_ring->tcp_data_split = dev->ethtool->hds_config;
|
||||
kernel_ring->hds_thresh = dev->ethtool->hds_thresh;
|
||||
kernel_ring->tcp_data_split = dev->cfg->hds_config;
|
||||
kernel_ring->hds_thresh = dev->cfg->hds_thresh;
|
||||
kernel_ring->hds_thresh_max = NSIM_HDS_THRESHOLD_MAX;
|
||||
|
||||
if (kernel_ring->tcp_data_split == ETHTOOL_TCP_DATA_SPLIT_UNKNOWN)
|
||||
|
@ -190,8 +191,8 @@ static void nsim_ethtool_ring_init(struct netdevsim *ns)
|
|||
ns->ethtool.ring.rx_mini_max_pending = 4096;
|
||||
ns->ethtool.ring.tx_max_pending = 4096;
|
||||
|
||||
ns->netdev->ethtool->hds_config = ETHTOOL_TCP_DATA_SPLIT_UNKNOWN;
|
||||
ns->netdev->ethtool->hds_thresh = 0;
|
||||
ns->netdev->cfg->hds_config = ETHTOOL_TCP_DATA_SPLIT_UNKNOWN;
|
||||
ns->netdev->cfg->hds_thresh = 0;
|
||||
}
|
||||
|
||||
void nsim_ethtool_init(struct netdevsim *ns)
|
||||
|
|
|
@ -55,10 +55,10 @@ static int nsim_forward_skb(struct net_device *dev, struct sk_buff *skb,
|
|||
static netdev_tx_t nsim_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
{
|
||||
struct netdevsim *ns = netdev_priv(dev);
|
||||
struct ethtool_netdev_state *ethtool;
|
||||
struct net_device *peer_dev;
|
||||
unsigned int len = skb->len;
|
||||
struct netdevsim *peer_ns;
|
||||
struct netdev_config *cfg;
|
||||
struct nsim_rq *rq;
|
||||
int rxq;
|
||||
|
||||
|
@ -76,11 +76,11 @@ static netdev_tx_t nsim_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||
rxq = rxq % peer_dev->num_rx_queues;
|
||||
rq = peer_ns->rq[rxq];
|
||||
|
||||
ethtool = peer_dev->ethtool;
|
||||
cfg = peer_dev->cfg;
|
||||
if (skb_is_nonlinear(skb) &&
|
||||
(ethtool->hds_config != ETHTOOL_TCP_DATA_SPLIT_ENABLED ||
|
||||
(ethtool->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
ethtool->hds_thresh > len)))
|
||||
(cfg->hds_config != ETHTOOL_TCP_DATA_SPLIT_ENABLED ||
|
||||
(cfg->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
cfg->hds_thresh > len)))
|
||||
skb_linearize(skb);
|
||||
|
||||
skb_tx_timestamp(skb);
|
||||
|
|
|
@ -1171,16 +1171,12 @@ int ethtool_virtdev_set_link_ksettings(struct net_device *dev,
|
|||
* @rss_ctx: XArray of custom RSS contexts
|
||||
* @rss_lock: Protects entries in @rss_ctx. May be taken from
|
||||
* within RTNL.
|
||||
* @hds_thresh: HDS Threshold value.
|
||||
* @hds_config: HDS value from userspace.
|
||||
* @wol_enabled: Wake-on-LAN is enabled
|
||||
* @module_fw_flash_in_progress: Module firmware flashing is in progress.
|
||||
*/
|
||||
struct ethtool_netdev_state {
|
||||
struct xarray rss_ctx;
|
||||
struct mutex rss_lock;
|
||||
u32 hds_thresh;
|
||||
u8 hds_config;
|
||||
unsigned wol_enabled:1;
|
||||
unsigned module_fw_flash_in_progress:1;
|
||||
};
|
||||
|
|
|
@ -63,6 +63,7 @@ struct dsa_port;
|
|||
struct ip_tunnel_parm_kern;
|
||||
struct macsec_context;
|
||||
struct macsec_ops;
|
||||
struct netdev_config;
|
||||
struct netdev_name_node;
|
||||
struct sd_flow_limit;
|
||||
struct sfp_bus;
|
||||
|
@ -2410,6 +2411,8 @@ struct net_device {
|
|||
const struct udp_tunnel_nic_info *udp_tunnel_nic_info;
|
||||
struct udp_tunnel_nic *udp_tunnel_nic;
|
||||
|
||||
/** @cfg: net_device queue-related configuration */
|
||||
struct netdev_config *cfg;
|
||||
struct ethtool_netdev_state *ethtool;
|
||||
|
||||
/* protected by rtnl_lock */
|
||||
|
|
|
@ -4,6 +4,16 @@
|
|||
|
||||
#include <linux/netdevice.h>
|
||||
|
||||
/**
|
||||
* struct netdev_config - queue-related configuration for a netdev
|
||||
* @hds_thresh: HDS Threshold value.
|
||||
* @hds_config: HDS value from userspace.
|
||||
*/
|
||||
struct netdev_config {
|
||||
u32 hds_thresh;
|
||||
u8 hds_config;
|
||||
};
|
||||
|
||||
/* See the netdev.yaml spec for definition of each statistic */
|
||||
struct netdev_queue_stats_rx {
|
||||
u64 bytes;
|
||||
|
|
|
@ -106,6 +106,7 @@
|
|||
#include <net/dst.h>
|
||||
#include <net/dst_metadata.h>
|
||||
#include <net/gro.h>
|
||||
#include <net/netdev_queues.h>
|
||||
#include <net/pkt_sched.h>
|
||||
#include <net/pkt_cls.h>
|
||||
#include <net/checksum.h>
|
||||
|
@ -9719,7 +9720,7 @@ int dev_xdp_propagate(struct net_device *dev, struct netdev_bpf *bpf)
|
|||
if (!dev->netdev_ops->ndo_bpf)
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
if (dev->ethtool->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
if (dev->cfg->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
bpf->command == XDP_SETUP_PROG &&
|
||||
bpf->prog && !bpf->prog->aux->xdp_has_frags) {
|
||||
NL_SET_ERR_MSG(bpf->extack,
|
||||
|
@ -9764,7 +9765,7 @@ static int dev_xdp_install(struct net_device *dev, enum bpf_xdp_mode mode,
|
|||
struct netdev_bpf xdp;
|
||||
int err;
|
||||
|
||||
if (dev->ethtool->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
if (dev->cfg->hds_config == ETHTOOL_TCP_DATA_SPLIT_ENABLED &&
|
||||
prog && !prog->aux->xdp_has_frags) {
|
||||
NL_SET_ERR_MSG(extack, "unable to install XDP to device using tcp-data-split");
|
||||
return -EBUSY;
|
||||
|
@ -11542,6 +11543,10 @@ struct net_device *alloc_netdev_mqs(int sizeof_priv, const char *name,
|
|||
if (!dev->ethtool)
|
||||
goto free_all;
|
||||
|
||||
dev->cfg = kzalloc(sizeof(*dev->cfg), GFP_KERNEL_ACCOUNT);
|
||||
if (!dev->cfg)
|
||||
goto free_all;
|
||||
|
||||
napi_config_sz = array_size(maxqs, sizeof(*dev->napi_config));
|
||||
dev->napi_config = kvzalloc(napi_config_sz, GFP_KERNEL_ACCOUNT);
|
||||
if (!dev->napi_config)
|
||||
|
@ -11610,6 +11615,7 @@ void free_netdev(struct net_device *dev)
|
|||
return;
|
||||
}
|
||||
|
||||
kfree(dev->cfg);
|
||||
kfree(dev->ethtool);
|
||||
netif_free_tx_queues(dev);
|
||||
netif_free_rx_queues(dev);
|
||||
|
|
|
@ -141,12 +141,12 @@ int net_devmem_bind_dmabuf_to_queue(struct net_device *dev, u32 rxq_idx,
|
|||
return -ERANGE;
|
||||
}
|
||||
|
||||
if (dev->ethtool->hds_config != ETHTOOL_TCP_DATA_SPLIT_ENABLED) {
|
||||
if (dev->cfg->hds_config != ETHTOOL_TCP_DATA_SPLIT_ENABLED) {
|
||||
NL_SET_ERR_MSG(extack, "tcp-data-split is disabled");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
if (dev->ethtool->hds_thresh) {
|
||||
if (dev->cfg->hds_thresh) {
|
||||
NL_SET_ERR_MSG(extack, "hds-thresh is not zero");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
// SPDX-License-Identifier: GPL-2.0-only
|
||||
|
||||
#include <net/netdev_queues.h>
|
||||
|
||||
#include "netlink.h"
|
||||
#include "common.h"
|
||||
|
||||
|
@ -219,7 +221,7 @@ ethnl_set_rings(struct ethnl_req_info *req_info, struct genl_info *info)
|
|||
|
||||
dev->ethtool_ops->get_ringparam(dev, &ringparam,
|
||||
&kernel_ringparam, info->extack);
|
||||
kernel_ringparam.tcp_data_split = dev->ethtool->hds_config;
|
||||
kernel_ringparam.tcp_data_split = dev->cfg->hds_config;
|
||||
|
||||
ethnl_update_u32(&ringparam.rx_pending, tb[ETHTOOL_A_RINGS_RX], &mod);
|
||||
ethnl_update_u32(&ringparam.rx_mini_pending,
|
||||
|
@ -295,8 +297,8 @@ ethnl_set_rings(struct ethnl_req_info *req_info, struct genl_info *info)
|
|||
ret = dev->ethtool_ops->set_ringparam(dev, &ringparam,
|
||||
&kernel_ringparam, info->extack);
|
||||
if (!ret) {
|
||||
dev->ethtool->hds_config = kernel_ringparam.tcp_data_split;
|
||||
dev->ethtool->hds_thresh = kernel_ringparam.hds_thresh;
|
||||
dev->cfg->hds_config = kernel_ringparam.tcp_data_split;
|
||||
dev->cfg->hds_thresh = kernel_ringparam.hds_thresh;
|
||||
}
|
||||
|
||||
return ret < 0 ? ret : 1;
|
||||
|
|
Loading…
Reference in New Issue
Block a user