| QEMU Machine Protocol |
| ===================== |
| |
| Introduction |
| ------------ |
| |
| The QEMU Machine Protocol (QMP) allows applications to operate a |
| QEMU instance. |
| |
| QMP is JSON[1] based and features the following: |
| |
| - Lightweight, text-based, easy to parse data format |
| - Asynchronous messages support (ie. events) |
| - Capabilities Negotiation |
| |
| For detailed information on QMP's usage, please, refer to the following files: |
| |
| o qmp-spec.txt QEMU Machine Protocol current specification |
| o qemu-qmp-ref.html QEMU QMP commands and events (auto-generated at build-time) |
| |
| [1] https://www.json.org |
| |
| Usage |
| ----- |
| |
| You can use the -qmp option to enable QMP. For example, the following |
| makes QMP available on localhost port 4444: |
| |
| $ qemu [...] -qmp tcp:localhost:4444,server=on,wait=off |
| |
| However, for more flexibility and to make use of more options, the -mon |
| command-line option should be used. For instance, the following example |
| creates one HMP instance (human monitor) on stdio and one QMP instance |
| on localhost port 4444: |
| |
| $ qemu [...] -chardev stdio,id=mon0 -mon chardev=mon0,mode=readline \ |
| -chardev socket,id=mon1,host=localhost,port=4444,server=on,wait=off \ |
| -mon chardev=mon1,mode=control,pretty=on |
| |
| Please, refer to QEMU's manpage for more information. |
| |
| Simple Testing |
| -------------- |
| |
| To manually test QMP one can connect with telnet and issue commands by hand: |
| |
| $ telnet localhost 4444 |
| Trying 127.0.0.1... |
| Connected to localhost. |
| Escape character is '^]'. |
| { |
| "QMP": { |
| "version": { |
| "qemu": { |
| "micro": 0, |
| "minor": 0, |
| "major": 3 |
| }, |
| "package": "v3.0.0" |
| }, |
| "capabilities": [ |
| "oob" |
| ] |
| } |
| } |
| |
| { "execute": "qmp_capabilities" } |
| { |
| "return": { |
| } |
| } |
| |
| { "execute": "query-status" } |
| { |
| "return": { |
| "status": "prelaunch", |
| "singlestep": false, |
| "running": false |
| } |
| } |
| |
| Please refer to docs/interop/qemu-qmp-ref.* for a complete command |
| reference, generated from qapi/qapi-schema.json. |
| |
| QMP wiki page |
| ------------- |
| |
| https://wiki.qemu.org/QMP |