Commit 0806e3f66f1fbc924741246716ef75272715543a
1 parent
39b4da28
updated
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@401 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
2 changed files
with
170 additions
and
52 deletions
Changelog
@@ -6,13 +6,18 @@ version 0.4.4: | @@ -6,13 +6,18 @@ version 0.4.4: | ||
6 | - popw (%esp) fix | 6 | - popw (%esp) fix |
7 | - mov to/from segment data width fix | 7 | - mov to/from segment data width fix |
8 | - added real mode support | 8 | - added real mode support |
9 | - - added Bochs BIOS and LGPL'ed VGA BIOS loader in vl | 9 | + - added Bochs BIOS and LGPL'ed VGA BIOS loader in qemu |
10 | - m68k host port (Richard Zidlicky) | 10 | - m68k host port (Richard Zidlicky) |
11 | - partial soft MMU support for memory mapped I/Os | 11 | - partial soft MMU support for memory mapped I/Os |
12 | - multi-target build | 12 | - multi-target build |
13 | - fixed: no error code in hardware interrupts | 13 | - fixed: no error code in hardware interrupts |
14 | - fixed: pop ss, mov ss, x and sti disable hardware irqs for the next insn | 14 | - fixed: pop ss, mov ss, x and sti disable hardware irqs for the next insn |
15 | - correct single stepping thru string operations | 15 | - correct single stepping thru string operations |
16 | + - preliminary SPARC target support (Thomas M. Ogrisegg) | ||
17 | + - tun-fd option (Rusty Russell) | ||
18 | + - automatic IDE geometry detection | ||
19 | + - renamed 'vl' to qemu and user qemu to qemu-{cpu}. | ||
20 | + - added man page | ||
16 | 21 | ||
17 | version 0.4.3: | 22 | version 0.4.3: |
18 | 23 |
qemu-doc.texi
1 | \input texinfo @c -*- texinfo -*- | 1 | \input texinfo @c -*- texinfo -*- |
2 | 2 | ||
3 | +@iftex | ||
3 | @settitle QEMU CPU Emulator Reference Documentation | 4 | @settitle QEMU CPU Emulator Reference Documentation |
4 | @titlepage | 5 | @titlepage |
5 | @sp 7 | 6 | @sp 7 |
6 | @center @titlefont{QEMU CPU Emulator Reference Documentation} | 7 | @center @titlefont{QEMU CPU Emulator Reference Documentation} |
7 | @sp 3 | 8 | @sp 3 |
8 | @end titlepage | 9 | @end titlepage |
10 | +@end iftex | ||
9 | 11 | ||
10 | @chapter Introduction | 12 | @chapter Introduction |
11 | 13 | ||
@@ -16,14 +18,18 @@ achieves a reasonnable speed while being easy to port on new host | @@ -16,14 +18,18 @@ achieves a reasonnable speed while being easy to port on new host | ||
16 | CPUs. | 18 | CPUs. |
17 | 19 | ||
18 | QEMU has two operating modes: | 20 | QEMU has two operating modes: |
19 | -@itemize | ||
20 | -@item User mode emulation. In this mode, QEMU can launch Linux processes | 21 | + |
22 | +@itemize @minus | ||
23 | + | ||
24 | +@item | ||
25 | +User mode emulation. In this mode, QEMU can launch Linux processes | ||
21 | compiled for one CPU on another CPU. Linux system calls are converted | 26 | compiled for one CPU on another CPU. Linux system calls are converted |
22 | because of endianness and 32/64 bit mismatches. The Wine Windows API | 27 | because of endianness and 32/64 bit mismatches. The Wine Windows API |
23 | emulator (@url{http://www.winehq.org}) and the DOSEMU DOS emulator | 28 | emulator (@url{http://www.winehq.org}) and the DOSEMU DOS emulator |
24 | (@url{www.dosemu.org}) are the main targets for QEMU. | 29 | (@url{www.dosemu.org}) are the main targets for QEMU. |
25 | 30 | ||
26 | -@item Full system emulation. In this mode, QEMU emulates a full | 31 | +@item |
32 | +Full system emulation. In this mode, QEMU emulates a full | ||
27 | system, including a processor and various peripherials. Currently, it | 33 | system, including a processor and various peripherials. Currently, it |
28 | is only used to launch an x86 Linux kernel on an x86 Linux system. It | 34 | is only used to launch an x86 Linux kernel on an x86 Linux system. It |
29 | enables easier testing and debugging of system code. It can also be | 35 | enables easier testing and debugging of system code. It can also be |
@@ -128,6 +134,10 @@ generic dynamic code generation architecture of QEMU. | @@ -128,6 +134,10 @@ generic dynamic code generation architecture of QEMU. | ||
128 | 134 | ||
129 | @end itemize | 135 | @end itemize |
130 | 136 | ||
137 | +@section SPARC emulation | ||
138 | + | ||
139 | +The SPARC emulation is currently in development. | ||
140 | + | ||
131 | @chapter QEMU User space emulator invocation | 141 | @chapter QEMU User space emulator invocation |
132 | 142 | ||
133 | @section Quick Start | 143 | @section Quick Start |
@@ -144,7 +154,7 @@ itself and all the target (x86) dynamic libraries used by it. | @@ -144,7 +154,7 @@ itself and all the target (x86) dynamic libraries used by it. | ||
144 | libraries: | 154 | libraries: |
145 | 155 | ||
146 | @example | 156 | @example |
147 | -qemu -L / /bin/ls | 157 | +qemu-i386 -L / /bin/ls |
148 | @end example | 158 | @end example |
149 | 159 | ||
150 | @code{-L /} tells that the x86 dynamic linker must be searched with a | 160 | @code{-L /} tells that the x86 dynamic linker must be searched with a |
@@ -153,7 +163,7 @@ qemu -L / /bin/ls | @@ -153,7 +163,7 @@ qemu -L / /bin/ls | ||
153 | @item Since QEMU is also a linux process, you can launch qemu with qemu: | 163 | @item Since QEMU is also a linux process, you can launch qemu with qemu: |
154 | 164 | ||
155 | @example | 165 | @example |
156 | -qemu -L / qemu -L / /bin/ls | 166 | +qemu-i386 -L / qemu-i386 -L / /bin/ls |
157 | @end example | 167 | @end example |
158 | 168 | ||
159 | @item On non x86 CPUs, you need first to download at least an x86 glibc | 169 | @item On non x86 CPUs, you need first to download at least an x86 glibc |
@@ -167,7 +177,7 @@ unset LD_LIBRARY_PATH | @@ -167,7 +177,7 @@ unset LD_LIBRARY_PATH | ||
167 | Then you can launch the precompiled @file{ls} x86 executable: | 177 | Then you can launch the precompiled @file{ls} x86 executable: |
168 | 178 | ||
169 | @example | 179 | @example |
170 | -qemu /usr/local/qemu-i386/bin/ls-i386 | 180 | +qemu-i386 /usr/local/qemu-i386/bin/ls-i386 |
171 | @end example | 181 | @end example |
172 | You can look at @file{/usr/local/qemu-i386/bin/qemu-conf.sh} so that | 182 | You can look at @file{/usr/local/qemu-i386/bin/qemu-conf.sh} so that |
173 | QEMU is automatically launched by the Linux kernel when you try to | 183 | QEMU is automatically launched by the Linux kernel when you try to |
@@ -176,7 +186,7 @@ Linux kernel. | @@ -176,7 +186,7 @@ Linux kernel. | ||
176 | 186 | ||
177 | @item The x86 version of QEMU is also included. You can try weird things such as: | 187 | @item The x86 version of QEMU is also included. You can try weird things such as: |
178 | @example | 188 | @example |
179 | -qemu /usr/local/qemu-i386/bin/qemu-i386 /usr/local/qemu-i386/bin/ls-i386 | 189 | +qemu-i386 /usr/local/qemu-i386/bin/qemu-i386 /usr/local/qemu-i386/bin/ls-i386 |
180 | @end example | 190 | @end example |
181 | 191 | ||
182 | @end itemize | 192 | @end itemize |
@@ -190,7 +200,7 @@ distribution (see previous section). In order to verify it, you must be | @@ -190,7 +200,7 @@ distribution (see previous section). In order to verify it, you must be | ||
190 | able to do: | 200 | able to do: |
191 | 201 | ||
192 | @example | 202 | @example |
193 | -qemu /usr/local/qemu-i386/bin/ls-i386 | 203 | +qemu-i386 /usr/local/qemu-i386/bin/ls-i386 |
194 | @end example | 204 | @end example |
195 | 205 | ||
196 | @item Download the binary x86 Wine install | 206 | @item Download the binary x86 Wine install |
@@ -203,7 +213,7 @@ qemu /usr/local/qemu-i386/bin/ls-i386 | @@ -203,7 +213,7 @@ qemu /usr/local/qemu-i386/bin/ls-i386 | ||
203 | @item Then you can try the example @file{putty.exe}: | 213 | @item Then you can try the example @file{putty.exe}: |
204 | 214 | ||
205 | @example | 215 | @example |
206 | -qemu /usr/local/qemu-i386/wine/bin/wine /usr/local/qemu-i386/wine/c/Program\ Files/putty.exe | 216 | +qemu-i386 /usr/local/qemu-i386/wine/bin/wine /usr/local/qemu-i386/wine/c/Program\ Files/putty.exe |
207 | @end example | 217 | @end example |
208 | 218 | ||
209 | @end itemize | 219 | @end itemize |
@@ -211,7 +221,7 @@ qemu /usr/local/qemu-i386/wine/bin/wine /usr/local/qemu-i386/wine/c/Program\ Fil | @@ -211,7 +221,7 @@ qemu /usr/local/qemu-i386/wine/bin/wine /usr/local/qemu-i386/wine/c/Program\ Fil | ||
211 | @section Command line options | 221 | @section Command line options |
212 | 222 | ||
213 | @example | 223 | @example |
214 | -usage: qemu [-h] [-d] [-L path] [-s size] program [arguments...] | 224 | +usage: qemu-i386 [-h] [-d] [-L path] [-s size] program [arguments...] |
215 | @end example | 225 | @end example |
216 | 226 | ||
217 | @table @option | 227 | @table @option |
@@ -234,20 +244,81 @@ Act as if the host page size was 'pagesize' bytes | @@ -234,20 +244,81 @@ Act as if the host page size was 'pagesize' bytes | ||
234 | 244 | ||
235 | @chapter QEMU System emulator invocation | 245 | @chapter QEMU System emulator invocation |
236 | 246 | ||
247 | +@section Introduction | ||
248 | + | ||
249 | +@c man begin DESCRIPTION | ||
250 | + | ||
251 | +The QEMU System emulator simulates a complete PC. It can either boot | ||
252 | +directly a Linux kernel (without any BIOS or boot loader) or boot like a | ||
253 | +real PC with the included BIOS. | ||
254 | + | ||
255 | +In order to meet specific user needs, two versions of QEMU are | ||
256 | +available: | ||
257 | + | ||
258 | +@enumerate | ||
259 | + | ||
260 | +@item | ||
261 | +@code{qemu} uses the host Memory Management Unit (MMU) to simulate | ||
262 | +the x86 MMU. It is @emph{fast} but has limitations because the whole 4 GB | ||
263 | +address space cannot be used and some memory mapped peripherials | ||
264 | +cannot be emulated accurately yet. Therefore, a specific Linux kernel | ||
265 | +must be used (@xref{linux_compile}). | ||
266 | + | ||
267 | +@item | ||
268 | +@code{qemu-softmmu} uses a software MMU. It is about @emph{two times | ||
269 | +slower} but gives a more accurate emulation. (XXX: Linux cannot be ran | ||
270 | +unpatched yet). | ||
271 | + | ||
272 | +@end enumerate | ||
273 | + | ||
274 | +QEMU emulates the following PC peripherials: | ||
275 | + | ||
276 | +@itemize @minus | ||
277 | +@item | ||
278 | +VGA (hardware level, including all non standard modes) | ||
279 | +@item | ||
280 | +PS/2 mouse and keyboard | ||
281 | +@item | ||
282 | +IDE disk interface (port=0x1f0, irq=14) | ||
283 | +@item | ||
284 | +NE2000 network adapter (port=0x300, irq=9) | ||
285 | +@item | ||
286 | +Serial port (port=0x3f8, irq=4) | ||
287 | +@item | ||
288 | +PIC (interrupt controler) | ||
289 | +@item | ||
290 | +PIT (timers) | ||
291 | +@item | ||
292 | +CMOS memory | ||
293 | +@end itemize | ||
294 | + | ||
295 | +@c man end | ||
296 | + | ||
237 | @section Quick Start | 297 | @section Quick Start |
238 | 298 | ||
239 | -This section explains how to launch a Linux kernel inside QEMU. | 299 | +Download the linux image (@file{linux.img}) and type: |
300 | + | ||
301 | +@example | ||
302 | +qemu-softmmu linux.img | ||
303 | +@end example | ||
304 | + | ||
305 | +Linux should boot and give you a prompt. | ||
306 | + | ||
307 | +@section Direct Linux Boot and Network emulation | ||
308 | + | ||
309 | +This section explains how to launch a Linux kernel inside QEMU without | ||
310 | +having to make a full bootable image. It is very useful for fast Linux | ||
311 | +kernel testing. The QEMU network configuration is also explained. | ||
240 | 312 | ||
241 | @enumerate | 313 | @enumerate |
242 | @item | 314 | @item |
243 | -Download the archive @file{vl-test-xxx.tar.gz} containing a Linux | ||
244 | -kernel and a disk image. The archive also contains a precompiled | ||
245 | -version of @file{vl}, the QEMU System emulator. | 315 | +Download the archive @file{linux-test-xxx.tar.gz} containing a Linux |
316 | +kernel and a disk image. | ||
246 | 317 | ||
247 | @item Optional: If you want network support (for example to launch X11 examples), you | 318 | @item Optional: If you want network support (for example to launch X11 examples), you |
248 | -must copy the script @file{vl-ifup} in @file{/etc} and configure | 319 | +must copy the script @file{qemu-ifup} in @file{/etc} and configure |
249 | properly @code{sudo} so that the command @code{ifconfig} contained in | 320 | properly @code{sudo} so that the command @code{ifconfig} contained in |
250 | -@file{vl-ifup} can be executed as root. You must verify that your host | 321 | +@file{qemu-ifup} can be executed as root. You must verify that your host |
251 | kernel supports the TUN/TAP network interfaces: the device | 322 | kernel supports the TUN/TAP network interfaces: the device |
252 | @file{/dev/net/tun} must be present. | 323 | @file{/dev/net/tun} must be present. |
253 | 324 | ||
@@ -256,10 +327,10 @@ the host kernel and the emulated kernel. The emulated kernel is seen | @@ -256,10 +327,10 @@ the host kernel and the emulated kernel. The emulated kernel is seen | ||
256 | from the host kernel at IP address 172.20.0.2 and the host kernel is | 327 | from the host kernel at IP address 172.20.0.2 and the host kernel is |
257 | seen from the emulated kernel at IP address 172.20.0.1. | 328 | seen from the emulated kernel at IP address 172.20.0.1. |
258 | 329 | ||
259 | -@item Launch @code{vl.sh}. You should have the following output: | 330 | +@item Launch @code{qemu.sh}. You should have the following output: |
260 | 331 | ||
261 | @example | 332 | @example |
262 | -> ./vl.sh | 333 | +> ./qemu.sh |
263 | connected to host network interface: tun0 | 334 | connected to host network interface: tun0 |
264 | Uncompressing Linux... Ok, booting the kernel. | 335 | Uncompressing Linux... Ok, booting the kernel. |
265 | Linux version 2.4.20 (fabrice@localhost.localdomain) (gcc version 2.96 20000731 (Red Hat Linux 7.3 2.96-110)) #22 lun jui 7 13:37:41 CEST 2003 | 336 | Linux version 2.4.20 (fabrice@localhost.localdomain) (gcc version 2.96 20000731 (Red Hat Linux 7.3 2.96-110)) #22 lun jui 7 13:37:41 CEST 2003 |
@@ -349,11 +420,11 @@ a real Virtual Linux system ! | @@ -349,11 +420,11 @@ a real Virtual Linux system ! | ||
349 | NOTES: | 420 | NOTES: |
350 | @enumerate | 421 | @enumerate |
351 | @item | 422 | @item |
352 | -A 2.5.74 kernel is also included in the vl-test archive. Just | ||
353 | -replace the bzImage in vl.sh to try it. | 423 | +A 2.5.74 kernel is also included in the archive. Just |
424 | +replace the bzImage in qemu.sh to try it. | ||
354 | 425 | ||
355 | @item | 426 | @item |
356 | -vl creates a temporary file in @var{$VLTMPDIR} (@file{/tmp} is the | 427 | +vl creates a temporary file in @var{$QEMU_TMPDIR} (@file{/tmp} is the |
357 | default) containing all the simulated PC memory. If possible, try to use | 428 | default) containing all the simulated PC memory. If possible, try to use |
358 | a temporary directory using the tmpfs filesystem to avoid too many | 429 | a temporary directory using the tmpfs filesystem to avoid too many |
359 | unnecessary disk accesses. | 430 | unnecessary disk accesses. |
@@ -379,16 +450,19 @@ Lawton for the plex86 Project (@url{www.plex86.org}). | @@ -379,16 +450,19 @@ Lawton for the plex86 Project (@url{www.plex86.org}). | ||
379 | @section Invocation | 450 | @section Invocation |
380 | 451 | ||
381 | @example | 452 | @example |
382 | -usage: vl [options] bzImage [kernel parameters...] | 453 | +@c man begin SYNOPSIS |
454 | +usage: qemu [options] [disk_image] | ||
455 | +@c man end | ||
383 | @end example | 456 | @end example |
384 | 457 | ||
385 | -@file{bzImage} is a Linux kernel image. | 458 | +@c man begin OPTIONS |
459 | +@var{disk_image} is a raw hard image image for IDE hard disk 0. | ||
386 | 460 | ||
387 | General options: | 461 | General options: |
388 | @table @option | 462 | @table @option |
389 | @item -hda file | 463 | @item -hda file |
390 | @item -hdb file | 464 | @item -hdb file |
391 | -Use 'file' as hard disk 0 or 1 image (@xref{disk_images}). | 465 | +Use @var{file} as hard disk 0 or 1 image (@xref{disk_images}). |
392 | 466 | ||
393 | @item -snapshot | 467 | @item -snapshot |
394 | 468 | ||
@@ -405,13 +479,41 @@ launched to configure the host network interface (usually tun0) | @@ -405,13 +479,41 @@ launched to configure the host network interface (usually tun0) | ||
405 | corresponding to the virtual NE2000 card. | 479 | corresponding to the virtual NE2000 card. |
406 | 480 | ||
407 | @item -initrd file | 481 | @item -initrd file |
408 | -Use 'file' as initial ram disk. | 482 | +Use @var{file} as initial ram disk. |
483 | + | ||
484 | +@item -tun-fd fd | ||
485 | +Assumes @var{fd} talks to tap/tun and use it. Read | ||
486 | +@url{http://bellard.org/qemu/tetrinet.html} to have an example of its | ||
487 | +use. | ||
488 | + | ||
489 | +@item -nographic | ||
490 | + | ||
491 | +Normally, QEMU uses SDL to display the VGA output. With this option, | ||
492 | +you can totally disable graphical output so that QEMU is a simple | ||
493 | +command line application. The emulated serial port is redirected on | ||
494 | +the console. Therefore, you can still use QEMU to debug a Linux kernel | ||
495 | +with a serial console. | ||
496 | + | ||
497 | +@end table | ||
498 | + | ||
499 | +Linux boot specific (does not require a full PC boot with a BIOS): | ||
500 | +@table @option | ||
501 | + | ||
502 | +@item -kernel bzImage | ||
503 | +Use @var{bzImage} as kernel image. | ||
504 | + | ||
505 | +@item -append cmdline | ||
506 | +Use @var{cmdline} as kernel command line | ||
507 | + | ||
508 | +@item -initrd file | ||
509 | +Use @var{file} as initial ram disk. | ||
510 | + | ||
409 | @end table | 511 | @end table |
410 | 512 | ||
411 | Debug options: | 513 | Debug options: |
412 | @table @option | 514 | @table @option |
413 | @item -s | 515 | @item -s |
414 | -Wait gdb connection to port 1234. | 516 | +Wait gdb connection to port 1234 (@xref{gdb_usage}). |
415 | @item -p port | 517 | @item -p port |
416 | Change gdb connection port. | 518 | Change gdb connection port. |
417 | @item -d | 519 | @item -d |
@@ -432,7 +534,25 @@ Send break (magic sysrq) | @@ -432,7 +534,25 @@ Send break (magic sysrq) | ||
432 | @item C-a C-a | 534 | @item C-a C-a |
433 | Send C-a | 535 | Send C-a |
434 | @end table | 536 | @end table |
537 | +@c man end | ||
538 | + | ||
539 | +@ignore | ||
540 | + | ||
541 | +@setfilename qemu | ||
542 | +@settitle QEMU System Emulator | ||
543 | + | ||
544 | +@c man begin SEEALSO | ||
545 | +The HTML documentation of QEMU for more precise information and Linux | ||
546 | +user mode emulator invocation. | ||
547 | +@c man end | ||
548 | + | ||
549 | +@c man begin AUTHOR | ||
550 | +Fabrice Bellard | ||
551 | +@c man end | ||
552 | + | ||
553 | +@end ignore | ||
435 | 554 | ||
555 | +@end ignore | ||
436 | @node disk_images | 556 | @node disk_images |
437 | @section Disk Images | 557 | @section Disk Images |
438 | 558 | ||
@@ -466,14 +586,14 @@ same disk image template for many users. | @@ -466,14 +586,14 @@ same disk image template for many users. | ||
466 | To create a COW disk images, use the command: | 586 | To create a COW disk images, use the command: |
467 | 587 | ||
468 | @example | 588 | @example |
469 | -vlmkcow -f myrawimage.bin mycowimage.cow | 589 | +qemu-mkcow -f myrawimage.bin mycowimage.cow |
470 | @end example | 590 | @end example |
471 | 591 | ||
472 | @file{myrawimage.bin} is a raw image you want to use as original disk | 592 | @file{myrawimage.bin} is a raw image you want to use as original disk |
473 | image. It will never be written to. | 593 | image. It will never be written to. |
474 | 594 | ||
475 | @file{mycowimage.cow} is the COW disk image which is created by | 595 | @file{mycowimage.cow} is the COW disk image which is created by |
476 | -@code{vlmkcow}. You can use it directly with the @option{-hdx} | 596 | +@code{qemu-mkcow}. You can use it directly with the @option{-hdx} |
477 | options. You must not modify the original raw disk image if you use | 597 | options. You must not modify the original raw disk image if you use |
478 | COW images, as COW images only store the modified sectors from the raw | 598 | COW images, as COW images only store the modified sectors from the raw |
479 | disk image. QEMU stores the original raw disk image name and its | 599 | disk image. QEMU stores the original raw disk image name and its |
@@ -489,7 +609,7 @@ image. It is useful to have a big initial virtual disk image without | @@ -489,7 +609,7 @@ image. It is useful to have a big initial virtual disk image without | ||
489 | using much disk space. Use: | 609 | using much disk space. Use: |
490 | 610 | ||
491 | @example | 611 | @example |
492 | -vlmkcow mycowimage.cow 1024 | 612 | +qemu-mkcow mycowimage.cow 1024 |
493 | @end example | 613 | @end example |
494 | 614 | ||
495 | to create a 1 gigabyte empty COW disk image. | 615 | to create a 1 gigabyte empty COW disk image. |
@@ -504,6 +624,7 @@ Since holes are used, the displayed size of the COW disk image is not | @@ -504,6 +624,7 @@ Since holes are used, the displayed size of the COW disk image is not | ||
504 | the real one. To know it, use the @code{ls -ls} command. | 624 | the real one. To know it, use the @code{ls -ls} command. |
505 | @end enumerate | 625 | @end enumerate |
506 | 626 | ||
627 | +@node linux_compile | ||
507 | @section Linux Kernel Compilation | 628 | @section Linux Kernel Compilation |
508 | 629 | ||
509 | You should be able to use any kernel with QEMU provided you make the | 630 | You should be able to use any kernel with QEMU provided you make the |
@@ -573,31 +694,11 @@ As you would do to make a real kernel. Then you can use with QEMU | @@ -573,31 +694,11 @@ As you would do to make a real kernel. Then you can use with QEMU | ||
573 | exactly the same kernel as you would boot on your PC (in | 694 | exactly the same kernel as you would boot on your PC (in |
574 | @file{arch/i386/boot/bzImage}). | 695 | @file{arch/i386/boot/bzImage}). |
575 | 696 | ||
576 | -@section PC Emulation | ||
577 | - | ||
578 | -QEMU emulates the following PC peripherials: | ||
579 | - | ||
580 | -@itemize | ||
581 | -@item | ||
582 | -PIC (interrupt controler) | ||
583 | -@item | ||
584 | -PIT (timers) | ||
585 | -@item | ||
586 | -CMOS memory | ||
587 | -@item | ||
588 | -Dumb VGA (to print the @code{Uncompressing Linux} message) | ||
589 | -@item | ||
590 | -Serial port (port=0x3f8, irq=4) | ||
591 | -@item | ||
592 | -NE2000 network adapter (port=0x300, irq=9) | ||
593 | -@item | ||
594 | -IDE disk interface (port=0x1f0, irq=14) | ||
595 | -@end itemize | ||
596 | - | 697 | +@node gdb_usage |
597 | @section GDB usage | 698 | @section GDB usage |
598 | 699 | ||
599 | QEMU has a primitive support to work with gdb, so that you can do | 700 | QEMU has a primitive support to work with gdb, so that you can do |
600 | -'Ctrl-C' while the kernel is running and inspect its state. | 701 | +'Ctrl-C' while the virtual machine is running and inspect its state. |
601 | 702 | ||
602 | In order to use gdb, launch vl with the '-s' option. It will wait for a | 703 | In order to use gdb, launch vl with the '-s' option. It will wait for a |
603 | gdb connection: | 704 | gdb connection: |
@@ -624,6 +725,18 @@ Then you can use gdb normally. For example, type 'c' to launch the kernel: | @@ -624,6 +725,18 @@ Then you can use gdb normally. For example, type 'c' to launch the kernel: | ||
624 | 725 | ||
625 | WARNING: breakpoints and single stepping are not yet supported. | 726 | WARNING: breakpoints and single stepping are not yet supported. |
626 | 727 | ||
728 | +Here are some useful tips in order to use gdb on system code: | ||
729 | + | ||
730 | +@enumerate | ||
731 | +@item | ||
732 | +Use @code{info reg} to display all the CPU registers. | ||
733 | +@item | ||
734 | +Use @code{x/10i $eip} to display the code at the PC position. | ||
735 | +@item | ||
736 | +Use @code{set architecture i8086} to dump 16 bit code. Then use | ||
737 | +@code{x/10i $cs*16+*eip} to dump the code at the PC position. | ||
738 | +@end enumerate | ||
739 | + | ||
627 | @chapter QEMU Internals | 740 | @chapter QEMU Internals |
628 | 741 | ||
629 | @section QEMU compared to other emulators | 742 | @section QEMU compared to other emulators |