Commit 0729cc0c authored by Alexander Gordeev's avatar Alexander Gordeev Committed by David S. Miller

myri10ge: Use pci_enable_msix_range() instead of pci_enable_msix()

As result of deprecation of MSI-X/MSI enablement functions
pci_enable_msix() and pci_enable_msi_block() all drivers
using these two interfaces need to be updated to use the
new pci_enable_msi_range() and pci_enable_msix_range()
interfaces.
Signed-off-by: default avatarAlexander Gordeev <agordeev@redhat.com>
Cc: Hyong-Youb Kim <hykim@myri.com>
Cc: netdev@vger.kernel.org
Cc: linux-pci@vger.kernel.org
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent f3c9407b
...@@ -2329,16 +2329,14 @@ static int myri10ge_request_irq(struct myri10ge_priv *mgp) ...@@ -2329,16 +2329,14 @@ static int myri10ge_request_irq(struct myri10ge_priv *mgp)
status = 0; status = 0;
if (myri10ge_msi) { if (myri10ge_msi) {
if (mgp->num_slices > 1) { if (mgp->num_slices > 1) {
status = status = pci_enable_msix_range(pdev, mgp->msix_vectors,
pci_enable_msix(pdev, mgp->msix_vectors, mgp->num_slices, mgp->num_slices);
mgp->num_slices); if (status < 0) {
if (status == 0) {
mgp->msix_enabled = 1;
} else {
dev_err(&pdev->dev, dev_err(&pdev->dev,
"Error %d setting up MSI-X\n", status); "Error %d setting up MSI-X\n", status);
return status; return status;
} }
mgp->msix_enabled = 1;
} }
if (mgp->msix_enabled == 0) { if (mgp->msix_enabled == 0) {
status = pci_enable_msi(pdev); status = pci_enable_msi(pdev);
...@@ -3895,32 +3893,34 @@ static void myri10ge_probe_slices(struct myri10ge_priv *mgp) ...@@ -3895,32 +3893,34 @@ static void myri10ge_probe_slices(struct myri10ge_priv *mgp)
mgp->msix_vectors = kcalloc(mgp->num_slices, sizeof(*mgp->msix_vectors), mgp->msix_vectors = kcalloc(mgp->num_slices, sizeof(*mgp->msix_vectors),
GFP_KERNEL); GFP_KERNEL);
if (mgp->msix_vectors == NULL) if (mgp->msix_vectors == NULL)
goto disable_msix; goto no_msix;
for (i = 0; i < mgp->num_slices; i++) { for (i = 0; i < mgp->num_slices; i++) {
mgp->msix_vectors[i].entry = i; mgp->msix_vectors[i].entry = i;
} }
while (mgp->num_slices > 1) { while (mgp->num_slices > 1) {
/* make sure it is a power of two */ mgp->num_slices = rounddown_pow_of_two(mgp->num_slices);
while (!is_power_of_2(mgp->num_slices))
mgp->num_slices--;
if (mgp->num_slices == 1) if (mgp->num_slices == 1)
goto disable_msix; goto no_msix;
status = pci_enable_msix(pdev, mgp->msix_vectors, status = pci_enable_msix_range(pdev,
mgp->num_slices); mgp->msix_vectors,
if (status == 0) { mgp->num_slices,
pci_disable_msix(pdev); mgp->num_slices);
if (status < 0)
goto no_msix;
pci_disable_msix(pdev);
if (status == mgp->num_slices) {
if (old_allocated) if (old_allocated)
kfree(old_fw); kfree(old_fw);
return; return;
} } else {
if (status > 0)
mgp->num_slices = status; mgp->num_slices = status;
else }
goto disable_msix;
} }
disable_msix: no_msix:
if (mgp->msix_vectors != NULL) { if (mgp->msix_vectors != NULL) {
kfree(mgp->msix_vectors); kfree(mgp->msix_vectors);
mgp->msix_vectors = NULL; mgp->msix_vectors = NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment