Commit ad9add52 authored by Oliver O'Halloran's avatar Oliver O'Halloran Committed by Michael Ellerman

powerpc/powernv/sriov: Simplify used window tracking

No need for the multi-dimensional arrays, just use a bitmap.
Signed-off-by: default avatarOliver O'Halloran <oohall@gmail.com>
Reviewed-by: default avatarAlexey Kardashevskiy <aik@ozlabs.ru>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20200722065715.1432738-8-oohall@gmail.com
parent fac248f8
// SPDX-License-Identifier: GPL-2.0 // SPDX-License-Identifier: GPL-2.0-or-later
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/ioport.h> #include <linux/ioport.h>
...@@ -302,28 +302,20 @@ static int pnv_pci_vf_release_m64(struct pci_dev *pdev, u16 num_vfs) ...@@ -302,28 +302,20 @@ static int pnv_pci_vf_release_m64(struct pci_dev *pdev, u16 num_vfs)
{ {
struct pnv_iov_data *iov; struct pnv_iov_data *iov;
struct pnv_phb *phb; struct pnv_phb *phb;
int i, j; int window_id;
int m64_bars;
phb = pci_bus_to_pnvhb(pdev->bus); phb = pci_bus_to_pnvhb(pdev->bus);
iov = pnv_iov_get(pdev); iov = pnv_iov_get(pdev);
if (iov->m64_single_mode) for_each_set_bit(window_id, iov->used_m64_bar_mask, MAX_M64_BARS) {
m64_bars = num_vfs;
else
m64_bars = 1;
for (i = 0; i < PCI_SRIOV_NUM_BARS; i++)
for (j = 0; j < m64_bars; j++) {
if (iov->m64_map[j][i] == IODA_INVALID_M64)
continue;
opal_pci_phb_mmio_enable(phb->opal_id, opal_pci_phb_mmio_enable(phb->opal_id,
OPAL_M64_WINDOW_TYPE, iov->m64_map[j][i], 0); OPAL_M64_WINDOW_TYPE,
clear_bit(iov->m64_map[j][i], &phb->ioda.m64_bar_alloc); window_id,
iov->m64_map[j][i] = IODA_INVALID_M64; 0);
clear_bit(window_id, &phb->ioda.m64_bar_alloc);
} }
kfree(iov->m64_map);
return 0; return 0;
} }
...@@ -349,23 +341,14 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs) ...@@ -349,23 +341,14 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs)
else else
m64_bars = 1; m64_bars = 1;
iov->m64_map = kmalloc_array(m64_bars,
sizeof(*iov->m64_map),
GFP_KERNEL);
if (!iov->m64_map)
return -ENOMEM;
/* Initialize the m64_map to IODA_INVALID_M64 */
for (i = 0; i < m64_bars ; i++)
for (j = 0; j < PCI_SRIOV_NUM_BARS; j++)
iov->m64_map[i][j] = IODA_INVALID_M64;
for (i = 0; i < PCI_SRIOV_NUM_BARS; i++) { for (i = 0; i < PCI_SRIOV_NUM_BARS; i++) {
res = &pdev->resource[i + PCI_IOV_RESOURCES]; res = &pdev->resource[i + PCI_IOV_RESOURCES];
if (!res->flags || !res->parent) if (!res->flags || !res->parent)
continue; continue;
for (j = 0; j < m64_bars; j++) { for (j = 0; j < m64_bars; j++) {
/* allocate a window ID for this BAR */
do { do {
win = find_next_zero_bit(&phb->ioda.m64_bar_alloc, win = find_next_zero_bit(&phb->ioda.m64_bar_alloc,
phb->ioda.m64_bar_idx + 1, 0); phb->ioda.m64_bar_idx + 1, 0);
...@@ -373,8 +356,7 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs) ...@@ -373,8 +356,7 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs)
if (win >= phb->ioda.m64_bar_idx + 1) if (win >= phb->ioda.m64_bar_idx + 1)
goto m64_failed; goto m64_failed;
} while (test_and_set_bit(win, &phb->ioda.m64_bar_alloc)); } while (test_and_set_bit(win, &phb->ioda.m64_bar_alloc));
set_bit(win, iov->used_m64_bar_mask);
iov->m64_map[j][i] = win;
if (iov->m64_single_mode) { if (iov->m64_single_mode) {
size = pci_iov_resource_size(pdev, size = pci_iov_resource_size(pdev,
...@@ -390,12 +372,12 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs) ...@@ -390,12 +372,12 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs)
pe_num = iov->pe_num_map[j]; pe_num = iov->pe_num_map[j];
rc = opal_pci_map_pe_mmio_window(phb->opal_id, rc = opal_pci_map_pe_mmio_window(phb->opal_id,
pe_num, OPAL_M64_WINDOW_TYPE, pe_num, OPAL_M64_WINDOW_TYPE,
iov->m64_map[j][i], 0); win, 0);
} }
rc = opal_pci_set_phb_mem_window(phb->opal_id, rc = opal_pci_set_phb_mem_window(phb->opal_id,
OPAL_M64_WINDOW_TYPE, OPAL_M64_WINDOW_TYPE,
iov->m64_map[j][i], win,
start, start,
0, /* unused */ 0, /* unused */
size); size);
...@@ -409,10 +391,10 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs) ...@@ -409,10 +391,10 @@ static int pnv_pci_vf_assign_m64(struct pci_dev *pdev, u16 num_vfs)
if (iov->m64_single_mode) if (iov->m64_single_mode)
rc = opal_pci_phb_mmio_enable(phb->opal_id, rc = opal_pci_phb_mmio_enable(phb->opal_id,
OPAL_M64_WINDOW_TYPE, iov->m64_map[j][i], 2); OPAL_M64_WINDOW_TYPE, win, 2);
else else
rc = opal_pci_phb_mmio_enable(phb->opal_id, rc = opal_pci_phb_mmio_enable(phb->opal_id,
OPAL_M64_WINDOW_TYPE, iov->m64_map[j][i], 1); OPAL_M64_WINDOW_TYPE, win, 1);
if (rc != OPAL_SUCCESS) { if (rc != OPAL_SUCCESS) {
dev_err(&pdev->dev, "Failed to enable M64 window #%d: %llx\n", dev_err(&pdev->dev, "Failed to enable M64 window #%d: %llx\n",
......
...@@ -154,6 +154,7 @@ struct pnv_phb { ...@@ -154,6 +154,7 @@ struct pnv_phb {
unsigned long m64_size; unsigned long m64_size;
unsigned long m64_segsize; unsigned long m64_segsize;
unsigned long m64_base; unsigned long m64_base;
#define MAX_M64_BARS 64
unsigned long m64_bar_alloc; unsigned long m64_bar_alloc;
/* IO ports */ /* IO ports */
...@@ -243,8 +244,11 @@ struct pnv_iov_data { ...@@ -243,8 +244,11 @@ struct pnv_iov_data {
/* Did we map the VF BARs with single-PE IODA BARs? */ /* Did we map the VF BARs with single-PE IODA BARs? */
bool m64_single_mode; bool m64_single_mode;
int (*m64_map)[PCI_SRIOV_NUM_BARS]; /*
#define IODA_INVALID_M64 (-1) * Bit mask used to track which m64 windows are used to map the
* SR-IOV BARs for this device.
*/
DECLARE_BITMAP(used_m64_bar_mask, MAX_M64_BARS);
/* /*
* If we map the SR-IOV BARs with a segmented window then * If we map the SR-IOV BARs with a segmented window then
......
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