Diff for /wikisrc/ports/xen/howto.mdwn between versions 1.149 and 1.152

version 1.149, 2018/07/26 11:00:10 version 1.152, 2018/07/26 11:44:17
Line 19  Xen supports different styles of guest: Line 19  Xen supports different styles of guest:
   
 [[!table data="""  [[!table data="""
 Style of guest  |Supported by NetBSD  Style of guest  |Supported by NetBSD
 PV              |Yes  PV              |Yes (dom0, domU)
 HVM             |Yes  HVM             |Yes (domU)
 PVHVM           |No  PVHVM           |No
 PVH             |No  PVH             |No
 """]]  """]]
Line 35  There are further features for IOMMU vir Line 35  There are further features for IOMMU vir
 AMD's AMD-Vi.  TODO: Explain whether Xen on NetBSD makes use of these  AMD's AMD-Vi.  TODO: Explain whether Xen on NetBSD makes use of these
 features.  TODO: Review by someone who really understands this.  features.  TODO: Review by someone who really understands this.
   
 Generally any machine that runs NetBSD/amd64 will work with Xen and PV  
 guests.  In theory i386 computers (without x86_64/amd64 support) can  
 be used for Xen <= 4.2, but we have no recent reports of this working  
 (this is a hint).  For HVM guests, hardware support is needed, but it  
 is common on recent machines.  
   
 At boot, the dom0 kernel is loaded as a module with Xen as the kernel.  At boot, the dom0 kernel is loaded as a module with Xen as the kernel.
 The dom0 can start one or more domUs.  (Booting is explained in detail  The dom0 can start one or more domUs.  (Booting is explained in detail
 in the dom0 section.)  in the dom0 section.)
   
 NetBSD supports Xen in that it can serve as dom0, be used as a domU,  
 and that Xen kernels and tools are available in pkgsrc.  This HOWTO  
 attempts to address both the case of running a NetBSD dom0 on hardware  
 and running domUs under it (NetBSD and other), and also running NetBSD  
 as a domU in a VPS.  
   
 Xen 3.1 in pkgsrc used to support "PCI passthrough", which means that  
 specific PCI devices can be made available to a specific domU instead  
 of the dom0.  This can be useful to let a domU run X11, or access some  
 network interface or other peripheral.  
   
 NetBSD 6 and earlier supported Xen 2; support was removed from NetBSD  
 7.  Xen 2 has been removed from pkgsrc.  
   
 Prerequisites  
 -------------  
   
 Installing NetBSD/Xen is not extremely difficult, but it is more  
 complex than a normal installation of NetBSD.  
 In general, this HOWTO is occasionally overly restrictive about how  
 things must be done, guiding the reader to stay on the established  
 path when there are no known good reasons to stray.  
   
 This HOWTO presumes a basic familiarity with the Xen system  This HOWTO presumes a basic familiarity with the Xen system
 architecture, with installing NetBSD on i386/amd64 hardware, and with  architecture, with installing NetBSD on i386/amd64 hardware, and with
 installing software from pkgsrc.  See also the [Xen  installing software from pkgsrc.  See also the [Xen
 website](http://www.xenproject.org/).  website](http://www.xenproject.org/).
   
   This HOWTO attempts to address both the case of running a NetBSD dom0
   on hardware and running domUs under it (NetBSD and other), and also
   running NetBSD as a domU in a VPS.
   
 Versions of Xen and NetBSD  Versions of Xen and NetBSD
 ==========================  ==========================
   
Line 82  which version to choose.  Versions not i Line 57  which version to choose.  Versions not i
 versions of NetBSD are intentionally ignored.  versions of NetBSD are intentionally ignored.
   
 The term "amd64" is used to refer to both the NetBSD port and to the  The term "amd64" is used to refer to both the NetBSD port and to the
 hardware architecture on which it runs.  (Such hardware is made by  hardware architecture on which it runs.  Such hardware is generally
 both Intel and AMD, and in 2016 a normal PC has this CPU  made by both Intel and AMD, and common on PC computers.
 architecture.)  
   
 Xen versions  Xen versions
 ------------  ------------
Line 155  Architecture Line 129  Architecture
 ------------  ------------
   
 Xen itself can run on i386 (Xen < 4.2) or amd64 hardware (all Xen  Xen itself can run on i386 (Xen < 4.2) or amd64 hardware (all Xen
 versions).  (Practically, almost any computer where one would want to  versions).  Practically, almost any computer where one would want to
 run Xen today supports amd64.)  run Xen today supports amd64.
   
 Xen, the dom0 system, and each domU system can be either i386 or  Xen, the dom0 system, and each domU system can be either i386 or
 amd64.  When building a xenkernel package, one obtains an i386 Xen  amd64.  When building a xenkernel package, one obtains an i386 Xen
Line 166  be i386.  With an amd64 Xen kernel, an a Line 140  be i386.  With an amd64 Xen kernel, an a
 work, and an i386 dom0 kernel should in theory work.  An amd64  work, and an i386 dom0 kernel should in theory work.  An amd64
 Xen/dom0 is known to support both i386 and amd64 domUs.  Xen/dom0 is known to support both i386 and amd64 domUs.
   
 i386 dom0 and domU kernels must be PAE (except for an i386 Xen 3.1  i386 dom0 and domU kernels must be PAE. PAE kernels are included in
 kernel, where one can use non-PAE for dom0 and all domUs); PAE kernels  the NetBSD default build.
 are included in the NetBSD default build.  (Note that emacs (at least)  
 fails if run on i386 with PAE when built without, and vice versa,  
 presumably due to bugs in the undump code.)  
   
 Because of the above, the standard approach is to use an amd64 Xen  Because of the above, the standard approach is to use an amd64 Xen
 kernel and NetBSD/amd64 for the dom0.  For domUs, NetBSD/i386 (with  kernel and NetBSD/amd64 for the dom0.  For domUs, NetBSD/i386 (with
Line 192  caution that the total situation is comp Line 163  caution that the total situation is comp
 understood. On top of that caution, the post is about Linux, not  understood. On top of that caution, the post is about Linux, not
 NetBSD.  TODO: Include link to benchmarks, if someone posts them.  NetBSD.  TODO: Include link to benchmarks, if someone posts them.
   
 Recommendation  
 --------------  
   
 Therefore, this HOWTO recommends running xenkernel46, xl, the NetBSD 7  
 stable branch, and therefore to use an amd64 kernel as the dom0.  
 Either the i386PAE or amd64 version of NetBSD may be used as domUs.  
   
 A tentative replacement recommendation is xenkernel48, xl, and NetBSD  
 8.  
   
 Because bugs are fixed quite often, and because of Xen security  
 advisories, it is good to stay up to date with NetBSD (tracking a  
 stable branch), with the Xen kernel (tracking a Xen version via  
 pkgsrc), and with the Xen tools.  Specifically, NetBSD (-7 and  
 -current) got an important fix affecting dom0/domU timesharing in  
 November, 2015, and xentools46 got a fix to enable Ubuntu guests to  
 boot in December, 2016.  
   
 NetBSD as a dom0  NetBSD as a dom0
 ================  ================
   
Line 300  documentation](https://www.NetBSD.org/do Line 253  documentation](https://www.NetBSD.org/do
 pkgsrc.  Ensure that your packages are recent; the HOWTO does not  pkgsrc.  Ensure that your packages are recent; the HOWTO does not
 contemplate old builds.  contemplate old builds.
   
   
 For Xen 3.1, support for HVM guests is in sysutils/xentool3-hvm.  More  
 recent versions have HVM support integrated in the main xentools  
 package.  It is entirely reasonable to run only PV guests.  
   
 Next you need to install the selected Xen kernel itself, which is  Next you need to install the selected Xen kernel itself, which is
 installed by pkgsrc as "/usr/pkg/xen*-kernel/xen.gz".  Copy it to /.  installed by pkgsrc as "/usr/pkg/xen*-kernel/xen.gz".  Copy it to /.
 For debugging, one may copy xen-debug.gz; this is conceptually similar  For debugging, one may copy xen-debug.gz; this is conceptually similar
Line 326  with an MBR bootblock, either bootxx_ffs Line 274  with an MBR bootblock, either bootxx_ffs
 beginning of your root file system, have /boot, and likely also  beginning of your root file system, have /boot, and likely also
 /boot.cfg.  (If not, fix before continuing!)  /boot.cfg.  (If not, fix before continuing!)
   
 Add a line to to /boot.cfg to boot Xen.  See boot.cfg(5) for an  Add a line to /boot.cfg to boot Xen.  See boot.cfg(5) for an
 example.  The basic line is  example.  The basic line is:
   
         menu=Xen:load /netbsd-XEN3_DOM0.gz console=pc;multiboot /xen.gz dom0_mem=512M  [[!template id=programlisting text="""
   menu=Xen:load /netbsd-XEN3_DOM0.gz console=pc;multiboot /xen.gz dom0_mem=512M
   """]]
   
 which specifies that the dom0 should have 512M, leaving the rest to be  which specifies that the dom0 should have 512M, leaving the rest to be
 allocated for domUs.  To use a serial console, use  allocated for domUs.  To use a serial console, use
   
         menu=Xen:load /netbsd-XEN3_DOM0.gz;multiboot /xen.gz dom0_mem=512M console=com1 com1=9600,8n1  [[!template id=programlisting text="""
   menu=Xen:load /netbsd-XEN3_DOM0.gz;multiboot /xen.gz dom0_mem=512M console=com1 com1=9600,8n1
   """]]
   
 which will use the first serial port for Xen (which counts starting  which will use the first serial port for Xen (which counts starting
 from 1, unlike NetBSD which counts starting from 0), forcing  from 1, unlike NetBSD which counts starting from 0), forcing
Line 343  speed/parity.  Because the NetBSD comman Line 295  speed/parity.  Because the NetBSD comman
 which directs the console I/O through Xen to the same console device Xen  which directs the console I/O through Xen to the same console device Xen
 itself uses (in this case, the serial port).  itself uses (in this case, the serial port).
   
 In an attempt to add performance, one can also add  In an attempt to add performance, one can also add:
   
         dom0_max_vcpus=1 dom0_vcpus_pin  [[!template id=programlisting text="""
   dom0_max_vcpus=1 dom0_vcpus_pin
   """]]
   
 to force only one vcpu to be provided (since NetBSD dom0 can't use  to force only one vcpu to be provided (since NetBSD dom0 can't use
 more) and to pin that vcpu to a physical CPU.  TODO: benchmark this.  more) and to pin that vcpu to a physical CPU.  TODO: benchmark this.
Line 393  There will be no domUs, and none can be  Line 347  There will be no domUs, and none can be 
 to configure the dom0 daemons.  to configure the dom0 daemons.
   
 The daemons which should be run vary with Xen version and with whether  The daemons which should be run vary with Xen version and with whether
 one is using xm or xl.  The Xen 3.1, 3.3 and 4.1 packages use xm.  Xen  one is using xm or xl. Xen 4.2 and up packages use xl. To use xm with 4.2,
 4.2 and up packages use xl.  To use xm with 4.2, edit xendomains to  edit xendomains to use xm instead.
 use xm instead.  
   
 For 3.1 and 3.3, you should enable xend and xenbackendd:  
   
         xend=YES  
         xenbackendd=YES  
   
 For 4.1 and up, you should enable xencommons.  Not enabling xencommons  For 4.1 and up, you should enable xencommons.  Not enabling xencommons
 will result in a hang; it is necessary to hit ^C on the console to let  will result in a hang; it is necessary to hit ^C on the console to let
 the machine finish booting.  If you are using xm (default in 4.1, or  the machine finish booting.  If you are using xm (default in 4.1, or
 if you changed xendomains in 4.2), you should also enable xend:  if you changed xendomains in 4.2), you should also enable xend:
   
         xend=YES # only if using xm, and only installed <= 4.2  [[!template id=programlisting text="""
         xencommons=YES  xend=YES # only if using xm, and only installed <= 4.2
   xencommons=YES
   """]]
   
 TODO: Recommend for/against xen-watchdog.  TODO: Recommend for/against xen-watchdog.
   

Removed from v.1.149  
changed lines
  Added in v.1.152


CVSweb for NetBSD wikisrc <wikimaster@NetBSD.org> software: FreeBSD-CVSweb