diff options
| author | Alexey Kardashevskiy | 2016-06-01 10:57:35 +0200 |
|---|---|---|
| committer | David Gibson | 2016-06-07 02:17:45 +0200 |
| commit | b4b6eb771a5c2eec47fd87ea28c499a5aa4b6db2 (patch) | |
| tree | e905b54eeafe82609c01e505fb915beb44c34804 /include | |
| parent | spapr_iommu: Migrate full state (diff) | |
| download | qemu-b4b6eb771a5c2eec47fd87ea28c499a5aa4b6db2.tar.gz qemu-b4b6eb771a5c2eec47fd87ea28c499a5aa4b6db2.tar.xz qemu-b4b6eb771a5c2eec47fd87ea28c499a5aa4b6db2.zip | |
spapr_iommu: Add root memory region
We are going to have multiple DMA windows at different offsets on
a PCI bus. For the sake of migration, we will have as many TCE table
objects pre-created as many windows supported.
So we need a way to map windows dynamically onto a PCI bus
when migration of a table is completed but at this stage a TCE table
object does not have access to a PHB to ask it to map a DMA window
backed by just migrated TCE table.
This adds a "root" memory region (UINT64_MAX long) to the TCE object.
This new region is mapped on a PCI bus with enabled overlapping as
there will be one root MR per TCE table, each of them mapped at 0.
The actual IOMMU memory region is a subregion of the root region and
a TCE table enables/disables this subregion and maps it at
the specific offset inside the root MR which is 1:1 mapping of
a PCI address space.
Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Diffstat (limited to 'include')
| -rw-r--r-- | include/hw/ppc/spapr.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/include/hw/ppc/spapr.h b/include/hw/ppc/spapr.h index f849714ad7..971df3d0df 100644 --- a/include/hw/ppc/spapr.h +++ b/include/hw/ppc/spapr.h @@ -544,7 +544,7 @@ struct sPAPRTCETable { bool bypass; bool need_vfio; int fd; - MemoryRegion iommu; + MemoryRegion root, iommu; struct VIOsPAPRDevice *vdev; /* for @bypass migration compatibility only */ QLIST_ENTRY(sPAPRTCETable) list; }; |
