Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp1690976pxv; Fri, 16 Jul 2021 15:38:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxUFBCP5Fhfknt+QcoOCmCJfKVxAbhc6CuyBglULwEY5gmpwyaE2inooTTZBPrJgaibC3o5 X-Received: by 2002:a17:906:c107:: with SMTP id do7mr14058427ejc.469.1626475109641; Fri, 16 Jul 2021 15:38:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626475109; cv=none; d=google.com; s=arc-20160816; b=Tmcn0mAw/TZIqkSj9KQt3fU4iS4sSWqdd742pt5niD1pbdee3juaO7ckj8FA/dAVYX +4b6MApI5NdTieg7NpZWGiQoWPHos5NXujP3rUXTQs9mySs+u98apwV1IjlseXk5evYt aN0MTnh0BUsl01atK9i1opSWLNhmGA7Zc9U3Vopx5Sdezl7hj/dn2DQToULeetT5ACko DPO84gdlZvoS2Gb+cxAnwGsG+W5ia6yjSwSYvbdyL3yT/1SdipPu4GlF3PvGsRhD48rP 4hOYeO4eT/FGKo/L7ygsYccqSI4t4wm3CFhZP6te0iUKGcdyuJiM4Egih54DitP768WK KkdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=/nDaIpR9liLS5nPpXER9wS5nEEm9ZmasTcWaKMtY4Bo=; b=OJpD/NCTKCG9as66guuPBVPV6nLazFtbUcu5G+SwOVHh316g3kd1NZYu8S//q5er+H jaLplmlRrSv1xy1yJslQl940QAI2kD2CyZzsHTRalIGdxnot7kHzFds/2B8LvGuWyITl LfnTRv9/NJmZ2GaaTdLDGTH1xUpYH4V3EnktUcKWcXOJM45qtT23A764Arq+uzGB/tk0 YCCtJ89fLw/4eIY35cRf2bfuDGF7cOFlj5gvcF607qpaJHnD6uJriYlz26ae0WG3+aa1 5CspElsDC1ef6faBPFhW9BE/zR2h/aWPXw+Nqg3dTiqPgYl8taNNIwZY9sX3s6zJfeBM elIA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vmware.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s14si12611892ejf.668.2021.07.16.15.37.59; Fri, 16 Jul 2021 15:38:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vmware.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237776AbhGPWjq (ORCPT + 99 others); Fri, 16 Jul 2021 18:39:46 -0400 Received: from ex13-edg-ou-002.vmware.com ([208.91.0.190]:11607 "EHLO EX13-EDG-OU-002.vmware.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236986AbhGPWjg (ORCPT ); Fri, 16 Jul 2021 18:39:36 -0400 Received: from sc9-mailhost2.vmware.com (10.113.161.72) by EX13-EDG-OU-002.vmware.com (10.113.208.156) with Microsoft SMTP Server id 15.0.1156.6; Fri, 16 Jul 2021 15:36:35 -0700 Received: from htb-1n-eng-dhcp122.eng.vmware.com (unknown [10.20.114.3]) by sc9-mailhost2.vmware.com (Postfix) with ESMTP id EFC54203F0; Fri, 16 Jul 2021 15:36:40 -0700 (PDT) Received: by htb-1n-eng-dhcp122.eng.vmware.com (Postfix, from userid 0) id EBF82AA043; Fri, 16 Jul 2021 15:36:40 -0700 (PDT) From: Ronak Doshi To: CC: Ronak Doshi , "maintainer:VMWARE VMXNET3 ETHERNET DRIVER" , "David S. Miller" , Jakub Kicinski , open list Subject: [PATCH net-next 3/7] vmxnet3: remove power of 2 limitation on the queues Date: Fri, 16 Jul 2021 15:36:22 -0700 Message-ID: <20210716223626.18928-4-doshir@vmware.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20210716223626.18928-1-doshir@vmware.com> References: <20210716223626.18928-1-doshir@vmware.com> MIME-Version: 1.0 Content-Type: text/plain Received-SPF: None (EX13-EDG-OU-002.vmware.com: doshir@vmware.com does not designate permitted sender hosts) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With version 6, vmxnet3 relaxes the restriction on queues to be power of two. This is helpful in cases (Edge VM) where vcpus are less than 8 and device requires more than 4 queues. Signed-off-by: Ronak Doshi Acked-by: Guolin Yang --- drivers/net/vmxnet3/vmxnet3_drv.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index d32fa6f3ae57..41e694d13c92 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c @@ -3399,7 +3399,6 @@ vmxnet3_probe_device(struct pci_dev *pdev, else #endif num_rx_queues = 1; - num_rx_queues = rounddown_pow_of_two(num_rx_queues); if (enable_mq) num_tx_queues = min(VMXNET3_DEVICE_MAX_TX_QUEUES, @@ -3407,7 +3406,6 @@ vmxnet3_probe_device(struct pci_dev *pdev, else num_tx_queues = 1; - num_tx_queues = rounddown_pow_of_two(num_tx_queues); netdev = alloc_etherdev_mq(sizeof(struct vmxnet3_adapter), max(num_tx_queues, num_rx_queues)); if (!netdev) @@ -3525,6 +3523,8 @@ vmxnet3_probe_device(struct pci_dev *pdev, } } else { adapter->queuesExtEnabled = false; + num_rx_queues = rounddown_pow_of_two(num_rx_queues); + num_tx_queues = rounddown_pow_of_two(num_tx_queues); adapter->num_rx_queues = min(num_rx_queues, VMXNET3_DEVICE_DEFAULT_RX_QUEUES); adapter->num_tx_queues = min(num_tx_queues, @@ -3705,7 +3705,9 @@ vmxnet3_remove_device(struct pci_dev *pdev) else #endif num_rx_queues = 1; - num_rx_queues = rounddown_pow_of_two(num_rx_queues); + if (!VMXNET3_VERSION_GE_6(adapter)) { + num_rx_queues = rounddown_pow_of_two(num_rx_queues); + } if (VMXNET3_VERSION_GE_6(adapter)) { spin_lock_irqsave(&adapter->cmd_lock, flags); VMXNET3_WRITE_BAR1_REG(adapter, VMXNET3_REG_CMD, -- 2.11.0