2017-01-13 22:41:23 +08:00
|
|
|
# -*- Mode: Python -*-
|
|
|
|
|
|
|
|
##
|
|
|
|
# = Other events
|
|
|
|
##
|
|
|
|
|
2014-06-18 14:43:33 +08:00
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SHUTDOWN:
|
2014-06-18 14:43:33 +08:00
|
|
|
#
|
2014-06-25 07:34:00 +08:00
|
|
|
# Emitted when the virtual machine has shut down, indicating that qemu is
|
|
|
|
# about to exit.
|
2014-06-18 14:43:33 +08:00
|
|
|
#
|
|
|
|
# Note: If the command-line option "-no-shutdown" has been specified, qemu will
|
|
|
|
# not exit, and a STOP event will eventually follow the SHUTDOWN event
|
|
|
|
#
|
|
|
|
# Since: 0.12.0
|
2016-06-23 22:11:21 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "SHUTDOWN",
|
|
|
|
# "timestamp": { "seconds": 1267040730, "microseconds": 682951 } }
|
|
|
|
#
|
2014-06-18 14:43:33 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'SHUTDOWN' }
|
2014-06-18 14:43:34 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @POWERDOWN:
|
2014-06-18 14:43:34 +08:00
|
|
|
#
|
|
|
|
# Emitted when the virtual machine is powered down through the power control
|
|
|
|
# system, such as via ACPI.
|
|
|
|
#
|
|
|
|
# Since: 0.12.0
|
2016-06-23 22:17:22 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "POWERDOWN",
|
|
|
|
# "timestamp": { "seconds": 1267040730, "microseconds": 682951 } }
|
|
|
|
#
|
2014-06-18 14:43:34 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'POWERDOWN' }
|
2014-06-18 14:43:35 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @RESET:
|
2014-06-18 14:43:35 +08:00
|
|
|
#
|
|
|
|
# Emitted when the virtual machine is reset
|
|
|
|
#
|
|
|
|
# Since: 0.12.0
|
2016-06-23 22:18:09 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "RESET",
|
|
|
|
# "timestamp": { "seconds": 1267041653, "microseconds": 9518 } }
|
|
|
|
#
|
2014-06-18 14:43:35 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'RESET' }
|
2014-06-18 14:43:36 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @STOP:
|
2014-06-18 14:43:36 +08:00
|
|
|
#
|
|
|
|
# Emitted when the virtual machine is stopped
|
|
|
|
#
|
|
|
|
# Since: 0.12.0
|
2016-06-23 22:18:36 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "STOP",
|
|
|
|
# "timestamp": { "seconds": 1267041730, "microseconds": 281295 } }
|
|
|
|
#
|
2014-06-18 14:43:36 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'STOP' }
|
2014-06-18 14:43:37 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @RESUME:
|
2014-06-18 14:43:37 +08:00
|
|
|
#
|
|
|
|
# Emitted when the virtual machine resumes execution
|
|
|
|
#
|
|
|
|
# Since: 0.12.0
|
2016-06-23 22:22:10 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "RESUME",
|
|
|
|
# "timestamp": { "seconds": 1271770767, "microseconds": 582542 } }
|
|
|
|
#
|
2014-06-18 14:43:37 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'RESUME' }
|
2014-06-18 14:43:38 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SUSPEND:
|
2014-06-18 14:43:38 +08:00
|
|
|
#
|
|
|
|
# Emitted when guest enters a hardware suspension state, for example, S3 state,
|
|
|
|
# which is sometimes called standby state
|
|
|
|
#
|
|
|
|
# Since: 1.1
|
2016-06-23 22:22:38 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "SUSPEND",
|
|
|
|
# "timestamp": { "seconds": 1344456160, "microseconds": 309119 } }
|
|
|
|
#
|
2014-06-18 14:43:38 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'SUSPEND' }
|
2014-06-18 14:43:39 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SUSPEND_DISK:
|
2014-06-18 14:43:39 +08:00
|
|
|
#
|
|
|
|
# Emitted when guest enters a hardware suspension state with data saved on
|
|
|
|
# disk, for example, S4 state, which is sometimes called hibernate state
|
|
|
|
#
|
|
|
|
# Note: QEMU shuts down (similar to event @SHUTDOWN) when entering this state
|
|
|
|
#
|
|
|
|
# Since: 1.2
|
2016-06-23 22:23:22 +08:00
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# <- { "event": "SUSPEND_DISK",
|
|
|
|
# "timestamp": { "seconds": 1344456160, "microseconds": 309119 } }
|
|
|
|
#
|
2014-06-18 14:43:39 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'SUSPEND_DISK' }
|
2014-06-18 14:43:40 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @WAKEUP:
|
2014-06-18 14:43:40 +08:00
|
|
|
#
|
|
|
|
# Emitted when the guest has woken up from suspend state and is running
|
|
|
|
#
|
|
|
|
# Since: 1.1
|
|
|
|
##
|
|
|
|
{ 'event': 'WAKEUP' }
|
2014-06-18 14:43:41 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @RTC_CHANGE:
|
2014-06-18 14:43:41 +08:00
|
|
|
#
|
|
|
|
# Emitted when the guest changes the RTC time.
|
|
|
|
#
|
|
|
|
# @offset: offset between base RTC clock (as specified by -rtc base), and
|
|
|
|
# new RTC clock value
|
|
|
|
#
|
|
|
|
# Since: 0.13.0
|
|
|
|
##
|
|
|
|
{ 'event': 'RTC_CHANGE',
|
|
|
|
'data': { 'offset': 'int' } }
|
2014-06-18 14:43:42 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @WATCHDOG:
|
2014-06-18 14:43:42 +08:00
|
|
|
#
|
|
|
|
# Emitted when the watchdog device's timer is expired
|
|
|
|
#
|
|
|
|
# @action: action that has been taken
|
|
|
|
#
|
|
|
|
# Note: If action is "reset", "shutdown", or "pause" the WATCHDOG event is
|
|
|
|
# followed respectively by the RESET, SHUTDOWN, or STOP events
|
|
|
|
#
|
|
|
|
# Since: 0.13.0
|
|
|
|
##
|
|
|
|
{ 'event': 'WATCHDOG',
|
|
|
|
'data': { 'action': 'WatchdogExpirationAction' } }
|
2014-06-18 14:43:43 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @DEVICE_DELETED:
|
2014-06-18 14:43:43 +08:00
|
|
|
#
|
|
|
|
# Emitted whenever the device removal completion is acknowledged by the guest.
|
|
|
|
# At this point, it's safe to reuse the specified device ID. Device removal can
|
|
|
|
# be initiated by the guest or by HMP/QMP commands.
|
|
|
|
#
|
|
|
|
# @device: #optional, device name
|
|
|
|
#
|
|
|
|
# @path: device path
|
|
|
|
#
|
|
|
|
# Since: 1.5
|
|
|
|
##
|
|
|
|
{ 'event': 'DEVICE_DELETED',
|
|
|
|
'data': { '*device': 'str', 'path': 'str' } }
|
2014-06-18 14:43:48 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @NIC_RX_FILTER_CHANGED:
|
2014-06-18 14:43:48 +08:00
|
|
|
#
|
|
|
|
# Emitted once until the 'query-rx-filter' command is executed, the first event
|
|
|
|
# will always be emitted
|
|
|
|
#
|
|
|
|
# @name: #optional, net client name
|
|
|
|
#
|
|
|
|
# @path: device path
|
|
|
|
#
|
|
|
|
# Since: 1.6
|
|
|
|
##
|
|
|
|
{ 'event': 'NIC_RX_FILTER_CHANGED',
|
|
|
|
'data': { '*name': 'str', 'path': 'str' } }
|
2014-06-18 14:43:49 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @VNC_CONNECTED:
|
2014-06-18 14:43:49 +08:00
|
|
|
#
|
|
|
|
# Emitted when a VNC client establishes a connection
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Note: This event is emitted before any authentication takes place, thus
|
|
|
|
# the authentication ID is not provided
|
|
|
|
#
|
|
|
|
# Since: 0.13.0
|
|
|
|
##
|
|
|
|
{ 'event': 'VNC_CONNECTED',
|
|
|
|
'data': { 'server': 'VncServerInfo',
|
|
|
|
'client': 'VncBasicInfo' } }
|
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @VNC_INITIALIZED:
|
2014-06-18 14:43:49 +08:00
|
|
|
#
|
|
|
|
# Emitted after authentication takes place (if any) and the VNC session is
|
|
|
|
# made active
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Since: 0.13.0
|
|
|
|
##
|
|
|
|
{ 'event': 'VNC_INITIALIZED',
|
|
|
|
'data': { 'server': 'VncServerInfo',
|
|
|
|
'client': 'VncClientInfo' } }
|
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @VNC_DISCONNECTED:
|
2014-06-18 14:43:49 +08:00
|
|
|
#
|
|
|
|
# Emitted when the connection is closed
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Since: 0.13.0
|
|
|
|
##
|
|
|
|
{ 'event': 'VNC_DISCONNECTED',
|
|
|
|
'data': { 'server': 'VncServerInfo',
|
|
|
|
'client': 'VncClientInfo' } }
|
2014-06-18 14:43:50 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SPICE_CONNECTED:
|
2014-06-18 14:43:50 +08:00
|
|
|
#
|
|
|
|
# Emitted when a SPICE client establishes a connection
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Since: 0.14.0
|
|
|
|
##
|
|
|
|
{ 'event': 'SPICE_CONNECTED',
|
|
|
|
'data': { 'server': 'SpiceBasicInfo',
|
|
|
|
'client': 'SpiceBasicInfo' } }
|
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SPICE_INITIALIZED:
|
2014-06-18 14:43:50 +08:00
|
|
|
#
|
|
|
|
# Emitted after initial handshake and authentication takes place (if any)
|
|
|
|
# and the SPICE channel is up and running
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Since: 0.14.0
|
|
|
|
##
|
|
|
|
{ 'event': 'SPICE_INITIALIZED',
|
|
|
|
'data': { 'server': 'SpiceServerInfo',
|
|
|
|
'client': 'SpiceChannel' } }
|
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SPICE_DISCONNECTED:
|
2014-06-18 14:43:50 +08:00
|
|
|
#
|
|
|
|
# Emitted when the SPICE connection is closed
|
|
|
|
#
|
|
|
|
# @server: server information
|
|
|
|
#
|
|
|
|
# @client: client information
|
|
|
|
#
|
|
|
|
# Since: 0.14.0
|
|
|
|
##
|
|
|
|
{ 'event': 'SPICE_DISCONNECTED',
|
|
|
|
'data': { 'server': 'SpiceBasicInfo',
|
|
|
|
'client': 'SpiceBasicInfo' } }
|
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @SPICE_MIGRATE_COMPLETED:
|
2014-06-18 14:43:50 +08:00
|
|
|
#
|
|
|
|
# Emitted when SPICE migration has completed
|
|
|
|
#
|
|
|
|
# Since: 1.3
|
|
|
|
##
|
|
|
|
{ 'event': 'SPICE_MIGRATE_COMPLETED' }
|
2014-06-23 21:26:57 +08:00
|
|
|
|
2015-05-20 18:16:15 +08:00
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @MIGRATION:
|
2015-05-20 18:16:15 +08:00
|
|
|
#
|
|
|
|
# Emitted when a migration event happens
|
|
|
|
#
|
|
|
|
# @status: @MigrationStatus describing the current migration status.
|
|
|
|
#
|
|
|
|
# Since: 2.4
|
|
|
|
##
|
|
|
|
{ 'event': 'MIGRATION',
|
|
|
|
'data': {'status': 'MigrationStatus'}}
|
|
|
|
|
2015-12-16 19:47:36 +08:00
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @MIGRATION_PASS:
|
2015-12-16 19:47:36 +08:00
|
|
|
#
|
|
|
|
# Emitted from the source side of a migration at the start of each pass
|
|
|
|
# (when it syncs the dirty bitmap)
|
|
|
|
#
|
|
|
|
# @pass: An incrementing count (starting at 1 on the first pass)
|
|
|
|
#
|
|
|
|
# Since: 2.6
|
|
|
|
##
|
|
|
|
{ 'event': 'MIGRATION_PASS',
|
|
|
|
'data': { 'pass': 'int' } }
|
|
|
|
|
2014-06-23 21:26:57 +08:00
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @ACPI_DEVICE_OST:
|
2014-06-23 21:26:57 +08:00
|
|
|
#
|
|
|
|
# Emitted when guest executes ACPI _OST method.
|
|
|
|
#
|
|
|
|
# @info: ACPIOSTInfo type as described in qapi-schema.json
|
2017-01-13 22:41:21 +08:00
|
|
|
#
|
|
|
|
# Since: 2.1
|
2014-06-23 21:26:57 +08:00
|
|
|
##
|
|
|
|
{ 'event': 'ACPI_DEVICE_OST',
|
|
|
|
'data': { 'info': 'ACPIOSTInfo' } }
|
2014-06-18 14:43:51 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @BALLOON_CHANGE:
|
2014-06-18 14:43:51 +08:00
|
|
|
#
|
|
|
|
# Emitted when the guest changes the actual BALLOON level. This value is
|
|
|
|
# equivalent to the @actual field return by the 'query-balloon' command
|
|
|
|
#
|
|
|
|
# @actual: actual level of the guest memory balloon in bytes
|
|
|
|
#
|
|
|
|
# Since: 1.2
|
|
|
|
##
|
|
|
|
{ 'event': 'BALLOON_CHANGE',
|
|
|
|
'data': { 'actual': 'int' } }
|
2014-06-18 14:43:52 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @GUEST_PANICKED:
|
2014-06-18 14:43:52 +08:00
|
|
|
#
|
|
|
|
# Emitted when guest OS panic is detected
|
|
|
|
#
|
|
|
|
# @action: action that has been taken, currently always "pause"
|
|
|
|
#
|
|
|
|
# Since: 1.5
|
|
|
|
##
|
|
|
|
{ 'event': 'GUEST_PANICKED',
|
|
|
|
'data': { 'action': 'GuestPanicAction' } }
|
2014-06-18 14:43:53 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @QUORUM_FAILURE:
|
2014-06-18 14:43:53 +08:00
|
|
|
#
|
|
|
|
# Emitted by the Quorum block driver if it fails to establish a quorum
|
|
|
|
#
|
|
|
|
# @reference: device name if defined else node name
|
|
|
|
#
|
|
|
|
# @sector-num: number of the first sector of the failed read operation
|
|
|
|
#
|
2014-06-30 23:05:41 +08:00
|
|
|
# @sectors-count: failed read operation sector count
|
2014-06-18 14:43:53 +08:00
|
|
|
#
|
|
|
|
# Since: 2.0
|
|
|
|
##
|
|
|
|
{ 'event': 'QUORUM_FAILURE',
|
2014-06-30 23:05:41 +08:00
|
|
|
'data': { 'reference': 'str', 'sector-num': 'int', 'sectors-count': 'int' } }
|
2014-06-18 14:43:53 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @QUORUM_REPORT_BAD:
|
2014-06-18 14:43:53 +08:00
|
|
|
#
|
|
|
|
# Emitted to report a corruption of a Quorum file
|
|
|
|
#
|
2016-02-26 09:39:01 +08:00
|
|
|
# @type: quorum operation type (Since 2.6)
|
|
|
|
#
|
2014-06-18 14:43:53 +08:00
|
|
|
# @error: #optional, error message. Only present on failure. This field
|
|
|
|
# contains a human-readable error message. There are no semantics other
|
|
|
|
# than that the block layer reported an error and clients should not
|
|
|
|
# try to interpret the error string.
|
|
|
|
#
|
|
|
|
# @node-name: the graph node name of the block driver state
|
|
|
|
#
|
|
|
|
# @sector-num: number of the first sector of the failed read operation
|
|
|
|
#
|
2014-06-30 23:05:41 +08:00
|
|
|
# @sectors-count: failed read operation sector count
|
2014-06-18 14:43:53 +08:00
|
|
|
#
|
|
|
|
# Since: 2.0
|
|
|
|
##
|
|
|
|
{ 'event': 'QUORUM_REPORT_BAD',
|
2016-02-26 09:39:01 +08:00
|
|
|
'data': { 'type': 'QuorumOpType', '*error': 'str', 'node-name': 'str',
|
2014-06-30 23:05:41 +08:00
|
|
|
'sector-num': 'int', 'sectors-count': 'int' } }
|
2014-06-26 23:50:02 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @VSERPORT_CHANGE:
|
2014-06-26 23:50:02 +08:00
|
|
|
#
|
|
|
|
# Emitted when the guest opens or closes a virtio-serial port.
|
|
|
|
#
|
|
|
|
# @id: device identifier of the virtio-serial port
|
|
|
|
#
|
|
|
|
# @open: true if the guest has opened the virtio-serial port
|
|
|
|
#
|
|
|
|
# Since: 2.1
|
|
|
|
##
|
|
|
|
{ 'event': 'VSERPORT_CHANGE',
|
|
|
|
'data': { 'id': 'str', 'open': 'bool' } }
|
2015-04-27 16:47:22 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @MEM_UNPLUG_ERROR:
|
2015-04-27 16:47:22 +08:00
|
|
|
#
|
|
|
|
# Emitted when memory hot unplug error occurs.
|
|
|
|
#
|
|
|
|
# @device: device name
|
|
|
|
#
|
|
|
|
# @msg: Informative message
|
|
|
|
#
|
|
|
|
# Since: 2.4
|
|
|
|
##
|
|
|
|
{ 'event': 'MEM_UNPLUG_ERROR',
|
|
|
|
'data': { 'device': 'str', 'msg': 'str' } }
|
2016-02-18 13:16:56 +08:00
|
|
|
|
|
|
|
##
|
2016-11-17 23:54:55 +08:00
|
|
|
# @DUMP_COMPLETED:
|
2016-02-18 13:16:56 +08:00
|
|
|
#
|
|
|
|
# Emitted when background dump has completed
|
|
|
|
#
|
|
|
|
# @result: DumpQueryResult type described in qapi-schema.json.
|
|
|
|
#
|
|
|
|
# @error: #optional human-readable error string that provides
|
|
|
|
# hint on why dump failed. Only presents on failure. The
|
|
|
|
# user should not try to interpret the error string.
|
|
|
|
#
|
|
|
|
# Since: 2.6
|
|
|
|
##
|
|
|
|
{ 'event': 'DUMP_COMPLETED' ,
|
|
|
|
'data': { 'result': 'DumpQueryResult', '*error': 'str' } }
|