Statistics
| Branch: | Revision:

root / balloon.c @ 753d11f2

History | View | Annotate | Download (5.1 kB)

1 28c28973 Paolo Bonzini
/*
2 73428a8e Amit Shah
 * Generic Balloon handlers and management
3 28c28973 Paolo Bonzini
 *
4 28c28973 Paolo Bonzini
 * Copyright (c) 2003-2008 Fabrice Bellard
5 73428a8e Amit Shah
 * Copyright (C) 2011 Red Hat, Inc.
6 73428a8e Amit Shah
 * Copyright (C) 2011 Amit Shah <amit.shah@redhat.com>
7 28c28973 Paolo Bonzini
 *
8 28c28973 Paolo Bonzini
 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 28c28973 Paolo Bonzini
 * of this software and associated documentation files (the "Software"), to deal
10 28c28973 Paolo Bonzini
 * in the Software without restriction, including without limitation the rights
11 28c28973 Paolo Bonzini
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 28c28973 Paolo Bonzini
 * copies of the Software, and to permit persons to whom the Software is
13 28c28973 Paolo Bonzini
 * furnished to do so, subject to the following conditions:
14 28c28973 Paolo Bonzini
 *
15 28c28973 Paolo Bonzini
 * The above copyright notice and this permission notice shall be included in
16 28c28973 Paolo Bonzini
 * all copies or substantial portions of the Software.
17 28c28973 Paolo Bonzini
 *
18 28c28973 Paolo Bonzini
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 28c28973 Paolo Bonzini
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 28c28973 Paolo Bonzini
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 28c28973 Paolo Bonzini
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 28c28973 Paolo Bonzini
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 28c28973 Paolo Bonzini
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24 28c28973 Paolo Bonzini
 * THE SOFTWARE.
25 28c28973 Paolo Bonzini
 */
26 28c28973 Paolo Bonzini
27 28c28973 Paolo Bonzini
#include "monitor.h"
28 28c28973 Paolo Bonzini
#include "qjson.h"
29 28c28973 Paolo Bonzini
#include "qint.h"
30 28c28973 Paolo Bonzini
#include "cpu-common.h"
31 28c28973 Paolo Bonzini
#include "kvm.h"
32 28c28973 Paolo Bonzini
#include "balloon.h"
33 62dd89de Prerna Saxena
#include "trace.h"
34 28c28973 Paolo Bonzini
35 0a2a30d5 Amit Shah
static QEMUBalloonEvent *balloon_event_fn;
36 30fb2ca6 Amit Shah
static QEMUBalloonStatus *balloon_stat_fn;
37 0a2a30d5 Amit Shah
static void *balloon_opaque;
38 28c28973 Paolo Bonzini
39 6c6ec182 Amit Shah
int qemu_add_balloon_handler(QEMUBalloonEvent *event_func,
40 6c6ec182 Amit Shah
                             QEMUBalloonStatus *stat_func, void *opaque)
