QEMU main repository: Please see https://www.qemu.org/docs/master/devel/submitting-a-patch.html for how to submit changes to QEMU. Pull Requests are ignored. Please only use release tarballs from the QEMU website. http://www.qemu.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Max Reitz 82fcf66e05 blockdev: Drop BD-{remove,insert}-medium's @device 9 years ago
accel virtio: postpone the execution of event_notifier_cleanup function 8 years ago
audio maint: Fix macros with broken 'do/while(0); ' usage 8 years ago
backends hostmem-file: add "align" option 8 years ago
block qcow2: Repair unaligned preallocated zero clusters 8 years ago
bsd-user misc: remove headers implicitly included 8 years ago
capstone@22ead3e0bf disas: Add capstone as submodule 9 years ago
chardev chardev: Clean up previous patch indentation 8 years ago
contrib contrib/vhost-user-blk: introduce a vhost-user-blk sample application 8 years ago
crypto crypto: fix stack-buffer-overflow error 8 years ago
default-configs default-configs/ppc-softmmu: Restructure the switches according to the machines 8 years ago
disas disas/s390: fix global-buffer-overflow 8 years ago
docs migration: Revert postcopy-blocktime commit set 8 years ago
dtc@e54388015a Update dtc to fix compilation problem on Mac OS 10.6 8 years ago
fpu softfloat: define floatx80_round() 9 years ago
fsdev fsdev: improve error handling of backend init 8 years ago
gdb-xml s390x/gdb: add gs registers 9 years ago
hw hw/block: Fix pin-based interrupt behaviour of NVMe 8 years ago
include hw/ide: Remove duplicated definitions from ahci_internal.h 8 years ago
io io: introduce a network socket listener API 8 years ago
libdecnumber build: remove CONFIG_LIBDECNUMBER 9 years ago
linux-headers linux-headers: update to 4.15-rc1 8 years ago
linux-user linux-user/arm/nwfpe: Check coprocessor number for FPA emulation 8 years ago
migration migration: Revert postcopy-blocktime commit set 8 years ago
nbd nbd/server: structurize option reply sending 8 years ago
net net: Remove the legacy "-net channel" parameter 8 years ago
pc-bios ppc/pnv: Update skiboot firmware image 8 years ago
po po: add missing translations in de, fr, it, zh 9 years ago
qapi blockdev: Drop BD-{remove,insert}-medium's @device 8 years ago
qga sockets: remove obsolete code that updated listen address 8 years ago
qobject qapi: Add qobject_is_equal() 9 years ago
qom tcg: Add CPUState cflags_next_tb 9 years ago
replay migration: pre_save return int 9 years ago
roms ppc/pnv: Update skiboot firmware image 8 years ago
scripts dump-guest-memory.py: fix python 2 support 8 years ago
scsi scsi: fix scsi_convert_sense crash when in_buf == NULL && in_len == 0 8 years ago
slirp slirp: add in6_dhcp_multicast() 8 years ago
stubs tpm: add stubs 9 years ago
target target/ppc: add support for hypervisor doorbells on book3s CPUs 8 years ago
tcg tcg/ppc: Allow a 32-bit offset to the constant pool 8 years ago
tests tests/ahci: Switch tray and medium commands to @id 8 years ago
trace trace: Try using tracefs first 8 years ago
ui cocoa.m: Fix scroll wheel support 8 years ago
util osdep: Retry SETLK upon EINTR 8 years ago
.dir-locals.el Add .dir-locals.el file to configure emacs coding style 11 years ago
.editorconfig add editorconfig 9 years ago
.exrc qemu: add .exrc 14 years ago
.gdbinit .gdbinit: load QEMU sub-commands when gdb starts 9 years ago
.gitignore contrib/vhost-user-blk: introduce a vhost-user-blk sample application 8 years ago
.gitmodules disas: Add capstone as submodule 9 years ago
.mailmap MAINTAINERS: Update Paul Burton's email address 9 years ago
.shippable.yml shippable: add win32/64 targets 9 years ago
.travis.yml travis: move make -j flag out of script 9 years ago
CODING_STYLE coding_style: add point about 0x in trace-events 9 years ago
COPYING COPYING: update from FSF 18 years ago
COPYING.LIB Update FSF address in GPL/LGPL boilerplate 18 years ago
COPYING.PYTHON scripts: add argparse module for Python 2.6 compatibility 9 years ago
Changelog Use HTTPS for qemu.org and other domains 8 years ago
HACKING HACKING: document #include order 9 years ago
LICENSE vfio: move hw/misc/vfio.c to hw/vfio/pci.c Move vfio.h into include/hw/vfio 11 years ago
MAINTAINERS MAINTAINERS: Add myself as maintainer to X86 machines 8 years ago
Makefile contrib/vhost-user-blk: introduce a vhost-user-blk sample application 8 years ago
Makefile.objs contrib/vhost-user-blk: introduce a vhost-user-blk sample application 8 years ago
Makefile.target Fix build of console and GUI executables for Windows 8 years ago
README Use HTTPS for qemu.org and other domains 8 years ago
VERSION Open 2.12 development tree 8 years ago
arch_init.c audio: Rename hw/audio/audio.h to hw/audio/soundhw.h 9 years ago
balloon.c trace: switch to modular code generation for sub-directories 9 years ago
block.c block: Keep nodes drained between reopen_queue/multiple 8 years ago
blockdev-nbd.c blockdev: convert internal NBD server to QIONetListener 8 years ago
blockdev.c blockdev: Drop BD-{remove,insert}-medium's @device 8 years ago
blockjob.c blockjob: Pause job on draining any job BDS 8 years ago
bootdevice.c Makefile: Move bootdevice.o to common-obj-y 9 years ago
bt-host.c all: Clean up includes 10 years ago
bt-vhci.c all: Clean up includes 10 years ago
configure * QemuMutex tracing improvements (Alex) 8 years ago
cpus-common.c *_run_on_cpu: introduce run_on_cpu_data type 10 years ago
cpus.c cpus: unify qemu_*_wait_io_event 8 years ago
device-hotplug.c blockdev: Split monitor reference from BB creation 10 years ago
device_tree.c device_tree: fix compiler warnings (clang 5) 9 years ago
disas.c disas: Dump insn bytes along with capstone disassembly 9 years ago
dma-helpers.c block: explicitly acquire aiocontext in bottom halves that need it 9 years ago
dump.c dump: fix note_name_equal() 8 years ago
exec.c hostmem-file: add "align" option 8 years ago
gdbstub.c gdbstub: add tracing 8 years ago
hmp-commands-info.hx hmp-commands-info: Change "@findex FOO" to "@findex info FOO" 9 years ago
hmp-commands.hx hmp-commands: Remove the deprecated usb_add and usb_del 8 years ago
hmp.c migration: Revert postcopy-blocktime commit set 8 years ago
hmp.h migrate: HMP migate_continue 9 years ago
ioport.c trace: switch to modular code generation for sub-directories 9 years ago
iothread.c iothread: fix iothread_stop() race condition 8 years ago
memory.c hostmem-file: add "align" option 8 years ago
memory_ldst.inc.c exec: introduce memory_ldst.inc.c 9 years ago
memory_mapping.c dump: fix memory_mapping_filter leak 9 years ago
module-common.c all: Clean up includes 10 years ago
monitor.c readline: add a free function 8 years ago
numa.c hostmem-file: add "align" option 8 years ago
os-posix.c os-posix: Drop misleading comment 9 years ago
os-win32.c shutdown: Add source information to SHUTDOWN and RESET 9 years ago
qapi-schema.json qmp: remove qmp_cpu 8 years ago
qdev-monitor.c qdev: Check for the availability of a hotplug controller before adding a device 8 years ago
qdict-test-data.txt Introduce QDict test data file 17 years ago
qemu-bridge-helper.c all: Remove unnecessary glib.h includes 10 years ago
qemu-doc.texi ui: deprecate use of GTK 2.x in favour of 3.x series 8 years ago
qemu-ga.texi qemu-ga: Remove stray 'q' in documentation 10 years ago
qemu-img-cmds.hx qemu-img: add --shrink flag for resize 9 years ago
qemu-img.c block: Add errp to bdrv_snapshot_goto() 8 years ago
qemu-img.texi qemu-img.1: Image invalidation on qemu-img commit 9 years ago
qemu-io-cmds.c block: Keep nodes drained between reopen_queue/multiple 8 years ago
qemu-io.c qemu-io: Add -C for opening with copy-on-read 9 years ago
qemu-keymap.c tools: add qemu-keymap 9 years ago
qemu-nbd.c blockdev: convert qemu-nbd server to QIONetListener 8 years ago
qemu-nbd.texi nbd: Add qemu-nbd -D for human-readable description 10 years ago
qemu-option-trace.texi docs: update manpage for stderr->log rename 9 years ago
qemu-options-wrapper.h qemu-options: Remove stray colons from output of --help 8 years ago
qemu-options.h Clean up ill-advised or unusual header guards 10 years ago
qemu-options.hx hostmem-file: add "align" option 8 years ago
qemu-seccomp.c seccomp: add resourcecontrol argument to command line 9 years ago
qemu-tech.texi qemu-doc: merge qemu-tech and qemu-doc 10 years ago
qemu.nsi Use HTTPS for qemu.org and other domains 8 years ago
qemu.sasl Default to GSSAPI (Kerberos) instead of DIGEST-MD5 for SASL 9 years ago
qmp.c qmp: remove qmp_cpu 8 years ago
qtest.c qtest: Don't perform side effects inside assertion 9 years ago
replication.c replication: Introduce new APIs to do replication operation 10 years ago
replication.h replication: Introduce new APIs to do replication operation 10 years ago
rules.mak build-sys: silence make by default or V=0 8 years ago
thunk.c thunk: assert nb_fields is valid 9 years ago
tpm.c tpm: remove tpm_register_model() 8 years ago
trace-events find_ram_offset: Add comments and tracing 8 years ago
version.rc Use HTTPS for qemu.org and other domains 8 years ago
vl.c possible_cpus: add CPUArchId::type field 8 years ago

