TranslateProject/published/201506/20150413 Linux FAQs with Answers--How to configure PCI-passthrough on virt-manager.md
2015-07-01 00:16:33 +08:00

56 lines
3.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

Linux有问必答如何在虚拟机上配置PCI直通
================================================================================
> **提问**我想要分配一块物理网卡到用KVM创建的虚拟机上。我打算为这台虚拟机启用网卡的PCI直通。请问我如何才能在virt-manager里面通过PCI直通增加一个PCI设备到虚拟机上
如今的hypervisor能够高效地在多个虚拟操作系统间共享和模拟硬件资源。然而虚拟资源共享不是总能使人满意甚至在虚拟机性能是重点考量时或者是虚拟机需要硬件DMA的完全控制时应该避免共享。一项名叫“PCI直通”的技术可以用在一个虚拟机需要独享PCI设备时例如网卡、声卡、显卡。本质上PCI直通穿透了虚拟层直接将PCI设备放到虚拟机里而其他虚拟机则不能访问该设备。
### 开启“PCI直通”的准备 ###
如果你想要为一台HVM实例开启PCI直通例如一台KVM创建的全虚拟化的虚拟机你的母系统包括CPU和主板必须满足以下条件。如果你的虚拟机是半虚拟化的由Xen创建你可以跳过这步。
为了在 HVM虚拟机上开启PCI直通系统需要支持**VT-d** (Intel处理器)或者**AMD-Vi** (AMD处理器)。Intel的VT-D“英特尔直接I/O虚拟化技术”是适用于最高端的Nehalem处理器和它的后继者例如Westmere、Sandy Bridge的Ivy Bridge。注意VT-d和VT-x是两个独立功能。intel/AMD处理器支持VT-D/AMD-VI功能的列表可以[查看这里][1]。
在确认你的设备支持VT-d/AMD-Vi后还有两件事情需要做。首先确保VT-d/AMD-Vi已经在BIOS中开启。然后在内核启动过程中开启IOMMU。IOMMU服务是由VT-d/AMD-Vi提供的可以保护虚拟机访问的主机内存同时它也是全虚拟化虚拟机支持PCI直通的前提。
Intel处理器中通过将“**intel_iommu=on**传给内核启动参数来开启IOMMU。参看[这篇教程][2]了解如何通过GRUB修改内核启动参数。
配置完启动参数后,重启电脑。
### 添加PCI设备到虚拟机 ###
我们已经完成了开启PCI直通的准备。事实上只需通过virt-manager就可以给虚拟机分配一个PCI设备。
打开virt-manager的虚拟机设置在左边工具栏点击增加硬件按钮。
选择从PCI设备表一个PCI设备来分配点击“完成”按钮
![](https://farm8.staticflickr.com/7587/17015584385_db49e96372_c.jpg)
最后启动实例。这样主机的PCI设备已经可以由虚拟机直接访问了。
### 常见问题 ###
在虚拟机启动时如果你看见下列任何一个错误这个错误有可能由于母机VT-d (或 IOMMU)未开启导致。
Error starting domain: unsupported configuration: host doesn't support passthrough of host PCI devices
----------
Error starting domain: Unable to read from monitor: Connection reset by peer
请确保"**intel_iommu=on**"启动参数已经按上文叙述开启。
--------------------------------------------------------------------------------
via: http://ask.xmodulo.com/pci-passthrough-virt-manager.html
作者:[Dan Nanni][a]
译者:[Vic020/VicYu](http://vicyu.net)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
[a]:http://ask.xmodulo.com/author/nanni
[1]:http://wiki.xenproject.org/wiki/VTdHowTo
[2]:http://xmodulo.com/add-kernel-boot-parameters-via-grub-linux.html