1 | <?xml version="1.0" encoding="UTF-8"?>
|
---|
2 | <!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN"
|
---|
3 | "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd">
|
---|
4 | <chapter id="Troubleshooting">
|
---|
5 | <title>Troubleshooting</title>
|
---|
6 |
|
---|
7 | <para>This chapter provides answers to commonly asked questions. In order to
|
---|
8 | improve your user experience with VirtualBox, it is recommended to read this
|
---|
9 | section to learn more about common pitfalls and get recommendations on how
|
---|
10 | to use the product.</para>
|
---|
11 |
|
---|
12 | <sect1>
|
---|
13 | <title>Procedures and tools</title>
|
---|
14 |
|
---|
15 | <sect2>
|
---|
16 | <title>Categorizing and isolating problems</title>
|
---|
17 |
|
---|
18 | <para>More often than not, a virtualized guest behaves like a physical
|
---|
19 | system. Any problems that a physical machine would encounter, a virtual
|
---|
20 | machine will encounter as well. If, for example, Internet connectivity
|
---|
21 | is lost due to external issues, virtual machines will be affected just
|
---|
22 | as much as physical ones.</para>
|
---|
23 |
|
---|
24 | <para>If a true VirtualBox problem is encountered, it helps to
|
---|
25 | categorize and isolate the problem first. Here are some of the questions
|
---|
26 | that should be answered before reporting a problem:<orderedlist>
|
---|
27 | <listitem>
|
---|
28 | <para>Is the problem specific to a certain guest OS? Specific
|
---|
29 | release of a guest OS? Especially with Linux guest related
|
---|
30 | problems, the issue may be specific to a certain distribution and
|
---|
31 | version of Linux.</para>
|
---|
32 | </listitem>
|
---|
33 |
|
---|
34 | <listitem>
|
---|
35 | <para>Is the problem specific to a certain host OS? Problems are
|
---|
36 | usually not host OS specific (because most of the VirtualBox code
|
---|
37 | base is shared across all supported platforms), but especially in
|
---|
38 | the areas of networking and USB support, there are significant
|
---|
39 | differences between host platforms. Some GUI related issues are
|
---|
40 | also host specific.</para>
|
---|
41 | </listitem>
|
---|
42 |
|
---|
43 | <listitem>
|
---|
44 | <para>Is the problem specific to certain host hardware? This
|
---|
45 | category of issues is typically related to the host CPU. Because
|
---|
46 | of significant differences between VT-x and AMD-V, problems may be
|
---|
47 | specific to one or the other technology. The exact CPU model may
|
---|
48 | also make a difference (even for software virtualization) because
|
---|
49 | different CPUs support different features, which may affect
|
---|
50 | certain aspects of guest CPU operation.</para>
|
---|
51 | </listitem>
|
---|
52 |
|
---|
53 | <listitem>
|
---|
54 | <para>Is the problem specific to a certain virtualization mode?
|
---|
55 | Some problems may only occur in software virtualization mode,
|
---|
56 | others may be specific to hardware virtualization.</para>
|
---|
57 | </listitem>
|
---|
58 |
|
---|
59 | <listitem>
|
---|
60 | <para>Is the problem specific to guest SMP? That is, is it related
|
---|
61 | to the number of virtual CPUs (VCPUs) in the guest? Using more
|
---|
62 | than one CPU usually significantly affects the internal operation
|
---|
63 | of a guest OS.</para>
|
---|
64 | </listitem>
|
---|
65 |
|
---|
66 | <listitem>
|
---|
67 | <para>Is the problem specific to the Guest Additions? In some
|
---|
68 | cases, this is a given (e.g., a shared folders problem), in other
|
---|
69 | cases it may be less obvious (for example, display problems). And
|
---|
70 | if the problem is Guest Additions specific, is it also specific to
|
---|
71 | a certain version of the Additions?</para>
|
---|
72 | </listitem>
|
---|
73 |
|
---|
74 | <listitem>
|
---|
75 | <para>Is the problem specific to a certain environment? Some
|
---|
76 | problems are related to a particular environment external to the
|
---|
77 | VM; this usually involves network setup. Certain configurations of
|
---|
78 | external servers such as DHCP or PXE may expose problems which do
|
---|
79 | not occur with other, similar servers.</para>
|
---|
80 | </listitem>
|
---|
81 |
|
---|
82 | <listitem>
|
---|
83 | <para>Is the problem a regression? Knowing that an issue is a
|
---|
84 | regression usually makes it significantly easier to find the
|
---|
85 | solution. In this case, it is crucial to know which version is
|
---|
86 | affected and which is not.</para>
|
---|
87 | </listitem>
|
---|
88 | </orderedlist></para>
|
---|
89 | </sect2>
|
---|
90 |
|
---|
91 | <sect2>
|
---|
92 | <title>Collecting debugging information</title>
|
---|
93 |
|
---|
94 | <para>For problem determination, it is often important to collect
|
---|
95 | debugging information which can be analyzed by VirtualBox support. This
|
---|
96 | section contains information about what kind of information can be
|
---|
97 | obtained.</para>
|
---|
98 |
|
---|
99 | <para>Every time VirtualBox starts up a VM, a so-called <emphasis
|
---|
100 | role="bold">"release log file"</emphasis> is created containing lots of
|
---|
101 | information about the VM configuration and runtime events. The log file
|
---|
102 | is called <computeroutput><literal>VBox.log</literal></computeroutput>
|
---|
103 | and resides in the VM log file folder. Typically this will be a
|
---|
104 | directory like this:<screen>$HOME/VirtualBox VMs/{machinename}/Logs</screen></para>
|
---|
105 |
|
---|
106 | <para>When starting a VM, the configuration file of the last run will be
|
---|
107 | renamed to <computeroutput>.1</computeroutput>, up to
|
---|
108 | <computeroutput>.3</computeroutput>. Sometimes when there is a problem,
|
---|
109 | it is useful to have a look at the logs. Also when requesting support
|
---|
110 | for VirtualBox, supplying the corresponding log file is
|
---|
111 | mandatory.</para>
|
---|
112 |
|
---|
113 | <para>For convenience, for each virtual machine, the VirtualBox main
|
---|
114 | window can show these logs in a window. To access it, select a virtual
|
---|
115 | machine from the list on the left and select "Show logs..." from the
|
---|
116 | "Machine" window.</para>
|
---|
117 |
|
---|
118 | <para>The release log file (VBox.log) contains a wealth of diagnostic
|
---|
119 | information, such as Host OS type and version, VirtualBox version and
|
---|
120 | build (32-bit or 64-bit), a complete dump of the guest's configuration
|
---|
121 | (CFGM), detailed information about the host CPU type and supported
|
---|
122 | features, whether hardware virtualization is enabled, information about
|
---|
123 | VT-x/AMD-V setup, state transitions (creating, running, paused,
|
---|
124 | stopping, etc.), guest BIOS messages, Guest Additions messages,
|
---|
125 | device-specific log entries and, at the end of execution, final guest
|
---|
126 | state and condensed statistics.</para>
|
---|
127 |
|
---|
128 | <para>In case of crashes, it is very important to collect <emphasis
|
---|
129 | role="bold">crash dumps</emphasis>. This is true for both host and guest
|
---|
130 | crashes. For information about enabling core dumps on Linux, Solaris,
|
---|
131 | and OS X systems, refer to the core dump article on the VirtualBox
|
---|
132 | website.<footnote>
|
---|
133 | <para><ulink
|
---|
134 | url="http://www.virtualbox.org/wiki/Core_dump">http://www.virtualbox.org/wiki/Core_dump</ulink>.</para>
|
---|
135 | </footnote></para>
|
---|
136 |
|
---|
137 | <para>You can also use <computeroutput>VBoxManage
|
---|
138 | debugvm</computeroutput> to create a dump of a complete virtual machine;
|
---|
139 | see <xref linkend="vboxmanage-debugvm" />.</para>
|
---|
140 |
|
---|
141 | <para>For network related problems, it is often helpful to capture a
|
---|
142 | trace of network traffic. If the traffic is routed through an adapter on
|
---|
143 | the host, it is possible to use Wireshark or a similar tool to capture
|
---|
144 | the traffic there. However, this often also includes a lot of traffic
|
---|
145 | unrelated to the VM.</para>
|
---|
146 |
|
---|
147 | <para>VirtualBox provides an ability to capture network traffic only on
|
---|
148 | a specific VM's network adapter. Refer to the network tracing article on
|
---|
149 | the VirtualBox website<footnote>
|
---|
150 | <para><ulink
|
---|
151 | url="http://www.virtualbox.org/wiki/Network_tips">http://www.virtualbox.org/wiki/Network_tips</ulink>.</para>
|
---|
152 | </footnote> for information on enabling this capture. The trace files
|
---|
153 | created by VirtualBox are in <computeroutput>.pcap</computeroutput>
|
---|
154 | format and can be easily analyzed with Wireshark.</para>
|
---|
155 | </sect2>
|
---|
156 |
|
---|
157 | <sect2>
|
---|
158 | <title id="debugger">The built-in VM debugger</title>
|
---|
159 |
|
---|
160 | <para>VirtualBox includes a built-in VM debugger, which advanced users
|
---|
161 | may find useful. This debugger allows for examining and, to some extent,
|
---|
162 | controlling the VM state.<warning>
|
---|
163 | <para>Use the VM debugger at your own risk. There is no support for
|
---|
164 | it, and the following documentation is only made available for
|
---|
165 | advanced users with a very high level of familiarity with the
|
---|
166 | x86/AMD64 machine instruction set, as well as detailed knowledge of
|
---|
167 | the PC architecture. A degree of familiarity with the internals of
|
---|
168 | the guest OS in question may also be very helpful.</para>
|
---|
169 | </warning></para>
|
---|
170 |
|
---|
171 | <para>The VM debugger is available in all regular production versions of
|
---|
172 | VirtualBox, but it is disabled by default because the average user will
|
---|
173 | have little use for it. There are two ways to access the
|
---|
174 | debugger:<itemizedlist>
|
---|
175 | <listitem>
|
---|
176 | <para>A debugger console window displayed alongside the VM</para>
|
---|
177 | </listitem>
|
---|
178 |
|
---|
179 | <listitem>
|
---|
180 | <para>Via the <computeroutput>telnet</computeroutput> protocol at
|
---|
181 | port 5000</para>
|
---|
182 | </listitem>
|
---|
183 | </itemizedlist></para>
|
---|
184 |
|
---|
185 | <para>The debugger can be enabled in three ways:<itemizedlist>
|
---|
186 | <listitem>
|
---|
187 | <para>Start the VM directly using <computeroutput>VirtualBox
|
---|
188 | --startvm</computeroutput>, with an additional
|
---|
189 | <computeroutput>--dbg</computeroutput>,
|
---|
190 | <computeroutput>--debug</computeroutput>, or
|
---|
191 | <computeroutput>--debug-command-line</computeroutput> argument.
|
---|
192 | See the VirtualBox usage help for details.</para>
|
---|
193 | </listitem>
|
---|
194 |
|
---|
195 | <listitem>
|
---|
196 | <para>Set the
|
---|
197 | <computeroutput>VBOX_GUI_DBG_ENABLED</computeroutput> or
|
---|
198 | <computeroutput>VBOX_GUI_DBG_AUTO_SHOW</computeroutput>
|
---|
199 | environment variable to <computeroutput>true</computeroutput>
|
---|
200 | before launching the VirtualBox process. Setting these variables
|
---|
201 | (only their presence is checked) is effective even when the first
|
---|
202 | VirtualBox process is the VM selector window. VMs subsequently
|
---|
203 | launched from the selector will have the debugger enabled.</para>
|
---|
204 | </listitem>
|
---|
205 |
|
---|
206 | <listitem>
|
---|
207 | <para>Set the <computeroutput>GUI/Dbg/Enabled</computeroutput>
|
---|
208 | extra data item to <computeroutput>true</computeroutput> before
|
---|
209 | launching the VM. This can be set globally or on a per VM
|
---|
210 | basis.</para>
|
---|
211 | </listitem>
|
---|
212 | </itemizedlist></para>
|
---|
213 |
|
---|
214 | <para>A new 'Debug' menu entry will be added to the VirtualBox
|
---|
215 | application. This menu allows the user to open the debugger
|
---|
216 | console.</para>
|
---|
217 |
|
---|
218 | <para>The VM debugger command syntax is loosely modeled on Microsoft and
|
---|
219 | IBM debuggers used on DOS, OS/2 and Windows. Users familiar with symdeb,
|
---|
220 | CodeView, or the OS/2 kernel debugger will find the VirtualBox VM
|
---|
221 | debugger familiar.</para>
|
---|
222 |
|
---|
223 | <para>The most important command is
|
---|
224 | <computeroutput>help</computeroutput>. This will print brief usage help
|
---|
225 | for all debugger commands. The set of commands supported by the VM
|
---|
226 | debugger changes frequently and the
|
---|
227 | <computeroutput>help</computeroutput> command is always
|
---|
228 | up-to-date.</para>
|
---|
229 |
|
---|
230 | <para>A brief summary of frequently used commands follows:<itemizedlist>
|
---|
231 | <listitem>
|
---|
232 | <para><computeroutput>stop</computeroutput> -- stops the VM
|
---|
233 | execution and enables single stepping</para>
|
---|
234 | </listitem>
|
---|
235 |
|
---|
236 | <listitem>
|
---|
237 | <para><computeroutput>g</computeroutput> -- continue VM
|
---|
238 | execution</para>
|
---|
239 | </listitem>
|
---|
240 |
|
---|
241 | <listitem>
|
---|
242 | <para><computeroutput>t</computeroutput> -- single step an
|
---|
243 | instruction</para>
|
---|
244 | </listitem>
|
---|
245 |
|
---|
246 | <listitem>
|
---|
247 | <para><computeroutput>rg/rh/r</computeroutput> -- print the
|
---|
248 | guest/hypervisor/current registers</para>
|
---|
249 | </listitem>
|
---|
250 |
|
---|
251 | <listitem>
|
---|
252 | <para><computeroutput>kg/kh/k</computeroutput> -- print the
|
---|
253 | guest/hypervisor/current call stack</para>
|
---|
254 | </listitem>
|
---|
255 |
|
---|
256 | <listitem>
|
---|
257 | <para><computeroutput>da/db/dw/dd/dq</computeroutput> -- print
|
---|
258 | memory contents as ASCII/bytes/words/dwords/qwords</para>
|
---|
259 | </listitem>
|
---|
260 |
|
---|
261 | <listitem>
|
---|
262 | <para><computeroutput>u</computeroutput> -- unassemble
|
---|
263 | memory</para>
|
---|
264 | </listitem>
|
---|
265 |
|
---|
266 | <listitem>
|
---|
267 | <para><computeroutput>dg</computeroutput> -- print the guest's
|
---|
268 | GDT</para>
|
---|
269 | </listitem>
|
---|
270 |
|
---|
271 | <listitem>
|
---|
272 | <para><computeroutput>di</computeroutput> -- print the guest's
|
---|
273 | IDT</para>
|
---|
274 | </listitem>
|
---|
275 |
|
---|
276 | <listitem>
|
---|
277 | <para><computeroutput>dl</computeroutput> -- print the guest's
|
---|
278 | LDT</para>
|
---|
279 | </listitem>
|
---|
280 |
|
---|
281 | <listitem>
|
---|
282 | <para><computeroutput>dt</computeroutput> -- print the guest's
|
---|
283 | TSS</para>
|
---|
284 | </listitem>
|
---|
285 |
|
---|
286 | <listitem>
|
---|
287 | <para><computeroutput>dp*</computeroutput> -- print the guest's
|
---|
288 | page table structures</para>
|
---|
289 | </listitem>
|
---|
290 |
|
---|
291 | <listitem>
|
---|
292 | <para><computeroutput>bp/br</computeroutput> -- set a
|
---|
293 | normal/recompiler breakpoint</para>
|
---|
294 | </listitem>
|
---|
295 |
|
---|
296 | <listitem>
|
---|
297 | <para><computeroutput>bl</computeroutput> -- list
|
---|
298 | breakpoints</para>
|
---|
299 | </listitem>
|
---|
300 |
|
---|
301 | <listitem>
|
---|
302 | <para><computeroutput>bc</computeroutput> -- clear a
|
---|
303 | breakpoint</para>
|
---|
304 | </listitem>
|
---|
305 |
|
---|
306 | <listitem>
|
---|
307 | <para><computeroutput>writecore</computeroutput> -- writes a VM
|
---|
308 | core file to disk, refer <xref linkend="guestcoreformat" /></para>
|
---|
309 | </listitem>
|
---|
310 | </itemizedlist></para>
|
---|
311 |
|
---|
312 | <para>See the built-in <computeroutput>help</computeroutput> for other
|
---|
313 | available commands.</para>
|
---|
314 |
|
---|
315 | <para>The VM debugger supports symbolic debugging, although symbols for
|
---|
316 | guest code are often not available. For Solaris guests, the
|
---|
317 | <computeroutput>detect</computeroutput> command automatically determines
|
---|
318 | the guest OS version and locates kernel symbols in guest's memory.
|
---|
319 | Symbolic debugging is then available. For Linux guests, the
|
---|
320 | <computeroutput>detect</computeroutput> commands also determines the
|
---|
321 | guest OS version, but there are no symbols in the guest's memory. Kernel
|
---|
322 | symbols are available in the file
|
---|
323 | <computeroutput>/proc/kallsyms</computeroutput> on Linux guests. This
|
---|
324 | file must be copied to the host, for example using
|
---|
325 | <computeroutput>scp</computeroutput>. The
|
---|
326 | <computeroutput>loadmap</computeroutput> debugger command can be used to
|
---|
327 | make the symbol information available to the VM debugger. Note that the
|
---|
328 | <computeroutput>kallsyms</computeroutput> file contains the symbols for
|
---|
329 | the currently loaded modules; if the guest's configuration changes, the
|
---|
330 | symbols will change as well and must be updated.</para>
|
---|
331 |
|
---|
332 | <para>For all guests, a simple way to verify that the correct symbols
|
---|
333 | are loaded is the <computeroutput>k</computeroutput> command. The guest
|
---|
334 | is normally idling and it should be clear from the symbolic information
|
---|
335 | that the guest operating system's idle loop is being executed.</para>
|
---|
336 |
|
---|
337 | <para>Another group of debugger commands is the set of
|
---|
338 | <computeroutput>info</computeroutput> commands. Running
|
---|
339 | <computeroutput>info help</computeroutput> provides complete usage
|
---|
340 | information. The information commands provide ad-hoc data pertinent to
|
---|
341 | various emulated devices and aspects of the VMM. There is no general
|
---|
342 | guideline for using the <computeroutput>info</computeroutput> commands,
|
---|
343 | the right command to use depends entirely on the problem being
|
---|
344 | investigated. Some of the info commands are:<itemizedlist>
|
---|
345 | <listitem>
|
---|
346 | <para><computeroutput>cfgm</computeroutput> -- print a branch of
|
---|
347 | the configuration tree</para>
|
---|
348 | </listitem>
|
---|
349 |
|
---|
350 | <listitem>
|
---|
351 | <para><computeroutput>cpuid</computeroutput> -- display the guest
|
---|
352 | CPUID leaves</para>
|
---|
353 | </listitem>
|
---|
354 |
|
---|
355 | <listitem>
|
---|
356 | <para><computeroutput>ioport</computeroutput> -- print registered
|
---|
357 | I/O port ranges</para>
|
---|
358 | </listitem>
|
---|
359 |
|
---|
360 | <listitem>
|
---|
361 | <para><computeroutput>mmio</computeroutput> -- print registered
|
---|
362 | MMIO ranges</para>
|
---|
363 | </listitem>
|
---|
364 |
|
---|
365 | <listitem>
|
---|
366 | <para><computeroutput>mode</computeroutput> -- print the current
|
---|
367 | paging mode</para>
|
---|
368 | </listitem>
|
---|
369 |
|
---|
370 | <listitem>
|
---|
371 | <para><computeroutput>pit</computeroutput> -- print the i8254 PIT
|
---|
372 | state</para>
|
---|
373 | </listitem>
|
---|
374 |
|
---|
375 | <listitem>
|
---|
376 | <para><computeroutput>pic</computeroutput> -- print the i8259A PIC
|
---|
377 | state</para>
|
---|
378 | </listitem>
|
---|
379 |
|
---|
380 | <listitem>
|
---|
381 | <para><computeroutput>ohci/ehci</computeroutput> -- print a subset
|
---|
382 | of the OHCI/EHCI USB controller state</para>
|
---|
383 | </listitem>
|
---|
384 |
|
---|
385 | <listitem>
|
---|
386 | <para><computeroutput>pcnet0</computeroutput> -- print the PCnet
|
---|
387 | state</para>
|
---|
388 | </listitem>
|
---|
389 |
|
---|
390 | <listitem>
|
---|
391 | <para><computeroutput>vgatext</computeroutput> -- print the
|
---|
392 | contents of the VGA framebuffer formatted as standard text
|
---|
393 | mode</para>
|
---|
394 | </listitem>
|
---|
395 |
|
---|
396 | <listitem>
|
---|
397 | <para><computeroutput>timers</computeroutput> -- print all VM
|
---|
398 | timers</para>
|
---|
399 | </listitem>
|
---|
400 | </itemizedlist></para>
|
---|
401 |
|
---|
402 | <para>The output of the <computeroutput>info</computeroutput> commands
|
---|
403 | generally requires in-depth knowledge of the emulated device and/or
|
---|
404 | VirtualBox VMM internals. However, when used properly, the information
|
---|
405 | provided can be invaluable.</para>
|
---|
406 | </sect2>
|
---|
407 |
|
---|
408 | <sect2 id="guestcoreformat">
|
---|
409 | <title>VM core format</title>
|
---|
410 |
|
---|
411 | <para>VirtualBox uses the 64-bit ELF format for its VM core files
|
---|
412 | created by <computeroutput>VBoxManage debugvm</computeroutput>; see
|
---|
413 | <xref linkend="vboxmanage-debugvm" />. The VM core file contain the
|
---|
414 | memory and CPU dumps of the VM and can be useful for debugging your
|
---|
415 | guest OS. The 64-bit ELF object format specficiation can be obtained
|
---|
416 | here: <literal><ulink
|
---|
417 | url="http://downloads.openwatcom.org/ftp/devel/docs/elf-64-gen.pdf">http://downloads.openwatcom.org/ftp/devel/docs/elf-64-gen.pdf</ulink></literal>.</para>
|
---|
418 |
|
---|
419 | <para>The overall layout of the VM core format is as follows:</para>
|
---|
420 |
|
---|
421 | <para><screen>[ ELF 64 Header]
|
---|
422 | [ Program Header, type PT_NOTE ]
|
---|
423 | -> offset to COREDESCRIPTOR
|
---|
424 | [ Program Header, type PT_LOAD ] - one for each contiguous physical memory range
|
---|
425 | -> Memory offset of range
|
---|
426 | -> File offset
|
---|
427 | [ Note Header, type NT_VBOXCORE ]
|
---|
428 | [ COREDESCRIPTOR ]
|
---|
429 | -> Magic
|
---|
430 | -> VM core file version
|
---|
431 | -> VBox version
|
---|
432 | -> Number of vCPUs etc.
|
---|
433 | [ Note Header, type NT_VBOXCPU ] - one for each vCPU
|
---|
434 | [ vCPU 1 Note Header ]
|
---|
435 | [ CPUMCTX - vCPU 1 dump ]
|
---|
436 | [ Additional Notes + Data ] - currently unused
|
---|
437 | [ Memory dump ]</screen></para>
|
---|
438 |
|
---|
439 | <para>The memory descriptors contain physical addresses relative to the
|
---|
440 | guest and not virtual addresses. Regions of memory such as MMIO regions
|
---|
441 | are not included in the core file.</para>
|
---|
442 |
|
---|
443 | <para>The relevant data structures and definitions can be found in the
|
---|
444 | VirtualBox sources under the following header files:
|
---|
445 | <computeroutput>include/VBox/dbgfcorefmt.h</computeroutput>,
|
---|
446 | <computeroutput>include/VBox/cpumctx.h</computeroutput> and
|
---|
447 | <computeroutput>src/VBox/Runtime/include/internal/ldrELFCommon.h</computeroutput>.</para>
|
---|
448 |
|
---|
449 | <para>The VM core file can be inspected using
|
---|
450 | <computeroutput>elfdump</computeroutput> and GNU
|
---|
451 | <computeroutput>readelf</computeroutput> or other similar
|
---|
452 | utilities.</para>
|
---|
453 | </sect2>
|
---|
454 | </sect1>
|
---|
455 |
|
---|
456 | <sect1>
|
---|
457 | <title>General</title>
|
---|
458 |
|
---|
459 | <sect2 id="configPeriodicFlush">
|
---|
460 | <title>Guest shows IDE/SATA errors for file-based images on slow host
|
---|
461 | file system</title>
|
---|
462 |
|
---|
463 | <para>Occasionally, some host file systems provide very poor writing
|
---|
464 | performance and as a consequence cause the guest to time out IDE/SATA
|
---|
465 | commands. This is normal behavior and should normally cause no real
|
---|
466 | problems, as the guest should repeat commands that have timed out.
|
---|
467 | However some guests (e.g. some Linux versions) have severe problems if a
|
---|
468 | write to an image file takes longer than about 15 seconds. Some file
|
---|
469 | systems however require more than a minute to complete a single write,
|
---|
470 | if the host cache contains a large amount of data that needs to be
|
---|
471 | written.</para>
|
---|
472 |
|
---|
473 | <para>The symptom for this problem is that the guest can no longer
|
---|
474 | access its files during large write or copying operations, usually
|
---|
475 | leading to an immediate hang of the guest.</para>
|
---|
476 |
|
---|
477 | <para>In order to work around this problem (the true fix is to use a
|
---|
478 | faster file system that doesn't exhibit such unacceptable write
|
---|
479 | performance), it is possible to flush the image file after a certain
|
---|
480 | amount of data has been written. This interval is normally infinite, but
|
---|
481 | can be configured individually for each disk of a VM.</para>
|
---|
482 |
|
---|
483 | <para>For IDE disks use the following command:</para>
|
---|
484 |
|
---|
485 | <screen>VBoxManage setextradata "VM name"
|
---|
486 | "VBoxInternal/Devices/piix3ide/0/LUN#[x]/Config/FlushInterval" [b]</screen>
|
---|
487 |
|
---|
488 | <para>For SATA disks use the following command:</para>
|
---|
489 |
|
---|
490 | <screen>VBoxManage setextradata "VM name"
|
---|
491 | "VBoxInternal/Devices/ahci/0/LUN#[x]/Config/FlushInterval" [b]</screen>
|
---|
492 |
|
---|
493 | <para>The value [x] that selects the disk for IDE is 0 for the master
|
---|
494 | device on the first channel, 1 for the slave device on the first
|
---|
495 | channel, 2 for the master device on the second channel or 3 for the
|
---|
496 | master device on the second channel. For SATA use values between 0 and
|
---|
497 | 29. Only disks support this configuration option; it must not be set for
|
---|
498 | CD/DVD drives.</para>
|
---|
499 |
|
---|
500 | <para>The unit of the interval [b] is the number of bytes written since
|
---|
501 | the last flush. The value for it must be selected so that the occasional
|
---|
502 | long write delays do not occur. Since the proper flush interval depends
|
---|
503 | on the performance of the host and the host filesystem, finding the
|
---|
504 | optimal value that makes the problem disappear requires some
|
---|
505 | experimentation. Values between 1000000 and 10000000 (1 to 10 megabytes)
|
---|
506 | are a good starting point. Decreasing the interval both decreases the
|
---|
507 | probability of the problem and the write performance of the guest.
|
---|
508 | Setting the value unnecessarily low will cost performance without
|
---|
509 | providing any benefits. An interval of 1 will cause a flush for each
|
---|
510 | write operation and should solve the problem in any case, but has a
|
---|
511 | severe write performance penalty.</para>
|
---|
512 |
|
---|
513 | <para>Providing a value of 0 for [b] is treated as an infinite flush
|
---|
514 | interval, effectively disabling this workaround. Removing the extra data
|
---|
515 | key by specifying no value for [b] has the same effect.</para>
|
---|
516 | </sect2>
|
---|
517 |
|
---|
518 | <sect2>
|
---|
519 | <title>Responding to guest IDE/SATA flush requests</title>
|
---|
520 |
|
---|
521 | <para>If desired, the virtual disk images can be flushed when the guest
|
---|
522 | issues the IDE FLUSH CACHE command. Normally these requests are ignored
|
---|
523 | for improved performance. The parameters below are only accepted for
|
---|
524 | disk drives. They must not be set for DVD drives.</para>
|
---|
525 |
|
---|
526 | <para>To enable flushing for IDE disks, issue the following
|
---|
527 | command:</para>
|
---|
528 |
|
---|
529 | <screen>VBoxManage setextradata "VM name" "VBoxInternal/Devices/piix3ide/0/LUN#[x]/Config/IgnoreFlush" 0</screen>
|
---|
530 |
|
---|
531 | <para>The value [x] that selects the disk is 0 for the master device on
|
---|
532 | the first channel, 1 for the slave device on the first channel, 2 for
|
---|
533 | the master device on the second channel or 3 for the master device on
|
---|
534 | the second channel.</para>
|
---|
535 |
|
---|
536 | <para>To enable flushing for SATA disks, issue the following
|
---|
537 | command:</para>
|
---|
538 |
|
---|
539 | <screen>VBoxManage setextradata "VM name" "VBoxInternal/Devices/ahci/0/LUN#[x]/Config/IgnoreFlush" 0</screen>
|
---|
540 |
|
---|
541 | <para>The value [x] that selects the disk can be a value between 0 and
|
---|
542 | 29.</para>
|
---|
543 |
|
---|
544 | <para>Note that this doesn't affect the flushes performed according to
|
---|
545 | the configuration described in <xref linkend="configPeriodicFlush"
|
---|
546 | xrefstyle="template: %n" />. Restoring the default of ignoring flush
|
---|
547 | commands is possible by setting the value to 1 or by removing the
|
---|
548 | key.</para>
|
---|
549 | </sect2>
|
---|
550 |
|
---|
551 | <sect2 id="hostPowerMgmt">
|
---|
552 | <title>Poor performance caused by host power management</title>
|
---|
553 |
|
---|
554 | <para>On some hardware platforms and operating systems, virtualization
|
---|
555 | peformance is negatively affected by host CPU power management. The
|
---|
556 | symptoms may be choppy audio in the guest or erratic guest clock
|
---|
557 | behavior.</para>
|
---|
558 |
|
---|
559 | <para>Some of the problems may be caused by firmware and/or host
|
---|
560 | operating system bugs. Therefore, updating the firmware and applying
|
---|
561 | operating systems fixes is recommended.</para>
|
---|
562 |
|
---|
563 | <para>For optimal virtualization performance, the C1E power state
|
---|
564 | support in the system's BIOS should be disabled, if such a setting is
|
---|
565 | available (not all systems support the C1E power state). Disabling other
|
---|
566 | power management settings may also improve performance. However, a
|
---|
567 | balance between performance and power consumption must always be
|
---|
568 | considered.</para>
|
---|
569 | </sect2>
|
---|
570 |
|
---|
571 | <sect2 id="gui2D_grayedout">
|
---|
572 | <title>GUI: 2D Video Acceleration option is grayed out</title>
|
---|
573 |
|
---|
574 | <para>To use 2D Video Acceleration within VirtualBox, your host's video
|
---|
575 | card should support certain OpenGL extensions. On startup, VirtualBox
|
---|
576 | checks for those extensions, and, if the test fails, this option is
|
---|
577 | silently grayed out.</para>
|
---|
578 |
|
---|
579 | <para>To find out why it has failed, you can manually execute the
|
---|
580 | following command:</para>
|
---|
581 |
|
---|
582 | <screen>VBoxTestOGL --log "log_file_name" --test 2D</screen>
|
---|
583 |
|
---|
584 | <para>It will list the required OpenGL extensions one by one and will
|
---|
585 | show you which one failed the test. This usually means that you are
|
---|
586 | running an outdated or misconfigured OpenGL driver on your host. It can
|
---|
587 | also mean that your video chip is lacking require functionality.</para>
|
---|
588 | </sect2>
|
---|
589 | </sect1>
|
---|
590 |
|
---|
591 | <sect1>
|
---|
592 | <title>Windows guests</title>
|
---|
593 |
|
---|
594 | <sect2>
|
---|
595 | <title>Windows bluescreens after changing VM configuration</title>
|
---|
596 |
|
---|
597 | <para>Changing certain virtual machine settings can cause Windows guests
|
---|
598 | to fail during start up with a bluescreen. This may happen if you change
|
---|
599 | VM settings after installing Windows, or if you copy a disk image with
|
---|
600 | an already installed Windows to a newly created VM which has settings
|
---|
601 | that differ from the original machine.</para>
|
---|
602 |
|
---|
603 | <para>This applies in particular to the following settings:<itemizedlist>
|
---|
604 | <listitem>
|
---|
605 | <para>The ACPI and I/O APIC settings should never be changed after
|
---|
606 | installing Windows. Depending on the presence of these hardware
|
---|
607 | features, the Windows installation program chooses special kernel
|
---|
608 | and device driver versions and will fail to startup should these
|
---|
609 | hardware features be removed. (Enabling them for a Windows VM
|
---|
610 | which was installed without them does not cause any harm. However,
|
---|
611 | Windows will not use these features in this case.)</para>
|
---|
612 | </listitem>
|
---|
613 |
|
---|
614 | <listitem>
|
---|
615 | <para>Changing the storage controller hardware will cause bootup
|
---|
616 | failures as well. This might also apply to you if you copy a disk
|
---|
617 | image from an older version of VirtualBox to a virtual machine
|
---|
618 | created with a newer VirtualBox version; the default subtype of
|
---|
619 | IDE controller hardware was changed from PIIX3 to PIIX4 with
|
---|
620 | VirtualBox 2.2. Make sure these settings are identical.</para>
|
---|
621 | </listitem>
|
---|
622 | </itemizedlist></para>
|
---|
623 | </sect2>
|
---|
624 |
|
---|
625 | <sect2>
|
---|
626 | <title>Windows 0x101 bluescreens with SMP enabled (IPI timeout)</title>
|
---|
627 |
|
---|
628 | <para>If a VM is configured to have more than one processor (symmetrical
|
---|
629 | multiprocessing, SMP), some configurations of Windows guests crash with
|
---|
630 | an 0x101 error message, indicating a timeout for inter-processor
|
---|
631 | interrupts (IPIs). These interrupts synchronize memory management
|
---|
632 | between processors.</para>
|
---|
633 |
|
---|
634 | <para>According to Microsoft, this is due to a race condition in
|
---|
635 | Windows. A hotfix is available.<footnote>
|
---|
636 | <para>See <ulink
|
---|
637 | url="http://support.microsoft.com/kb/955076">http://support.microsoft.com/kb/955076</ulink>.</para>
|
---|
638 | </footnote> If this does not help, please reduce the number of virtual
|
---|
639 | processors to 1.</para>
|
---|
640 | </sect2>
|
---|
641 |
|
---|
642 | <sect2>
|
---|
643 | <title>Windows 2000 installation failures</title>
|
---|
644 |
|
---|
645 | <para>When installing Windows 2000 guests, you might run into one of the
|
---|
646 | following issues:</para>
|
---|
647 |
|
---|
648 | <itemizedlist>
|
---|
649 | <listitem>
|
---|
650 | <para>Installation reboots, usually during component
|
---|
651 | registration.</para>
|
---|
652 | </listitem>
|
---|
653 |
|
---|
654 | <listitem>
|
---|
655 | <para>Installation fills the whole hard disk with empty log
|
---|
656 | files.</para>
|
---|
657 | </listitem>
|
---|
658 |
|
---|
659 | <listitem>
|
---|
660 | <para>Installation complains about a failure installing
|
---|
661 | <literal>msgina.dll</literal>.</para>
|
---|
662 | </listitem>
|
---|
663 | </itemizedlist>
|
---|
664 |
|
---|
665 | <para>These problems are all caused by a bug in the hard disk driver of
|
---|
666 | Windows 2000. After issuing a hard disk request, there is a race
|
---|
667 | condition in the Windows driver code which leads to corruption if the
|
---|
668 | operation completes too fast, i.e. the hardware interrupt from the IDE
|
---|
669 | controller arrives too soon. With physical hardware, there is a
|
---|
670 | guaranteed delay in most systems so the problem is usually hidden there
|
---|
671 | (however it should be possible to reproduce it on physical hardware as
|
---|
672 | well). In a virtual environment, it is possible for the operation to be
|
---|
673 | done immediately (especially on very fast systems with multiple CPUs)
|
---|
674 | and the interrupt is signaled sooner than on a physical system. The
|
---|
675 | solution is to introduce an artificial delay before delivering such
|
---|
676 | interrupts. This delay can be configured for a VM using the following
|
---|
677 | command:</para>
|
---|
678 |
|
---|
679 | <screen>VBoxManage setextradata "VM name" "VBoxInternal/Devices/piix3ide/0/Config/IRQDelay" 1</screen>
|
---|
680 |
|
---|
681 | <para>This sets the delay to one millisecond. In case this doesn't help,
|
---|
682 | increase it to a value between 1 and 5 milliseconds. Please note that
|
---|
683 | this slows down disk performance. After installation, you should be able
|
---|
684 | to remove the key (or set it to 0).</para>
|
---|
685 | </sect2>
|
---|
686 |
|
---|
687 | <sect2>
|
---|
688 | <title>How to record bluescreen information from Windows guests</title>
|
---|
689 |
|
---|
690 | <para>When Windows guests run into a kernel crash, they display the
|
---|
691 | infamous bluescreen. Depending on how Windows is configured, the
|
---|
692 | information will remain on the screen until the machine is restarted or
|
---|
693 | it will reboot automatically. During installation, Windows is usually
|
---|
694 | configured to reboot automatically. With automatic reboots, there is no
|
---|
695 | chance to record the bluescreen information which might be important for
|
---|
696 | problem determination.</para>
|
---|
697 |
|
---|
698 | <para>VirtualBox provides a method of halting a guest when it wants to
|
---|
699 | perform a reset. In order to enable this feature, issue the following
|
---|
700 | command:</para>
|
---|
701 |
|
---|
702 | <para><screen>VBoxManage setextradata "VM name" "VBoxInternal/PDM/HaltOnReset" 1</screen></para>
|
---|
703 | </sect2>
|
---|
704 |
|
---|
705 | <sect2>
|
---|
706 | <title>No networking in Windows Vista guests</title>
|
---|
707 |
|
---|
708 | <para>With Windows Vista, Microsoft dropped support for the AMD PCNet
|
---|
709 | card that VirtualBox used to provide as the default virtual network card
|
---|
710 | before version 1.6.0. For Windows Vista guests, VirtualBox now uses an
|
---|
711 | Intel E1000 card by default.</para>
|
---|
712 |
|
---|
713 | <para>If, for some reason, you still want to use the AMD card,
|
---|
714 | VirtualBox ships a 32-bit driver for that card with the Windows Guest
|
---|
715 | Additions; see <xref linkend="vista_networking" />.</para>
|
---|
716 | </sect2>
|
---|
717 |
|
---|
718 | <sect2>
|
---|
719 | <title>Windows guests may cause a high CPU load</title>
|
---|
720 |
|
---|
721 | <para>Several background applications of Windows guests, especially
|
---|
722 | virus scanners, are known to increases the CPU load notably even if the
|
---|
723 | guest appears to be idle. We recommend to deactivate virus scanners
|
---|
724 | within virtualized guests if possible.</para>
|
---|
725 | </sect2>
|
---|
726 |
|
---|
727 | <sect2>
|
---|
728 | <title>Long delays when accessing shared folders</title>
|
---|
729 |
|
---|
730 | <para>The performance for accesses to shared folders from a Windows
|
---|
731 | guest might be decreased due to delays during the resolution of the
|
---|
732 | VirtualBox shared folders name service. To fix these delays, add the
|
---|
733 | following entries to the file
|
---|
734 | <computeroutput>\windows\system32\drivers\etc\lmhosts</computeroutput>
|
---|
735 | of the Windows guest:</para>
|
---|
736 |
|
---|
737 | <screen>255.255.255.255 VBOXSVR #PRE
|
---|
738 | 255.255.255.255 VBOXSRV #PRE</screen>
|
---|
739 |
|
---|
740 | <para>After doing this change, a reboot of the guest is required.</para>
|
---|
741 | </sect2>
|
---|
742 | </sect1>
|
---|
743 |
|
---|
744 | <sect1>
|
---|
745 | <title>Linux and X11 guests</title>
|
---|
746 |
|
---|
747 | <sect2>
|
---|
748 | <title>Linux guests may cause a high CPU load</title>
|
---|
749 |
|
---|
750 | <para>Some Linux guests may cause a high CPU load even if the guest
|
---|
751 | system appears to be idle. This can be caused by a high timer frequency
|
---|
752 | of the guest kernel. Some Linux distributions, for example Fedora, ship
|
---|
753 | a Linux kernel configured for a timer frequency of <emphasis
|
---|
754 | role="bold"> 1000Hz</emphasis>. We recommend to recompile the guest
|
---|
755 | kernel and to select a timer frequency of 100Hz.</para>
|
---|
756 |
|
---|
757 | <para>Linux kernels shipped with Red Hat Enterprise Linux (RHEL) as of
|
---|
758 | release 4.7 and 5.1 as well as kernels of related Linux distributions
|
---|
759 | (for instance CentOS and Oracle Enterprise Linux) support a kernel
|
---|
760 | parameter <emphasis>divider=N</emphasis>. Hence, such kernels support a
|
---|
761 | lower timer frequency without recompilation. We suggest to add the
|
---|
762 | kernel parameter <emphasis>divider=10</emphasis> to select a guest
|
---|
763 | kernel timer frequency of 100Hz.</para>
|
---|
764 | </sect2>
|
---|
765 |
|
---|
766 | <sect2>
|
---|
767 | <title>AMD Barcelona CPUs</title>
|
---|
768 |
|
---|
769 | <para>Most Linux-based guests will fail with AMD Phenoms or
|
---|
770 | Barcelona-level Opterons due to a bug in the Linux kernel. Enable the
|
---|
771 | I/O-APIC to work around the problem (see <xref
|
---|
772 | linkend="settings-general-advanced" />).</para>
|
---|
773 | </sect2>
|
---|
774 |
|
---|
775 | <sect2 id="trouble-linux-buggy">
|
---|
776 | <title>Buggy Linux 2.6 kernel versions</title>
|
---|
777 |
|
---|
778 | <para>The following bugs in Linux kernels prevent them from executing
|
---|
779 | correctly in VirtualBox, causing VM boot crashes:<itemizedlist>
|
---|
780 | <listitem>
|
---|
781 | <para>The Linux kernel version 2.6.18 (and some 2.6.17 versions)
|
---|
782 | introduced a race condition that can cause boot crashes in
|
---|
783 | VirtualBox. Please use a kernel version 2.6.19 or later.</para>
|
---|
784 | </listitem>
|
---|
785 |
|
---|
786 | <listitem>
|
---|
787 | <para>With hardware virtualization and the I/O APIC enabled,
|
---|
788 | kernels before 2.6.24-rc6 may panic on boot with the following
|
---|
789 | message:<screen>Kernel panic - not syncing: IO-APIC + timer doesn't work! Boot with
|
---|
790 | apic=debug and send a report. Then try booting with the 'noapic' option</screen></para>
|
---|
791 |
|
---|
792 | <para>If you see this message, either disable hardware
|
---|
793 | virtualization or the I/O APIC (see <xref
|
---|
794 | linkend="settings-system" />), or upgrade the guest to a newer
|
---|
795 | kernel.<footnote>
|
---|
796 | <para>See <ulink
|
---|
797 | url="http://www.mail-archive.com/git-commits-head@vger.kernel.org/msg30813.html">http://www.mail-archive.com/git-commits-head@vger.kernel.org/msg30813.html</ulink>
|
---|
798 | for details about the kernel fix.</para>
|
---|
799 | </footnote></para>
|
---|
800 | </listitem>
|
---|
801 | </itemizedlist></para>
|
---|
802 | </sect2>
|
---|
803 |
|
---|
804 | <sect2>
|
---|
805 | <title>Shared clipboard, auto-resizing and seamless desktop in X11
|
---|
806 | guests</title>
|
---|
807 |
|
---|
808 | <para>Guest desktop services in guests running the X11 window system
|
---|
809 | (Solaris, Linux and others) are provided by a guest service called
|
---|
810 | <computeroutput>VBoxClient</computeroutput>, which runs under the ID of
|
---|
811 | the user who started the desktop session and is automatically started
|
---|
812 | using the following command lines <screen>VBoxClient --clipboard
|
---|
813 | VBoxClient --display
|
---|
814 | VBoxClient --seamless</screen> when your X11 user session is started if you
|
---|
815 | are using a common desktop environment (Gnome, KDE and others). If a
|
---|
816 | particular desktop service is not working correctly, it is worth
|
---|
817 | checking whether the process which should provide it is running.</para>
|
---|
818 |
|
---|
819 | <para>The <computeroutput>VBoxClient</computeroutput> processes create
|
---|
820 | files in the user's home directory with names of the form
|
---|
821 | <computeroutput>.vboxclient-*.pid</computeroutput> when they are running
|
---|
822 | in order to prevent a given service from being started twice. It can
|
---|
823 | happen due to misconfiguration that these files are created owned by
|
---|
824 | root and not deleted when the services are stopped, which will prevent
|
---|
825 | them from being started in future sessions. If the services cannot be
|
---|
826 | started, you may wish to check whether these files still exist.</para>
|
---|
827 | </sect2>
|
---|
828 | </sect1>
|
---|
829 |
|
---|
830 | <sect1>
|
---|
831 | <title>Windows hosts</title>
|
---|
832 |
|
---|
833 | <sect2>
|
---|
834 | <title>VBoxSVC out-of-process COM server issues</title>
|
---|
835 |
|
---|
836 | <para>VirtualBox makes use of the Microsoft Component Object Model (COM)
|
---|
837 | for inter- and intra-process communication. This allows VirtualBox to
|
---|
838 | share a common configuration among different virtual machine processes
|
---|
839 | and provide several user interface options based on a common
|
---|
840 | architecture. All global status information and configuration is
|
---|
841 | maintained by the process <computeroutput>VBoxSVC.exe</computeroutput>,
|
---|
842 | which is an out-of-process COM server. Whenever a VirtualBox process is
|
---|
843 | started, it requests access to the COM server and Windows automatically
|
---|
844 | starts the process. Note that it should never be started by the end
|
---|
845 | user.</para>
|
---|
846 |
|
---|
847 | <para>When the last process disconnects from the COM server, it will
|
---|
848 | terminate itself after some seconds. The VirtualBox configuration (XML
|
---|
849 | files) is maintained and owned by the COM server and the files are
|
---|
850 | locked whenever the server runs.</para>
|
---|
851 |
|
---|
852 | <para>In some cases - such as when a virtual machine is terminated
|
---|
853 | unexpectedly - the COM server will not notice that the client is
|
---|
854 | disconnected and stay active for a longer period (10 minutes or so)
|
---|
855 | keeping the configuration files locked. In other rare cases the COM
|
---|
856 | server might experience an internal error and subsequently other
|
---|
857 | processes fail to initialize it. In these situations, it is recommended
|
---|
858 | to use the Windows task manager to kill the process
|
---|
859 | <computeroutput>VBoxSVC.exe</computeroutput>.</para>
|
---|
860 | </sect2>
|
---|
861 |
|
---|
862 | <sect2>
|
---|
863 | <title>CD/DVD changes not recognized</title>
|
---|
864 |
|
---|
865 | <para>In case you have assigned a physical CD/DVD drive to a guest and
|
---|
866 | the guest does not notice when the medium changes, make sure that the
|
---|
867 | Windows media change notification (MCN) feature is not turned off. This
|
---|
868 | is represented by the following key in the Windows registry:<screen><literal>HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Cdrom\Autorun</literal></screen>Certain
|
---|
869 | applications may disable this key against Microsoft's advice. If it is
|
---|
870 | set to 0, change it to 1 and reboot your system. VirtualBox relies on
|
---|
871 | Windows notifying it of media changes.</para>
|
---|
872 | </sect2>
|
---|
873 |
|
---|
874 | <sect2>
|
---|
875 | <title>Sluggish response when using Microsoft RDP client</title>
|
---|
876 |
|
---|
877 | <para>If connecting to a Virtual Machine via the Microsoft RDP client
|
---|
878 | (called Remote Desktop Connection), there can be large delays between
|
---|
879 | input (moving the mouse over a menu is the most obvious situation) and
|
---|
880 | output. This is because this RDP client collects input for a certain
|
---|
881 | time before sending it to the VRDP server built into VirtualBox.</para>
|
---|
882 |
|
---|
883 | <para>The interval can be decreased by setting a Windows registry key to
|
---|
884 | smaller values than the default of 100. The key does not exist initially
|
---|
885 | and must be of type DWORD. The unit for its values is milliseconds.
|
---|
886 | Values around 20 are suitable for low-bandwidth connections between the
|
---|
887 | RDP client and server. Values around 4 can be used for a gigabit
|
---|
888 | Ethernet connection. Generally values below 10 achieve a performance
|
---|
889 | that is very close to that of the local input devices and screen of the
|
---|
890 | host on which the Virtual Machine is running.</para>
|
---|
891 |
|
---|
892 | <para>Depending whether the setting should be changed for an individual
|
---|
893 | user or for the system, either</para>
|
---|
894 |
|
---|
895 | <screen>HKEY_CURRENT_USER\Software\Microsoft\Terminal Server Client\Min Send Interval</screen>
|
---|
896 |
|
---|
897 | <para>or</para>
|
---|
898 |
|
---|
899 | <screen>HKEY_LOCAL_MACHINE\Software\Microsoft\Terminal Server Client\Min Send Interval</screen>
|
---|
900 |
|
---|
901 | <para>can be set appropriately.</para>
|
---|
902 | </sect2>
|
---|
903 |
|
---|
904 | <sect2>
|
---|
905 | <title>Running an iSCSI initiator and target on a single system</title>
|
---|
906 |
|
---|
907 | <para>Deadlocks can occur on a Windows host when attempting to access an
|
---|
908 | iSCSI target running in a guest virtual machine with an iSCSI initiator
|
---|
909 | (e.g. Microsoft iSCSI Initiator) that is running on the host. This is
|
---|
910 | caused by a flaw in the Windows cache manager component, and causes
|
---|
911 | sluggish host system response for several minutes, followed by a
|
---|
912 | "Delayed Write Failed" error message in the system tray or in a separate
|
---|
913 | message window. The guest is blocked during that period and may show
|
---|
914 | error messages or become unstable.</para>
|
---|
915 |
|
---|
916 | <para>Setting the environment variable
|
---|
917 | <computeroutput>VBOX_DISABLE_HOST_DISK_CACHE</computeroutput> to 1 will
|
---|
918 | enable a workaround for this problem until Microsoft addresses the
|
---|
919 | issue. For example, open a command prompt window and start VirtualBox
|
---|
920 | like this:</para>
|
---|
921 |
|
---|
922 | <screen>set VBOX_DISABLE_HOST_DISK_CACHE=1
|
---|
923 | VirtualBox</screen>
|
---|
924 |
|
---|
925 | <para>While this will decrease guest disk performance (especially
|
---|
926 | writes), it does not affect the performance of other applications
|
---|
927 | running on the host.</para>
|
---|
928 | </sect2>
|
---|
929 |
|
---|
930 | <sect2>
|
---|
931 | <title>Bridged Networking</title>
|
---|
932 |
|
---|
933 | <para>In case no Bridge adapters are listed in bridged networking
|
---|
934 | settings UI, this typically means that Bridged networking driver was not
|
---|
935 | installed properly on your host. This could be due to any of the
|
---|
936 | following reasons: <itemizedlist>
|
---|
937 | <listitem>
|
---|
938 | <para>The maximum allowed filter count is reached on the host. The
|
---|
939 | MSI log would mention the 0x8004a029 error code returned on NetFlt
|
---|
940 | network component install: "VBoxNetCfgWinInstallComponent: Install
|
---|
941 | failed, hr (0x8004a029)". The solution would typically be to
|
---|
942 | increase the maximum filter count under
|
---|
943 | HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Network\MaxNumFilters
|
---|
944 | (the maximum number allowed is 14), reboot and try to re-install
|
---|
945 | the VirtualBox</para>
|
---|
946 | </listitem>
|
---|
947 |
|
---|
948 | <listitem>
|
---|
949 | <para>Inf cache is corrupt. The %windir%\inf\setupapi.log (for XP)
|
---|
950 | or %windir%\inf\setupapi.dev.log (for Vista+) would typically
|
---|
951 | mention the failure to find a suitable driver package for either
|
---|
952 | sun_VBoxNetFlt or sun_VBoxNetFltmp components. The solution is to
|
---|
953 | uninstall VirtualBox, remove the inf cache
|
---|
954 | (%windir%\inf\INFCACHE.1, reboot and try to re-install the
|
---|
955 | VirtualBox</para>
|
---|
956 | </listitem>
|
---|
957 | </itemizedlist></para>
|
---|
958 | </sect2>
|
---|
959 |
|
---|
960 | <sect2>
|
---|
961 | <title>Host-Only Networking</title>
|
---|
962 |
|
---|
963 | <para>Host-Only adapter creation (either via GUI or VBoxManage) may fail
|
---|
964 | due to any of the following reasons: <itemizedlist>
|
---|
965 | <listitem>
|
---|
966 | <para>Inf cache is corrupt. The %windir%\inf\setupapi.log (for XP)
|
---|
967 | or %windir%\inf\setupapi.dev.log (for Vista+) would typically
|
---|
968 | mention the failure to find a suitable driver package for
|
---|
969 | sun_VBoxNetAdp component. The solution is to uninstall VirtualBox,
|
---|
970 | remove the inf cache (%windir%\inf\INFCACHE.1, reboot and try to
|
---|
971 | re-install the VirtualBox</para>
|
---|
972 | </listitem>
|
---|
973 | </itemizedlist></para>
|
---|
974 | </sect2>
|
---|
975 | </sect1>
|
---|
976 |
|
---|
977 | <sect1>
|
---|
978 | <title>Linux hosts</title>
|
---|
979 |
|
---|
980 | <sect2 id="linuxkernelmodulefailstoload">
|
---|
981 | <title>Linux kernel module refuses to load</title>
|
---|
982 |
|
---|
983 | <para>If the VirtualBox kernel module
|
---|
984 | (<computeroutput>vboxdrv</computeroutput>) refuses to load, i.e. you get
|
---|
985 | an "Error inserting vboxdrv: Invalid argument", check (as root) the
|
---|
986 | output of the <computeroutput>dmesg</computeroutput> command to find out
|
---|
987 | why the load failed. Most probably the kernel disagrees with the version
|
---|
988 | of the gcc used to compile the module. Make sure that you use the same
|
---|
989 | compiler as used to build the kernel.</para>
|
---|
990 | </sect2>
|
---|
991 |
|
---|
992 | <sect2>
|
---|
993 | <title>Linux host CD/DVD drive not found</title>
|
---|
994 |
|
---|
995 | <para>If you have configured a virtual machine to use the host's CD/DVD
|
---|
996 | drive, but this does not appear to work, make sure that the current user
|
---|
997 | has permission to access the corresponding Linux device file
|
---|
998 | (<computeroutput>/dev/hdc</computeroutput> or
|
---|
999 | <computeroutput>/dev/scd0</computeroutput> or
|
---|
1000 | <computeroutput>/dev/cdrom</computeroutput> or similar). On most
|
---|
1001 | distributions, the user must be added to a corresponding group (usually
|
---|
1002 | called <computeroutput>cdrom</computeroutput> or
|
---|
1003 | <computeroutput>cdrw</computeroutput>).</para>
|
---|
1004 | </sect2>
|
---|
1005 |
|
---|
1006 | <sect2>
|
---|
1007 | <title>Linux host CD/DVD drive not found (older distributions)</title>
|
---|
1008 |
|
---|
1009 | <para>On older Linux distributions, if your CD/DVD device has a
|
---|
1010 | different name, VirtualBox may be unable to find it. On older Linux
|
---|
1011 | hosts, VirtualBox performs the following steps to locate your CD/DVD
|
---|
1012 | drives:</para>
|
---|
1013 |
|
---|
1014 | <para><orderedlist>
|
---|
1015 | <listitem>
|
---|
1016 | <para>VirtualBox examines if the environment variable
|
---|
1017 | <computeroutput>VBOX_CDROM</computeroutput> is defined (see
|
---|
1018 | below). If so, VirtualBox omits all the following checks.</para>
|
---|
1019 | </listitem>
|
---|
1020 |
|
---|
1021 | <listitem>
|
---|
1022 | <para>VirtualBox tests if
|
---|
1023 | <computeroutput>/dev/cdrom</computeroutput> works.</para>
|
---|
1024 | </listitem>
|
---|
1025 |
|
---|
1026 | <listitem>
|
---|
1027 | <para>In addition, VirtualBox checks if any CD/DVD drives are
|
---|
1028 | currently mounted by checking
|
---|
1029 | <computeroutput>/etc/mtab</computeroutput>.</para>
|
---|
1030 | </listitem>
|
---|
1031 |
|
---|
1032 | <listitem>
|
---|
1033 | <para>In addition, VirtualBox checks if any of the entries in
|
---|
1034 | <computeroutput>/etc/fstab</computeroutput> point to CD/DVD
|
---|
1035 | devices.</para>
|
---|
1036 | </listitem>
|
---|
1037 | </orderedlist></para>
|
---|
1038 |
|
---|
1039 | <para>In other words, you can try to set VBOX_CDROM to contain a list of
|
---|
1040 | your CD/DVD devices, separated by colons, for example as follows:</para>
|
---|
1041 |
|
---|
1042 | <para><screen>export VBOX_CDROM='/dev/cdrom0:/dev/cdrom1'</screen>On
|
---|
1043 | modern Linux distributions, VirtualBox uses the hardware abstraction
|
---|
1044 | layer (hal) to locate CD and DVD hardware.</para>
|
---|
1045 | </sect2>
|
---|
1046 |
|
---|
1047 | <sect2>
|
---|
1048 | <title>Linux host floppy not found</title>
|
---|
1049 |
|
---|
1050 | <para>The previous instructions (for CD and DVD drives) apply
|
---|
1051 | accordingly to floppy disks, except that on older distributions
|
---|
1052 | VirtualBox tests for <computeroutput>/dev/fd*</computeroutput> devices
|
---|
1053 | by default, and this can be overridden with the
|
---|
1054 | <computeroutput>VBOX_FLOPPY</computeroutput> environment
|
---|
1055 | variable.</para>
|
---|
1056 | </sect2>
|
---|
1057 |
|
---|
1058 | <sect2>
|
---|
1059 | <title>Strange guest IDE error messages when writing to CD/DVD</title>
|
---|
1060 |
|
---|
1061 | <para>If the experimental CD/DVD writer support is enabled with an
|
---|
1062 | incorrect VirtualBox, host or guest configuration, it is possible that
|
---|
1063 | any attempt to access the CD/DVD writer fails and simply results in
|
---|
1064 | guest kernel error messages (for Linux guests) or application error
|
---|
1065 | messages (for Windows guests). VirtualBox performs the usual consistency
|
---|
1066 | checks when a VM is powered up (in particular it aborts with an error
|
---|
1067 | message if the device for the CD/DVD writer is not writable by the user
|
---|
1068 | starting the VM), but it cannot detect all misconfigurations. The
|
---|
1069 | necessary host and guest OS configuration is not specific for
|
---|
1070 | VirtualBox, but a few frequent problems are listed here which occurred
|
---|
1071 | in connection with VirtualBox.</para>
|
---|
1072 |
|
---|
1073 | <para>Special care must be taken to use the correct device. The
|
---|
1074 | configured host CD/DVD device file name (in most cases
|
---|
1075 | <literal>/dev/cdrom</literal>) must point to the device that allows
|
---|
1076 | writing to the CD/DVD unit. For CD/DVD writer units connected to a SCSI
|
---|
1077 | controller or to a IDE controller that interfaces to the Linux SCSI
|
---|
1078 | subsystem (common for some SATA controllers), this must refer to the
|
---|
1079 | SCSI device node (e.g. <literal>/dev/scd0</literal>). Even for IDE
|
---|
1080 | CD/DVD writer units this must refer to the appropriate SCSI CD-ROM
|
---|
1081 | device node (e.g. <literal>/dev/scd0</literal>) if the
|
---|
1082 | <literal>ide-scsi</literal> kernel module is loaded. This module is
|
---|
1083 | required for CD/DVD writer support with all Linux 2.4 kernels and some
|
---|
1084 | early 2.6 kernels. Many Linux distributions load this module whenever a
|
---|
1085 | CD/DVD writer is detected in the system, even if the kernel would
|
---|
1086 | support CD/DVD writers without the module. VirtualBox supports the use
|
---|
1087 | of IDE device files (e.g. <literal>/dev/hdc</literal>), provided the
|
---|
1088 | kernel supports this and the <literal>ide-scsi</literal> module is not
|
---|
1089 | loaded.</para>
|
---|
1090 |
|
---|
1091 | <para>Similar rules (except that within the guest the CD/DVD writer is
|
---|
1092 | always an IDE device) apply to the guest configuration. Since this setup
|
---|
1093 | is very common, it is likely that the default configuration of the guest
|
---|
1094 | works as expected.</para>
|
---|
1095 | </sect2>
|
---|
1096 |
|
---|
1097 | <sect2>
|
---|
1098 | <title>VBoxSVC IPC issues</title>
|
---|
1099 |
|
---|
1100 | <para>On Linux, VirtualBox makes use of a custom version of Mozilla
|
---|
1101 | XPCOM (cross platform component object model) for inter- and
|
---|
1102 | intra-process communication (IPC). The process
|
---|
1103 | <computeroutput>VBoxSVC</computeroutput> serves as a communication hub
|
---|
1104 | between different VirtualBox processes and maintains the global
|
---|
1105 | configuration, i.e. the XML database. When starting a VirtualBox
|
---|
1106 | component, the processes <computeroutput>VBoxSVC</computeroutput> and
|
---|
1107 | <computeroutput>VirtualBoxXPCOMIPCD</computeroutput> are started
|
---|
1108 | automatically. They are only accessible from the user account they are
|
---|
1109 | running under. <computeroutput>VBoxSVC</computeroutput> owns the
|
---|
1110 | VirtualBox configuration database which normally resides in
|
---|
1111 | <computeroutput>~/.VirtualBox</computeroutput>. While it is running, the
|
---|
1112 | configuration files are locked. Communication between the various
|
---|
1113 | VirtualBox components and <computeroutput>VBoxSVC</computeroutput> is
|
---|
1114 | performed through a local domain socket residing in
|
---|
1115 | <computeroutput>/tmp/.vbox-<username>-ipc</computeroutput>. In
|
---|
1116 | case there are communication problems (i.e. a VirtualBox application
|
---|
1117 | cannot communicate with <computeroutput>VBoxSVC</computeroutput>),
|
---|
1118 | terminate the daemons and remove the local domain socket
|
---|
1119 | directory.</para>
|
---|
1120 | </sect2>
|
---|
1121 |
|
---|
1122 | <sect2 id="usb_linux">
|
---|
1123 | <title>USB not working</title>
|
---|
1124 |
|
---|
1125 | <para>If USB is not working on your Linux host, make sure that the
|
---|
1126 | current user is a member of the
|
---|
1127 | <computeroutput>vboxusers</computeroutput> group. On older hosts, you
|
---|
1128 | need to make sure that the user has permission to access the USB
|
---|
1129 | filesystem (<computeroutput>usbfs</computeroutput>), which VirtualBox
|
---|
1130 | relies on to retrieve valid information about your host's USB devices.
|
---|
1131 | The rest of this section only applies to those older systems.</para>
|
---|
1132 |
|
---|
1133 | <para>As <computeroutput>usbfs</computeroutput> is a virtual filesystem,
|
---|
1134 | a <computeroutput>chmod</computeroutput> on
|
---|
1135 | <computeroutput>/proc/bus/usb</computeroutput> has no effect. The
|
---|
1136 | permissions for <computeroutput>usbfs</computeroutput> can therefore
|
---|
1137 | <emphasis>only</emphasis> be changed by editing the
|
---|
1138 | <computeroutput>/etc/fstab</computeroutput> file.</para>
|
---|
1139 |
|
---|
1140 | <para>For example, most Linux distributions have a user group called
|
---|
1141 | <computeroutput>usb</computeroutput> or similar, of which the current
|
---|
1142 | user must be a member. To give all users of that group access to usbfs,
|
---|
1143 | make sure the following line is present:<screen># 85 is the USB group
|
---|
1144 | none /proc/bus/usb usbfs devgid=85,devmode=664 0 0</screen>Replace
|
---|
1145 | 85 with the group ID that matches your system (search
|
---|
1146 | <computeroutput>/etc/group</computeroutput> for "usb" or similar).
|
---|
1147 | Alternatively, if you don't mind the security hole, give all users
|
---|
1148 | access to USB by changing "664" to "666".</para>
|
---|
1149 |
|
---|
1150 | <para>The various distributions are very creative from which script the
|
---|
1151 | <computeroutput>usbfs</computeroutput> filesystem is mounted. Sometimes
|
---|
1152 | the command is hidden in unexpected places. For SuSE 10.0 the mount
|
---|
1153 | command is part of the udev configuration file
|
---|
1154 | <computeroutput>/etc/udev/rules.d/50-udev.rules</computeroutput>. As
|
---|
1155 | this distribution has no user group called
|
---|
1156 | <computeroutput>usb</computeroutput>, you may e.g. use the
|
---|
1157 | <computeroutput>vboxusers</computeroutput> group which was created by
|
---|
1158 | the VirtualBox installer. Since group numbers are allocated dynamically,
|
---|
1159 | the following example uses 85 as a placeholder. Modify the line
|
---|
1160 | containing (a linebreak has been inserted to improve
|
---|
1161 | readability)<screen>DEVPATH="/module/usbcore", ACTION=="add",
|
---|
1162 | RUN+="/bin/mount -t usbfs usbfs /proc/bus/usb"</screen> and add the
|
---|
1163 | necessary options (make sure that everything is in a single
|
---|
1164 | line):<screen>DEVPATH="/module/usbcore", ACTION=="add",
|
---|
1165 | RUN+="/bin/mount -t usbfs usbfs /proc/bus/usb -o devgid=85,devmode=664"</screen></para>
|
---|
1166 |
|
---|
1167 | <para>Debian Etch has the mount command in
|
---|
1168 | <computeroutput>/etc/init.d/mountkernfs.sh</computeroutput>. Since that
|
---|
1169 | distribution has no group <computeroutput>usb</computeroutput>, it is
|
---|
1170 | also the easiest solution to allow all members of the group
|
---|
1171 | <computeroutput>vboxusers</computeroutput> to access the USB subsystem.
|
---|
1172 | Modify the line <screen>domount usbfs usbdevfs /proc/bus/usb -onoexec,nosuid,nodev</screen>
|
---|
1173 | so that it contains <screen>domount usbfs usbdevfs /proc/bus/usb -onoexec,nosuid,nodev,devgid=85,devmode=664</screen>
|
---|
1174 | As usual, replace the 85 with the actual group number which should get
|
---|
1175 | access to USB devices.</para>
|
---|
1176 |
|
---|
1177 | <para>Other distributions do similar operations in scripts stored in the
|
---|
1178 | <computeroutput>/etc/init.d</computeroutput> directory.</para>
|
---|
1179 | </sect2>
|
---|
1180 |
|
---|
1181 | <sect2>
|
---|
1182 | <title>PAX/grsec kernels</title>
|
---|
1183 |
|
---|
1184 | <para>Linux kernels including the grsec patch (see <literal><ulink
|
---|
1185 | url="http://www.grsecurity.net/">http://www.grsecurity.net/</ulink></literal>)
|
---|
1186 | and derivates have to disable PAX_MPROTECT for the VBox binaries to be
|
---|
1187 | able to start a VM. The reason is that VBox has to create executable
|
---|
1188 | code on anonymous memory.</para>
|
---|
1189 | </sect2>
|
---|
1190 |
|
---|
1191 | <sect2>
|
---|
1192 | <title>Linux kernel vmalloc pool exhausted</title>
|
---|
1193 |
|
---|
1194 | <para>When running a large number of VMs with a lot of RAM on a Linux
|
---|
1195 | system (say 20 VMs with 1GB of RAM each), additional VMs might fail to
|
---|
1196 | start with a kernel error saying that the vmalloc pool is exhausted and
|
---|
1197 | should be extended. The error message also tells you to specify
|
---|
1198 | <computeroutput>vmalloc=256MB</computeroutput> in your kernel parameter
|
---|
1199 | list. If adding this parameter to your GRUB or LILO configuration makes
|
---|
1200 | the kernel fail to boot (with a weird error message such as "failed to
|
---|
1201 | mount the root partition"), then you have probably run into a memory
|
---|
1202 | conflict of your kernel and initial RAM disk. This can be solved by
|
---|
1203 | adding the following parameter to your GRUB configuration:</para>
|
---|
1204 |
|
---|
1205 | <screen>uppermem 524288</screen>
|
---|
1206 | </sect2>
|
---|
1207 | </sect1>
|
---|
1208 |
|
---|
1209 | <sect1>
|
---|
1210 | <title>Solaris hosts</title>
|
---|
1211 |
|
---|
1212 | <sect2>
|
---|
1213 | <title>Cannot start VM, not enough contiguous memory</title>
|
---|
1214 |
|
---|
1215 | <para>The ZFS file system is known to use all available RAM as cache if
|
---|
1216 | the default system settings are not changed. This may lead to a heavy
|
---|
1217 | fragmentation of the host memory preventing VirtualBox VMs from being
|
---|
1218 | started. We recommend to limit the ZFS cache by adding a line<screen>set zfs:zfs_arc_max = xxxx</screen>
|
---|
1219 | to /etc/system where <computeroutput>xxxx</computeroutput> bytes is the
|
---|
1220 | amount of memory usable for the ZFS cache.</para>
|
---|
1221 | </sect2>
|
---|
1222 |
|
---|
1223 | <sect2>
|
---|
1224 | <title>VM aborts with out of memory errors on Solaris 10 hosts</title>
|
---|
1225 |
|
---|
1226 | <para>32-bit Solaris 10 hosts (bug 1225025) require swap space equal to,
|
---|
1227 | or greater than the host's physical memory size. For example, 8 GB
|
---|
1228 | physical memory would require at least 8 GB swap. This can be configured
|
---|
1229 | during a Solaris 10 install by choosing a 'custom install' and changing
|
---|
1230 | the default partitions.</para>
|
---|
1231 |
|
---|
1232 | <note>
|
---|
1233 | <para>This restriction applies only to 32-bit Solaris hosts, 64-bit
|
---|
1234 | hosts are not affected!</para>
|
---|
1235 | </note>
|
---|
1236 |
|
---|
1237 | <para>For existing Solaris 10 installs, an additional swap image needs
|
---|
1238 | to be mounted and used as swap. Hence if you have 1 GB swap and 8 GB of
|
---|
1239 | physical memory, you require to add 7 GB more swap. This can be done as
|
---|
1240 | follows:</para>
|
---|
1241 |
|
---|
1242 | <para>For ZFS (as root user):</para>
|
---|
1243 |
|
---|
1244 | <para><screen>zfs create -V 8gb /_<ZFS volume>_/swap
|
---|
1245 | swap -a /dev/zvol/dsk/_<ZFS volume>_/swap</screen></para>
|
---|
1246 |
|
---|
1247 | <para>To mount if after reboot, add the following line to
|
---|
1248 | /etc/vfstab:</para>
|
---|
1249 |
|
---|
1250 | <screen>/dev/zvol/dsk/_<ZFS volume>_/swap - - swap - no -</screen>
|
---|
1251 |
|
---|
1252 | <para>Alternatively, you could grow the existing swap using:</para>
|
---|
1253 |
|
---|
1254 | <screen>zfs set volsize=8G rpool/swap</screen>
|
---|
1255 |
|
---|
1256 | <para>And reboot the system for the changes to take effect.</para>
|
---|
1257 |
|
---|
1258 | <para>For UFS (as root user):</para>
|
---|
1259 |
|
---|
1260 | <screen>mkfile 7g /path/to/swapfile.img
|
---|
1261 | swap -a /path/to/swapfile.img</screen>
|
---|
1262 |
|
---|
1263 | <para>To mount it after reboot, add the following line to
|
---|
1264 | /etc/vfstab:</para>
|
---|
1265 |
|
---|
1266 | <screen>/path/to/swap.img - - swap - no -</screen>
|
---|
1267 | </sect2>
|
---|
1268 | </sect1>
|
---|
1269 | </chapter>
|
---|