41 28c28973 Paolo Bonzini
{
42 6c6ec182 Amit Shah
    if (balloon_event_fn || balloon_stat_fn || balloon_opaque) {
43 6c6ec182 Amit Shah
        /* We're already registered one balloon handler.  How many can
44 6c6ec182 Amit Shah
         * a guest really have?
45 6c6ec182 Amit Shah
         */
46 6c6ec182 Amit Shah
        error_report("Another balloon device already registered");
47 6c6ec182 Amit Shah
        return -1;
48 6c6ec182 Amit Shah
    }
49 30fb2ca6 Amit Shah
    balloon_event_fn = event_func;
50 30fb2ca6 Amit Shah
    balloon_stat_fn = stat_func;
51 0a2a30d5 Amit Shah
    balloon_opaque = opaque;
52 6c6ec182 Amit Shah
    return 0;
53 28c28973 Paolo Bonzini
}
54 28c28973 Paolo Bonzini
55 8a7d552c Amit Shah
void qemu_remove_balloon_handler(void *opaque)
56 8a7d552c Amit Shah
{
57 8a7d552c Amit Shah
    if (balloon_opaque != opaque) {
58 8a7d552c Amit Shah
        return;
59 8a7d552c Amit Shah
    }
60 8a7d552c Amit Shah
    balloon_event_fn = NULL;
61 8a7d552c Amit Shah
    balloon_stat_fn = NULL;
62 8a7d552c Amit Shah
    balloon_opaque = NULL;
63 8a7d552c Amit Shah
}
64 8a7d552c Amit Shah
65 30fb2ca6 Amit Shah
static int qemu_balloon(ram_addr_t target)
66 28c28973 Paolo Bonzini
{
67 182b9203 Amit Shah
    if (!balloon_event_fn) {
68 28c28973 Paolo Bonzini
        return 0;
69 28c28973 Paolo Bonzini
    }
70 182b9203 Amit Shah
    trace_balloon_event(balloon_opaque, target);
71 30fb2ca6 Amit Shah
    balloon_event_fn(balloon_opaque, target);
72 182b9203 Amit Shah
    return 1;
73 28c28973 Paolo Bonzini
}
74 28c28973 Paolo Bonzini
75 0a2a30d5 Amit Shah
static int qemu_balloon_status(MonitorCompletion cb, void *opaque)
76 28c28973 Paolo Bonzini
{
77 30fb2ca6 Amit Shah
    if (!balloon_stat_fn) {
78 28c28973 Paolo Bonzini
        return 0;
79 28c28973 Paolo Bonzini
    }
80 30fb2ca6 Amit Shah
    balloon_stat_fn(balloon_opaque, cb, opaque);
81 182b9203 Amit Shah
    return 1;
82 28c28973 Paolo Bonzini
}
83 28c28973 Paolo Bonzini
84 28c28973 Paolo Bonzini
static void print_balloon_stat(const char *key, QObject *obj, void *opaque)
85 28c28973 Paolo Bonzini
{
86 28c28973 Paolo Bonzini
    Monitor *mon = opaque;
87 28c28973 Paolo Bonzini
88 b80bc1dd Amit Shah
    if (strcmp(key, "actual")) {
89 28c28973 Paolo Bonzini
        monitor_printf(mon, ",%s=%" PRId64, key,
90 28c28973 Paolo Bonzini
                       qint_get_int(qobject_to_qint(obj)));
91 b80bc1dd Amit Shah
    }
92 28c28973 Paolo Bonzini
}
93 28c28973 Paolo Bonzini
94 28c28973 Paolo Bonzini
void monitor_print_balloon(Monitor *mon, const QObject *data)
95 28c28973 Paolo Bonzini
{
96 28c28973 Paolo Bonzini
    QDict *qdict;
97 28c28973 Paolo Bonzini
98 28c28973 Paolo Bonzini
    qdict = qobject_to_qdict(data);
99 b80bc1dd Amit Shah
    if (!qdict_haskey(qdict, "actual")) {
100 28c28973 Paolo Bonzini
        return;
101 b80bc1dd Amit Shah
    }
102 28c28973 Paolo Bonzini
    monitor_printf(mon, "balloon: actual=%" PRId64,
103 28c28973 Paolo Bonzini
                   qdict_get_int(qdict, "actual") >> 20);
104 28c28973 Paolo Bonzini
    qdict_iter(qdict, print_balloon_stat, mon);
105 28c28973 Paolo Bonzini
    monitor_printf(mon, "\n");
106 28c28973 Paolo Bonzini
}
107 28c28973 Paolo Bonzini
108 28c28973 Paolo Bonzini
/**
109 28c28973 Paolo Bonzini
 * do_info_balloon(): Balloon information
110 28c28973 Paolo Bonzini
 *
111 28c28973 Paolo Bonzini
 * Make an asynchronous request for balloon info.  When the request completes
112 28c28973 Paolo Bonzini
 * a QDict will be returned according to the following specification:
113 28c28973 Paolo Bonzini
 *
114 28c28973 Paolo Bonzini
 * - "actual": current balloon value in bytes
115 28c28973 Paolo Bonzini
 * The following fields may or may not be present:
116 28c28973 Paolo Bonzini
 * - "mem_swapped_in": Amount of memory swapped in (bytes)
117 28c28973 Paolo Bonzini
 * - "mem_swapped_out": Amount of memory swapped out (bytes)
118 28c28973 Paolo Bonzini
 * - "major_page_faults": Number of major faults
119 28c28973 Paolo Bonzini
 * - "minor_page_faults": Number of minor faults
120 28c28973 Paolo Bonzini
 * - "free_mem": Total amount of free and unused memory (bytes)
121 28c28973 Paolo Bonzini
 * - "total_mem": Total amount of available memory (bytes)
122 28c28973 Paolo Bonzini
 *
123 28c28973 Paolo Bonzini
 * Example:
124 28c28973 Paolo Bonzini
 *
125 28c28973 Paolo Bonzini
 * { "actual": 1073741824, "mem_swapped_in": 0, "mem_swapped_out": 0,
126 28c28973 Paolo Bonzini
 *   "major_page_faults": 142, "minor_page_faults": 239245,
127 28c28973 Paolo Bonzini
 *   "free_mem": 1014185984, "total_mem": 1044668416 }
128 28c28973 Paolo Bonzini
 */
