No Description

Peter Maydell b117efcf11 Update version for v8.0.0 release 2 years ago
.github 5cf434b5af github: fix config mistake preventing repo lockdown commenting 3 years ago
.gitlab 954a6c4f78 .gitlab/issue_templates: Move suggestions into comments 2 years ago
.gitlab-ci.d fc9988916a gitlab: fix typo 2 years ago
accel b5fba99ec7 Merge tag 'for-upstream' of https://gitlab.com/bonzini/qemu into staging 2 years ago
audio e74fec9aa4 audio/dbus: there are no sender for p2p mode 2 years ago
authz 6f1e91f716 error: Drop superfluous #include "qapi/qmp/qerror.h" 2 years ago
backends 25657fc6c1 win32: replace closesocket() with close() wrapper 2 years ago
block 3fe64abcde block/nfs: do not poll within a coroutine 2 years ago
bsd-user 95059f9c31 include/exec: Change reserved_va semantics to last byte 2 years ago
chardev 48805df9c2 replace TABs with spaces 2 years ago
common-user ffe98631b3 common-user/host/ppc: Implement safe-syscall.inc.S 2 years ago
configs e995d5cce4 target/arm: Implement gdbstub pauth extension 2 years ago
contrib 6205a70b92 contrib/gitdm: add group map for AMD 2 years ago
crypto 25657fc6c1 win32: replace closesocket() with close() wrapper 2 years ago
disas 0d581506de Fix incorrect register name in disassembler for fmv,fabs,fneg instructions 2 years ago
docs 8635a3a153 Revert "docs/about/deprecated: Deprecate 32-bit arm hosts for system emulation" 2 years ago
dtc @ b6910bec11 962fde57b7 dtc: Update to version 1.6.1 3 years ago
dump cc37d98bfb *: Add missing includes of qemu/error-report.h 2 years ago
ebpf 197a137290 ebpf: fix compatibility with libbpf 1.0+ 2 years ago
fpu 3cf7196909 softfloat: logB(0) should raise divideByZero exception 2 years ago
fsdev bfe7bf8590 Don't include headers already included by qemu/osdep.h 2 years ago
gdb-xml e995d5cce4 target/arm: Implement gdbstub pauth extension 2 years ago
gdbstub 0beaebc041 gdbstub: don't report auxv feature unless on Linux 2 years ago
hw c38b2ca738 Merge tag 'migration-20230412-pull-request' of https://gitlab.com/juan.quintela/qemu into staging 2 years ago
include 81f730d4d0 block, block-backend: write some hot coroutine wrappers by hand 2 years ago
io 86d063fa83 io: tls: Inherit QIO_CHANNEL_FEATURE_SHUTDOWN on server side 2 years ago
libdecnumber b2a3cbb80c libdecnumber/dpd/decimal64: Fix compiler warning from Clang 15 2 years ago
linux-headers 93d7620c25 linux-headers: Update to v6.2-rc8 2 years ago
linux-user 6cda41daa2 Revert "linux-user/arm: Take more care allocating commpage" 2 years ago
meson @ 3a9b285a55 8a29c20597 meson: require 0.61.3 2 years ago
migration 28ef5339c3 migration: fix ram_state_pending_exact() 2 years ago
monitor 4bf21c7f74 monitor: restrict command getfd to POSIX hosts 2 years ago
nbd f1426881a8 nbd/server: Request TCP_NODELAY 2 years ago
net 25657fc6c1 win32: replace closesocket() with close() wrapper 2 years ago
pc-bios aa9e7fa468 Merge tag 'edk2-stable202302-20230320-pull-request' of https://gitlab.com/kraxel/qemu into staging 2 years ago
plugins 507271d468 include/qemu/plugin: Inline qemu_plugin_disable_mem_helpers 2 years ago
po 6d17020a80 po: add ukrainian translation 3 years ago
python 6832189fd7 python: drop pipenv 2 years ago
qapi ac19b51678 Add qemu qcode support for keys F13 to F24 2 years ago
qga a219645ce3 Merge tag 'qga-pull-2023-03-22' of github.com:kostyanf14/qemu into staging 2 years ago
qobject d709bbf3b1 include/qapi: add g_autoptr support for qobject types 3 years ago
qom 919a0423d8 qom/object_interfaces: Fix QAPI headers included 2 years ago
replay 0ec8384f83 replay: Simplify setting replay blockers 2 years ago
roms 22e11539e1 edk2: replace build scripts 2 years ago
scripts 899c3fc2dc scripts/coverage: initial coverage comparison script 2 years ago
scsi 84615a19dd io: Add support for MSG_PEEK for socket channel 2 years ago
semihosting 0820a075af gdbstub: Adjust gdb_do_syscall to only use uint32_t and uint64_t 2 years ago
softmmu b1ab8f9cc5 Revert "memory: Optimize replay of guest mapping" 2 years ago
stats f2b901098e cryptodev: Support query-stats QMP command 2 years ago
storage-daemon 9d2b5f2ce4 monitor: Loosen coupling between misc.c and monitor.c slightly 2 years ago
stubs ad66b5cbbb stubs: split semihosting_get_target from system only stubs 2 years ago
subprojects 9c1916057a libvhost-user: check for NULL when allocating a virtqueue element 2 years ago
target 8539dc0055 target/arm: Copy guarded bit in combine_cacheattrs 2 years ago
tcg 20861f34e0 tcg/ppc: Fix TCG_TARGET_CALL_{ARG,RET}_I128 for ppc32 2 years ago
tests 2b1f8fcb84 iotests: Regression test for vhdx log corruption 2 years ago
tools 197a137290 ebpf: fix compatibility with libbpf 1.0+ 2 years ago
trace 5ac034b1c2 trace: Do not try to include QMP commands in user emulation binaries 2 years ago
ui 7b1bde9560 ui/spice: fix compilation on win32 2 years ago
util 64f1c63d87 Merge tag 'pull_error_handle_fix_use_after_free.v1' of https://github.com/stefanberger/qemu-tpm into staging 2 years ago
.dir-locals.el 91288a58a5 Add .dir-locals.el file to configure emacs coding style 10 years ago
.editorconfig 2c9192c177 .editorconfig: update the automatic mode setting for Emacs 4 years ago
.exrc 692e587fc6 qemu: add .exrc 13 years ago
.gdbinit 3a586d2f0b .gdbinit: load QEMU sub-commands when gdb starts 8 years ago
.git-blame-ignore-revs 452b3eeacc metadata: add .git-blame-ignore-revs 2 years ago
.gitattributes bc4ca8efba gitattributes: Cover Objective-C source files 3 years ago
.gitignore 8ad708a9d8 .gitignore: add multiple items to .gitignore 2 years ago
.gitlab-ci.yml 9ada9fd259 docs: Document GitLab custom CI/CD variables 4 years ago
.gitmodules b482fb43de hw/misc/sga: Remove the deprecated "sga" device 2 years ago
.gitpublish 08bb160e02 Add a git-publish configuration file 7 years ago
.mailmap 1d7e672700 MAINTAINERS: update my email address for the clock framework 2 years ago
.patchew.yml 66cf70149a scripts/checkpatch: roll diff tweaking into checkpatch itself 4 years ago
.readthedocs.yml 36d9c2883e readthedocs: build with Python 3.6 4 years ago
.travis.yml 5b5b0c73c8 travis.yml: Remove the generic addons section 2 years ago
COPYING a013cc6593 COPYING: update from FSF 17 years ago
COPYING.LIB f0d44cc446 COPYING.LIB: Synchronize the LGPL 2.1 with the version from gnu.org 6 years ago
Kconfig f4063f9c31 meson: Introduce target-specific Kconfig 4 years ago
Kconfig.host 55116968de vfio-user: build library 3 years ago
LICENSE cb974c95df tcg/LICENSE: Remove out of date claim about TCG subdirectory licensing 5 years ago
MAINTAINERS 8a712df4d4 Merge tag 'pull-for-8.0-040423-2' of https://gitlab.com/stsquad/qemu into staging 2 years ago
Makefile d31d240479 Makefile: qemu-bundle is a directory 2 years ago
README.rst 9567fc1665 README.rst: fix link formatting 3 years ago
VERSION c1eb2ddf0f Update version for v8.0.0 release 2 years ago
block.c 81f730d4d0 block, block-backend: write some hot coroutine wrappers by hand 2 years ago
blockdev-nbd.c 54fde4ff06 qapi block: Elide redundant has_FOO in generated C 2 years ago
blockdev.c 1e97be9156 block: Convert bdrv_is_inserted() to co_wrapper 2 years ago
blockjob.c e2c1c34f13 include/block: Untangle inclusion loops 2 years ago
configure e3feb2cc22 util: import GTree as QTree 2 years ago
cpu.c 720ace24ae *: Add missing includes of qemu/plugin.h 2 years ago
cpus-common.c 8a8dc26790 cpu: Move breakpoint helpers to common code 2 years ago
disas.c 2e0d91513d target/loongarch: Enable the disassembler for host tcg 2 years ago
event-loop-base.c 71ad4713cc util/event-loop-base: Introduce options to set the thread pool size 3 years ago
gitdm.config 6205a70b92 contrib/gitdm: add group map for AMD 2 years ago
hmp-commands-info.hx ef52091aeb hmp: add cryptodev info command 2 years ago
hmp-commands.hx 4bf21c7f74 monitor: restrict command getfd to POSIX hosts 2 years ago
iothread.c dc892d1e4c iothread: Remove unused IOThreadClass / IOTHREAD_CLASS 2 years ago
job-qmp.c 107111bf6f qapi job: Elide redundant has_FOO in generated C 2 years ago
job.c 142e690712 block: remove bdrv_try_set_aio_context and replace it with bdrv_try_change_aio_context 2 years ago
memory_ldst.c.inc f933b02b59 exec/memory_ldst: Use correct type sizes 4 years ago
meson.build e3feb2cc22 util: import GTree as QTree 2 years ago
meson_options.txt 1b1be8d3cc meson: stop looking for 'sphinx-build-3' 2 years ago
module-common.c d38ea87ac5 all: Clean up includes 9 years ago
os-posix.c 8b6aa69365 Refactoring: refactor TFR() macro to RETRY_ON_EINTR() 2 years ago
os-win32.c 0f9668e0c1 Remove qemu-common.h include from most units 3 years ago
page-vary-common.c 0f9668e0c1 Remove qemu-common.h include from most units 3 years ago
page-vary.c ec5f7ca857 include: move target page bits declaration to page-vary.h 3 years ago
qemu-bridge-helper.c f761b41a62 qemu-bridge-helper: relocate path to default ACL 4 years ago
qemu-edid.c 82a628f887 qemu-edid: Restrict input parameter -d to avoid division by zero 2 years ago
qemu-img-cmds.hx 111fbd74f6 qemu-img: Unify [-b [-F]] documentation 3 years ago
qemu-img.c 742bf09b20 block: Mark bdrv_co_copy_range() GRAPH_RDLOCK 2 years ago
qemu-io-cmds.c 00e2a04c27 qemu-io: add -r option to register I/O buffer 2 years ago
qemu-io.c 06680b15b4 include: move qemu_*_exec_dir() to cutils 3 years ago
qemu-keymap.c 5c70adbfbb qemu-keymap: Silence memory leak warning from Clang's sanitizer 2 years ago
qemu-nbd.c 54fde4ff06 qapi block: Elide redundant has_FOO in generated C 2 years ago
qemu-options.hx a234ec311b qemu-options.hx: remove stray quote 2 years ago
qemu.nsi c08796378d nsis installer: Fix mouse-over descriptions for emulators 3 years ago
qemu.sasl 213de8a2fb sasl: remove comment about obsolete kerberos versions 4 years ago
replication.c b02629550d replication: move include out of root directory 4 years ago
trace-events 518077638f accel/tcg: Remove trace events from trace-root.h 2 years ago
version.rc ddfcb8c43c configure: remove CONFIG_FILEVERSION and CONFIG_PRODUCTVERSION 4 years ago

