diff options
author | Nishanth Aravamudan <nacc@linux.vnet.ibm.com> | 2015-02-21 11:00:50 -0800 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2015-03-04 13:19:33 +1100 |
commit | 4ad04e5987115ece5fa8a0cf1dc72fcd4707e33e (patch) | |
tree | 61b5a9fa79e15af596924997068e2c69edd965ca /arch/powerpc/platforms/pseries/iommu.c | |
parent | 875ebe940d77a41682c367ad799b4f39f128d3fa (diff) | |
download | lwn-4ad04e5987115ece5fa8a0cf1dc72fcd4707e33e.tar.gz lwn-4ad04e5987115ece5fa8a0cf1dc72fcd4707e33e.zip |
powerpc/iommu: Remove IOMMU device references via bus notifier
After d905c5df9aef ("PPC: POWERNV: move iommu_add_device earlier"), the
refcnt on the kobject backing the IOMMU group for a PCI device is
elevated by each call to pci_dma_dev_setup_pSeriesLP() (via
set_iommu_table_base_and_group). When we go to dlpar a multi-function
PCI device out:
iommu_reconfig_notifier ->
iommu_free_table ->
iommu_group_put
BUG_ON(tbl->it_group)
We trip this BUG_ON, because there are still references on the table, so
it is not freed. Fix this by moving the powernv bus notifier to common
code and calling it for both powernv and pseries.
Fixes: d905c5df9aef ("PPC: POWERNV: move iommu_add_device earlier")
Signed-off-by: Nishanth Aravamudan <nacc@linux.vnet.ibm.com>
Tested-by: Nishanth Aravamudan <nacc@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Diffstat (limited to 'arch/powerpc/platforms/pseries/iommu.c')
-rw-r--r-- | arch/powerpc/platforms/pseries/iommu.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/powerpc/platforms/pseries/iommu.c b/arch/powerpc/platforms/pseries/iommu.c index 1d3d52dc3ff3..7803a19adb31 100644 --- a/arch/powerpc/platforms/pseries/iommu.c +++ b/arch/powerpc/platforms/pseries/iommu.c @@ -1340,3 +1340,5 @@ static int __init disable_multitce(char *str) } __setup("multitce=", disable_multitce); + +machine_subsys_initcall_sync(pseries, tce_iommu_bus_notifier_init); |