diff options
author | Alexey Kardashevskiy <aik@ozlabs.ru> | 2013-01-07 18:51:52 +1100 |
---|---|---|
committer | Joerg Roedel <joro@8bytes.org> | 2013-01-10 18:07:53 +0100 |
commit | 097e3635dc35d1cfc14057f8006f1b1f0eaf1987 (patch) | |
tree | 425dd47c2f119ba8db941622b1fa26d97c674a6a /drivers/iommu | |
parent | 9931faca02c604c22335f5a935a501bb2ace6e20 (diff) | |
download | talos-op-linux-097e3635dc35d1cfc14057f8006f1b1f0eaf1987.tar.gz talos-op-linux-097e3635dc35d1cfc14057f8006f1b1f0eaf1987.zip |
iommu: moving initialization earlier
The iommu_init() initializes IOMMU internal structures and data
required for the IOMMU API as iommu_group_alloc().
It is registered as a subsys_initcall now.
One of the IOMMU users is going to be a PCI subsystem on POWER.
It discovers new IOMMU tables during the PCI scan so the logical
place to call iommu_group_alloc() is the moment when a new group
is discovered. However PCI scan is done from subsys_initcall hook
as IOMMU does so PCI hook can be (and is) called before the IOMMU one.
The patch moves IOMMU subsystem initialization one step earlier
to make sure that IOMMU is initialized before PCI scan begins.
Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
Signed-off-by: Joerg Roedel <joro@8bytes.org>
Diffstat (limited to 'drivers/iommu')
-rw-r--r-- | drivers/iommu/iommu.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/iommu/iommu.c b/drivers/iommu/iommu.c index ddbdacad7768..1065a1a19478 100644 --- a/drivers/iommu/iommu.c +++ b/drivers/iommu/iommu.c @@ -861,7 +861,7 @@ static int __init iommu_init(void) return 0; } -subsys_initcall(iommu_init); +arch_initcall(iommu_init); int iommu_domain_get_attr(struct iommu_domain *domain, enum iommu_attr attr, void *data) |