Input–output memory management unit explained

In computing, an input–output memory management unit (IOMMU) is a memory management unit (MMU) connecting a direct-memory-access–capable (DMA-capable) I/O bus to the main memory. Like a traditional MMU, which translates CPU-visible virtual addresses to physical addresses, the IOMMU maps device-visible virtual addresses (also called device addresses or memory mapped I/O addresses in this context) to physical addresses. Some units also provide memory protection from faulty or malicious devices.

An example IOMMU is the graphics address remapping table (GART) used by AGP and PCI Express graphics cards on Intel Architecture and AMD computers.

On the x86 architecture, prior to splitting the functionality of northbridge and southbridge between the CPU and Platform Controller Hub (PCH), I/O virtualization was not performed by the CPU but instead by the chipset.[1] [2]

Advantages

The advantages of having an IOMMU, compared to direct physical addressing of the memory (DMA), include:

For system architectures in which port I/O is a distinct address space from the memory address space, an IOMMU is not used when the CPU communicates with devices via I/O ports. In system architectures in which port I/O and memory are mapped into a suitable address space, an IOMMU can translate port I/O accesses.

Disadvantages

The disadvantages of having an IOMMU, compared to direct physical addressing of the memory, include:[4]

Virtualization

When an operating system is running inside a virtual machine, including systems that use paravirtualization, such as Xen and KVM, it does not usually know the host-physical addresses of memory that it accesses. This makes providing direct access to the computer hardware difficult, because if the guest OS tried to instruct the hardware to perform a direct memory access (DMA) using guest-physical addresses, it would likely corrupt the memory, as the hardware does not know about the mapping between the guest-physical and host-physical addresses for the given virtual machine. The corruption can be avoided if the hypervisor or host OS intervenes in the I/O operation to apply the translations. However, this approach incurs a delay in the I/O operation.

An IOMMU solves this problem by re-mapping the addresses accessed by the hardware according to the same (or a compatible) translation table that is used to map guest-physical address to host-physical addresses.[5]

Published specifications

See also

External links

Notes and References

  1. Web site: Intel platform hardware support for I/O virtualization . https://web.archive.org/web/20070120024219/http://www.intel.com/technology/itj/2006/v10i3/2-io/5-platform-hardware-support.htm . 2006-08-10 . 2014-06-07 . 2007-01-20 . intel.com.
  2. Web site: Desktop Boards: Compatibility with Intel Virtualization Technology (Intel VT) . 2014-02-14 . 2014-06-07 . intel.com.
  3. Web site: Physical Address Extension — PAE Memory and Windows. Microsoft Windows Hardware Development Central. 2005. 2008-04-07.
  4. Muli Ben-Yehuda . Jimi Xenidis . Michal Ostrowski . 2007-06-27 . Price of Safety: Evaluating IOMMU Performance . . Proceedings of the Linux Symposium 2007 . Ottawa, Ontario, Canada . 2013-02-28 .
  5. Web site: Xen FAQ: In DomU, how can I use 3D graphics . https://web.archive.org/web/20050423215726/http://wiki.xensource.com/xenwiki/XenFaq#head-d5a7a247a5168517291228a6f02fd74b419badeb . dead . 2005-04-23 . 2006-12-12 .
  6. Web site: AMD I/O Virtualization Technology (IOMMU) Specification Revision 2.0 . 2011-03-24 . 2014-01-11 . amd.com .
  7. Web site: AMD I/O Virtualization Technology (IOMMU) Specification . 2020-07-09 . amd.com . PDF.
  8. IBM 4300 Processors Principles of Operation for ECPS:VSE Mode . SA22-7070-0 . First . January 1979 . IBM . 2021-06-30 . 2012-03-14 . https://web.archive.org/web/20120314101925/http://www.bitsavers.org/pdf/ibm/43xx/GA22-7070-0_4300_ECPS_VSE_Mode_Principles_Of_Operation_Jan79.pdf . dead.
  9. Web site: Intel Virtualization Technology for Directed I/O (VT-d) Architecture Specification . 2020-07-09.
  10. Web site: DVMA Resources and IOMMU Translations . 2007-04-30.
  11. Web site: Logical Partition Security in the IBM eServer pSeries 690 . https://web.archive.org/web/20070310212900/http://www-03.ibm.com/servers/eserver/pseries/hardware/whitepapers/lpar_security.html . dead . March 10, 2007 . 2007-04-30.
  12. Web site: PCI Express Base Specification . 2023-01-18.
  13. Web site: ARM SMMU. 2013-05-13.
  14. Web site: ARM Virtualization Extensions . 2013-05-13 . https://web.archive.org/web/20130503180818/http://www.arm.com/products/processors/technologies/virtualization-extensions.php . 2013-05-03 . dead .