xref: /openbmc/qemu/docs/interop/virtio-balloon-stats.rst (revision 126d4123c50a78a99e04196126d42627911ef5b8)
1Virtio balloon memory statistics
2================================
3
4The virtio balloon driver supports guest memory statistics reporting. These
5statistics are available to QEMU users as QOM (QEMU Object Model) device
6properties via a polling mechanism.
7
8Before querying the available stats, clients first have to enable polling.
9This is done by writing a time interval value (in seconds) to the
10guest-stats-polling-interval property. This value can be:
11
12  > 0
13       enables polling in the specified interval. If polling is already
14       enabled, the polling time interval is changed to the new value
15
16  0
17       disables polling. Previous polled statistics are still valid and
18       can be queried.
19
20Once polling is enabled, the virtio-balloon device in QEMU will start
21polling the guest's balloon driver for new stats in the specified time
22interval.
23
24To retrieve those stats, clients have to query the guest-stats property,
25which will return a dictionary containing:
26
27  * A key named 'stats', containing all available stats. If the guest
28    doesn't support a particular stat, or if it couldn't be retrieved,
29    its value will be -1. Currently, the following stats are supported:
30
31      - stat-swap-in
32      - stat-swap-out
33      - stat-major-faults
34      - stat-minor-faults
35      - stat-free-memory
36      - stat-total-memory
37      - stat-available-memory
38      - stat-disk-caches
39      - stat-htlb-pgalloc
40      - stat-htlb-pgfail
41
42  * A key named last-update, which contains the last stats update
43    timestamp in seconds. Since this timestamp is generated by the host,
44    a buggy guest can't influence its value. The value is 0 if the guest
45    has not updated the stats (yet).
46
47It's also important to note the following:
48
49 - Previously polled statistics remain available even if the polling is
50   later disabled
51
52 - As noted above, if a guest doesn't support a particular stat its value
53   will always be -1. However, it's also possible that a guest temporarily
54   couldn't update one or even all stats. If this happens, just wait for
55   the next update
56
57 - Polling can be enabled even if the guest doesn't have stats support
58   or the balloon driver wasn't loaded in the guest. If this is the case
59   and stats are queried, last-update will be 0.
60
61 - The polling timer is only re-armed when the guest responds to the
62   statistics request. This means that if a (buggy) guest doesn't ever
63   respond to the request the timer will never be re-armed, which has
64   the same effect as disabling polling
65
66Here are a few examples. QEMU is started with ``-device virtio-balloon``,
67which generates ``/machine/peripheral-anon/device[1]`` as the QOM path for
68the balloon device.
69
70Enable polling with 2 seconds interval::
71
72  { "execute": "qom-set",
73               "arguments": { "path": "/machine/peripheral-anon/device[1]",
74               "property": "guest-stats-polling-interval", "value": 2 } }
75
76  { "return": {} }
77
78Change polling to 10 seconds::
79
80  { "execute": "qom-set",
81               "arguments": { "path": "/machine/peripheral-anon/device[1]",
82               "property": "guest-stats-polling-interval", "value": 10 } }
83
84  { "return": {} }
85
86Get stats::
87
88  { "execute": "qom-get",
89               "arguments": { "path": "/machine/peripheral-anon/device[1]",
90               "property": "guest-stats" } }
91  {
92    "return": {
93        "stats": {
94            "stat-swap-out": 0,
95            "stat-free-memory": 844943360,
96            "stat-minor-faults": 219028,
97            "stat-major-faults": 235,
98            "stat-total-memory": 1044406272,
99            "stat-swap-in": 0
100        },
101        "last-update": 1358529861
102    }
103  }
104
105Disable polling::
106
107  { "execute": "qom-set",
108               "arguments": { "path": "/machine/peripheral-anon/device[1]",
109               "property": "stats-polling-interval", "value": 0 } }
110
111  { "return": {} }
112