Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 59995370 authored by Andrew Schwartzmeyer's avatar Andrew Schwartzmeyer Committed by David S. Miller
Browse files

hyperv: Implement netvsc_get_channels() ethool op



This adds support for reporting the actual and maximum combined channels
count of the hv_netvsc driver via 'ethtool --show-channels'.

This required adding 'max_chn' to 'struct netvsc_device', and assigning
it 'rsscap.num_recv_que' in 'rndis_filter_device_add'. Now we can access
the combined maximum channel count via 'struct netvsc_device' in the
ethtool callback.

Signed-off-by: default avatarAndrew Schwartzmeyer <andrew@schwartzmeyer.com>
Signed-off-by: default avatarHaiyang Zhang <haiyangz@microsoft.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f9c7ce18
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -634,6 +634,7 @@ struct netvsc_device {

	struct vmbus_channel *chn_table[NR_CPUS];
	u32 send_table[VRSS_SEND_TAB_SIZE];
	u32 max_chn;
	u32 num_chn;
	atomic_t queue_sends[NR_CPUS];

+14 −0
Original line number Diff line number Diff line
@@ -687,6 +687,19 @@ static void netvsc_get_drvinfo(struct net_device *net,
	strlcpy(info->fw_version, "N/A", sizeof(info->fw_version));
}

static void netvsc_get_channels(struct net_device *net,
				struct ethtool_channels *channel)
{
	struct net_device_context *net_device_ctx = netdev_priv(net);
	struct hv_device *dev = net_device_ctx->device_ctx;
	struct netvsc_device *nvdev = hv_get_drvdata(dev);

	if (nvdev) {
		channel->max_combined	= nvdev->max_chn;
		channel->combined_count = nvdev->num_chn;
	}
}

static int netvsc_change_mtu(struct net_device *ndev, int mtu)
{
	struct net_device_context *ndevctx = netdev_priv(ndev);
@@ -760,6 +773,7 @@ static void netvsc_poll_controller(struct net_device *net)
static const struct ethtool_ops ethtool_ops = {
	.get_drvinfo	= netvsc_get_drvinfo,
	.get_link	= ethtool_op_get_link,
	.get_channels   = netvsc_get_channels,
};

static const struct net_device_ops device_ops = {
+5 −1
Original line number Diff line number Diff line
@@ -1027,6 +1027,7 @@ int rndis_filter_device_add(struct hv_device *dev,

	/* Initialize the rndis device */
	net_device = hv_get_drvdata(dev);
	net_device->max_chn = 1;
	net_device->num_chn = 1;

	net_device->extension = rndis_device;
@@ -1094,6 +1095,7 @@ int rndis_filter_device_add(struct hv_device *dev,
	if (ret || rsscap.num_recv_que < 2)
		goto out;

	net_device->max_chn = rsscap.num_recv_que;
	net_device->num_chn = (num_online_cpus() < rsscap.num_recv_que) ?
			       num_online_cpus() : rsscap.num_recv_que;
	if (net_device->num_chn == 1)
@@ -1140,8 +1142,10 @@ int rndis_filter_device_add(struct hv_device *dev,
	ret = rndis_filter_set_rss_param(rndis_device, net_device->num_chn);

out:
	if (ret)
	if (ret) {
		net_device->max_chn = 1;
		net_device->num_chn = 1;
	}
	return 0; /* return 0 because primary channel can be used alone */

err_dev_remv: