[[PageOutline]]
{{{
#!html
實作七:Xen PCI Passthrough 操作手冊
}}}
----
= 【前言】 =
* '''''小叮嚀__'''''
* 為了使 Xen patched Kerenl 能支援 PCI Passthrough, 請務必確認以下Xen 相關的核心配置.
{{{
CONFIG_XEN_PCIDEV_FRONTEND=y
CONFIG_XEN_PCIDEV_BACKEND=y
CONFIG_XEN_PCIDEV_BACKEND_PASS is not set
CONFIG_XEN_PCIDEV_BACKEND_VPCI=y
CONFIG_XEN_PCIDEV_BACKEND_SLOT is not set
}}}
* '''''小技巧__'''''
* Binding at Boot-Time.
* 直接將顯示卡所佔的 PCI_Address 在開機時就隱藏起來,使得一開始便能直接 bind 到該 PCI_Address.
* 透過 lspci 指令來查詢顯示卡所佔的實體 PCI Address.
{{{
# 台中機器
/boot/vmlinuz-2.6.26-2-xen-amd64 root=/dev/sda1 ro console=tty0 pciback.permissive pciback.hide=(0000:01:00.0)
}}}
{{{
# 新竹機器
/boot/vmlinuz-2.6.26-2-xen-amd64 root=/dev/sda1 ro console=tty0 pciback.permissive pciback.hide=(0000:08:00.0)
}}}
* 如果透過 lspci 指令查出顯示卡為 unknown 或是其他不明資訊, 請先更新 PCI ID database 試看看.
{{{
$ update-pciids
}}}
----
= 【Step 0: 流程】 =
* 本範例將說明如何使用及設定 Xen PCI Passthrough
{{{
#!graphviz
digraph finite_state_machine {
rankdir=LR;
ranksep=0.3;
size="11,8";
node[shape=box,width=3.0];
"1.先確認主機上的顯示卡相關資訊及規格" -> "2. 建立一台虛擬機器供測試用" -> "3.如何設定 PCI Frontend ?";
"1.先確認主機上的顯示卡相關資訊及規格" -> "2. 建立一台虛擬機器供測試用" -> "4.如何設定 PCI Backend ?";
"5.如何設定 Xen 硬體定址存取 ?" -> "6.啟動並登入虛擬機器" -> "7.檢查虛擬機器有無成功分配到顯示卡的資源";
}
}}}
----
= 【Step 1: 首先查看主機上的顯卡資訊】 =
{{{
$ lspci -vv | more
}}}
{{{
# 台中機器
01:00.0 VGA compatible controller: nVidia Corporation G92 [GeForce 9800 GT] (rev a2)
Subsystem: ASUSTeK Computer Inc. Device 82a0
Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx-
Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- SERR-
Kernel driver in use: nvidia
Kernel modules: nvidia, nvidiafb
}}}
{{{
# 新竹機器
08:00.0 VGA compatible controller: nVidia Corporation G92 [GeForce 9800 GT] (rev a2) (prog-if 00 [VGA controller])
Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx-
Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- SERR-
Kernel driver in use: nvidia
Kernel modules: nvidiafb, nvidia
}}}
----
= 【Step 2: 產生一台實驗用虛擬機器】 =
* 設定你想要怎樣規格的虛擬機器.
{{{
$ sudo gedit /etc/xen-tools/xen-tools.conf
}}}
{{{
#!sh
45 dir = /home
128 size = 1Gb # Disk image size.
129 memory = 128Mb # Memory size
130 swap = 128Mb # Swap size
133 dist = lenny # Default distribution to install.
134 image = sparse # Specify sparse vs. full disk images.
163 gateway = 192.168.1.254
164 netmask = 255.255.255.0
165 broadcast = 192.168.1.255
214 mirror = http://free.nchc.org.tw/debian/
257 serial_device = hvc0 #default
}}}
{{{
$ sudo xen-create-image --hostname=xg01 --ip=192.168.1.X --mac=00:16:00:00:00:XX --force
}}}
----
= 【Step 3: PCI Frontend Configuration 設定你的 DomU 】 =
{{{
$ sudo gedit /home/domains/xg01.cfg
}}}
{{{
#!sh
9 kernel = '/boot/vmlinuz-2.6.26-2-xen-amd64'
10 ramdisk = '/boot/initrd.img-2.6.26-2-xen-amd64'
11 memory = '128'
12 vcpus = '1'
14 pci = ['08:00.0']
19 root = '/dev/sda2 ro'
20 disk = [
'file:/home/domains/xg01/disk.img,sda2,w',
'file:/home/domains/xg01/swap.img,sda1,w',
]
29 name = 'xg01'
#
# Networking
#
34 vif = [ 'ip=192.168.1.X ,mac=00:16:00:00:00:XX' ]
#
# Behaviour
#
39 on_poweroff = 'destroy'
40 on_reboot = 'restart'
41 on_crash = 'restart'
}}}
----
= 【Step 4: PCI Backend Configuration 設定你的 Dom0 】 =
* 切換身份為 Super user.
{{{
$ sudo su -
}}}
* 隱藏 dom0 的PCI 匯流排的位址, 並交由 pciback 模組來控制該匯流排存取權.
{{{
# echo -n "0000:08:00.0" > /sys/bus/pci/drivers/nvidia/unbind
}}}
* 將 dev_ids 轉到 pciback 成為新的 binding slot.
{{{
# echo -n "0000:08:00.0" > /sys/bus/pci/drivers/pciback/new_slot
# echo -n "0000:08:00.0" > /sys/bus/pci/drivers/pciback/bind
}}}
{{{
# cat /sys/bus/pci/drivers/pciback/slots
}}}
{{{
#!sh
0000:08:00.0
}}}
* 警告: 請確認您的顯示卡資源沒有被其 Kernel module 佔有及控制.
{{{
$ ls -al /sys/bus/pci/devices/0000:08:00.0/ | grep driver
}}}
{{{
#!sh
driver -> ../../../../bus/pci/drivers/nvidia ---> 此連結應該已經不存在. NVIDIA module 已無該裝置控制權.
driver -> ../../../../bus/pci/drivers/pciback ---> 控制權應該已經交賦予 pciback module.
}}}
----
= 【Step 5: 硬體定址存取設定】 =
== Permissive Flag ==
* 說明: 透過 "lspci" 指令來查詢您顯示卡的 PCI address.
{{{
# su clouder
$ sudo gedit /etc/xen/xend-pci-permissive.sxp
}}}
{{{
#!sh
/*** 台中機器 ***/
(unconstrained_dev_ids
#('0123:4567:89AB:CDEF')
('0000:01:00.0')
)
}}}
{{{
#!sh
/*** 新竹機器 ***/
(unconstrained_dev_ids
#('0123:4567:89AB:CDEF')
('0000:08:00.0')
)
}}}
== User-space Quirks ==
{{{
$ sudo gedit /etc/xen/xend-pci-quirks.sxp
}}}
* 說明: 請到 PCI_DB 網站: http://www.pcidatabase.com/ 來查詢您顯示卡的 vendor_id & device_id.
{{{
#!sh
(pci_ids
# Entries are formated as follows:
# :[::]
('10de:0605' # NVIDIA 9800GT
)
)
}}}
----
= 【Step 6: 啟動並登入你的虛擬機器 DomU 】 =
* 說明: 先用 root 免密碼登入.
* @ Dom0
{{{
$ cd /home/domains
$ sudo xm create -c xg01.cfg
}}}
----
= 【Step 7: 檢查 DomU 的 PCI Passthrough 有無成功】 =
* 先用 root 免密碼登入 xg01, 然後新增使用者 clouder.
{{{
# adduser clouder
}}}
{{{
#!sh
Adding user `clouder' ...
Adding new group `clouder' (1000) ...
Adding new user `clouder' (1000) with group `clouder' ...
Creating home directory `/home/clouder' ...
Copying files from `/etc/skel' ...
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
Changing the user information for clouder
Enter the new value, or press ENTER for the default
Full Name []:
Room Number []:
Work Phone []:
Home Phone []:
Other []:
Is the information correct? [Y/n] y
}}}
* 先登出 "root" 並且改用使用者 "clouder" 登入,並查看顯卡資訊有無正常顯示.
{{{
$ exit
$ sudo apt-get update
$ sudo apt-get install wget pciutils udev
$ lspci
}}}
{{{
#!sh
00:00.0 VGA compatible controller: nVidia Corporation Unknown device 0605 (rev a2)
}}}
* 更新 PCI ID Database.(當您發現系統無法正常偵測到你的顯示卡時)
{{{
$ sudo update-pciids
$ lspci
}}}
{{{
#!sh
00:00.0 VGA compatible controller: nVidia Corporation G92 [GeForce 9800 GT] (rev a2)
}}}
* @DomU 查看顯卡資源有無順利分配到 DomU.
{{{
$ dmesg | grep pci
}}}
{{{
#!sh
[ 0.745795] pcifront pci-0: Installing PCI frontend
[ 0.745872] pcifront pci-0: Creating PCI Frontend Bus 0000:00
[ 0.848291] pci 0000:00:00.0: Boot video device
}}}
* @Dom0 查看顯卡資源有無順利分配到 DomU.
{{{
$ dmesg | grep pci
}}}
{{{
# 台中機器
[ 0.718704] ACPI: bus type pci registered
[ 0.902598] pci 0000:00:1f.0: quirk: region 0400-047f claimed by ICH6 ACPI/GPIO/TCO
[ 0.902695] pci 0000:00:1f.0: quirk: region 0480-04bf claimed by ICH6 GPIO
[ 0.925960] pnp 00:01: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.928118] pnp 00:0a: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.928580] pnp 00:0b: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.929060] pnp 00:0c: PNP0c01: calling quirk_system_pci_resources+0x0/0x15c
[ 1.061488] pci 0000:01:00.0: Boot video device
[ 1.061674] Allocate Port Service[0000:00:01.0:pcie00]
[ 1.065543] Allocate Port Service[0000:00:01.0:pcie03]
[ 476.851360] pciback 0000:08:00.0: seizing device
[ 560.262910] pciback: vpci: 0000:08:00.0: assign to virtual slot 0
}}}
{{{
# 新竹機器
[ 0.655891] ACPI: bus type pci registered
[ 0.673706] pci 0000:00:1f.0: quirk: region f800-f87f claimed by ICH6 ACPI/GPIO/TCO
[ 0.673706] pci 0000:00:1f.0: quirk: region fa00-fa3f claimed by ICH6 GPIO
[ 0.706664] pnp 00:0c: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.706664] pnp 00:0d: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.706664] pnp 00:0e: PNP0c02: calling quirk_system_pci_resources+0x0/0x15c
[ 0.707107] pnp 00:0f: PNP0c01: calling quirk_system_pci_resources+0x0/0x15c
[ 0.836266] pci 0000:08:00.0: Boot video device
[ 0.836266] Allocate Port Service[0000:00:06.0:pcie00]
[ 0.836266] Allocate Port Service[0000:00:06.0:pcie03]
[ 0.836266] Allocate Port Service[0000:00:1c.0:pcie00]
[ 0.836266] Allocate Port Service[0000:00:1c.0:pcie02]
[ 0.836266] Allocate Port Service[0000:00:1c.0:pcie03]
[ 0.836266] Allocate Port Service[0000:00:1c.4:pcie00]
[ 0.836266] Allocate Port Service[0000:00:1c.4:pcie02]
[ 0.836266] Allocate Port Service[0000:00:1c.4:pcie03]
[ 0.836266] Allocate Port Service[0000:00:1c.5:pcie00]
[ 0.840261] Allocate Port Service[0000:00:1c.5:pcie02]
[ 0.840261] Allocate Port Service[0000:00:1c.5:pcie03]
[ 1891.425509] pciback 0000:08:00.0: seizing device
[ 2133.589319] pciback: vpci: 0000:08:00.0: assign to virtual slot 0
}}}
----
= 【討論 & 休息】 =
[[BR]]
[[BR]]