Commit 481e96fc authored by Matteo Croce's avatar Matteo Croce Committed by Jakub Kicinski
Browse files

mvpp2: take care of xdp_features when reconfiguring queues



XDP is supported only if enough queues are present, so when reconfiguring
the queues set xdp_features accordingly.

Fixes: 66c0e13a ("drivers: net: turn on XDP features")
Suggested-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarMatteo Croce <teknoraver@meta.com>
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 4d5ab0ad
Loading
Loading
Loading
Loading
+12 −3
Original line number Diff line number Diff line
@@ -4996,6 +4996,14 @@ static int mvpp2_bm_switch_buffers(struct mvpp2 *priv, bool percpu)

	for (i = 0; i < priv->port_count; i++) {
		port = priv->port_list[i];
		if (percpu && port->ntxqs >= num_possible_cpus() * 2)
			xdp_set_features_flag(port->dev,
					      NETDEV_XDP_ACT_BASIC |
					      NETDEV_XDP_ACT_REDIRECT |
					      NETDEV_XDP_ACT_NDO_XMIT);
		else
			xdp_clear_features_flag(port->dev);

		mvpp2_swf_bm_pool_init(port);
		if (status[i])
			mvpp2_open(port->dev);
@@ -6863,13 +6871,14 @@ static int mvpp2_port_probe(struct platform_device *pdev,

	if (!port->priv->percpu_pools)
		mvpp2_set_hw_csum(port, port->pool_long->id);
	else if (port->ntxqs >= num_possible_cpus() * 2)
		dev->xdp_features = NETDEV_XDP_ACT_BASIC |
				    NETDEV_XDP_ACT_REDIRECT |
				    NETDEV_XDP_ACT_NDO_XMIT;

	dev->vlan_features |= features;
	netif_set_tso_max_segs(dev, MVPP2_MAX_TSO_SEGS);

	dev->xdp_features = NETDEV_XDP_ACT_BASIC | NETDEV_XDP_ACT_REDIRECT |
			    NETDEV_XDP_ACT_NDO_XMIT;

	dev->priv_flags |= IFF_UNICAST_FLT;

	/* MTU range: 68 - 9704 */