README.rst

===========
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.


Documentation
=============

Documentation can be found hosted online at
``_. The documentation for the
current development version that is available at
``_ is generated from the ``docs/``
folder in the source tree, and is built by `Sphinx
`_.


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:


.. code-block:: shell

mkdir build
cd build
../configure
make

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

* ``_
* ``_
* ``_


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

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

.. code-block:: shell

git clone https://gitlab.com/qemu-project/qemu.git

When submitting patches, one common 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 `style section
`_ of
the Developers Guide.

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

* ``_
* ``_

The QEMU website is also maintained under source control.

.. code-block:: shell

git clone https://gitlab.com/qemu-project/qemu-web.git

* ``_

A 'git-publish' utility was created to make above process less
cumbersome, and is highly recommended for making regular contributions,
or even just for sending consecutive patch series revisions. It also
requires a working 'git send-email' setup, and by default doesn't
automate everything, so you may want to go through the above steps
manually for once.

For installation instructions, please go to

* ``_

The workflow with 'git-publish' is:

.. code-block:: shell

$ git checkout master -b my-feature
$ # work on new commits, add your 'Signed-off-by' lines to each
$ git publish

Your patch series will be sent and tagged as my-feature-v1 if you need to refer
back to it in the future.

Sending v2:

.. code-block:: shell

$ git checkout my-feature # same topic branch
$ # making changes to the commits (using 'git rebase', for example)
$ git publish

Your patch series will be sent with 'v2' tag in the subject and the git tip
will be tagged as my-feature-v2.

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

The QEMU project uses GitLab issues to track bugs. Bugs
found when running code built from QEMU git or upstream released sources
should be reported via:

* ``_

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 GitLab.

For additional information on bug reporting consult:

* ``_


ChangeLog
=========

For version history and release notes, please visit
``_ or look at the git history for
more detailed information.


Contact
=======

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

* ``_
* ``_
* #qemu on irc.oftc.net

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

* ``_