README

         QEMU README
===========

QEMU is a generic and open source machine & userspace emulator and
virtualizer.

QEMU is capable of emulating a complete machine in software without any
need for hardware virtualization support. By using dynamic translation,
it achieves very good performance. QEMU can also integrate with the Xen
and KVM hypervisors to provide emulated hardware while allowing the
hypervisor to manage the CPU. With hypervisor support, QEMU can achieve
near native performance for CPUs. When QEMU emulates CPUs directly it is
capable of running operating systems made for one machine (e.g. an ARMv7
board) on a different machine (e.g. an x86_64 PC board).

QEMU is also capable of providing userspace API virtualization for Linux
and BSD kernel interfaces. This allows binaries compiled against one
architecture ABI (e.g. the Linux PPC64 ABI) to be run on a host using a
different architecture ABI (e.g. the Linux x86_64 ABI). This does not
involve any hardware emulation, simply CPU and syscall emulation.

QEMU aims to fit into a variety of use cases. It can be invoked directly
by users wishing to have full control over its behaviour and settings.
It also aims to facilitate integration into higher level management
layers, by providing a stable command line interface and monitor API.
It is commonly invoked indirectly via the libvirt library when using
open source applications such as oVirt, OpenStack and virt-manager.

QEMU as a whole is released under the GNU General Public License,
version 2. For full licensing details, consult the LICENSE file.