129 28c28973 Paolo Bonzini
int do_info_balloon(Monitor *mon, MonitorCompletion cb, void *opaque)
130 28c28973 Paolo Bonzini
{
131 28c28973 Paolo Bonzini
    int ret;
132 28c28973 Paolo Bonzini
133 28c28973 Paolo Bonzini
    if (kvm_enabled() && !kvm_has_sync_mmu()) {
134 28c28973 Paolo Bonzini
        qerror_report(QERR_KVM_MISSING_CAP, "synchronous MMU", "balloon");
135 28c28973 Paolo Bonzini
        return -1;
136 28c28973 Paolo Bonzini
    }
137 28c28973 Paolo Bonzini
138 28c28973 Paolo Bonzini
    ret = qemu_balloon_status(cb, opaque);
139 28c28973 Paolo Bonzini
    if (!ret) {
140 28c28973 Paolo Bonzini
        qerror_report(QERR_DEVICE_NOT_ACTIVE, "balloon");
141 28c28973 Paolo Bonzini
        return -1;
142 28c28973 Paolo Bonzini
    }
143 28c28973 Paolo Bonzini
144 28c28973 Paolo Bonzini
    return 0;
145 28c28973 Paolo Bonzini
}
146 28c28973 Paolo Bonzini
147 28c28973 Paolo Bonzini
/**
148 28c28973 Paolo Bonzini
 * do_balloon(): Request VM to change its memory allocation
149 28c28973 Paolo Bonzini
 */
150 28c28973 Paolo Bonzini
int do_balloon(Monitor *mon, const QDict *params,
151 28c28973 Paolo Bonzini
               MonitorCompletion cb, void *opaque)
152 28c28973 Paolo Bonzini
{
153 514e73ec Amit Shah
    int64_t target;
154 28c28973 Paolo Bonzini
    int ret;
155 28c28973 Paolo Bonzini
156 28c28973 Paolo Bonzini
    if (kvm_enabled() && !kvm_has_sync_mmu()) {
157 28c28973 Paolo Bonzini
        qerror_report(QERR_KVM_MISSING_CAP, "synchronous MMU", "balloon");
158 28c28973 Paolo Bonzini
        return -1;
159 28c28973 Paolo Bonzini
    }
160 28c28973 Paolo Bonzini
161 514e73ec Amit Shah
    target = qdict_get_int(params, "value");
162 514e73ec Amit Shah
    if (target <= 0) {
163 514e73ec Amit Shah
        qerror_report(QERR_INVALID_PARAMETER_VALUE, "target", "a size");
164 514e73ec Amit Shah
        return -1;
165 514e73ec Amit Shah
    }
166 514e73ec Amit Shah
    ret = qemu_balloon(target);
167 28c28973 Paolo Bonzini
    if (ret == 0) {
168 28c28973 Paolo Bonzini
        qerror_report(QERR_DEVICE_NOT_ACTIVE, "balloon");
169 28c28973 Paolo Bonzini
        return -1;
170 28c28973 Paolo Bonzini
    }
171 28c28973 Paolo Bonzini
172 28c28973 Paolo Bonzini
    cb(opaque, NULL);
173 28c28973 Paolo Bonzini
    return 0;
174 28c28973 Paolo Bonzini
}