]> git.baikalelectronics.ru Git - kernel.git/commit
hv_netvsc: Properly size the vrss queues
authorKY Srinivasan <kys@microsoft.com>
Wed, 27 May 2015 20:16:57 +0000 (13:16 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 31 May 2015 00:38:44 +0000 (17:38 -0700)
commitb6ffb69ea2ef1242c8bfcdc020a90b73921f2dd9
tree8b85d6e5667092dd5f9cb083685c6d6e61f1b560
parentcf746f0c618d5adcae2745b78f11cc5f5af90ca0
hv_netvsc: Properly size the vrss queues

The current algorithm for deciding on the number of VRSS channels is
not optimal since we open up the min of number of CPUs online and the
number of VRSS channels the host is offering. So on a 32 VCPU guest
we could potentially open 32 VRSS subchannels. Experimentation has
shown that it is best to limit the number of VRSS channels to the number
of CPUs within a NUMA node.

Here is the new algorithm for deciding on the number of sub-channels we
would open up:
        1) Pick the minimum of what the host is offering and what the driver
           in the guest is specifying as the default value.
        2) Pick the minimum of (1) and the numbers of CPUs in the NUMA
           node the primary channel is bound to.

Signed-off-by: K. Y. Srinivasan <kys@microsoft.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/hyperv/hyperv_net.h
drivers/net/hyperv/netvsc_drv.c
drivers/net/hyperv/rndis_filter.c