Building
========

QEMU is multi-platform software intended to be buildable on all modern
Linux platforms, OS-X, Win32 (via the Mingw64 toolchain) and a variety
of other UNIX targets. The simple steps to build QEMU are:

mkdir build
cd build
../configure
make

Additional information can also be found online via the QEMU website:

https://qemu.org/Hosts/Linux
https://qemu.org/Hosts/Mac
https://qemu.org/Hosts/W32


Submitting patches
==================

The QEMU source code is maintained under the GIT version control system.

git clone git://git.qemu.org/qemu.git

When submitting patches, the preferred approach is to use 'git
format-patch' and/or 'git send-email' to format & send the mail to the
qemu-devel@nongnu.org mailing list. All patches submitted must contain
a 'Signed-off-by' line from the author. Patches should follow the
guidelines set out in the HACKING and CODING_STYLE files.

Additional information on submitting patches can be found online via
the QEMU website

https://qemu.org/Contribute/SubmitAPatch
https://qemu.org/Contribute/TrivialPatches


Bug reporting
=============

The QEMU project uses Launchpad as its primary upstream bug tracker. Bugs
found when running code built from QEMU git or upstream released sources
should be reported via:

https://bugs.launchpad.net/qemu/

If using QEMU via an operating system vendor pre-built binary package, it
is preferable to report bugs to the vendor's own bug tracker first. If
the bug is also known to affect latest upstream code, it can also be
reported via launchpad.

For additional information on bug reporting consult:

https://qemu.org/Contribute/ReportABug


Contact
=======

The QEMU community can be contacted in a number of ways, with the two
main methods being email and IRC

- qemu-devel@nongnu.org
https://lists.nongnu.org/mailman/listinfo/qemu-devel
- #qemu on irc.oftc.net

Information on additional methods of contacting the community can be
found online via the QEMU website:

https://qemu.org/Contribute/StartHere

-- End