svn commit: r304858 - in head/sys/amd64/vmm: . io

John Baldwin jhb at freebsd.org
Fri Aug 26 23:18:20 UTC 2016


On Friday, August 26, 2016 08:15:23 PM John Baldwin wrote:
> Author: jhb
> Date: Fri Aug 26 20:15:22 2016
> New Revision: 304858
> URL: https://svnweb.freebsd.org/changeset/base/304858
> 
> Log:
>   Enable I/O MMU when PCI pass through is first used.
>   
>   Rather than enabling the I/O MMU when the vmm module is loaded,
>   defer initialization until the first attempt to pass a PCI device
>   through to a guest.  If the I/O MMU fails to initialize or is not
>   present, than fail the attempt to pass a PCI device through to a
>   guest.
>   
>   The hw.vmm.force_iommu tunable has been removed since the I/O MMU is
>   no longer enabled during boot.  However, the I/O MMU support can be
>   disabled by setting the hw.vmm.iommu.enable tunable to 0 to prevent
>   use of the I/O MMU on any systems where it is buggy.
>   
>   Reviewed by:	grehan
>   MFC after:	1 week
>   Differential Revision:	https://reviews.freebsd.org/D7448

Forgot 'Sponsored by: Chelsio Communications'

Previously if you did the following:

# kldload vmm
# devctl set driver <some pci device> ppt

And then started a virtual machine that used ppt0 as a PCI
pass through device, the I/O MMU was never enabled.  The result
was that DMA requests for the PCI device weren't translated.  This
would cause the driver to not work in the guest and possibly trash
memory in either the guest or host.  Now the I/O MMU is always
enabled before passing a device to a guest, and if the I/O MMU
doesn't work for some reason, bhyve will fail to start the
guest.

-- 
John Baldwin


More information about the svn-src-head mailing list