mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-14 17:53:39 +00:00
powerpc/powernv/pci: Always tear down DMA windows on PE release
Currently we have these two functions: pnv_pci_ioda2_release_dma_pe(), and pnv_pci_ioda2_release_pe_dma() The first is used when tearing down VF PEs and the other is used for normal devices. There's very little difference between the two though. The latter (non-VF) will skip a call to pnv_pci_ioda2_unset_window() unless CONFIG_IOMMU_API=y is set. There's no real point in doing this so fold the two together. Signed-off-by: Oliver O'Halloran <oohall@gmail.com> Reviewed-by: Alexey Kardashevskiy <aik@ozlabs.ru> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20200722065715.1432738-2-oohall@gmail.com
This commit is contained in:
parent
5609ffddd1
commit
7a52ffabe8
@ -1422,26 +1422,7 @@ m64_failed:
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
static long pnv_pci_ioda2_unset_window(struct iommu_table_group *table_group,
|
static void pnv_pci_ioda2_release_pe_dma(struct pnv_ioda_pe *pe);
|
||||||
int num);
|
|
||||||
|
|
||||||
static void pnv_pci_ioda2_release_dma_pe(struct pci_dev *dev, struct pnv_ioda_pe *pe)
|
|
||||||
{
|
|
||||||
struct iommu_table *tbl;
|
|
||||||
int64_t rc;
|
|
||||||
|
|
||||||
tbl = pe->table_group.tables[0];
|
|
||||||
rc = pnv_pci_ioda2_unset_window(&pe->table_group, 0);
|
|
||||||
if (rc)
|
|
||||||
pe_warn(pe, "OPAL error %lld release DMA window\n", rc);
|
|
||||||
|
|
||||||
pnv_pci_ioda2_set_bypass(pe, false);
|
|
||||||
if (pe->table_group.group) {
|
|
||||||
iommu_group_put(pe->table_group.group);
|
|
||||||
BUG_ON(pe->table_group.group);
|
|
||||||
}
|
|
||||||
iommu_tce_table_put(tbl);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void pnv_ioda_release_vf_PE(struct pci_dev *pdev)
|
static void pnv_ioda_release_vf_PE(struct pci_dev *pdev)
|
||||||
{
|
{
|
||||||
@ -1455,11 +1436,12 @@ static void pnv_ioda_release_vf_PE(struct pci_dev *pdev)
|
|||||||
if (!pdev->is_physfn)
|
if (!pdev->is_physfn)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
/* FIXME: Use pnv_ioda_release_pe()? */
|
||||||
list_for_each_entry_safe(pe, pe_n, &phb->ioda.pe_list, list) {
|
list_for_each_entry_safe(pe, pe_n, &phb->ioda.pe_list, list) {
|
||||||
if (pe->parent_dev != pdev)
|
if (pe->parent_dev != pdev)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
pnv_pci_ioda2_release_dma_pe(pdev, pe);
|
pnv_pci_ioda2_release_pe_dma(pe);
|
||||||
|
|
||||||
/* Remove from list */
|
/* Remove from list */
|
||||||
mutex_lock(&phb->ioda.pe_list_mutex);
|
mutex_lock(&phb->ioda.pe_list_mutex);
|
||||||
@ -2429,7 +2411,6 @@ static long pnv_pci_ioda2_setup_default_config(struct pnv_ioda_pe *pe)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(CONFIG_IOMMU_API) || defined(CONFIG_PCI_IOV)
|
|
||||||
static long pnv_pci_ioda2_unset_window(struct iommu_table_group *table_group,
|
static long pnv_pci_ioda2_unset_window(struct iommu_table_group *table_group,
|
||||||
int num)
|
int num)
|
||||||
{
|
{
|
||||||
@ -2453,7 +2434,6 @@ static long pnv_pci_ioda2_unset_window(struct iommu_table_group *table_group,
|
|||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_IOMMU_API
|
#ifdef CONFIG_IOMMU_API
|
||||||
unsigned long pnv_pci_ioda2_get_table_size(__u32 page_shift,
|
unsigned long pnv_pci_ioda2_get_table_size(__u32 page_shift,
|
||||||
@ -3334,18 +3314,14 @@ static void pnv_pci_ioda2_release_pe_dma(struct pnv_ioda_pe *pe)
|
|||||||
{
|
{
|
||||||
struct iommu_table *tbl = pe->table_group.tables[0];
|
struct iommu_table *tbl = pe->table_group.tables[0];
|
||||||
unsigned int weight = pnv_pci_ioda_pe_dma_weight(pe);
|
unsigned int weight = pnv_pci_ioda_pe_dma_weight(pe);
|
||||||
#ifdef CONFIG_IOMMU_API
|
|
||||||
int64_t rc;
|
int64_t rc;
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!weight)
|
if (!weight)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#ifdef CONFIG_IOMMU_API
|
|
||||||
rc = pnv_pci_ioda2_unset_window(&pe->table_group, 0);
|
rc = pnv_pci_ioda2_unset_window(&pe->table_group, 0);
|
||||||
if (rc)
|
if (rc)
|
||||||
pe_warn(pe, "OPAL error %lld release DMA window\n", rc);
|
pe_warn(pe, "OPAL error %lld release DMA window\n", rc);
|
||||||
#endif
|
|
||||||
|
|
||||||
pnv_pci_ioda2_set_bypass(pe, false);
|
pnv_pci_ioda2_set_bypass(pe, false);
|
||||||
if (pe->table_group.group) {
|
if (pe->table_group.group) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user