diff options
author | jhb <jhb@FreeBSD.org> | 2015-11-16 21:36:50 +0000 |
---|---|---|
committer | jhb <jhb@FreeBSD.org> | 2015-11-16 21:36:50 +0000 |
commit | afb0cf753729c46a4352a25759e56706565a897a (patch) | |
tree | 9ddb5ebef396cd2f882c77885e8d9847956defc4 /sys/dev | |
parent | 4a83aa80d5b0f882bababcbb0b8f778d5bbd3d8a (diff) | |
download | FreeBSD-src-afb0cf753729c46a4352a25759e56706565a897a.zip FreeBSD-src-afb0cf753729c46a4352a25759e56706565a897a.tar.gz |
Only use a power of 2 for the number of receive and transmit queues.
Using other values causes VMXNET3_CMD_ENABLE to fail. The Linux
driver also enforces this restriction.
Reviewed by: bryanv
MFC after: 1 week
Sponsored by: Norse
Differential Revision: https://reviews.freebsd.org/D4139
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/vmware/vmxnet3/if_vmx.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/sys/dev/vmware/vmxnet3/if_vmx.c b/sys/dev/vmware/vmxnet3/if_vmx.c index 5faf716..be249c9 100644 --- a/sys/dev/vmware/vmxnet3/if_vmx.c +++ b/sys/dev/vmware/vmxnet3/if_vmx.c @@ -510,6 +510,13 @@ vmxnet3_check_version(struct vmxnet3_softc *sc) return (0); } +static int +trunc_powerof2(int val) +{ + + return (1U << (fls(val) - 1)); +} + static void vmxnet3_initial_config(struct vmxnet3_softc *sc) { @@ -520,14 +527,14 @@ vmxnet3_initial_config(struct vmxnet3_softc *sc) nqueue = VMXNET3_DEF_TX_QUEUES; if (nqueue > mp_ncpus) nqueue = mp_ncpus; - sc->vmx_max_ntxqueues = nqueue; + sc->vmx_max_ntxqueues = trunc_powerof2(nqueue); nqueue = vmxnet3_tunable_int(sc, "rxnqueue", vmxnet3_default_rxnqueue); if (nqueue > VMXNET3_MAX_RX_QUEUES || nqueue < 1) nqueue = VMXNET3_DEF_RX_QUEUES; if (nqueue > mp_ncpus) nqueue = mp_ncpus; - sc->vmx_max_nrxqueues = nqueue; + sc->vmx_max_nrxqueues = trunc_powerof2(nqueue); if (vmxnet3_tunable_int(sc, "mq_disable", vmxnet3_mq_disable)) { sc->vmx_max_nrxqueues = 1; |