]> git.proxmox.com Git - mirror_qemu.git/blame - docs/interop/qmp-intro.txt
Use qemu.org domain name
[mirror_qemu.git] / docs / interop / qmp-intro.txt
CommitLineData
52bbff77 1 QEMU Machine Protocol
26d5a1cd
LC
2 =====================
3
4Introduction
52bbff77 5------------
26d5a1cd 6
52bbff77
LC
7The QEMU Machine Protocol (QMP) allows applications to operate a
8QEMU instance.
26d5a1cd 9
52bbff77 10QMP is JSON[1] based and features the following:
052f1b9b
LC
11
12- Lightweight, text-based, easy to parse data format
d29f3196
LC
13- Asynchronous messages support (ie. events)
14- Capabilities Negotiation
26d5a1cd 15
d29f3196 16For detailed information on QMP's usage, please, refer to the following files:
26d5a1cd 17
52bbff77 18o qmp-spec.txt QEMU Machine Protocol current specification
56e8bdd4 19o qemu-qmp-ref.html QEMU QMP commands and events (auto-generated at build-time)
26d5a1cd 20
26d5a1cd
LC
21[1] http://www.json.org
22
23Usage
24-----
25
52bbff77
LC
26You can use the -qmp option to enable QMP. For example, the following
27makes QMP available on localhost port 4444:
d29f3196 28
52bbff77 29$ qemu [...] -qmp tcp:localhost:4444,server,nowait
26d5a1cd 30
52bbff77
LC
31However, for more flexibility and to make use of more options, the -mon
32command-line option should be used. For instance, the following example
33creates one HMP instance (human monitor) on stdio and one QMP instance
34on localhost port 4444:
26d5a1cd 35
52bbff77
LC
36$ qemu [...] -chardev stdio,id=mon0 -mon chardev=mon0,mode=readline \
37 -chardev socket,id=mon1,host=localhost,port=4444,server,nowait \
38 -mon chardev=mon1,mode=control,pretty=on
26d5a1cd 39
d29f3196 40Please, refer to QEMU's manpage for more information.
052f1b9b
LC
41
42Simple Testing
43--------------
44
d29f3196 45To manually test QMP one can connect with telnet and issue commands by hand:
26d5a1cd
LC
46
47$ telnet localhost 4444
052f1b9b 48Trying 127.0.0.1...
26d5a1cd
LC
49Connected to localhost.
50Escape character is '^]'.
52bbff77
LC
51{
52 "QMP": {
53 "version": {
54 "qemu": {
55 "micro": 50,
56 "minor": 6,
57 "major": 1
58 },
59 "package": ""
60 },
61 "capabilities": [
62 ]
63 }
64}
d29f3196 65
52bbff77
LC
66{ "execute": "qmp_capabilities" }
67{
68 "return": {
69 }
70}
71
72{ "execute": "query-status" }
73{
74 "return": {
75 "status": "prelaunch",
76 "singlestep": false,
77 "running": false
78 }
79}
80
81Please, refer to the qapi-schema.json file for a complete command reference.
82
83QMP wiki page
84-------------
26d5a1cd 85
1b3bbc68 86http://wiki.qemu.org/QMP